summaryrefslogtreecommitdiffstats
path: root/modules/gltf/editor
diff options
context:
space:
mode:
authorRémi Verschelde <rverschelde@gmail.com>2024-08-19 16:05:26 +0200
committerRémi Verschelde <rverschelde@gmail.com>2024-08-19 16:05:26 +0200
commitce1ba7328ff877a8f945de1b228ec190ac15f949 (patch)
tree80a47cb4719e71d4cc768366d3969c84b5ab85af /modules/gltf/editor
parent6bf64027b738431de196507b8b184e718b62f5ea (diff)
parent2dc9cf50c5d5be344498deb7b5472c3c7212a339 (diff)
downloadredot-engine-ce1ba7328ff877a8f945de1b228ec190ac15f949.tar.gz
Merge pull request #94934 from Hilderin/fix-no-validation-blender-path-on-import
Fix no validation on Blender path on import
Diffstat (limited to 'modules/gltf/editor')
-rw-r--r--modules/gltf/editor/editor_scene_importer_blend.cpp11
-rw-r--r--modules/gltf/editor/editor_scene_importer_blend.h1
2 files changed, 10 insertions, 2 deletions
diff --git a/modules/gltf/editor/editor_scene_importer_blend.cpp b/modules/gltf/editor/editor_scene_importer_blend.cpp
index 4201dcd2ad..0aab6e84b4 100644
--- a/modules/gltf/editor/editor_scene_importer_blend.cpp
+++ b/modules/gltf/editor/editor_scene_importer_blend.cpp
@@ -115,8 +115,15 @@ Node *EditorSceneFormatImporterBlend::import_scene(const String &p_path, uint32_
List<String> *r_missing_deps, Error *r_err) {
String blender_path = EDITOR_GET("filesystem/import/blender/blender_path");
- if (blender_major_version == -1 || blender_minor_version == -1) {
- _get_blender_version(blender_path, blender_major_version, blender_minor_version, nullptr);
+ ERR_FAIL_COND_V_MSG(blender_path.is_empty(), nullptr, "Blender path is empty, check your Editor Settings.");
+ ERR_FAIL_COND_V_MSG(!FileAccess::exists(blender_path), nullptr, vformat("Invalid Blender path: %s, check your Editor Settings.", blender_path));
+
+ if (blender_major_version == -1 || blender_minor_version == -1 || last_tested_blender_path != blender_path) {
+ String error;
+ if (!_get_blender_version(blender_path, blender_major_version, blender_minor_version, &error)) {
+ ERR_FAIL_V_MSG(nullptr, error);
+ }
+ last_tested_blender_path = blender_path;
}
// Get global paths for source and sink.
diff --git a/modules/gltf/editor/editor_scene_importer_blend.h b/modules/gltf/editor/editor_scene_importer_blend.h
index 8a6c65a624..6adace9276 100644
--- a/modules/gltf/editor/editor_scene_importer_blend.h
+++ b/modules/gltf/editor/editor_scene_importer_blend.h
@@ -45,6 +45,7 @@ class EditorSceneFormatImporterBlend : public EditorSceneFormatImporter {
int blender_major_version = -1;
int blender_minor_version = -1;
+ String last_tested_blender_path;
public:
enum {