summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJuan <reduzio@gmail.com>2024-10-07 11:12:51 +0200
committerJuan <reduzio@gmail.com>2024-10-07 15:33:37 +0200
commitdb25c8fce1a1889c35e4a190ba49eaae6c741874 (patch)
treeb91f8fb55104d73da60423f792c45f75c97400a9
parentdb66bd35af704fe0d83ba9348b8c50a48e51b2ba (diff)
downloadredot-engine-db25c8fce1a1889c35e4a190ba49eaae6c741874.tar.gz
Exposed path properties save UID if referencing a resource
Currently, if a user or some resource exposes a path in a script, if this references a resource path it will be saved as a full path. This will make refactoring not work if the resource pointed towards changes location or is renamed. This change makes it so an uid:// path is saved internally in case a path to a resource has been selected, effectively making it refactor proof.
-rw-r--r--editor/editor_properties.cpp25
-rw-r--r--editor/editor_properties.h2
2 files changed, 22 insertions, 5 deletions
diff --git a/editor/editor_properties.cpp b/editor/editor_properties.cpp
index c5a35e466c..820060a336 100644
--- a/editor/editor_properties.cpp
+++ b/editor/editor_properties.cpp
@@ -462,10 +462,26 @@ void EditorPropertyPath::_set_read_only(bool p_read_only) {
}
void EditorPropertyPath::_path_selected(const String &p_path) {
- emit_changed(get_edited_property(), p_path);
+ String full_path = p_path;
+ ResourceUID::ID id = ResourceLoader::get_resource_uid(full_path);
+
+ if (id != ResourceUID::INVALID_ID) {
+ full_path = ResourceUID::get_singleton()->id_to_text(id);
+ }
+
+ emit_changed(get_edited_property(), full_path);
update_property();
}
+String EditorPropertyPath::_get_path_text() {
+ String full_path = get_edited_property_value();
+ if (full_path.begins_with("uid://")) {
+ full_path = ResourceUID::get_singleton()->get_id_path(ResourceUID::get_singleton()->text_to_id(full_path));
+ }
+
+ return full_path;
+}
+
void EditorPropertyPath::_path_pressed() {
if (!dialog) {
dialog = memnew(EditorFileDialog);
@@ -474,7 +490,7 @@ void EditorPropertyPath::_path_pressed() {
add_child(dialog);
}
- String full_path = get_edited_property_value();
+ String full_path = _get_path_text();
dialog->clear_filters();
@@ -502,7 +518,7 @@ void EditorPropertyPath::_path_pressed() {
}
void EditorPropertyPath::update_property() {
- String full_path = get_edited_property_value();
+ String full_path = _get_path_text();
path->set_text(full_path);
path->set_tooltip_text(full_path);
}
@@ -547,8 +563,7 @@ void EditorPropertyPath::_drop_data_fw(const Point2 &p_point, const Variant &p_d
return;
}
- emit_changed(get_edited_property(), filesPaths[0]);
- update_property();
+ _path_selected(filesPaths[0]);
}
bool EditorPropertyPath::_can_drop_data_fw(const Point2 &p_point, const Variant &p_data, Control *p_from) const {
diff --git a/editor/editor_properties.h b/editor/editor_properties.h
index 004630da3e..11110b18be 100644
--- a/editor/editor_properties.h
+++ b/editor/editor_properties.h
@@ -142,6 +142,8 @@ class EditorPropertyPath : public EditorProperty {
LineEdit *path = nullptr;
Button *path_edit = nullptr;
+ String _get_path_text();
+
void _path_selected(const String &p_path);
void _path_pressed();
void _path_focus_exited();