Merge pull request #62302 from lawnjelly/sync_shaders_editor

[3.x] Synchronous shaders in editor
This commit is contained in:
Rémi Verschelde 2022-06-22 21:51:01 +02:00 committed by GitHub
commit b9d1683eb8
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -34,6 +34,7 @@
#include "core/os/os.h" #include "core/os/os.h"
#include "core/project_settings.h" #include "core/project_settings.h"
#include "core/threaded_callable_queue.h" #include "core/threaded_callable_queue.h"
#include "main/main.h"
#include "rasterizer_canvas_gles3.h" #include "rasterizer_canvas_gles3.h"
#include "rasterizer_scene_gles3.h" #include "rasterizer_scene_gles3.h"
#include "servers/visual_server.h" #include "servers/visual_server.h"
@ -8098,7 +8099,10 @@ void RasterizerStorageGLES3::initialize() {
config.parallel_shader_compile_supported = config.extensions.has("GL_KHR_parallel_shader_compile") || config.extensions.has("GL_ARB_parallel_shader_compile"); config.parallel_shader_compile_supported = config.extensions.has("GL_KHR_parallel_shader_compile") || config.extensions.has("GL_ARB_parallel_shader_compile");
#endif #endif
const int compilation_mode = ProjectSettings::get_singleton()->get("rendering/gles3/shaders/shader_compilation_mode"); int compilation_mode = 0;
if (!(Engine::get_singleton()->is_editor_hint() || Main::is_project_manager())) {
compilation_mode = ProjectSettings::get_singleton()->get("rendering/gles3/shaders/shader_compilation_mode");
}
config.async_compilation_enabled = compilation_mode >= 1; config.async_compilation_enabled = compilation_mode >= 1;
config.shader_cache_enabled = compilation_mode == 2; config.shader_cache_enabled = compilation_mode == 2;