Perform safe copies in AnimatedValuesBackup::get_cache_copy()

This commit is contained in:
Pedro J. Estébanez 2023-11-24 10:48:02 +01:00
parent 066e7d483a
commit fbb931df8c
2 changed files with 63 additions and 10 deletions

View File

@ -2166,8 +2166,7 @@ AnimationMixer::TrackCache *AnimatedValuesBackup::get_cache_copy(AnimationMixer:
switch (p_cache->type) { switch (p_cache->type) {
case Animation::TYPE_VALUE: { case Animation::TYPE_VALUE: {
AnimationMixer::TrackCacheValue *src = static_cast<AnimationMixer::TrackCacheValue *>(p_cache); AnimationMixer::TrackCacheValue *src = static_cast<AnimationMixer::TrackCacheValue *>(p_cache);
AnimationMixer::TrackCacheValue *tc = memnew(AnimationMixer::TrackCacheValue); AnimationMixer::TrackCacheValue *tc = memnew(AnimationMixer::TrackCacheValue(*src));
memcpy((void *)tc, (void *)src, sizeof(AnimationMixer::TrackCacheValue));
return tc; return tc;
} }
@ -2175,29 +2174,25 @@ AnimationMixer::TrackCache *AnimatedValuesBackup::get_cache_copy(AnimationMixer:
case Animation::TYPE_ROTATION_3D: case Animation::TYPE_ROTATION_3D:
case Animation::TYPE_SCALE_3D: { case Animation::TYPE_SCALE_3D: {
AnimationMixer::TrackCacheTransform *src = static_cast<AnimationMixer::TrackCacheTransform *>(p_cache); AnimationMixer::TrackCacheTransform *src = static_cast<AnimationMixer::TrackCacheTransform *>(p_cache);
AnimationMixer::TrackCacheTransform *tc = memnew(AnimationMixer::TrackCacheTransform); AnimationMixer::TrackCacheTransform *tc = memnew(AnimationMixer::TrackCacheTransform(*src));
memcpy((void *)tc, (void *)src, sizeof(AnimationMixer::TrackCacheTransform));
return tc; return tc;
} }
case Animation::TYPE_BLEND_SHAPE: { case Animation::TYPE_BLEND_SHAPE: {
AnimationMixer::TrackCacheBlendShape *src = static_cast<AnimationMixer::TrackCacheBlendShape *>(p_cache); AnimationMixer::TrackCacheBlendShape *src = static_cast<AnimationMixer::TrackCacheBlendShape *>(p_cache);
AnimationMixer::TrackCacheBlendShape *tc = memnew(AnimationMixer::TrackCacheBlendShape); AnimationMixer::TrackCacheBlendShape *tc = memnew(AnimationMixer::TrackCacheBlendShape(*src));
memcpy((void *)tc, (void *)src, sizeof(AnimationMixer::TrackCacheBlendShape));
return tc; return tc;
} }
case Animation::TYPE_BEZIER: { case Animation::TYPE_BEZIER: {
AnimationMixer::TrackCacheBezier *src = static_cast<AnimationMixer::TrackCacheBezier *>(p_cache); AnimationMixer::TrackCacheBezier *src = static_cast<AnimationMixer::TrackCacheBezier *>(p_cache);
AnimationMixer::TrackCacheBezier *tc = memnew(AnimationMixer::TrackCacheBezier); AnimationMixer::TrackCacheBezier *tc = memnew(AnimationMixer::TrackCacheBezier(*src));
memcpy((void *)tc, (void *)src, sizeof(AnimationMixer::TrackCacheBezier));
return tc; return tc;
} }
case Animation::TYPE_AUDIO: { case Animation::TYPE_AUDIO: {
AnimationMixer::TrackCacheAudio *src = static_cast<AnimationMixer::TrackCacheAudio *>(p_cache); AnimationMixer::TrackCacheAudio *src = static_cast<AnimationMixer::TrackCacheAudio *>(p_cache);
AnimationMixer::TrackCacheAudio *tc = memnew(AnimationMixer::TrackCacheAudio); AnimationMixer::TrackCacheAudio *tc = memnew(AnimationMixer::TrackCacheAudio(*src));
memcpy((void *)tc, (void *)src, sizeof(AnimationMixer::TrackCacheAudio));
return tc; return tc;
} }

View File

@ -142,6 +142,15 @@ protected:
ObjectID object_id; ObjectID object_id;
real_t total_weight = 0.0; real_t total_weight = 0.0;
TrackCache() = default;
TrackCache(const TrackCache &p_other) :
root_motion(p_other.root_motion),
setup_pass(p_other.setup_pass),
type(p_other.type),
object(p_other.object),
object_id(p_other.object_id),
total_weight(p_other.total_weight) {}
virtual ~TrackCache() {} virtual ~TrackCache() {}
}; };
@ -161,6 +170,24 @@ protected:
Quaternion rot; Quaternion rot;
Vector3 scale; Vector3 scale;
TrackCacheTransform(const TrackCacheTransform &p_other) :
TrackCache(p_other),
#ifndef _3D_DISABLED
node_3d(p_other.node_3d),
skeleton(p_other.skeleton),
#endif
bone_idx(p_other.bone_idx),
loc_used(p_other.loc_used),
rot_used(p_other.rot_used),
scale_used(p_other.scale_used),
init_loc(p_other.init_loc),
init_rot(p_other.init_rot),
init_scale(p_other.init_scale),
loc(p_other.loc),
rot(p_other.rot),
scale(p_other.scale) {
}
TrackCacheTransform() { TrackCacheTransform() {
type = Animation::TYPE_POSITION_3D; type = Animation::TYPE_POSITION_3D;
} }
@ -178,6 +205,14 @@ protected:
float init_value = 0; float init_value = 0;
float value = 0; float value = 0;
int shape_index = -1; int shape_index = -1;
TrackCacheBlendShape(const TrackCacheBlendShape &p_other) :
TrackCache(p_other),
mesh_3d(p_other.mesh_3d),
init_value(p_other.init_value),
value(p_other.value),
shape_index(p_other.shape_index) {}
TrackCacheBlendShape() { type = Animation::TYPE_BLEND_SHAPE; } TrackCacheBlendShape() { type = Animation::TYPE_BLEND_SHAPE; }
~TrackCacheBlendShape() {} ~TrackCacheBlendShape() {}
}; };
@ -189,6 +224,16 @@ protected:
bool is_continuous = false; bool is_continuous = false;
bool is_using_angle = false; bool is_using_angle = false;
Variant element_size; Variant element_size;
TrackCacheValue(const TrackCacheValue &p_other) :
TrackCache(p_other),
init_value(p_other.init_value),
value(p_other.value),
subpath(p_other.subpath),
is_continuous(p_other.is_continuous),
is_using_angle(p_other.is_using_angle),
element_size(p_other.element_size) {}
TrackCacheValue() { type = Animation::TYPE_VALUE; } TrackCacheValue() { type = Animation::TYPE_VALUE; }
~TrackCacheValue() { ~TrackCacheValue() {
// Clear ref to avoid leaking. // Clear ref to avoid leaking.
@ -206,6 +251,13 @@ protected:
real_t init_value = 0.0; real_t init_value = 0.0;
real_t value = 0.0; real_t value = 0.0;
Vector<StringName> subpath; Vector<StringName> subpath;
TrackCacheBezier(const TrackCacheBezier &p_other) :
TrackCache(p_other),
init_value(p_other.init_value),
value(p_other.value),
subpath(p_other.subpath) {}
TrackCacheBezier() { TrackCacheBezier() {
type = Animation::TYPE_BEZIER; type = Animation::TYPE_BEZIER;
} }
@ -235,6 +287,12 @@ protected:
Ref<AudioStreamPlaybackPolyphonic> audio_stream_playback; Ref<AudioStreamPlaybackPolyphonic> audio_stream_playback;
HashMap<ObjectID, PlayingAudioTrackInfo> playing_streams; // Key is Animation resource ObjectID. HashMap<ObjectID, PlayingAudioTrackInfo> playing_streams; // Key is Animation resource ObjectID.
TrackCacheAudio(const TrackCacheAudio &p_other) :
TrackCache(p_other),
audio_stream(p_other.audio_stream),
audio_stream_playback(p_other.audio_stream_playback),
playing_streams(p_other.playing_streams) {}
TrackCacheAudio() { TrackCacheAudio() {
type = Animation::TYPE_AUDIO; type = Animation::TYPE_AUDIO;
} }