Compare commits

..

3 Commits

Author SHA1 Message Date
fallenoak
553a59c808
chore(object): tidy up return type for ClntObjMgrAllocObject
Some checks are pending
Push / ${{ matrix.build.system_name }} / ${{ matrix.build.build_type }} / ${{ matrix.build.compiler_name }} (map[build_type:Release cc:cl compiler_name:MSVC cxx:cl os:windows-latest system_name:Windows test_path:WhoaTest]) (push) Waiting to run
Push / ${{ matrix.build.system_name }} / ${{ matrix.build.build_type }} / ${{ matrix.build.compiler_name }} (map[build_type:Release cc:clang compiler_name:Clang cxx:clang++ os:macos-latest system_name:macOS test_path:WhoaTest]) (push) Waiting to run
Push / ${{ matrix.build.system_name }} / ${{ matrix.build.build_type }} / ${{ matrix.build.compiler_name }} (map[build_type:Release cc:gcc compiler_name:GCC cxx:g++ os:ubuntu-latest system_name:Linux test_path:WhoaTest]) (push) Waiting to run
2026-01-17 20:34:46 -06:00
fallenoak
2efef87898
feat(object): set disable time in CGObject_C::Disable 2026-01-17 20:29:40 -06:00
fallenoak
c92f1b8de8
feat(world): add time handling functions to CWorld 2026-01-17 19:20:30 -06:00
8 changed files with 102 additions and 11 deletions

View File

