diff --git a/.gitignore b/.gitignore index 1b1e37bf..a6a149ff 100644 --- a/.gitignore +++ b/.gitignore @@ -1,3 +1,5 @@ +*.VC.db +*.VC.opendb *.asi *.dll *.pdb diff --git a/CLEO4/CCustomOpcodeSystem.cpp b/CLEO4/CCustomOpcodeSystem.cpp index e89abd53..d8c9ba14 100644 --- a/CLEO4/CCustomOpcodeSystem.cpp +++ b/CLEO4/CCustomOpcodeSystem.cpp @@ -334,17 +334,17 @@ namespace CLEO inline CRunningScript& operator>>(CRunningScript& thread, CVector& vec) { GetScriptParams(&thread, 3); - vec.fX = opcodeParams[0].fParam; - vec.fY = opcodeParams[1].fParam; - vec.fZ = opcodeParams[2].fParam; + vec.x = opcodeParams[0].fParam; + vec.y = opcodeParams[1].fParam; + vec.z = opcodeParams[2].fParam; return thread; } inline CRunningScript& operator<<(CRunningScript& thread, const CVector& vec) { - opcodeParams[0].fParam = vec.fX; - opcodeParams[1].fParam = vec.fY; - opcodeParams[2].fParam = vec.fZ; + opcodeParams[0].fParam = vec.x; + opcodeParams[1].fParam = vec.y; + opcodeParams[2].fParam = vec.z; SetScriptParams(&thread, 3); return thread; } @@ -811,8 +811,10 @@ namespace CLEO prevScmFunctionId(reinterpret_cast(thread)->GetScmFunction()), retnAddress(thread->GetBytePointer()) { auto cs = reinterpret_cast(thread); + auto scope = cs->IsMission() ? missionLocals : cs->LocalVar; std::copy(scope, scope + 32, savedTls); + SCRIPT_VAR fill_val; fill_val.dwParam = 0; // CLEO 3 didnt initialise local storage, so dont do it if we're processing a CLEO 3 script in case the storage is used @@ -1016,7 +1018,7 @@ namespace CLEO { DWORD handle; *thread >> handle; - *thread << GetPedPool().GetAt(handle); + *thread << GetPedPool().AtHandle(handle); return OR_CONTINUE; } @@ -1025,7 +1027,7 @@ namespace CLEO { DWORD handle; *thread >> handle; - *thread << GetVehiclePool().GetAt(handle); + *thread << GetVehiclePool().AtHandle(handle); return OR_CONTINUE; } @@ -1034,7 +1036,7 @@ namespace CLEO { DWORD handle; *thread >> handle; - *thread << GetObjectPool().GetAt(handle); + *thread << GetObjectPool().AtHandle(handle); return OR_CONTINUE; } @@ -1644,15 +1646,15 @@ namespace CLEO { DWORD actor; *thread >> actor; - auto pPlayerPed = GetPedPool().GetAt(actor); + auto pPlayerPed = GetPedPool().AtHandle(actor); CPedIntelligence * pedintel; - if(pPlayerPed && (pedintel = pPlayerPed->GetPedIntelligence())) + if(pPlayerPed && (pedintel = pPlayerPed->m_pIntelligence)) { CVehicle * pVehicle = nullptr; for(int i=0; im_VehicleScanner.m_pEntities[i]; - if(pVehicle && pVehicle->GetOwner() != 2 && !pVehicle->m_nVehicleFlags.bFadeOut) + pVehicle = (CVehicle*) pedintel->m_vehicleScanner.m_apEntities[i]; + if(pVehicle && pVehicle->m_nCreatedBy != 2 && !pVehicle->m_nFlags.bFadeOut) break; pVehicle = nullptr; } @@ -1660,8 +1662,8 @@ namespace CLEO CPed * pPed = nullptr; for(int i=0; im_PedScanner.m_pEntities[i]; - if(pPed && pPed != pPlayerPed && pPed->GetOwner() == 1 && !pPed->GetPedFlags().bFadeOut) + pPed = (CPed*) pedintel->m_pedScanner.m_apEntities[i]; + if(pPed && pPed != pPlayerPed && (pPed->m_dwUsageType & 0xFF) == 1 && !pPed->m_nPedFlags.bFadeOut) break; pPed = nullptr; } @@ -1677,12 +1679,12 @@ namespace CLEO { // steam offset is different, so get it manually for now CGameVersionManager& gvm = GetInstance().VersionManager; - DWORD hMarker = gvm.GetGameVersion() != GV_STEAM ? MenuManager->GetWaypointHandle() : *((DWORD*)0xC3312C); + DWORD hMarker = gvm.GetGameVersion() != GV_STEAM ? MenuManager->m_nTargetBlipIndex : *((DWORD*)0xC3312C); CMarker *pMarker; if(hMarker && (pMarker = &RadarBlips[LOWORD(hMarker)]) && /*pMarker->m_nPoolIndex == HIWORD(hMarker) && */pMarker->m_nBlipDisplayFlag) { - CVector coords(pMarker->m_vCoords); - coords.fZ = FindGroundZ(coords.fX, coords.fY); + CVector coords(pMarker->m_vPosition); + coords.z = FindGroundZ(coords.x, coords.y); *thread << coords; SetScriptCondResult(thread, true); } @@ -1700,7 +1702,7 @@ namespace CLEO { DWORD hVehicle; *thread >> hVehicle; - auto id = reinterpret_cast(Models[GetVehiclePool().GetAt(hVehicle)->GetModelIndex()])->vehicleHandlingID; + auto id = reinterpret_cast(Models[GetVehiclePool().AtHandle(hVehicle)->m_wModelIndex])->m_wHandlingIndex; *thread << Handling->Automobile[id].m_Transmission.ucNumberOfGears; return OR_CONTINUE; } @@ -1710,7 +1712,7 @@ namespace CLEO { DWORD hVehicle; *thread >> hVehicle; - *thread << GetVehiclePool().GetAt(hVehicle)->m_nCurrentGear; + *thread << GetVehiclePool().AtHandle(hVehicle)->m_nCurrentGear; return OR_CONTINUE; } @@ -1760,7 +1762,7 @@ namespace CLEO { DWORD hVehicle; *thread >> hVehicle; - SetScriptCondResult(thread, GetVehiclePool().GetAt(hVehicle)->m_nVehicleFlags.bSirenOrAlarm); + SetScriptCondResult(thread, GetVehiclePool().AtHandle(hVehicle)->m_nFlags.bSirenOrAlarm); return OR_CONTINUE; } @@ -1769,7 +1771,7 @@ namespace CLEO { DWORD hVehicle; *thread >> hVehicle; - SetScriptCondResult(thread, GetVehiclePool().GetAt(hVehicle)->m_nVehicleFlags.bEngineOn); + SetScriptCondResult(thread, GetVehiclePool().AtHandle(hVehicle)->m_nFlags.bEngineOn); return OR_CONTINUE; } @@ -1779,8 +1781,8 @@ namespace CLEO DWORD hVehicle, state; *thread >> hVehicle >> state; - auto veh = GetVehiclePool().GetAt(hVehicle); - veh->m_nVehicleFlags.bEngineOn = state != false; + auto veh = GetVehiclePool().AtHandle(hVehicle); + veh->m_nFlags.bEngineOn = state != false; return OR_CONTINUE; } @@ -1819,7 +1821,7 @@ namespace CLEO CAudioStream *stream; DWORD handle; *thread >> stream >> handle; - if(stream) stream->Link(GetObjectPool().GetAt(handle)); + if(stream) stream->Link(GetObjectPool().AtHandle(handle)); return OR_CONTINUE; } @@ -1829,7 +1831,7 @@ namespace CLEO CAudioStream *stream; DWORD handle; *thread >> stream >> handle; - if(stream) stream->Link(GetPedPool().GetAt(handle)); + if(stream) stream->Link(GetPedPool().AtHandle(handle)); return OR_CONTINUE; } @@ -1839,7 +1841,7 @@ namespace CLEO CAudioStream *stream; DWORD handle; *thread >> stream >> handle; - if(stream) stream->Link(GetVehiclePool().GetAt(handle)); + if(stream) stream->Link(GetVehiclePool().AtHandle(handle)); return OR_CONTINUE; } @@ -1980,9 +1982,9 @@ namespace CLEO DWORD playerId; *thread >> playerId; auto pPlayerPed = GetPlayerPed(playerId); - auto pTargetEntity = pPlayerPed->GetWeaponTarget(); - if(!pTargetEntity) pTargetEntity = pPlayerPed->GetManualWeaponTarget(); - if(pTargetEntity && pTargetEntity->IsPed()) + auto pTargetEntity = GetWeaponTarget(pPlayerPed); + if(!pTargetEntity) pTargetEntity = (CEntity*) pPlayerPed->m_pPlayerTargettedPed; + if(pTargetEntity && pTargetEntity->m_nType == ENTITY_TYPE_PED) { *thread << GetPedPool().GetIndex(reinterpret_cast(pTargetEntity)); SetScriptCondResult(thread, true); @@ -2150,7 +2152,7 @@ namespace CLEO auto model = reinterpret_cast(Models[mi]); if (*thread->GetBytePointer() >= 1 && *thread->GetBytePointer() <= 8) *thread >> buf; else buf = (char *)GetScriptParamPointer(thread); - memcpy(buf, model->Name, 8); + memcpy(buf, model->m_szGameName, 8); return OR_CONTINUE; } @@ -2167,7 +2169,7 @@ namespace CLEO DWORD mi; *thread >> mi; auto model = reinterpret_cast(Models[mi]); - if(model->VehicleType != VEHICLE_TYPE_TRAIN && model->VehicleType != VEHICLE_TYPE_UNKNOWN) SpawnCar(mi); + if(model->m_dwType != VEHICLE_TYPE_TRAIN && model->m_dwType != VEHICLE_TYPE_UNKNOWN) SpawnCar(mi); return OR_CONTINUE; } @@ -2176,9 +2178,9 @@ namespace CLEO { const char *gxt = readString(thread); if(*thread->GetBytePointer() >= 1 && *thread->GetBytePointer() <= 8) - *thread << CText__locate(gameTexts, 0, gxt); + *thread << GetInstance().TextManager.Get(gxt); else - strcpy((char *)GetScriptParamPointer(thread), CText__locate(gameTexts, 0, gxt)); + strcpy((char *)GetScriptParamPointer(thread), GetInstance().TextManager.Get(gxt)); return OR_CONTINUE; } @@ -2208,7 +2210,7 @@ namespace CLEO float radius; DWORD next, pass_deads; static DWORD stat_last_found = 0; - auto pool = GetPedPool(); + auto& pool = GetPedPool(); *thread >> center >> radius >> next >> pass_deads; DWORD& last_found = reinterpret_cast(thread)->IsCustom() ? @@ -2217,16 +2219,14 @@ namespace CLEO if (!next) last_found = 0; - for(int index = last_found; index < pool.GetSize(); ++index) + for(int index = last_found; index < pool.m_Size; ++index) { - if(!pool.IsValid(index)) continue; - - if(auto obj = pool.Get(index)) + if(auto obj = pool.GetAt(index)) { - if(obj->IsPlayer() || (pass_deads && !obj->IsAvailable())/* || obj->GetOwner() == 2*/ || obj->PedFlags.bFadeOut) + if(obj->IsPlayer() || (pass_deads && !IsAvailable(obj))/* || obj->GetOwner() == 2*/ || obj->m_nPedFlags.bFadeOut) continue; - if((obj->GetPos() - center).Length() <= radius) + if((obj->GetPosition() - center).Magnitude() <= radius) { last_found = index + 1; // on next opcode call start search from next index //if(last_found >= (unsigned)pool.GetSize()) last_found = 0; @@ -2253,7 +2253,7 @@ namespace CLEO DWORD next, pass_wrecked; static DWORD stat_last_found = 0; - auto pool = GetVehiclePool(); + auto& pool = GetVehiclePool(); *thread >> center >> radius >> next >> pass_wrecked; DWORD& last_found = reinterpret_cast(thread)->IsCustom() ? @@ -2262,16 +2262,14 @@ namespace CLEO if (!next) last_found = 0; - for (int index = last_found; index < pool.GetSize(); ++index) + for (int index = last_found; index < pool.m_Size; ++index) { - if (!pool.IsValid(index)) continue; - - if(auto obj = pool.Get(index)) + if(auto obj = pool.GetAt(index)) { - if((pass_wrecked && obj->IsWrecked()) || (/*obj->GetOwner() == 2 ||*/ obj->m_nVehicleFlags.bFadeOut)) + if((pass_wrecked && IsWrecked(obj)) || (/*obj->GetOwner() == 2 ||*/ obj->m_nFlags.bFadeOut)) continue; - if((obj->GetPos() - center).Length() <= radius) + if((obj->GetPosition() - center).Magnitude() <= radius) { last_found = index + 1; // on next opcode call start search from next index //if(last_found >= (unsigned)pool.GetSize()) last_found = 0; @@ -2296,7 +2294,7 @@ namespace CLEO float radius; DWORD next; static DWORD stat_last_found = 0; - auto pool = GetObjectPool(); + auto& pool = GetObjectPool(); *thread >> center >> radius >> next; auto cs = reinterpret_cast(thread); @@ -2304,15 +2302,13 @@ namespace CLEO if(!next) last_found = 0; - for(int index = last_found; index < pool.GetSize(); ++index) + for(int index = last_found; index < pool.m_Size; ++index) { - if (!pool.IsValid(index)) continue; // empty slot - - if(auto obj = pool.Get(index)) + if(auto obj = pool.GetAt(index)) { - if(obj->GetFlags().bFadeOut) continue; + if(obj->m_nObjectFlags.bFadingIn) continue; // this is actually .bFadingOut - if((obj->GetPos() - center).Length() <= radius) + if((obj->GetPosition() - center).Magnitude() <= radius) { last_found = index + 1; // on next opcode call start search from next index //if(last_found >= (unsigned)pool.GetSize()) last_found = 0; @@ -2681,4 +2677,4 @@ extern "C" { return GetScriptParamPointer(thread); } -} \ No newline at end of file +} diff --git a/CLEO4/CGameMenu.cpp b/CLEO4/CGameMenu.cpp index 2e087b8e..a42a2544 100644 --- a/CLEO4/CGameMenu.cpp +++ b/CLEO4/CGameMenu.cpp @@ -1,5 +1,4 @@ #include "stdafx.h" -#include "StdInc.h" #include "CGameMenu.h" #include "cleo.h" #include "CDebug.h" diff --git a/CLEO4/CScriptEngine.cpp b/CLEO4/CScriptEngine.cpp index 70874030..52ef2df7 100644 --- a/CLEO4/CScriptEngine.cpp +++ b/CLEO4/CScriptEngine.cpp @@ -685,7 +685,7 @@ namespace CLEO // steam offset is different, so get it manually for now CGameVersionManager& gvm = GetInstance().VersionManager; - int nSlot = gvm.GetGameVersion() != GV_STEAM ? MenuManager->GetSaveSlot() : *((BYTE*)MenuManager+0x15B); + int nSlot = gvm.GetGameVersion() != GV_STEAM ? *(BYTE*)&MenuManager->m_bSelectedSaveGame : *((BYTE*)MenuManager+0x15B); sprintf(safe_name, "./cleo/cleo_saves/cs%d.sav", nSlot); @@ -805,7 +805,7 @@ namespace CLEO // steam offset is different, so get it manually for now CGameVersionManager& gvm = GetInstance().VersionManager; - int nSlot = gvm.GetGameVersion() != GV_STEAM ? MenuManager->GetSaveSlot() : *((BYTE*)MenuManager+0x15B); + int nSlot = gvm.GetGameVersion() != GV_STEAM ? *(BYTE*)&MenuManager->m_bSelectedSaveGame : *((BYTE*)MenuManager+0x15B); char safe_name[MAX_PATH]; sprintf(safe_name, "./cleo/cleo_saves/cs%d.sav", nSlot); diff --git a/CLEO4/CSoundSystem.cpp b/CLEO4/CSoundSystem.cpp index d7a4d921..ff17d321 100644 --- a/CLEO4/CSoundSystem.cpp +++ b/CLEO4/CSoundSystem.cpp @@ -3,7 +3,6 @@ #include "bass\bass.h" #include "CDebug.h" #include "cleo.h" -#include "CMenuManager.h" #include namespace CLEO @@ -187,14 +186,14 @@ namespace CLEO // not in menu // process camera movements - RwMatrix * pMatrix = nullptr; - RwV3D * pVec = nullptr; - if(camera->matrix) + CMatrixLink * pMatrix = nullptr; + CVector * pVec = nullptr; + if(camera->m_matrix) { - pMatrix = &camera->matrix->matrix; + pMatrix = camera->m_matrix; pVec = &pMatrix->pos; } - else pVec = &camera->m_transform.m_translate; + else pVec = &camera->m_placement.m_vPosn; BASS_Set3DPosition( &BASS_3DVECTOR(pVec->y, pVec->z, pVec->x), @@ -353,9 +352,9 @@ namespace CLEO void C3DAudioStream::Set3dPosition(const CVector& pos) { - position.x = pos.fY; - position.y = pos.fZ; - position.z = pos.fX; + position.x = pos.y; + position.y = pos.z; + position.z = pos.x; link = nullptr; BASS_ChannelSet3DPosition(streamInternal, &position, nullptr, nullptr); } @@ -386,7 +385,7 @@ namespace CLEO { if (link) { - RwV3D * pVec = link->matrix ? &link->matrix->matrix.pos : &link->m_transform.m_translate; + CVector * pVec = link->m_matrix ? &link->m_matrix->pos : &link->m_placement.m_vPosn; BASS_ChannelSet3DPosition(streamInternal, &BASS_3DVECTOR(pVec->y, pVec->z, pVec->x), nullptr, nullptr); } else diff --git a/CLEO4/CTextManager.cpp b/CLEO4/CTextManager.cpp index 93759625..2b43c290 100644 --- a/CLEO4/CTextManager.cpp +++ b/CLEO4/CTextManager.cpp @@ -1,5 +1,4 @@ #include "stdafx.h" -#include "StdInc.h" #include "CTextManager.h" #include "cleo.h" @@ -18,11 +17,12 @@ namespace CLEO void (__cdecl * _PrintBig)(const char *, unsigned time, unsigned style); void (__cdecl * _Print) (const char *, unsigned time, bool flag1, bool flag2); void (__cdecl * _PrintNow) (const char *, unsigned time, bool flag1, bool flag2); + const char* (__fastcall * CText__Get)(CText*, int dummy, const char*); DWORD _CText__TKey__locate; char message_buf[0x80]; - const char * __fastcall CText__TKey__locate(CText::CKeyArray *key, int dummy, const char *gxt, bool& found) + const char * __fastcall CText__TKey__locate(CText__TKey *key, int dummy, const char *gxt, bool& found) { const char * result; _asm @@ -85,13 +85,13 @@ namespace CLEO szResult = GetInstance().TextManager.LocateFxt(gxt); if(szResult) return szResult; - szResult = CText__TKey__locate(&text->MainKeys, 0, gxt, bFound); + szResult = CText__TKey__locate(&text->tkeyMain, 0, gxt, bFound); if(!bFound) { - if (text->m_bMissionLoaded || *mpackNumber || text->haveTabl) + if (text->missionTableLoaded || *mpackNumber || text->haveTabl) { - szResult = CText__TKey__locate(&text->MissionKeys, 0, gxt, bFound); + szResult = CText__TKey__locate(&text->tkeyMission, 0, gxt, bFound); if (!bFound) return ""; //else TRACE("Failed to find used text label '%s'", gxt); } @@ -127,6 +127,11 @@ namespace CLEO _chdir(cwd); } + const char* CTextManager::Get(const char* key) + { + return CText__Get(gameTexts, 0, key); + } + bool CTextManager::AddFxt(const char *key, const char *value, bool dynamic) { // TODO: replace this part with in-place construction of FxtEntry, @@ -214,7 +219,8 @@ namespace CLEO gameTexts = gvm.TranslateMemoryAddress(MA_GAME_TEXTS); cheatString = gvm.TranslateMemoryAddress(MA_CHEAT_STRING); mpackNumber = gvm.TranslateMemoryAddress(MA_MPACK_NUMBER); - inj.InjectFunction(CText__locate, gvm.TranslateMemoryAddress(MA_CALL_CTEXT_LOCATE)); + CText__Get = gvm.TranslateMemoryAddress(MA_CALL_CTEXT_LOCATE); + inj.InjectFunction(CText__locate, CText__Get); } CTextManager::FxtEntry::FxtEntry(const char *_text, bool _static) : text(_text), is_static(_static) diff --git a/CLEO4/CTextManager.h b/CLEO4/CTextManager.h index 342385e7..4217814d 100644 --- a/CLEO4/CTextManager.h +++ b/CLEO4/CTextManager.h @@ -1,6 +1,5 @@ #pragma once #include "stdafx.h" -#include "StdInc.h" #include "CCodeInjector.h" #include "crc32.h" #include @@ -26,6 +25,7 @@ namespace CLEO public: CTextManager(); ~CTextManager(); + const char* Get(const char* key); bool AddFxt(const char *key, const char *value, bool dynamic = true); bool RemoveFxt(const char *key); // find fxt text by its key diff --git a/CLEO4/cleo.def b/CLEO4/cleo.def index 30c6be30..ba20ceb9 100644 --- a/CLEO4/cleo.def +++ b/CLEO4/cleo.def @@ -19,4 +19,4 @@ EXPORTS missionLocals @16 opcodeParams @17 staticThreads @18 - _CLEO_GetPointerToScriptVariable@4 @19 \ No newline at end of file + _CLEO_GetPointerToScriptVariable@4 @19 diff --git a/CLEO4/stdafx.h b/CLEO4/stdafx.h index 03671e6b..0244048b 100644 --- a/CLEO4/stdafx.h +++ b/CLEO4/stdafx.h @@ -15,7 +15,19 @@ #include #include #include +#include #include +#include + +#include +#include +#include +#include +#include +#include +#include + +#include "CTheScripts.h" enum CLEO_Version { @@ -32,15 +44,91 @@ enum CLEO_Version #define VERSION_LONG 0x04031300 #define VERSION_STRING "4.3" +#define CPOOL_USE_HANDLE_ACCESS + +//#define VALIDATE_SIZE(struc, size) static_assert(sizeof(struc) == size, #struc " (Invalid Structure Size)") + +#define NUM_SCAN_ENTITIES 16 + +using CPedPool = CPool; +using CVehiclePool = CPool; +using CObjectPool = CPool; +using CBuildingPool = CPool; +using RGBA = CRGBA; +using RwV3D = RwV3d; +struct RwRect2D; +using CHandling = cHandlingDataMgr; +using CMarker = tRadarTrace; + +class CTexture +{ + RwTexture *texture; +}; + +// stolen from GTASA +class CTextDrawer +{ +public: + float m_fScaleX; + float m_fScaleY; + CRGBA m_Colour; + BYTE m_bJustify; + BYTE m_bCenter; + BYTE m_bBackground; + BYTE m_bUnk1; + float m_fLineHeight; + float m_fLineWidth; + CRGBA m_BackgroundColour; + BYTE m_bProportional; + CRGBA m_EffectColour; + BYTE m_ucShadow; + BYTE m_ucOutline; + BYTE m_bDrawBeforeFade; + BYTE m_bAlignRight; + int m_nFont; + float m_fPosX; + float m_fPosY; + char m_szGXT[8]; + int m_nParam1; + int m_nParam2; +}; + +VALIDATE_SIZE(CTextDrawer, 0x44); + +enum +{ + VEHICLE_TYPE_AUTOMOBILE, + VEHICLE_TYPE_PLANE, + VEHICLE_TYPE_BIKE, + VEHICLE_TYPE_HELI, + VEHICLE_TYPE_BOAT, + VEHICLE_TYPE_TRAIN, + VEHICLE_TYPE_TRAILER, + VEHICLE_TYPE_BMX, + VEHICLE_TYPE_MTRUCK, + VEHICLE_TYPE_QUAD, + VEHICLE_TYPE_UNKNOWN = -1, +}; + +inline CEntity* GetWeaponTarget(CPed* pSelf) +{ + return reinterpret_cast(pSelf->m_pTargetedObject) != -1? pSelf->m_pTargetedObject : nullptr; +} + +inline bool IsAvailable(CPed* pSelf) +{ + return pSelf->m_pedState != PEDSTATE_DIE && pSelf->m_pedState != PEDSTATE_DEAD; +} + +inline bool IsWrecked(CVehicle* pSelf) +{ + return pSelf->m_nStatus == STATUS_WRECKED || pSelf->m_nFlags.bIsDrowning; +} + + #define OP_NOP 0x90 #define OP_RET 0xC3 #define OP_CALL 0xE8 #define OP_JMP 0xE9 #define OP_JMPSHORT 0xEB - -#define CPOOL_USE_HANDLE_ACCESS - -//#define VALIDATE_SIZE(struc, size) static_assert(sizeof(struc) == size, #struc " (Invalid Structure Size)") - -#include "StdInc.h" -#include "Mem.h" \ No newline at end of file +#include "Mem.h" diff --git a/CTheScripts.h b/CTheScripts.h new file mode 100644 index 00000000..b676126a --- /dev/null +++ b/CTheScripts.h @@ -0,0 +1,260 @@ +#pragma once + +enum eDataType +{ + DT_END, + DT_DWORD, + DT_VAR, + DT_LVAR, + DT_BYTE, + DT_WORD, + DT_FLOAT, + DT_VAR_ARRAY, + DT_LVAR_ARRAY, + DT_TEXTLABEL, + DT_VAR_TEXTLABEL, + DT_LVAR_TEXTLABEL, + DT_VAR_TEXTLABEL_ARRAY, + DT_LVAR_TEXTLABEL_ARRAY, + DT_VARLEN_STRING, + DT_STRING, + DT_VAR_STRING, + DT_LVAR_STRING, + DT_VAR_STRING_ARRAY, + DT_LVAR_STRING_ARRAY +}; + +union SCRIPT_VAR +{ + DWORD dwParam; + short wParam; + WORD usParam; + BYTE ucParam; + char cParam; + bool bParam; + int nParam; + float fParam; + void* pParam; + char* pcParam; +}; + +class CRunningScript +{ +protected: + CRunningScript *Previous; // +0x0 + CRunningScript *Next; // +0x4 + char Name[8]; // +0x8 + void *BaseIP; // +0x10 + BYTE *CurrentIP; // +0x14 + BYTE *Stack[8]; // +0x18 + WORD SP; // +0x38 + SCRIPT_VAR LocalVar[32]; // +0x3C + DWORD Timers[2]; // +0xBC + bool bIsActive; // +0xC4 + bool bCondResult; // +0xC5 + bool bUseMissionCleanup; // +0xC6 + bool bIsExternal; // +0xC7 + bool bTextBlockOverride; // +0xC8 + BYTE bExternalType; // +0xC9 + DWORD WakeTime; // +0xCC + WORD LogicalOp; // +0xD0 + bool NotFlag; // +0xD2 + bool bWastedBustedCheck; // +0xD3 + bool bWastedOrBusted; // +0xD4 + void *SceneSkipIP; // +0xD8 + bool bIsMission; // +0xDC + +public: + inline bool IsActive() { + return bIsActive; + } + inline bool IsExternal() { + return bIsExternal; + } + inline bool IsMission() { + return bIsMission; + } + inline const char * GetName() { + return Name; + } + inline BYTE * GetBasePointer() { + return (BYTE*)BaseIP; + } + inline BYTE * GetBytePointer() { + return CurrentIP; + } + inline void SetIp(void *ip) { + CurrentIP = (BYTE*)ip; + } + inline void SetBaseIp(void *ip) { + BaseIP = ip; + } + inline CRunningScript * GetNext() { + return Next; + } + inline CRunningScript * GetPrev() { + return Previous; + } + inline void SetIsExternal(bool b) { + bIsExternal = b; + } + inline void SetActive(bool b) { + bIsActive = b; + } + inline void SetNext(CRunningScript *v) { + Next = v; + } + inline void SetPrev(CRunningScript *v) { + Previous = v; + } + inline SCRIPT_VAR * GetVarPtr() { + return LocalVar; + } + inline SCRIPT_VAR * GetVarPtr(int i) { + return &LocalVar[i]; + } + inline int * GetIntVarPtr(int i) { + return (int*)&LocalVar[i].dwParam; + } + inline int GetIntVar(int i) { + return LocalVar[i].dwParam; + } + inline void SetIntVar(int i, int v) { + LocalVar[i].dwParam = v; + } + inline void SetFloatVar(int i, float v) { + LocalVar[i].fParam = v; + } + inline char GetByteVar(int i) { + return LocalVar[i].bParam; + } + inline bool GetConditionResult() { + return bCondResult != 0; + } + /* + inline int GetLocalVarVal(int i) { + return IsMission() ? CTheScripts::GetMissionLocal(i) : GetIntVar(i); + } + inline int * GetLocalVarPtr(int i) { + return IsMission() ? CTheScripts::GetMissionLocalPtr(i) : GetIntVarPtr(i); + }*/ + + inline char ReadDataType() { + return ReadDataByte(); + } + inline short ReadDataVarIndex() { + return ReadDataWord(); + } + inline short ReadDataArrayOffset() { + return ReadDataWord(); + } + inline short ReadDataArrayIndex() { + return ReadDataWord(); + } + inline short ReadDataArraySize() { + return ReadDataByte(); + } + inline short ReadDataArrayFlags() { + return ReadDataByte(); + } + /* + inline int ReadDataGlobalIntVal() + { + short i = ReadDataVarIndex(); + return CTheScripts::GetGlobalVarVal(i); + }; + + inline int ReadDataLocalIntVal() + { + short i = ReadDataVarIndex(); + return IsMission() ? CTheScripts::GetMissionLocal(i) : GetIntVar(i); + };*/ + /* + inline int ReadDataGlobalArrayIntVal() + { + short offset = ReadDataArrayOffset(), + index = ReadDataArrayIndex(), + size = ReadDataArraySize(), + flags = ReadDataArrayFlags(), + indexVal; + + if(flags >= 0x80) indexVal = GetLocalVarVal(index); + else indexVal = CTheScripts::GetGlobalVarVal(index); + + return CTheScripts::GetGlobalVarVal(indexVal + offset); + }; + + inline int ReadDataLocalArrayIntVal() + { + short offset = ReadDataArrayOffset(), + index = ReadDataArrayIndex(), + size = ReadDataArraySize(), + flags = ReadDataArrayFlags(), + indexVal; + + if(flags >= 0x80) indexVal = GetLocalVarVal(index); + else indexVal = CTheScripts::GetGlobalVarVal(index); + + return GetLocalVarVal(indexVal + offset); + };*/ + + inline void IncPtr(int n = 1) { + CurrentIP += n; + }; + + inline int ReadDataByte() + { + char b = *CurrentIP; + ++CurrentIP; + return b; + }; + + inline short ReadDataWord() + { + short v = *(short*)CurrentIP; + CurrentIP += 2; + return v; + }; + + inline int ReadDataInt() + { + int i = *(int*)CurrentIP; + CurrentIP += 4; + return i; + }; + + inline void PushStack(BYTE *ptr) + { + Stack[SP++] = ptr; + } + + inline BYTE * PopStack() + { + return Stack[--SP]; + } + + CRunningScript() + { + strcpy(Name, "noname"); + BaseIP = 0; + Previous = 0; + Next = 0; + CurrentIP = 0; + memset(Stack, 0, sizeof(Stack)); + SP = 0; + WakeTime = 0; + bIsActive = 0; + bCondResult = 0; + bUseMissionCleanup = 0; + bIsExternal = 0; + bTextBlockOverride = 0; + bExternalType = -1; + memset(LocalVar, 0, sizeof(LocalVar)); + LogicalOp = 0; + NotFlag = 0; + bWastedOrBusted = 0; + SceneSkipIP = 0; + bIsMission = 0; + bWastedBustedCheck = 1; + } +};