diff options
author | aap <aap@papnet.eu> | 2019-06-19 23:41:43 +0200 |
---|---|---|
committer | aap <aap@papnet.eu> | 2019-06-20 00:12:12 +0200 |
commit | 2fcdf6fa21a173dcc033fd03b6d08b46b916c2e7 (patch) | |
tree | 1402bf32292b0ec260777d32f1f1069e41a37b67 /src/entities/Building.cpp | |
parent | implemented CObjectData (diff) | |
download | re3-2fcdf6fa21a173dcc033fd03b6d08b46b916c2e7.tar re3-2fcdf6fa21a173dcc033fd03b6d08b46b916c2e7.tar.gz re3-2fcdf6fa21a173dcc033fd03b6d08b46b916c2e7.tar.bz2 re3-2fcdf6fa21a173dcc033fd03b6d08b46b916c2e7.tar.lz re3-2fcdf6fa21a173dcc033fd03b6d08b46b916c2e7.tar.xz re3-2fcdf6fa21a173dcc033fd03b6d08b46b916c2e7.tar.zst re3-2fcdf6fa21a173dcc033fd03b6d08b46b916c2e7.zip |
Diffstat (limited to '')
-rw-r--r-- | src/entities/Building.cpp | 21 |
1 files changed, 20 insertions, 1 deletions
diff --git a/src/entities/Building.cpp b/src/entities/Building.cpp index e8f19b01..ef236e89 100644 --- a/src/entities/Building.cpp +++ b/src/entities/Building.cpp @@ -1,7 +1,26 @@ #include "common.h" -#include "rpworld.h" +#include "patcher.h" #include "Building.h" +#include "Streaming.h" #include "Pools.h" void *CBuilding::operator new(size_t sz) { return CPools::GetBuildingPool()->New(); } void CBuilding::operator delete(void *p, size_t sz) { CPools::GetBuildingPool()->Delete((CBuilding*)p); } + +void +CBuilding::ReplaceWithNewModel(int32 id) +{ + DeleteRwObject(); + + if(CModelInfo::GetModelInfo(m_modelIndex)->m_refCount == 0) + CStreaming::RemoveModel(m_modelIndex); + m_modelIndex = id; + + if(bIsBIGBuilding) + if(m_level == LEVEL_NONE || m_level == CGame::currLevel) + CStreaming::RequestModel(id, STREAM_DONT_REMOVE); +} + +STARTPATCHES + InjectHook(0x405850, &CBuilding::ReplaceWithNewModel, PATCH_JUMP); +ENDPATCHES |