You've already forked godot
mirror of
https://github.com/godotengine/godot.git
synced 2025-11-22 15:06:45 +00:00
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:
@@ -654,8 +654,8 @@ void AudioServer::_update_bus_effects(int p_bus) {
|
||||
buses[p_bus]->channels[i].effect_instances.resize(buses[p_bus]->effects.size());
|
||||
for (int j = 0; j < buses[p_bus]->effects.size(); j++) {
|
||||
Ref<AudioEffectInstance> fx = buses[p_bus]->effects[j].effect->instance();
|
||||
if (fx->cast_to<AudioEffectCompressorInstance>()) {
|
||||
fx->cast_to<AudioEffectCompressorInstance>()->set_current_channel(i);
|
||||
if (Object::cast_to<AudioEffectCompressorInstance>(*fx)) {
|
||||
Object::cast_to<AudioEffectCompressorInstance>(*fx)->set_current_channel(i);
|
||||
}
|
||||
buses[p_bus]->channels[i].effect_instances[j] = fx;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user