@ -520,8 +520,9 @@ void WowClientDestroy() {
}
void WowClientInit() {
EventRegister(EVENT_ID_TICK, reinterpret_cast<EVENTHANDLERFUNC>(&CWorld::OnTick));
// TODO
// EventRegister(EVENT_ID_5, (int)sub_4020E0);
// _cfltcvt_init_0();
ClientRegisterConsoleCommands();

View File

@ -1,5 +1,6 @@
#include "object/client/CGObject_C.hpp"
#include "object/client/ObjMgr.hpp"
#include "world/World.hpp"
CGObject_C::CGObject_C(uint32_t time, CClientObjCreate& objCreate) {
// TODO
@ -23,10 +24,12 @@ void CGObject_C::AddWorldObject() {
}
void CGObject_C::Disable() {
// TODO
this->m_disabled = true;
// TODO other flag manipulation
// TODO
this->m_disableTimeMs = CWorld::GetCurTimeMs();
}
int32_t CGObject_C::IsInReenable() {

View File

@ -12,6 +12,7 @@ class CGObject_C : public CGObject, public TSHashObject<CGObject_C, CHashKeyGUID
public:
// Public member variables
TSLink<CGObject_C> m_link;
uint32_t m_disableTimeMs;
// TODO
uint32_t m_lockCount : 16;
uint32_t m_disabled : 1;

View File

@ -236,7 +236,7 @@ int32_t CreateObject(CDataStore* msg, uint32_t time) {
ClntObjMgrSetActivePlayer(guid);
}
auto newObject = static_cast<CGObject_C*>(ClntObjMgrAllocObject(typeID, guid));
auto newObject = ClntObjMgrAllocObject(typeID, guid);
SetupObjectStorage(typeID, newObject, guid);

View File

@ -67,12 +67,12 @@ void MirrorInitialize() {
// TODO
}
void* ClntObjMgrAllocObject(OBJECT_TYPE_ID typeID, WOWGUID guid) {
CGObject_C* ClntObjMgrAllocObject(OBJECT_TYPE_ID typeID, WOWGUID guid) {
auto playerGUID = ClntObjMgrGetActivePlayer();
// Heap allocate player object for current player
if (guid == playerGUID) {
return STORM_ALLOC(sizeof(CGPlayer_C) + CGPlayer::GetDataSize() + CGPlayer::GetDataSizeSaved());
return static_cast<CGObject_C*>(STORM_ALLOC(sizeof(CGPlayer_C) + CGPlayer::GetDataSize() + CGPlayer::GetDataSizeSaved()));
}
// TODO GarbageCollect(typeID, 10000);
@ -85,9 +85,10 @@ void* ClntObjMgrAllocObject(OBJECT_TYPE_ID typeID, WOWGUID guid) {
}
// TODO pointer should be fetched via ObjectPtr
static_cast<CGObject_C*>(mem)->m_memHandle = memHandle;
auto object = static_cast<CGObject_C*>(mem);
object->m_memHandle = memHandle;
return mem;
return object;
}
WOWGUID ClntObjMgrGetActivePlayer() {

View File

@ -6,7 +6,7 @@
#include "object/Types.hpp"
#include <cstdint>
void* ClntObjMgrAllocObject(OBJECT_TYPE_ID typeID, WOWGUID guid);
CGObject_C* ClntObjMgrAllocObject(OBJECT_TYPE_ID typeID, WOWGUID guid);
WOWGUID ClntObjMgrGetActivePlayer();

View File

@ -6,10 +6,49 @@
#include "world/Weather.hpp"
#include <storm/Memory.hpp>
uint32_t CWorld::s_curTimeMs;
float CWorld::s_curTimeSec;
uint32_t CWorld::s_enables;
uint32_t CWorld::s_enables2;
uint32_t CWorld::s_gameTimeFixed;
float CWorld::s_gameTimeSec;
uint32_t CWorld::s_tickTimeFixed;
uint32_t CWorld::s_tickTimeMs;
float CWorld::s_tickTimeSec;
Weather* CWorld::s_weather;
uint32_t CWorld::GetCurTimeMs() {
return CWorld::s_curTimeMs;
}
float CWorld::GetCurTimeSec() {
return CWorld::s_curTimeSec;
}
uint32_t CWorld::GetFixedPrecisionTime(float timeSec) {
return static_cast<uint32_t>(timeSec * 1024.0f);
}
uint32_t CWorld::GetGameTimeFixed() {
return CWorld::s_gameTimeFixed;
}
float CWorld::GetGameTimeSec() {
return CWorld::s_gameTimeSec;
}
uint32_t CWorld::GetTickTimeFixed() {
return CWorld::s_tickTimeFixed;
}
uint32_t CWorld::GetTickTimeMs() {
return CWorld::s_tickTimeMs;
}
float CWorld::GetTickTimeSec() {
return CWorld::s_tickTimeSec;
}
void CWorld::Initialize() {
CWorld::s_enables |=
Enables::Enable_1
@ -26,6 +65,9 @@ void CWorld::Initialize() {
| Enables::Enable_Particulates
| Enables::Enable_LowDetail;
CWorld::s_gameTimeFixed = 0;
CWorld::s_gameTimeSec = 0.0f;
// TODO
if (GxCaps().m_shaderTargets[GxSh_Pixel] > GxShPS_none) {
@ -58,3 +100,23 @@ void CWorld::LoadMap(const char* mapName, const C3Vector& position, int32_t zone
// TODO
}
int32_t CWorld::OnTick(const EVENT_DATA_TICK* data, void* param) {
CWorld::SetUpdateTime(data->tickTimeSec, data->curTimeMs);
return 1;
}
void CWorld::SetUpdateTime(float tickTimeSec, uint32_t curTimeMs) {
auto tickTimeFixed = CWorld::GetFixedPrecisionTime(tickTimeSec);
CWorld::s_curTimeMs = curTimeMs;
CWorld::s_curTimeSec = static_cast<float>(curTimeMs) * 0.001f;
CWorld::s_gameTimeFixed += tickTimeFixed;
CWorld::s_gameTimeSec += tickTimeSec;
CWorld::s_tickTimeFixed = tickTimeFixed;
CWorld::s_tickTimeMs = static_cast<uint32_t>(tickTimeSec * 1000.0f);
CWorld::s_tickTimeSec = tickTimeSec;
}

View File

@ -1,6 +1,7 @@
#ifndef WORLD_C_WORLD_HPP
#define WORLD_C_WORLD_HPP
#include "event/Event.hpp"
#include <tempest/Vector.hpp>
#include <cstdint>
@ -44,14 +45,36 @@ class CWorld {
Enable_HwPcf = 0x2
};
// Static variables
// Public static variables
static uint32_t s_enables;
static uint32_t s_enables2;
static Weather* s_weather;
// Static functions
static void Initialize(void);
// Public static functions
static uint32_t GetCurTimeMs();
static float GetCurTimeSec();
static uint32_t GetGameTimeFixed();
static float GetGameTimeSec();
static uint32_t GetTickTimeFixed();
static uint32_t GetTickTimeMs();
static float GetTickTimeSec();
static void Initialize();
static void LoadMap(const char* mapName, const C3Vector& position, int32_t zoneID);
static int32_t OnTick(const EVENT_DATA_TICK* data, void* param);
static void SetUpdateTime(float tickTimeSec, uint32_t curTimeMs);
private:
// Private static variables
static uint32_t s_curTimeMs;
static float s_curTimeSec;
static uint32_t s_gameTimeFixed;
static float s_gameTimeSec;
static uint32_t s_tickTimeFixed;
static uint32_t s_tickTimeMs;
static float s_tickTimeSec;
// Private static functions
static uint32_t GetFixedPrecisionTime(float timeSec);
};
#endif