mirror of
https://github.com/Mauler125/r5sdk.git
synced 2025-02-09 19:15:03 +01:00
Some fixes and new features, see description.
* Add CServerGameDLL interface to SDK (unfinished) * Inline all CHostState members. Calling discrete member functions will result in a corrupt stack. It also alters with the VTable layout in the engine since we assign our SDK instance directly to it. Forcing everything to be inline (like the assembled counterpart within the executable itself) will ensure no virtual calls will get created and misalign the base VTable. * Patch SQVM_CompileError to call SQVM_Error with the severity flag set to false (0 = do not terminate process, 1 is terminate process).
This commit is contained in:
parent
d3c7b9baf5
commit
3616b85f6a
@ -18,6 +18,7 @@
|
||||
#include "game/server/fairfight_impl.h"
|
||||
#include "materialsystem/materialsystem.h"
|
||||
#include "studiorender/studiorendercontext.h"
|
||||
#include "squirrel/sqvm.h"
|
||||
#include "bsplib/bsplib.h"
|
||||
#include "ebisusdk/EbisuSDK.h"
|
||||
#ifndef DEDICATED
|
||||
@ -295,6 +296,7 @@ void RuntimePtc_Init() /* .TEXT */
|
||||
FairFight_Init.Offset(0x0).FindPatternSelf("0F 87", ADDRESS::Direction::DOWN, 200).Patch({ 0x0F, 0x85 }); // JA --> JNZ | Prevent 'FairFight' anti-cheat from initializing on the server by comparing RAX against 0x0 instead. Init will crash since the plugins aren't shipped.
|
||||
SCR_BeginLoadingPlaque.Offset(0x1AD).FindPatternSelf("75 27", ADDRESS::Direction::DOWN).Patch({ 0xEB, 0x27 }); // JNE --> JMP | Prevent connect command from crashing by invalid call to UI function.
|
||||
#endif // !DEDICATED
|
||||
p_SQVM_CompileError.FindPatternSelf("41 B0 01", ADDRESS::Direction::DOWN, 400).Patch({ 0x41, 0xB0, 0x00 }); // MOV --> MOV | Set script error level to 0 (not severe): 'mov r8b, 0'.
|
||||
}
|
||||
|
||||
void RuntimePtc_Toggle() /* .TEXT */
|
||||
|
@ -63,6 +63,7 @@
|
||||
#include "engine/debugoverlay.h"
|
||||
#endif // !DEDICATED
|
||||
#include "game/server/fairfight_impl.h"
|
||||
#include "game/server/gameinterface.h"
|
||||
#ifndef DEDICATED
|
||||
#include "inputsystem/inputsystem.h"
|
||||
#include "windows/id3dx.h"
|
||||
|
@ -26,11 +26,12 @@
|
||||
#include "client/IVEngineClient.h"
|
||||
#include "networksystem/pylon.h"
|
||||
#include "public/include/bansystem.h"
|
||||
#include "game/server/gameinterface.h"
|
||||
|
||||
//-----------------------------------------------------------------------------
|
||||
// Purpose: state machine's main processing loop
|
||||
//-----------------------------------------------------------------------------
|
||||
void CHostState::FrameUpdate(void* rcx, void* rdx, float time)
|
||||
FORCEINLINE void CHostState::FrameUpdate(void* rcx, void* rdx, float time)
|
||||
{
|
||||
static bool bInitialized = false;
|
||||
if (!bInitialized)
|
||||
@ -126,7 +127,7 @@ void CHostState::FrameUpdate(void* rcx, void* rdx, float time)
|
||||
//-----------------------------------------------------------------------------
|
||||
// Purpose: setup state machine
|
||||
//-----------------------------------------------------------------------------
|
||||
void CHostState::Setup(void) const
|
||||
FORCEINLINE void CHostState::Setup(void) const
|
||||
{
|
||||
g_pHostState->LoadConfig();
|
||||
g_pConVar->ClearHostNames();
|
||||
@ -169,7 +170,7 @@ void CHostState::Setup(void) const
|
||||
//-----------------------------------------------------------------------------
|
||||
// Purpose: load and execute configuration files
|
||||
//-----------------------------------------------------------------------------
|
||||
void CHostState::LoadConfig(void) const
|
||||
FORCEINLINE void CHostState::LoadConfig(void) const
|
||||
{
|
||||
if (!g_pCmdLine->CheckParm("-devsdk"))
|
||||
{
|
||||
@ -196,7 +197,7 @@ void CHostState::LoadConfig(void) const
|
||||
//-----------------------------------------------------------------------------
|
||||
// Purpose: initialize new game
|
||||
//-----------------------------------------------------------------------------
|
||||
void CHostState::State_NewGame(void)
|
||||
FORCEINLINE void CHostState::State_NewGame(void)
|
||||
{
|
||||
m_bSplitScreenConnect = false;
|
||||
if (!g_ServerGameClients) // Init Game if it ain't valid.
|
||||
@ -226,12 +227,11 @@ void CHostState::State_NewGame(void)
|
||||
//-----------------------------------------------------------------------------
|
||||
// Purpose: shutdown active game
|
||||
//-----------------------------------------------------------------------------
|
||||
void CHostState::GameShutDown(void)
|
||||
FORCEINLINE void CHostState::GameShutDown(void)
|
||||
{
|
||||
if (m_bActiveGame)
|
||||
{
|
||||
using GameShutdownFn = void(*)(void*);
|
||||
(*reinterpret_cast<GameShutdownFn**>(g_ServerDLL))[9](g_ServerDLL); // (*(void(__fastcall**)(void*))(*(_QWORD*)g_ServerDLL + 72i64))(g_ServerDLL);// GameShutdown
|
||||
g_pServerGameDLL->GameShutdown();
|
||||
m_bActiveGame = 0;
|
||||
}
|
||||
}
|
||||
@ -239,7 +239,7 @@ void CHostState::GameShutDown(void)
|
||||
//-----------------------------------------------------------------------------
|
||||
// Purpose: change singleplayer level
|
||||
//-----------------------------------------------------------------------------
|
||||
void CHostState::State_ChangeLevelSP(void)
|
||||
FORCEINLINE void CHostState::State_ChangeLevelSP(void)
|
||||
{
|
||||
DevMsg(eDLL_T::ENGINE, "Changing singleplayer level to: '%s'\n", m_levelName);
|
||||
m_flShortFrameTime = 1.5; // Set frame time.
|
||||
@ -265,19 +265,17 @@ void CHostState::State_ChangeLevelSP(void)
|
||||
//-----------------------------------------------------------------------------
|
||||
// Purpose: change multiplayer level
|
||||
//-----------------------------------------------------------------------------
|
||||
void CHostState::State_ChangeLevelMP(void)
|
||||
FORCEINLINE void CHostState::State_ChangeLevelMP(void)
|
||||
{
|
||||
DevMsg(eDLL_T::ENGINE, "Changing multiplayer level to: '%s'\n", m_levelName);
|
||||
m_flShortFrameTime = 0.5; // Set frame time.
|
||||
|
||||
using LevelShutdownFn = void(__thiscall*)(void*);
|
||||
(*reinterpret_cast<LevelShutdownFn**>(*g_ServerDLL))[8](g_ServerDLL); // (*(void (__fastcall **)(void *))(*(_QWORD *)server_dll_var + 64i64))(server_dll_var);// LevelShutdown
|
||||
|
||||
g_pServerGameDLL->LevelShutdown();
|
||||
if (CModelLoader_Map_IsValidFn(g_CModelLoader, m_levelName)) // Check if map is valid and if we can start a new game.
|
||||
{
|
||||
#ifndef DEDICATED
|
||||
using EnabledProgressBarForNextLoadFn = void(*)(void*);
|
||||
(*reinterpret_cast<EnabledProgressBarForNextLoadFn**>(g_pEngineVGui))[31](g_pEngineVGui); // (*((void(__fastcall**)(void**))g_CEngineVGUI + 31))(&g_CEngineVGUI);// EnabledProgressBarForNextLoad
|
||||
(*reinterpret_cast<EnabledProgressBarForNextLoadFn**>(g_pEngineVGui))[31](g_pEngineVGui); // EnabledProgressBarForNextLoad
|
||||
#endif // !DEDICATED
|
||||
Host_ChangelevelFn(false, m_levelName, m_mapGroupName); // Call change level as multiplayer level.
|
||||
}
|
||||
|
@ -16,16 +16,16 @@ enum class HostStates_t : int
|
||||
class CHostState
|
||||
{
|
||||
public:
|
||||
static void FrameUpdate(void* rcx, void* rdx, float time);
|
||||
FORCEINLINE static void FrameUpdate(void* rcx, void* rdx, float time);
|
||||
|
||||
void Setup(void) const;
|
||||
void LoadConfig(void) const;
|
||||
FORCEINLINE void Setup(void) const;
|
||||
FORCEINLINE void LoadConfig(void) const;
|
||||
|
||||
void State_NewGame(void);
|
||||
void GameShutDown(void);
|
||||
FORCEINLINE void State_NewGame(void);
|
||||
FORCEINLINE void GameShutDown(void);
|
||||
|
||||
void State_ChangeLevelSP(void);
|
||||
void State_ChangeLevelMP(void);
|
||||
FORCEINLINE void State_ChangeLevelSP(void);
|
||||
FORCEINLINE void State_ChangeLevelMP(void);
|
||||
|
||||
public:
|
||||
HostStates_t m_iCurrentState; //0x0000
|
||||
@ -65,7 +65,6 @@ namespace // !TEMP
|
||||
static auto CModelLoader_Map_IsValidFn = ADDRESS(0x1402562F0).RCast<bool(*)(void*, const char*)>();
|
||||
static auto Host_NewGameFn = ADDRESS(0x140238DA0).RCast<bool(*)(char*, char*, bool, bool, void*)>();
|
||||
static auto Host_Game_ShutdownFn = ADDRESS(0x14023EDA0).RCast<void(*)(CHostState*)>();
|
||||
static auto g_ServerDLL = ADDRESS(0x141732048).RCast<void**>();
|
||||
static auto Host_ChangelevelFn = ADDRESS(0x1402387B0).RCast<void(*)(bool, const char*, const char*)>();
|
||||
static auto CL_EndMovieFn = ADDRESS(0x1402C03D0).RCast<void(*)()>();
|
||||
static auto SendOfflineRequestToStryderFn = ADDRESS(0x14033D380).RCast<void(*)()>();
|
||||
|
@ -5,6 +5,9 @@
|
||||
namespace
|
||||
{
|
||||
/* ==== SV_MAIN ======================================================================================================================================================= */
|
||||
ADDRESS p_SV_CreateBaseline = g_mGameDll.FindPatternSIMD((std::uint8_t*)"\x48\x83\xEC\x28\x48\x8B\x0D\x00\x00\x00\x00\x48\x85\xC9\x75\x07", "xxxxxxx????xxxxx");
|
||||
bool (*SV_CreateBaseline)() = (bool(*)())p_SV_CreateBaseline.GetPtr(); /*48 83 EC 28 48 8B 0D ? ? ? ? 48 85 C9 75 07*/
|
||||
|
||||
ADDRESS p_SV_ShutdownGameDLL = g_mGameDll.FindPatternSIMD((std::uint8_t*)"\x48\x83\xEC\x28\x80\x3D\x00\x00\x00\x00\x00\x0F\x84\x00\x00\x00\x00\x48\x8B\x0D\x00\x00\x00\x00\x48\x89\x5C\x24\x00", "xxxxxx?????xx????xxx????xxxx?");
|
||||
void (*SV_ShutdownGameDLL)() = (void(*)())p_SV_ShutdownGameDLL.GetPtr(); /*48 83 EC 28 80 3D ? ? ? ? ? 0F 84 ? ? ? ? 48 8B 0D ? ? ? ? 48 89 5C 24 ?*/
|
||||
|
||||
@ -25,6 +28,7 @@ class HSV_Main : public IDetour
|
||||
{
|
||||
virtual void debugp()
|
||||
{
|
||||
std::cout << "| FUN: SV_CreateBaseline : 0x" << std::hex << std::uppercase << p_SV_CreateBaseline.GetPtr() << std::setw(npad) << " |" << std::endl;
|
||||
std::cout << "| FUN: SV_ShutdownGameDLL : 0x" << std::hex << std::uppercase << p_SV_ShutdownGameDLL.GetPtr() << std::setw(npad) << " |" << std::endl;
|
||||
std::cout << "| FUN: CGameServer::SpawnServer : 0x" << std::hex << std::uppercase << CGameServer__SpawnServer.GetPtr() << std::setw(npad) << " |" << std::endl;
|
||||
std::cout << "+----------------------------------------------------------------+" << std::endl;
|
||||
|
60
r5dev/game/server/gameinterface.cpp
Normal file
60
r5dev/game/server/gameinterface.cpp
Normal file
@ -0,0 +1,60 @@
|
||||
//=============================================================================//
|
||||
//
|
||||
// Purpose: Implement things from GameInterface.cpp. Mostly the engine interfaces.
|
||||
//
|
||||
// $NoKeywords: $
|
||||
//=============================================================================//
|
||||
|
||||
#include "core/stdafx.h"
|
||||
#include "engine/sv_main.h"
|
||||
#include "game/server/gameinterface.h"
|
||||
|
||||
//-----------------------------------------------------------------------------
|
||||
// This is called when a new game is started. (restart, map)
|
||||
//-----------------------------------------------------------------------------
|
||||
void CServerGameDLL::GameInit(void)
|
||||
{
|
||||
static int index = 1;
|
||||
CallVFunc<void>(index, this);
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------
|
||||
// This is called when scripts are getting recompiled. (restart, map, changelevel)
|
||||
//-----------------------------------------------------------------------------
|
||||
void CServerGameDLL::PrecompileScriptsJob(void)
|
||||
{
|
||||
static int index = 2;
|
||||
CallVFunc<void>(index, this);
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------
|
||||
// Called when a level is shutdown (including changing levels)
|
||||
//-----------------------------------------------------------------------------
|
||||
void CServerGameDLL::LevelShutdown(void)
|
||||
{
|
||||
static int index = 8;
|
||||
CallVFunc<void>(index, this);
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------
|
||||
// This is called when a game ends (server disconnect, death, restart, load)
|
||||
// NOT on level transitions within a game
|
||||
//-----------------------------------------------------------------------------
|
||||
void CServerGameDLL::GameShutdown(void)
|
||||
{
|
||||
static int index = 9;
|
||||
CallVFunc<void>(index, this);
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------
|
||||
// Purpose: Gets the simulation tick interfal
|
||||
// Output : float
|
||||
//-----------------------------------------------------------------------------
|
||||
float CServerGameDLL::GetTickInterval(void)
|
||||
{
|
||||
static int index = 11;
|
||||
return CallVFunc<float>(index, this);
|
||||
}
|
||||
|
||||
// Pointer to CServerGameDLL virtual function table.
|
||||
CServerGameDLL* g_pServerGameDLL = reinterpret_cast<CServerGameDLL*>(p_SV_CreateBaseline.Offset(0x0).FindPatternSelf("48 8B", ADDRESS::Direction::DOWN).ResolveRelativeAddressSelf(0x3, 0x7).Deref().GetPtr());
|
31
r5dev/game/server/gameinterface.h
Normal file
31
r5dev/game/server/gameinterface.h
Normal file
@ -0,0 +1,31 @@
|
||||
//=============================================================================//
|
||||
//
|
||||
// Purpose: Interface server dll virtual functions to the SDK.
|
||||
//
|
||||
// $NoKeywords: $
|
||||
//=============================================================================//
|
||||
|
||||
class CServerGameDLL
|
||||
{
|
||||
public:
|
||||
void GameInit(void);
|
||||
void PrecompileScriptsJob(void);
|
||||
void LevelShutdown(void);
|
||||
void GameShutdown(void);
|
||||
float GetTickInterval(void);
|
||||
};
|
||||
|
||||
extern CServerGameDLL* g_pServerGameDLL;
|
||||
|
||||
///////////////////////////////////////////////////////////////////////////////
|
||||
class HServerGameDLL : public IDetour
|
||||
{
|
||||
virtual void debugp()
|
||||
{
|
||||
std::cout << "| VAR: g_pServerGameDLL : 0x" << std::hex << std::uppercase << g_pServerGameDLL << std::setw(0) << " |" << std::endl;
|
||||
std::cout << "+----------------------------------------------------------------+" << std::endl;
|
||||
}
|
||||
};
|
||||
///////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
REGISTER(HServerGameDLL);
|
@ -451,7 +451,6 @@ void CConsole::FindFromPartial(void)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
m_vsvSuggest.push_back(g_vsvCommandBases[i] + svValue);
|
||||
}
|
||||
}
|
||||
|
@ -91,10 +91,14 @@ namespace
|
||||
|
||||
ADDRESS p_SQVM_CreateUIVM = g_mGameDll.FindPatternSIMD((std::uint8_t*)"\x40\x53\x48\x83\xEC\x20\x48\x8B\x1D\x00\x00\x00\x00\xC6\x05\x00\x00\x00\x00\x00", "xxxxxxxxx????xx?????"); /*40 53 48 83 EC 20 48 8B 1D ? ? ? ? C6 05 ? ? ? ? ?*/
|
||||
bool (*SQVM_CreateUIVM)() = (bool(*)())p_SQVM_CreateUIVM.GetPtr();
|
||||
ADDRESS p_SQVM_UIVM = (void*)p_SQVM_CreateUIVM.FindPatternSelf("48 8B 1D", ADDRESS::Direction::DOWN, 50).ResolveRelativeAddressSelf(0x3, 0x7).GetPtr();
|
||||
|
||||
ADDRESS p_SQVM_RegisterOriginFuncs = g_mGameDll.FindPatternSIMD((std::uint8_t*)"\xE8\x00\x00\x00\x00\x48\x8B\x0D\x00\x00\x00\x00\x48\x8D\x15\x00\x00\x00\x00\xE8\x00\x00\x00\x00\x48\x8B\x05\x00\x00\x00\x00\xC7\x05\x00\x00\x00\x00\x00\x00\x00\x00", "x????xxx????xxx????x????xxx????xx????????"); /*E8 ? ? ? ? 48 8B 0D ? ? ? ? 48 8D 15 ? ? ? ? E8 ? ? ? ? 48 8B 05 ? ? ? ? C7 05 ? ? ? ? ? ? ? ?*/
|
||||
void (*SQVM_RegisterOriginFuncs)(void* sqvm) = (void(*)(void*))p_SQVM_RegisterOriginFuncs.FollowNearCall().GetPtr();
|
||||
ADDRESS p_SQVM_CompileError = g_mGameDll.FindPatternSIMD((std::uint8_t*)"\x48\x89\x5C\x24\x00\x48\x89\x6C\x24\x00\x48\x89\x74\x24\x00\x48\x89\x7C\x24\x00\x41\x56\x48\x81\xEC\x00\x00\x00\x00\x48\x8B\xD9\x4C\x8B\xF2", "xxxx?xxxx?xxxx?xxxx?xxxxx????xxxxxx");
|
||||
void (*SQVM_CompileError)(void* sqvm, std::int64_t a2, std::int64_t a3, std::uint32_t a4, int a5) = (void(*)(void*, std::int64_t, std::int64_t, std::uint32_t, int))p_SQVM_CompileError.GetPtr();/*48 89 5C 24 ? 48 89 6C 24 ? 48 89 74 24 ? 48 89 7C 24 ? 41 56 48 81 EC ? ? ? ? 48 8B D9 4C 8B F2*/
|
||||
|
||||
ADDRESS p_SQVM_RegisterOriginFuncs = g_mGameDll.FindPatternSIMD((std::uint8_t*)"\xE8\x00\x00\x00\x00\x48\x8B\x0D\x00\x00\x00\x00\x48\x8D\x15\x00\x00\x00\x00\xE8\x00\x00\x00\x00\x48\x8B\x05\x00\x00\x00\x00\xC7\x05\x00\x00\x00\x00\x00\x00\x00\x00", "x????xxx????xxx????x????xxx????xx????????");
|
||||
void (*SQVM_RegisterOriginFuncs)(void* sqvm) = (void(*)(void*))p_SQVM_RegisterOriginFuncs.FollowNearCall().GetPtr(); /*E8 ? ? ? ? 48 8B 0D ? ? ? ? 48 8D 15 ? ? ? ? E8 ? ? ? ? 48 8B 05 ? ? ? ? C7 05 ? ? ? ? ? ? ? ?*/
|
||||
|
||||
ADDRESS p_SQVM_UIVM = (void*)p_SQVM_CreateUIVM.FindPatternSelf("48 8B 1D", ADDRESS::Direction::DOWN, 50).ResolveRelativeAddressSelf(0x3, 0x7).GetPtr();
|
||||
}
|
||||
|
||||
void* HSQVM_PrintFunc(void* sqvm, char* fmt, ...);
|
||||
@ -119,7 +123,9 @@ class HSQVM : public IDetour
|
||||
std::cout << "| FUN: SQVM_LoadRson : 0x" << std::hex << std::uppercase << p_SQVM_LoadRson.GetPtr() << std::setw(npad) << " |" << std::endl;
|
||||
std::cout << "| FUN: SQVM_RegisterFunc : 0x" << std::hex << std::uppercase << p_SQVM_RegisterFunc.GetPtr() << std::setw(npad) << " |" << std::endl;
|
||||
std::cout << "| FUN: SQVM_CreateUIVM : 0x" << std::hex << std::uppercase << p_SQVM_CreateUIVM.GetPtr() << std::setw(npad) << " |" << std::endl;
|
||||
std::cout << "| FUN: SQVM_CompileError : 0x" << std::hex << std::uppercase << p_SQVM_CompileError.GetPtr() << std::setw(npad) << " |" << std::endl;
|
||||
std::cout << "| FUN: SQVM_RegisterOriginFuncs : 0x" << std::hex << std::uppercase << p_SQVM_RegisterOriginFuncs.GetPtr() << std::setw(npad) << " |" << std::endl;
|
||||
std::cout << "| VAR: SQVM_UIVM : 0x" << std::hex << std::uppercase << p_SQVM_UIVM.GetPtr() << std::setw(npad) << " |" << std::endl;
|
||||
std::cout << "+----------------------------------------------------------------+" << std::endl;
|
||||
}
|
||||
};
|
||||
|
@ -216,6 +216,7 @@
|
||||
<ClInclude Include="..\engine\sys_getmodes.h" />
|
||||
<ClInclude Include="..\engine\sys_utils.h" />
|
||||
<ClInclude Include="..\game\server\fairfight_impl.h" />
|
||||
<ClInclude Include="..\game\server\gameinterface.h" />
|
||||
<ClInclude Include="..\launcher\IApplication.h" />
|
||||
<ClInclude Include="..\launcher\prx.h" />
|
||||
<ClInclude Include="..\mathlib\adler32.h" />
|
||||
@ -419,6 +420,7 @@
|
||||
<ClCompile Include="..\engine\sys_dll2.cpp" />
|
||||
<ClCompile Include="..\engine\sys_engine.cpp" />
|
||||
<ClCompile Include="..\engine\sys_utils.cpp" />
|
||||
<ClCompile Include="..\game\server\gameinterface.cpp" />
|
||||
<ClCompile Include="..\launcher\IApplication.cpp" />
|
||||
<ClCompile Include="..\launcher\prx.cpp" />
|
||||
<ClCompile Include="..\mathlib\adler32.cpp" />
|
||||
|
@ -765,6 +765,9 @@
|
||||
<ClInclude Include="..\thirdparty\lzham\lzhamdecomp\lzham_lzdecompbase.h">
|
||||
<Filter>thirdparty\lzham\lzhamdecomp\include</Filter>
|
||||
</ClInclude>
|
||||
<ClInclude Include="..\game\server\gameinterface.h">
|
||||
<Filter>sdk\game\server</Filter>
|
||||
</ClInclude>
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<ClCompile Include="..\client\IVEngineClient.cpp">
|
||||
@ -944,6 +947,9 @@
|
||||
<ClCompile Include="..\networksystem\pylon.cpp">
|
||||
<Filter>sdk\networksystem</Filter>
|
||||
</ClCompile>
|
||||
<ClCompile Include="..\game\server\gameinterface.cpp">
|
||||
<Filter>sdk\game\server</Filter>
|
||||
</ClCompile>
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<None Include="..\Dedicated.def" />
|
||||
|
@ -49,6 +49,7 @@
|
||||
<ClCompile Include="..\engine\sys_utils.cpp" />
|
||||
<ClCompile Include="..\gameui\IConsole.cpp" />
|
||||
<ClCompile Include="..\gameui\IBrowser.cpp" />
|
||||
<ClCompile Include="..\game\server\gameinterface.cpp" />
|
||||
<ClCompile Include="..\inputsystem\inputsystem.cpp" />
|
||||
<ClCompile Include="..\launcher\IApplication.cpp" />
|
||||
<ClCompile Include="..\mathlib\adler32.cpp" />
|
||||
@ -141,6 +142,7 @@
|
||||
<ClInclude Include="..\gameui\IConsole.h" />
|
||||
<ClInclude Include="..\gameui\IBrowser.h" />
|
||||
<ClInclude Include="..\game\server\fairfight_impl.h" />
|
||||
<ClInclude Include="..\game\server\gameinterface.h" />
|
||||
<ClInclude Include="..\inputsystem\ButtonCode.h" />
|
||||
<ClInclude Include="..\inputsystem\inputsystem.h" />
|
||||
<ClInclude Include="..\launcher\IApplication.h" />
|
||||
|
@ -375,6 +375,9 @@
|
||||
<ClCompile Include="..\thirdparty\imgui\src\imgui_utility.cpp">
|
||||
<Filter>thirdparty\imgui</Filter>
|
||||
</ClCompile>
|
||||
<ClCompile Include="..\game\server\gameinterface.cpp">
|
||||
<Filter>sdk\game\server</Filter>
|
||||
</ClCompile>
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<ClInclude Include="..\client\cdll_engine_int.h">
|
||||
@ -1091,6 +1094,9 @@
|
||||
<ClInclude Include="..\thirdparty\lzham\lzhamdecomp\lzham_lzdecompbase.h">
|
||||
<Filter>thirdparty\lzham\lzhamdecomp\include</Filter>
|
||||
</ClInclude>
|
||||
<ClInclude Include="..\game\server\gameinterface.h">
|
||||
<Filter>sdk\game\server</Filter>
|
||||
</ClInclude>
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<Image Include="..\shared\resource\lockedserver.png">
|
||||
|
Loading…
x
Reference in New Issue
Block a user