Stopped trying to revert to default values when script implementation of property_can_revert exists
(cherry picked from commit 27ada5c114
)
This commit is contained in:
parent
23d473f488
commit
d744f4a678
|
@ -464,18 +464,20 @@ bool EditorPropertyRevert::can_property_revert(Object *p_object, const StringNam
|
|||
}
|
||||
}
|
||||
|
||||
if (p_object->call("property_can_revert", p_property).operator bool()) {
|
||||
|
||||
has_revert = true;
|
||||
}
|
||||
|
||||
if (!has_revert && !p_object->get_script().is_null()) {
|
||||
Ref<Script> scr = p_object->get_script();
|
||||
if (scr.is_valid()) {
|
||||
Variant orig_value;
|
||||
if (scr->get_property_default_value(p_property, orig_value)) {
|
||||
if (orig_value != p_object->get(p_property)) {
|
||||
has_revert = true;
|
||||
// If the object implements property_can_revert, rely on that completely
|
||||
// (i.e. don't then try to revert to default value - the property_get_revert implementation
|
||||
// can do that if so desired)
|
||||
if (p_object->has_method("property_can_revert")) {
|
||||
has_revert = p_object->call("property_can_revert", p_property).operator bool();
|
||||
} else {
|
||||
if (!has_revert && !p_object->get_script().is_null()) {
|
||||
Ref<Script> scr = p_object->get_script();
|
||||
if (scr.is_valid()) {
|
||||
Variant orig_value;
|
||||
if (scr->get_property_default_value(p_property, orig_value)) {
|
||||
if (orig_value != p_object->get(p_property)) {
|
||||
has_revert = true;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue