From 0a69496bad9b20cc98ea810f9b187f843711a026 Mon Sep 17 00:00:00 2001 From: Ali Akbar Mohammadi Date: Fri, 23 Aug 2019 02:50:53 +0800 Subject: [PATCH] Fix a memory curreption. --- src/net/PropertyReplicator.hpp | 33 ++++++++++++++++++++++++++++++++- 1 file changed, 32 insertions(+), 1 deletion(-) diff --git a/src/net/PropertyReplicator.hpp b/src/net/PropertyReplicator.hpp index d0f566a..3e5a0fc 100644 --- a/src/net/PropertyReplicator.hpp +++ b/src/net/PropertyReplicator.hpp @@ -4,6 +4,7 @@ #include "core/containers/Array.hpp" #include "core/defines.hpp" #include "en/World.hpp" +#include "core/log.h" namespace ari::net { @@ -21,6 +22,28 @@ namespace ari::net uint32_t ComponentId; bool(*isDiffFn)(void*, void*, int); + PropertyIndex() = default; + + PropertyIndex(PropertyIndex& other) + { + Index = other.Index; + Component = other.Component; + PropertyClone = other.PropertyClone; + ComponentId = other.ComponentId; + isDiffFn = other.isDiffFn; + other.PropertyClone = nullptr; + } + + PropertyIndex(PropertyIndex&& other) + { + Index = other.Index; + Component = other.Component; + PropertyClone = other.PropertyClone; + ComponentId = other.ComponentId; + isDiffFn = other.isDiffFn; + other.PropertyClone = nullptr; + } + ~PropertyIndex() { core::Memory::Free(PropertyClone); @@ -47,6 +70,8 @@ namespace ari::net clone = core::Memory::Alloc(sizeof(MemberT)); if (member.canGetConstRef()) { *((MemberT*)clone) = member.get(*cmp.Component); + MemberT* temp = (MemberT*)clone; + int hj = 0; } else if (member.hasGetter()) { *((MemberT*)clone) = member.getCopy(*cmp.Component); @@ -61,7 +86,13 @@ namespace ari::net { // We found the property add it to the list en::ComponentHandle cmpVoid = { cmp.Handle, cmp.Index, (void*)cmp.Component }; - Properties.Add({ property_index, cmpVoid, clone, T::Id, T::IsDiff }); + PropertyIndex property; + property.Component = cmpVoid; + property.ComponentId = T::Id; + property.Index = property_index; + property.PropertyClone = clone; + property.isDiffFn = T::IsDiff; + Properties.Add(property); } } };