Convert Object::cast_to() to the static version
Currently we rely on some undefined behavior when Object->cast_to() gets called with a Null pointer. This used to work fine with GCC < 6 but newer versions of GCC remove all codepaths in which the this pointer is Null. However, the non-static cast_to() was supposed to be null safe. This patch makes cast_to() Null safe and removes the now redundant Null checks where they existed. It is explained in this article: https://www.viva64.com/en/b/0226/
This commit is contained in:
parent
4aa2c18cb4
commit
cacced7e50
185 changed files with 1314 additions and 1508 deletions
|
|
@ -98,10 +98,10 @@ void PropertySelector::_update_search() {
|
|||
} else {
|
||||
|
||||
Object *obj = ObjectDB::get_instance(script);
|
||||
if (obj && obj->cast_to<Script>()) {
|
||||
if (Object::cast_to<Script>(obj)) {
|
||||
|
||||
props.push_back(PropertyInfo(Variant::NIL, "Script Variables", PROPERTY_HINT_NONE, "", PROPERTY_USAGE_CATEGORY));
|
||||
obj->cast_to<Script>()->get_script_property_list(&props);
|
||||
Object::cast_to<Script>(obj)->get_script_property_list(&props);
|
||||
}
|
||||
|
||||
StringName base = base_type;
|
||||
|
|
@ -200,10 +200,10 @@ void PropertySelector::_update_search() {
|
|||
} else {
|
||||
|
||||
Object *obj = ObjectDB::get_instance(script);
|
||||
if (obj && obj->cast_to<Script>()) {
|
||||
if (Object::cast_to<Script>(obj)) {
|
||||
|
||||
methods.push_back(MethodInfo("*Script Methods"));
|
||||
obj->cast_to<Script>()->get_script_method_list(&methods);
|
||||
Object::cast_to<Script>(obj)->get_script_method_list(&methods);
|
||||
}
|
||||
|
||||
StringName base = base_type;
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue