Merge pull request #44981 from RandomShaper/fix_res_lifetime_3.2
Fix cases of resources destroyed too early (3.2)
This commit is contained in:
commit
2a928ea880
@ -515,7 +515,7 @@ String CreateDialog::get_selected_type() {
|
|||||||
return String();
|
return String();
|
||||||
}
|
}
|
||||||
|
|
||||||
Object *CreateDialog::instance_selected() {
|
Variant CreateDialog::instance_selected() {
|
||||||
|
|
||||||
TreeItem *selected = search_options->get_selected();
|
TreeItem *selected = search_options->get_selected();
|
||||||
|
|
||||||
@ -529,7 +529,7 @@ Object *CreateDialog::instance_selected() {
|
|||||||
|
|
||||||
if (custom != String()) {
|
if (custom != String()) {
|
||||||
if (ScriptServer::is_global_class(custom)) {
|
if (ScriptServer::is_global_class(custom)) {
|
||||||
Object *obj = EditorNode::get_editor_data().script_class_instance(custom);
|
Variant obj = EditorNode::get_editor_data().script_class_instance(custom);
|
||||||
Node *n = Object::cast_to<Node>(obj);
|
Node *n = Object::cast_to<Node>(obj);
|
||||||
if (n)
|
if (n)
|
||||||
n->set_name(custom);
|
n->set_name(custom);
|
||||||
@ -541,7 +541,7 @@ Object *CreateDialog::instance_selected() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return NULL;
|
return Variant();
|
||||||
}
|
}
|
||||||
|
|
||||||
void CreateDialog::_item_selected() {
|
void CreateDialog::_item_selected() {
|
||||||
|
@ -97,7 +97,7 @@ protected:
|
|||||||
void _save_and_update_favorite_list();
|
void _save_and_update_favorite_list();
|
||||||
|
|
||||||
public:
|
public:
|
||||||
Object *instance_selected();
|
Variant instance_selected();
|
||||||
String get_selected_type();
|
String get_selected_type();
|
||||||
|
|
||||||
void set_base_type(const String &p_base);
|
void set_base_type(const String &p_base);
|
||||||
|
@ -497,7 +497,7 @@ void EditorData::add_custom_type(const String &p_type, const String &p_inherits,
|
|||||||
custom_types[p_inherits].push_back(ct);
|
custom_types[p_inherits].push_back(ct);
|
||||||
}
|
}
|
||||||
|
|
||||||
Object *EditorData::instance_custom_type(const String &p_type, const String &p_inherits) {
|
Variant EditorData::instance_custom_type(const String &p_type, const String &p_inherits) {
|
||||||
|
|
||||||
if (get_custom_types().has(p_inherits)) {
|
if (get_custom_types().has(p_inherits)) {
|
||||||
|
|
||||||
@ -505,18 +505,19 @@ Object *EditorData::instance_custom_type(const String &p_type, const String &p_i
|
|||||||
if (get_custom_types()[p_inherits][i].name == p_type) {
|
if (get_custom_types()[p_inherits][i].name == p_type) {
|
||||||
Ref<Script> script = get_custom_types()[p_inherits][i].script;
|
Ref<Script> script = get_custom_types()[p_inherits][i].script;
|
||||||
|
|
||||||
Object *ob = ClassDB::instance(p_inherits);
|
Variant ob = ClassDB::instance(p_inherits);
|
||||||
ERR_FAIL_COND_V(!ob, NULL);
|
ERR_FAIL_COND_V(!ob, Variant());
|
||||||
if (ob->is_class("Node")) {
|
Node *n = Object::cast_to<Node>(ob);
|
||||||
ob->call("set_name", p_type);
|
if (n) {
|
||||||
|
n->set_name(p_type);
|
||||||
}
|
}
|
||||||
ob->set_script(script.get_ref_ptr());
|
((Object *)ob)->set_script(script.get_ref_ptr());
|
||||||
return ob;
|
return ob;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return NULL;
|
return Variant();
|
||||||
}
|
}
|
||||||
|
|
||||||
void EditorData::remove_custom_type(const String &p_type) {
|
void EditorData::remove_custom_type(const String &p_type) {
|
||||||
@ -905,17 +906,17 @@ StringName EditorData::script_class_get_base(const String &p_class) const {
|
|||||||
return script->get_language()->get_global_class_name(base_script->get_path());
|
return script->get_language()->get_global_class_name(base_script->get_path());
|
||||||
}
|
}
|
||||||
|
|
||||||
Object *EditorData::script_class_instance(const String &p_class) {
|
Variant EditorData::script_class_instance(const String &p_class) {
|
||||||
if (ScriptServer::is_global_class(p_class)) {
|
if (ScriptServer::is_global_class(p_class)) {
|
||||||
Object *obj = ClassDB::instance(ScriptServer::get_global_class_native_base(p_class));
|
Variant obj = ClassDB::instance(ScriptServer::get_global_class_native_base(p_class));
|
||||||
if (obj) {
|
if (obj) {
|
||||||
Ref<Script> script = script_class_load_script(p_class);
|
Ref<Script> script = script_class_load_script(p_class);
|
||||||
if (script.is_valid())
|
if (script.is_valid())
|
||||||
obj->set_script(script.get_ref_ptr());
|
((Object *)obj)->set_script(script.get_ref_ptr());
|
||||||
return obj;
|
return obj;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return NULL;
|
return Variant();
|
||||||
}
|
}
|
||||||
|
|
||||||
Ref<Script> EditorData::script_class_load_script(const String &p_class) const {
|
Ref<Script> EditorData::script_class_load_script(const String &p_class) const {
|
||||||
|
@ -179,7 +179,7 @@ public:
|
|||||||
void restore_editor_global_states();
|
void restore_editor_global_states();
|
||||||
|
|
||||||
void add_custom_type(const String &p_type, const String &p_inherits, const Ref<Script> &p_script, const Ref<Texture> &p_icon);
|
void add_custom_type(const String &p_type, const String &p_inherits, const Ref<Script> &p_script, const Ref<Texture> &p_icon);
|
||||||
Object *instance_custom_type(const String &p_type, const String &p_inherits);
|
Variant instance_custom_type(const String &p_type, const String &p_inherits);
|
||||||
void remove_custom_type(const String &p_type);
|
void remove_custom_type(const String &p_type);
|
||||||
const Map<String, Vector<CustomType> > &get_custom_types() const { return custom_types; }
|
const Map<String, Vector<CustomType> > &get_custom_types() const { return custom_types; }
|
||||||
|
|
||||||
@ -217,7 +217,7 @@ public:
|
|||||||
|
|
||||||
bool script_class_is_parent(const String &p_class, const String &p_inherits);
|
bool script_class_is_parent(const String &p_class, const String &p_inherits);
|
||||||
StringName script_class_get_base(const String &p_class) const;
|
StringName script_class_get_base(const String &p_class) const;
|
||||||
Object *script_class_instance(const String &p_class);
|
Variant script_class_instance(const String &p_class);
|
||||||
|
|
||||||
Ref<Script> script_class_load_script(const String &p_class) const;
|
Ref<Script> script_class_load_script(const String &p_class) const;
|
||||||
|
|
||||||
|
@ -2342,35 +2342,32 @@ void EditorPropertyResource::_menu_option(int p_which) {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
Object *obj = NULL;
|
Variant obj;
|
||||||
RES res_temp;
|
|
||||||
|
|
||||||
if (ScriptServer::is_global_class(intype)) {
|
if (ScriptServer::is_global_class(intype)) {
|
||||||
obj = ClassDB::instance(ScriptServer::get_global_class_native_base(intype));
|
obj = ClassDB::instance(ScriptServer::get_global_class_native_base(intype));
|
||||||
if (obj) {
|
if (obj) {
|
||||||
res_temp = obj;
|
|
||||||
Ref<Script> script = ResourceLoader::load(ScriptServer::get_global_class_path(intype));
|
Ref<Script> script = ResourceLoader::load(ScriptServer::get_global_class_path(intype));
|
||||||
if (script.is_valid()) {
|
if (script.is_valid()) {
|
||||||
obj->set_script(Variant(script));
|
((Object *)obj)->set_script(script.get_ref_ptr());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
obj = ClassDB::instance(intype);
|
obj = ClassDB::instance(intype);
|
||||||
res_temp = obj;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!obj) {
|
if (!obj) {
|
||||||
obj = EditorNode::get_editor_data().instance_custom_type(intype, "Resource");
|
obj = EditorNode::get_editor_data().instance_custom_type(intype, "Resource");
|
||||||
res_temp = obj;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
ERR_BREAK(!res_temp.is_valid());
|
Resource *resp = Object::cast_to<Resource>(obj);
|
||||||
|
ERR_BREAK(!resp);
|
||||||
if (get_edited_object() && base_type != String() && base_type == "Script") {
|
if (get_edited_object() && base_type != String() && base_type == "Script") {
|
||||||
//make visual script the right type
|
//make visual script the right type
|
||||||
res_temp->call("set_instance_base_type", get_edited_object()->get_class());
|
resp->call("set_instance_base_type", get_edited_object()->get_class());
|
||||||
}
|
}
|
||||||
|
|
||||||
res = res_temp;
|
res = RES(resp);
|
||||||
emit_changed(get_edited_property(), res);
|
emit_changed(get_edited_property(), res);
|
||||||
update_property();
|
update_property();
|
||||||
|
|
||||||
|
@ -1781,7 +1781,7 @@ void FileSystemDock::_file_option(int p_option, const Vector<String> &p_selected
|
|||||||
}
|
}
|
||||||
|
|
||||||
void FileSystemDock::_resource_created() const {
|
void FileSystemDock::_resource_created() const {
|
||||||
Object *c = new_resource_dialog->instance_selected();
|
Variant c = new_resource_dialog->instance_selected();
|
||||||
|
|
||||||
ERR_FAIL_COND(!c);
|
ERR_FAIL_COND(!c);
|
||||||
Resource *r = Object::cast_to<Resource>(c);
|
Resource *r = Object::cast_to<Resource>(c);
|
||||||
@ -1795,17 +1795,14 @@ void FileSystemDock::_resource_created() const {
|
|||||||
memdelete(node);
|
memdelete(node);
|
||||||
}
|
}
|
||||||
|
|
||||||
REF res(r);
|
editor->push_item(r);
|
||||||
editor->push_item(c);
|
|
||||||
|
|
||||||
RES current_res = RES(r);
|
|
||||||
|
|
||||||
String fpath = path;
|
String fpath = path;
|
||||||
if (!fpath.ends_with("/")) {
|
if (!fpath.ends_with("/")) {
|
||||||
fpath = fpath.get_base_dir();
|
fpath = fpath.get_base_dir();
|
||||||
}
|
}
|
||||||
|
|
||||||
editor->save_resource_as(current_res, fpath);
|
editor->save_resource_as(RES(r), fpath);
|
||||||
}
|
}
|
||||||
|
|
||||||
void FileSystemDock::_search_changed(const String &p_text, const Control *p_from) {
|
void FileSystemDock::_search_changed(const String &p_text, const Control *p_from) {
|
||||||
|
@ -269,14 +269,13 @@ void InspectorDock::_select_history(int p_idx) const {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void InspectorDock::_resource_created() const {
|
void InspectorDock::_resource_created() const {
|
||||||
Object *c = new_resource_dialog->instance_selected();
|
Variant c = new_resource_dialog->instance_selected();
|
||||||
|
|
||||||
ERR_FAIL_COND(!c);
|
ERR_FAIL_COND(!c);
|
||||||
Resource *r = Object::cast_to<Resource>(c);
|
Resource *r = Object::cast_to<Resource>(c);
|
||||||
ERR_FAIL_COND(!r);
|
ERR_FAIL_COND(!r);
|
||||||
|
|
||||||
REF res(r);
|
editor->push_item(r);
|
||||||
editor->push_item(c);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void InspectorDock::_resource_selected(const RES &p_res, const String &p_property) const {
|
void InspectorDock::_resource_selected(const RES &p_res, const String &p_property) const {
|
||||||
|
@ -293,7 +293,7 @@ void CustomPropertyEditor::_menu_option(int p_which) {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
Object *obj = ClassDB::instance(intype);
|
Variant obj = ClassDB::instance(intype);
|
||||||
|
|
||||||
if (!obj) {
|
if (!obj) {
|
||||||
if (ScriptServer::is_global_class(intype)) {
|
if (ScriptServer::is_global_class(intype)) {
|
||||||
@ -311,7 +311,7 @@ void CustomPropertyEditor::_menu_option(int p_which) {
|
|||||||
res->call("set_instance_base_type", owner->get_class());
|
res->call("set_instance_base_type", owner->get_class());
|
||||||
}
|
}
|
||||||
|
|
||||||
v = Ref<Resource>(res).get_ref_ptr();
|
v = obj;
|
||||||
emit_signal("variant_changed");
|
emit_signal("variant_changed");
|
||||||
|
|
||||||
} break;
|
} break;
|
||||||
@ -1153,7 +1153,7 @@ void CustomPropertyEditor::_type_create_selected(int p_idx) {
|
|||||||
|
|
||||||
String intype = inheritors_array[p_idx];
|
String intype = inheritors_array[p_idx];
|
||||||
|
|
||||||
Object *obj = ClassDB::instance(intype);
|
Variant obj = ClassDB::instance(intype);
|
||||||
|
|
||||||
if (!obj) {
|
if (!obj) {
|
||||||
if (ScriptServer::is_global_class(intype)) {
|
if (ScriptServer::is_global_class(intype)) {
|
||||||
@ -1164,11 +1164,9 @@ void CustomPropertyEditor::_type_create_selected(int p_idx) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
ERR_FAIL_COND(!obj);
|
ERR_FAIL_COND(!obj);
|
||||||
|
ERR_FAIL_COND(!Object::cast_to<Resource>(obj));
|
||||||
|
|
||||||
Resource *res = Object::cast_to<Resource>(obj);
|
v = obj;
|
||||||
ERR_FAIL_COND(!res);
|
|
||||||
|
|
||||||
v = Ref<Resource>(res).get_ref_ptr();
|
|
||||||
emit_signal("variant_changed");
|
emit_signal("variant_changed");
|
||||||
hide();
|
hide();
|
||||||
}
|
}
|
||||||
@ -1359,7 +1357,7 @@ void CustomPropertyEditor::_action_pressed(int p_which) {
|
|||||||
|
|
||||||
if (hint == PROPERTY_HINT_RESOURCE_TYPE) {
|
if (hint == PROPERTY_HINT_RESOURCE_TYPE) {
|
||||||
|
|
||||||
Object *obj = ClassDB::instance(intype);
|
Variant obj = ClassDB::instance(intype);
|
||||||
|
|
||||||
if (!obj) {
|
if (!obj) {
|
||||||
if (ScriptServer::is_global_class(intype)) {
|
if (ScriptServer::is_global_class(intype)) {
|
||||||
@ -1370,10 +1368,9 @@ void CustomPropertyEditor::_action_pressed(int p_which) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
ERR_BREAK(!obj);
|
ERR_BREAK(!obj);
|
||||||
Resource *res = Object::cast_to<Resource>(obj);
|
ERR_BREAK(!Object::cast_to<Resource>(obj));
|
||||||
ERR_BREAK(!res);
|
|
||||||
|
|
||||||
v = Ref<Resource>(res).get_ref_ptr();
|
v = obj;
|
||||||
emit_signal("variant_changed");
|
emit_signal("variant_changed");
|
||||||
hide();
|
hide();
|
||||||
}
|
}
|
||||||
|
@ -1968,7 +1968,7 @@ Node *SceneTreeDock::_get_selection_group_tail(Node *p_node, List<Node *> p_list
|
|||||||
}
|
}
|
||||||
|
|
||||||
void SceneTreeDock::_do_create(Node *p_parent) {
|
void SceneTreeDock::_do_create(Node *p_parent) {
|
||||||
Object *c = create_dialog->instance_selected();
|
Variant c = create_dialog->instance_selected();
|
||||||
|
|
||||||
ERR_FAIL_COND(!c);
|
ERR_FAIL_COND(!c);
|
||||||
Node *child = Object::cast_to<Node>(c);
|
Node *child = Object::cast_to<Node>(c);
|
||||||
@ -2046,7 +2046,7 @@ void SceneTreeDock::_create() {
|
|||||||
Node *n = E->get();
|
Node *n = E->get();
|
||||||
ERR_FAIL_COND(!n);
|
ERR_FAIL_COND(!n);
|
||||||
|
|
||||||
Object *c = create_dialog->instance_selected();
|
Variant c = create_dialog->instance_selected();
|
||||||
|
|
||||||
ERR_FAIL_COND(!c);
|
ERR_FAIL_COND(!c);
|
||||||
Node *newnode = Object::cast_to<Node>(c);
|
Node *newnode = Object::cast_to<Node>(c);
|
||||||
|
Loading…
Reference in New Issue
Block a user