summaryrefslogtreecommitdiffstats
path: root/platform/ios
diff options
context:
space:
mode:
authorRémi Verschelde <rverschelde@gmail.com>2024-06-29 13:04:06 +0200
committerRémi Verschelde <rverschelde@gmail.com>2024-06-29 13:04:06 +0200
commit0b23be968aa5c7c35e0267b190d8946b3a80d4cf (patch)
tree4d74b4b368336e0e1c065361e3a8a5b4cf14b703 /platform/ios
parentf64f1b3b6d2a3f1d21ea36fe8f619fc2b83d799b (diff)
parent32d9c93af3e5ff999444eb8e52699110b0fe9afd (diff)
downloadredot-engine-0b23be968aa5c7c35e0267b190d8946b3a80d4cf.tar.gz
Merge pull request #93706 from RandomShaper/fix_rend_misc
Improve handling of rendering startup errors
Diffstat (limited to 'platform/ios')
-rw-r--r--platform/ios/display_server_ios.mm9
1 files changed, 8 insertions, 1 deletions
diff --git a/platform/ios/display_server_ios.mm b/platform/ios/display_server_ios.mm
index a454dd5ba0..802fbefc0d 100644
--- a/platform/ios/display_server_ios.mm
+++ b/platform/ios/display_server_ios.mm
@@ -91,6 +91,7 @@ DisplayServerIOS::DisplayServerIOS(const String &p_rendering_driver, WindowMode
ERR_PRINT(vformat("Failed to initialize %s context", rendering_driver));
memdelete(rendering_context);
rendering_context = nullptr;
+ r_error = ERR_UNAVAILABLE;
return;
}
@@ -107,7 +108,13 @@ DisplayServerIOS::DisplayServerIOS(const String &p_rendering_driver, WindowMode
rendering_context->window_set_vsync_mode(MAIN_WINDOW_ID, p_vsync_mode);
rendering_device = memnew(RenderingDevice);
- rendering_device->initialize(rendering_context, MAIN_WINDOW_ID);
+ if (rendering_device->initialize(rendering_context, MAIN_WINDOW_ID) != OK) {
+ rendering_device = nullptr;
+ memdelete(rendering_context);
+ rendering_context = nullptr;
+ r_error = ERR_UNAVAILABLE;
+ return;
+ }
rendering_device->screen_create(MAIN_WINDOW_ID);
RendererCompositorRD::make_current();