mirror of
https://github.com/s1lentq/ReGameDLL_CS.git
synced 2025-01-28 06:28:04 +03:00
996 lines
30 KiB
C++
996 lines
30 KiB
C++
#include "precompiled.h"
|
|
|
|
CRecorderFuncCall::CRecorderFuncCall(IEngExtCall* fcall)
|
|
{
|
|
m_FuncCall = fcall;
|
|
m_StartWritten = false;
|
|
m_Next = m_Prev = NULL;
|
|
}
|
|
|
|
CSteamCallbackRecordingWrapper::CSteamCallbackRecordingWrapper(CRecordingEngExtInterceptor* recorder, CCallbackBase* cb, int id)
|
|
{
|
|
m_Recorder = recorder;
|
|
m_Wrapped = cb;
|
|
m_Id = id;
|
|
m_Size = cb->GetCallbackSizeBytes();
|
|
m_iCallback = cb->GetICallback();
|
|
this->m_nCallbackFlags = cb->GetFlags();
|
|
}
|
|
|
|
void CSteamCallbackRecordingWrapper::Run(void *pvParam)
|
|
{
|
|
if (m_Wrapped->GetICallback() != this->GetICallback()) regamedll_syserror("%s: iCallback desync", __FUNCTION__);
|
|
if (m_Wrapped->GetFlags() != this->GetFlags()) regamedll_syserror("%s: flags desync", __FUNCTION__);
|
|
|
|
CSteamCallbackCall1 fcall(m_Id, pvParam, m_Size, m_Wrapped); CRecorderFuncCall frec(&fcall);
|
|
m_Recorder->PushFunc(&frec);
|
|
m_Wrapped->Run(pvParam);
|
|
fcall.setResult(m_Wrapped);
|
|
this->SetFlags(m_Wrapped->GetFlags());
|
|
this->SetICallback(m_Wrapped->GetICallback());
|
|
m_Recorder->PopFunc(&frec);
|
|
}
|
|
|
|
void CSteamCallbackRecordingWrapper::Run(void *pvParam, bool bIOFailure, SteamAPICall_t hSteamAPICall)
|
|
{
|
|
if (m_Wrapped->GetICallback() != this->GetICallback()) regamedll_syserror("%s: iCallback desync", __FUNCTION__);
|
|
if (m_Wrapped->GetFlags() != this->GetFlags()) regamedll_syserror("%s: flags desync", __FUNCTION__);
|
|
|
|
CSteamCallbackCall2 fcall(m_Id, pvParam, m_Size, bIOFailure, hSteamAPICall, m_Wrapped); CRecorderFuncCall frec(&fcall);
|
|
m_Recorder->PushFunc(&frec);
|
|
m_Wrapped->Run(pvParam, bIOFailure, hSteamAPICall);
|
|
fcall.setResult(m_Wrapped);
|
|
this->SetFlags(m_Wrapped->GetFlags());
|
|
this->SetICallback(m_Wrapped->GetICallback());
|
|
m_Recorder->PopFunc(&frec);
|
|
}
|
|
|
|
int CSteamCallbackRecordingWrapper::GetCallbackSizeBytes()
|
|
{
|
|
return m_Wrapped->GetCallbackSizeBytes();
|
|
}
|
|
|
|
|
|
|
|
|
|
CSteamAppsRecordingWrapper::CSteamAppsRecordingWrapper(ISteamApps* original, CRecordingEngExtInterceptor* recorder)
|
|
{
|
|
m_Wrapped = original;
|
|
m_Recorder = recorder;
|
|
}
|
|
|
|
bool CSteamAppsRecordingWrapper::BIsSubscribed()
|
|
{
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return false;
|
|
}
|
|
|
|
bool CSteamAppsRecordingWrapper::BIsLowViolence()
|
|
{
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return false;
|
|
}
|
|
|
|
bool CSteamAppsRecordingWrapper::BIsCybercafe()
|
|
{
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return false;
|
|
}
|
|
|
|
bool CSteamAppsRecordingWrapper::BIsVACBanned()
|
|
{
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return false;
|
|
}
|
|
|
|
const char* CSteamAppsRecordingWrapper::GetCurrentGameLanguage()
|
|
{
|
|
CSteamAppGetCurrentGameLanguageCall fcall; CRecorderFuncCall frec(&fcall);
|
|
m_Recorder->PushFunc(&frec);
|
|
const char* res = m_Wrapped->GetCurrentGameLanguage();
|
|
fcall.setResult(res);
|
|
m_Recorder->PopFunc(&frec);
|
|
return res;
|
|
}
|
|
|
|
const char* CSteamAppsRecordingWrapper::GetAvailableGameLanguages()
|
|
{
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return NULL;
|
|
}
|
|
|
|
bool CSteamAppsRecordingWrapper::BIsSubscribedApp(AppId_t appID)
|
|
{
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return false;
|
|
}
|
|
|
|
bool CSteamAppsRecordingWrapper::BIsDlcInstalled(AppId_t appID)
|
|
{
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return false;
|
|
}
|
|
|
|
uint32 CSteamAppsRecordingWrapper::GetEarliestPurchaseUnixTime(AppId_t nAppID)
|
|
{
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return 0;
|
|
}
|
|
|
|
bool CSteamAppsRecordingWrapper::BIsSubscribedFromFreeWeekend()
|
|
{
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return false;
|
|
}
|
|
|
|
int CSteamAppsRecordingWrapper::GetDLCCount()
|
|
{
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return 0;
|
|
}
|
|
|
|
bool CSteamAppsRecordingWrapper::BGetDLCDataByIndex(int iDLC, AppId_t *pAppID, bool *pbAvailable, char *pchName, int cchNameBufferSize)
|
|
{
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return false;
|
|
}
|
|
|
|
void CSteamAppsRecordingWrapper::InstallDLC(AppId_t nAppID)
|
|
{
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
}
|
|
|
|
void CSteamAppsRecordingWrapper::UninstallDLC(AppId_t nAppID)
|
|
{
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
}
|
|
|
|
void CSteamAppsRecordingWrapper::RequestAppProofOfPurchaseKey(AppId_t nAppID)
|
|
{
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
}
|
|
|
|
bool CSteamAppsRecordingWrapper::GetCurrentBetaName(char *pchName, int cchNameBufferSize)
|
|
{
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return false;
|
|
}
|
|
|
|
bool CSteamAppsRecordingWrapper::MarkContentCorrupt(bool bMissingFilesOnly)
|
|
{
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return false;
|
|
}
|
|
|
|
uint32 CSteamAppsRecordingWrapper::GetInstalledDepots(DepotId_t *pvecDepots, uint32 cMaxDepots)
|
|
{
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return 0;
|
|
}
|
|
|
|
uint32 CSteamAppsRecordingWrapper::GetAppInstallDir(AppId_t appID, char *pchFolder, uint32 cchFolderBufferSize)
|
|
{
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return 0;
|
|
}
|
|
|
|
|
|
CSteamGameServerRecordingWrapper::CSteamGameServerRecordingWrapper(ISteamGameServer* original, CRecordingEngExtInterceptor* recorder)
|
|
{
|
|
m_Wrapped = original;
|
|
m_Recorder = recorder;
|
|
}
|
|
|
|
bool CSteamGameServerRecordingWrapper::InitGameServer(uint32 unIP, uint16 usGamePort, uint16 usQueryPort, uint32 unFlags, AppId_t nGameAppId, const char *pchVersionString)
|
|
{
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return false;
|
|
}
|
|
|
|
void CSteamGameServerRecordingWrapper::SetProduct(const char *pszProduct)
|
|
{
|
|
CGameServerSetProductCall fcall(pszProduct); CRecorderFuncCall frec(&fcall);
|
|
m_Recorder->PushFunc(&frec);
|
|
m_Wrapped->SetProduct(pszProduct);
|
|
m_Recorder->PopFunc(&frec);
|
|
}
|
|
|
|
void CSteamGameServerRecordingWrapper::SetGameDescription(const char *pszGameDescription)
|
|
{
|
|
CGameServerSetGameDescCall fcall(pszGameDescription); CRecorderFuncCall frec(&fcall);
|
|
m_Recorder->PushFunc(&frec);
|
|
m_Wrapped->SetGameDescription(pszGameDescription);
|
|
m_Recorder->PopFunc(&frec);
|
|
}
|
|
|
|
void CSteamGameServerRecordingWrapper::SetModDir(const char *pszModDir)
|
|
{
|
|
CGameServerSetModDirCall fcall(pszModDir); CRecorderFuncCall frec(&fcall);
|
|
m_Recorder->PushFunc(&frec);
|
|
m_Wrapped->SetModDir(pszModDir);
|
|
m_Recorder->PopFunc(&frec);
|
|
}
|
|
|
|
void CSteamGameServerRecordingWrapper::SetDedicatedServer(bool bDedicated)
|
|
{
|
|
CGameServerSetDedicatedServerCall fcall(bDedicated); CRecorderFuncCall frec(&fcall);
|
|
m_Recorder->PushFunc(&frec);
|
|
m_Wrapped->SetDedicatedServer(bDedicated);
|
|
m_Recorder->PopFunc(&frec);
|
|
}
|
|
|
|
void CSteamGameServerRecordingWrapper::LogOn(const char *pszAccountName, const char *pszPassword)
|
|
{
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
}
|
|
|
|
void CSteamGameServerRecordingWrapper::LogOnAnonymous()
|
|
{
|
|
CGameServerLogOnAnonymousCall fcall; CRecorderFuncCall frec(&fcall);
|
|
m_Recorder->PushFunc(&frec);
|
|
m_Wrapped->LogOnAnonymous();
|
|
m_Recorder->PopFunc(&frec);
|
|
}
|
|
|
|
void CSteamGameServerRecordingWrapper::LogOff()
|
|
{
|
|
CGameServerLogOffCall fcall; CRecorderFuncCall frec(&fcall);
|
|
m_Recorder->PushFunc(&frec);
|
|
m_Wrapped->LogOff();
|
|
m_Recorder->PopFunc(&frec);
|
|
}
|
|
|
|
bool CSteamGameServerRecordingWrapper::BLoggedOn()
|
|
{
|
|
CGameServerBLoggedOnCall fcall; CRecorderFuncCall frec(&fcall);
|
|
m_Recorder->PushFunc(&frec);
|
|
bool res = m_Wrapped->BLoggedOn();
|
|
fcall.setResult(res);
|
|
m_Recorder->PopFunc(&frec);
|
|
return res;
|
|
}
|
|
|
|
bool CSteamGameServerRecordingWrapper::BSecure()
|
|
{
|
|
CGameServerBSecureCall fcall; CRecorderFuncCall frec(&fcall);
|
|
m_Recorder->PushFunc(&frec);
|
|
bool res = m_Wrapped->BSecure();
|
|
fcall.setResult(res);
|
|
m_Recorder->PopFunc(&frec);
|
|
return res;
|
|
}
|
|
|
|
CSteamID CSteamGameServerRecordingWrapper::GetSteamID()
|
|
{
|
|
CGameServerGetSteamIdCall fcall; CRecorderFuncCall frec(&fcall);
|
|
m_Recorder->PushFunc(&frec);
|
|
CSteamID res = m_Wrapped->GetSteamID();
|
|
fcall.setResult(res);
|
|
m_Recorder->PopFunc(&frec);
|
|
return res;
|
|
}
|
|
|
|
bool CSteamGameServerRecordingWrapper::WasRestartRequested()
|
|
{
|
|
CGameServerWasRestartRequestedCall fcall; CRecorderFuncCall frec(&fcall);
|
|
m_Recorder->PushFunc(&frec);
|
|
bool res = m_Wrapped->WasRestartRequested();
|
|
fcall.setResult(res);
|
|
m_Recorder->PopFunc(&frec);
|
|
return res;
|
|
}
|
|
|
|
void CSteamGameServerRecordingWrapper::SetMaxPlayerCount(int cPlayersMax)
|
|
{
|
|
CGameServerSetMaxPlayersCall fcall(cPlayersMax); CRecorderFuncCall frec(&fcall);
|
|
m_Recorder->PushFunc(&frec);
|
|
m_Wrapped->SetMaxPlayerCount(cPlayersMax);
|
|
m_Recorder->PopFunc(&frec);
|
|
}
|
|
|
|
void CSteamGameServerRecordingWrapper::SetBotPlayerCount(int cBotplayers)
|
|
{
|
|
CGameServerSetBotCountCall fcall(cBotplayers); CRecorderFuncCall frec(&fcall);
|
|
m_Recorder->PushFunc(&frec);
|
|
m_Wrapped->SetBotPlayerCount(cBotplayers);
|
|
m_Recorder->PopFunc(&frec);
|
|
}
|
|
|
|
void CSteamGameServerRecordingWrapper::SetServerName(const char *pszServerName)
|
|
{
|
|
CGameServerSetServerNameCall fcall(pszServerName); CRecorderFuncCall frec(&fcall);
|
|
m_Recorder->PushFunc(&frec);
|
|
m_Wrapped->SetServerName(pszServerName);
|
|
m_Recorder->PopFunc(&frec);
|
|
}
|
|
|
|
void CSteamGameServerRecordingWrapper::SetMapName(const char *pszMapName)
|
|
{
|
|
CGameServerSetMapNameCall fcall(pszMapName); CRecorderFuncCall frec(&fcall);
|
|
m_Recorder->PushFunc(&frec);
|
|
m_Wrapped->SetMapName(pszMapName);
|
|
m_Recorder->PopFunc(&frec);
|
|
}
|
|
|
|
void CSteamGameServerRecordingWrapper::SetPasswordProtected(bool bPasswordProtected)
|
|
{
|
|
CGameServerSetPasswordProtectedCall fcall(bPasswordProtected); CRecorderFuncCall frec(&fcall);
|
|
m_Recorder->PushFunc(&frec);
|
|
m_Wrapped->SetPasswordProtected(bPasswordProtected);
|
|
m_Recorder->PopFunc(&frec);
|
|
}
|
|
|
|
void CSteamGameServerRecordingWrapper::SetSpectatorPort(uint16 unSpectatorPort)
|
|
{
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
}
|
|
|
|
void CSteamGameServerRecordingWrapper::SetSpectatorServerName(const char *pszSpectatorServerName)
|
|
{
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
}
|
|
|
|
void CSteamGameServerRecordingWrapper::ClearAllKeyValues()
|
|
{
|
|
CGameServerClearAllKVsCall fcall; CRecorderFuncCall frec(&fcall);
|
|
m_Recorder->PushFunc(&frec);
|
|
m_Wrapped->ClearAllKeyValues();
|
|
m_Recorder->PopFunc(&frec);
|
|
}
|
|
|
|
void CSteamGameServerRecordingWrapper::SetKeyValue(const char *pKey, const char *pValue)
|
|
{
|
|
CGameServerSetKeyValueCall fcall(pKey, pValue); CRecorderFuncCall frec(&fcall);
|
|
m_Recorder->PushFunc(&frec);
|
|
m_Wrapped->SetKeyValue(pKey, pValue);
|
|
m_Recorder->PopFunc(&frec);
|
|
}
|
|
|
|
void CSteamGameServerRecordingWrapper::SetGameTags(const char *pchGameTags)
|
|
{
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
}
|
|
|
|
void CSteamGameServerRecordingWrapper::SetGameData(const char *pchGameData)
|
|
{
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
}
|
|
|
|
void CSteamGameServerRecordingWrapper::SetRegion(const char *pszRegion)
|
|
{
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
}
|
|
|
|
bool CSteamGameServerRecordingWrapper::SendUserConnectAndAuthenticate(uint32 unIPClient, const void *pvAuthBlob, uint32 cubAuthBlobSize, CSteamID *pSteamIDUser)
|
|
{
|
|
CGameServerSendUserConnectAndAuthenticateCall fcall(unIPClient, pvAuthBlob, cubAuthBlobSize); CRecorderFuncCall frec(&fcall);
|
|
m_Recorder->PushFunc(&frec);
|
|
bool res = m_Wrapped->SendUserConnectAndAuthenticate(unIPClient, pvAuthBlob, cubAuthBlobSize, pSteamIDUser);
|
|
fcall.setResult(*pSteamIDUser, res);
|
|
m_Recorder->PopFunc(&frec);
|
|
return res;
|
|
}
|
|
|
|
CSteamID CSteamGameServerRecordingWrapper::CreateUnauthenticatedUserConnection()
|
|
{
|
|
CGameServerCreateUnauthUserConnectionCall fcall; CRecorderFuncCall frec(&fcall);
|
|
m_Recorder->PushFunc(&frec);
|
|
CSteamID res = m_Wrapped->CreateUnauthenticatedUserConnection();
|
|
fcall.setResult(res);
|
|
m_Recorder->PopFunc(&frec);
|
|
return res;
|
|
}
|
|
|
|
void CSteamGameServerRecordingWrapper::SendUserDisconnect(CSteamID steamIDUser)
|
|
{
|
|
CGameServerSendUserDisconnectCall fcall(steamIDUser); CRecorderFuncCall frec(&fcall);
|
|
m_Recorder->PushFunc(&frec);
|
|
m_Wrapped->SendUserDisconnect(steamIDUser);
|
|
m_Recorder->PopFunc(&frec);
|
|
}
|
|
|
|
bool CSteamGameServerRecordingWrapper::BUpdateUserData(CSteamID steamIDUser, const char *pchPlayerName, uint32 uScore)
|
|
{
|
|
CGameServerBUpdateUserDataCall fcall(steamIDUser, pchPlayerName, uScore); CRecorderFuncCall frec(&fcall);
|
|
m_Recorder->PushFunc(&frec);
|
|
bool res = m_Wrapped->BUpdateUserData(steamIDUser, pchPlayerName, uScore);
|
|
fcall.setResult(res);
|
|
m_Recorder->PopFunc(&frec);
|
|
return res;
|
|
}
|
|
|
|
HAuthTicket CSteamGameServerRecordingWrapper::GetAuthSessionTicket(void *pTicket, int cbMaxTicket, uint32 *pcbTicket)
|
|
{
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return k_HAuthTicketInvalid;
|
|
}
|
|
|
|
EBeginAuthSessionResult CSteamGameServerRecordingWrapper::BeginAuthSession(const void *pAuthTicket, int cbAuthTicket, CSteamID steamID)
|
|
{
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return k_EBeginAuthSessionResultInvalidTicket;
|
|
}
|
|
|
|
void CSteamGameServerRecordingWrapper::EndAuthSession(CSteamID steamID)
|
|
{
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
}
|
|
|
|
void CSteamGameServerRecordingWrapper::CancelAuthTicket(HAuthTicket hAuthTicket)
|
|
{
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
}
|
|
|
|
EUserHasLicenseForAppResult CSteamGameServerRecordingWrapper::UserHasLicenseForApp(CSteamID steamID, AppId_t appID)
|
|
{
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return k_EUserHasLicenseResultDoesNotHaveLicense;
|
|
}
|
|
|
|
bool CSteamGameServerRecordingWrapper::RequestUserGroupStatus(CSteamID steamIDUser, CSteamID steamIDGroup)
|
|
{
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return false;
|
|
}
|
|
|
|
void CSteamGameServerRecordingWrapper::GetGameplayStats()
|
|
{
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
}
|
|
|
|
SteamAPICall_t CSteamGameServerRecordingWrapper::GetServerReputation()
|
|
{
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return k_uAPICallInvalid;
|
|
}
|
|
|
|
uint32 CSteamGameServerRecordingWrapper::GetPublicIP()
|
|
{
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return 0;
|
|
}
|
|
|
|
bool CSteamGameServerRecordingWrapper::HandleIncomingPacket(const void *pData, int cbData, uint32 srcIP, uint16 srcPort)
|
|
{
|
|
CGameServerHandleIncomingPacketCall fcall(pData, cbData, srcIP, srcPort); CRecorderFuncCall frec(&fcall);
|
|
m_Recorder->PushFunc(&frec);
|
|
bool res = m_Wrapped->HandleIncomingPacket(pData, cbData, srcIP, srcPort);
|
|
fcall.setResult(res);
|
|
m_Recorder->PopFunc(&frec);
|
|
return res;
|
|
}
|
|
|
|
int CSteamGameServerRecordingWrapper::GetNextOutgoingPacket(void *pOut, int cbMaxOut, uint32 *pNetAdr, uint16 *pPort)
|
|
{
|
|
CGameServerGetNextOutgoingPacketCall fcall(cbMaxOut); CRecorderFuncCall frec(&fcall);
|
|
m_Recorder->PushFunc(&frec);
|
|
int res = m_Wrapped->GetNextOutgoingPacket(pOut, cbMaxOut, pNetAdr, pPort);
|
|
fcall.setResult(pOut, res, pNetAdr, pPort);
|
|
m_Recorder->PopFunc(&frec);
|
|
return res;
|
|
}
|
|
|
|
void CSteamGameServerRecordingWrapper::EnableHeartbeats(bool bActive)
|
|
{
|
|
CGameServerEnableHeartbeatsCall fcall(bActive); CRecorderFuncCall frec(&fcall);
|
|
m_Recorder->PushFunc(&frec);
|
|
m_Wrapped->EnableHeartbeats(bActive);
|
|
m_Recorder->PopFunc(&frec);
|
|
}
|
|
|
|
void CSteamGameServerRecordingWrapper::SetHeartbeatInterval(int iHeartbeatInterval)
|
|
{
|
|
CGameServerSetHeartbeatIntervalCall fcall(iHeartbeatInterval); CRecorderFuncCall frec(&fcall);
|
|
m_Recorder->PushFunc(&frec);
|
|
m_Wrapped->SetHeartbeatInterval(iHeartbeatInterval);
|
|
m_Recorder->PopFunc(&frec);
|
|
}
|
|
|
|
void CSteamGameServerRecordingWrapper::ForceHeartbeat()
|
|
{
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
}
|
|
|
|
SteamAPICall_t CSteamGameServerRecordingWrapper::AssociateWithClan(CSteamID steamIDClan)
|
|
{
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return k_uAPICallInvalid;
|
|
}
|
|
|
|
SteamAPICall_t CSteamGameServerRecordingWrapper::ComputeNewPlayerCompatibility(CSteamID steamIDNewPlayer)
|
|
{
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return k_uAPICallInvalid;
|
|
}
|
|
|
|
CRecordingEngExtInterceptor::CRecordingEngExtInterceptor(const char* fname, IReGameDLLPlatform* basePlatform)
|
|
{
|
|
m_OutStream.exceptions(std::ios::badbit | std::ios::failbit);
|
|
m_OutStream.open(fname, std::ios::out | std::ios::binary);
|
|
|
|
m_ServerSocket = INVALID_SOCKET;
|
|
m_SteamCallbacksCounter = 0;
|
|
m_SteamAppsWrapper = NULL;
|
|
m_GameServerWrapper = NULL;
|
|
m_SteamBreakpadContext = NULL;
|
|
m_RootFunc = m_LastFunc = NULL;
|
|
m_BasePlatform = basePlatform;
|
|
|
|
uint16 versionMajor = TESTSUITE_PROTOCOL_VERSION_MAJOR;
|
|
uint16 versionMinor = TESTSUITE_PROTOCOL_VERSION_MINOR;
|
|
m_OutStream.write((char*)&versionMinor, 2).write((char*)&versionMajor, 2);
|
|
|
|
const char* cmdLine = GetCommandLineA();
|
|
int cmdLineLength = strlen(cmdLine) + 1;
|
|
|
|
m_OutStream.write((char*)&cmdLineLength, 4);
|
|
m_OutStream.write(cmdLine, cmdLineLength);
|
|
}
|
|
|
|
void CRecordingEngExtInterceptor::writeCall(bool start, bool end, IEngExtCall* fcall)
|
|
{
|
|
uint16 opc = fcall->getOpcode();
|
|
if (start)
|
|
opc |= (1 << 15);
|
|
|
|
if (end)
|
|
opc |= (1 << 14);
|
|
|
|
m_OutStream.write((char*)&opc, 2);
|
|
if (start)
|
|
fcall->writePrologue(m_OutStream);
|
|
|
|
if (end)
|
|
fcall->writeEpilogue(m_OutStream);
|
|
|
|
m_OutStream.flush();
|
|
}
|
|
|
|
void CRecordingEngExtInterceptor::PushFunc(CRecorderFuncCall* func)
|
|
{
|
|
CRecorderFuncCall* cc = m_LastFunc;
|
|
while (cc != NULL) {
|
|
if (!cc->m_StartWritten) {
|
|
writeCall(true, false, cc->m_FuncCall);
|
|
cc->m_StartWritten = true;
|
|
}
|
|
cc = cc->m_Prev;
|
|
}
|
|
|
|
if (m_LastFunc != NULL) {
|
|
m_LastFunc->m_Next = func;
|
|
func->m_Next = NULL;
|
|
func->m_Prev = m_LastFunc;
|
|
m_LastFunc = func;
|
|
}
|
|
else
|
|
{
|
|
m_LastFunc = m_RootFunc = func;
|
|
func->m_Next = func->m_Prev = NULL;
|
|
}
|
|
|
|
}
|
|
|
|
void CRecordingEngExtInterceptor::PopFunc(CRecorderFuncCall* func)
|
|
{
|
|
if (func != m_LastFunc)
|
|
regamedll_syserror("%s: stack corrupted", __FUNCTION__);
|
|
|
|
writeCall(!func->m_StartWritten, true, func->m_FuncCall);
|
|
if (m_LastFunc->m_Prev == NULL) {
|
|
m_LastFunc = m_RootFunc = NULL;
|
|
}
|
|
else
|
|
{
|
|
m_LastFunc = m_LastFunc->m_Prev;
|
|
m_LastFunc->m_Next = NULL;
|
|
}
|
|
}
|
|
|
|
uint32 CRecordingEngExtInterceptor::time(uint32* pTime)
|
|
{
|
|
CStdTimeCall fcall(pTime); CRecorderFuncCall frec(&fcall);
|
|
PushFunc(&frec);
|
|
uint32 res = m_BasePlatform->time(pTime);
|
|
fcall.setResult(res);
|
|
PopFunc(&frec);
|
|
|
|
return res;
|
|
}
|
|
|
|
struct tm* CRecordingEngExtInterceptor::localtime(uint32 time)
|
|
{
|
|
CStdLocalTimeCall fcall; CRecorderFuncCall frec(&fcall);
|
|
PushFunc(&frec);
|
|
struct tm* res = m_BasePlatform->localtime(time);
|
|
fcall.setResult(res);
|
|
PopFunc(&frec);
|
|
|
|
return res;
|
|
}
|
|
|
|
void CRecordingEngExtInterceptor::srand(uint32 seed)
|
|
{
|
|
CStdSrandCall fcall(seed); CRecorderFuncCall frec(&fcall);
|
|
PushFunc(&frec);
|
|
m_BasePlatform->srand(seed);
|
|
PopFunc(&frec);
|
|
}
|
|
|
|
int CRecordingEngExtInterceptor::rand()
|
|
{
|
|
CStdRandCall fcall; CRecorderFuncCall frec(&fcall);
|
|
PushFunc(&frec);
|
|
int res = m_BasePlatform->rand();
|
|
fcall.setResult(res);
|
|
PopFunc(&frec);
|
|
|
|
return res;
|
|
}
|
|
|
|
void CRecordingEngExtInterceptor::Sleep(DWORD msec)
|
|
{
|
|
CSleepExtCall fcall(msec); CRecorderFuncCall frec(&fcall);
|
|
PushFunc(&frec);
|
|
m_BasePlatform->Sleep(msec);
|
|
PopFunc(&frec);
|
|
}
|
|
|
|
BOOL CRecordingEngExtInterceptor::QueryPerfCounter(LARGE_INTEGER* counter)
|
|
{
|
|
CQueryPerfCounterCall fcall; CRecorderFuncCall frec(&fcall);
|
|
PushFunc(&frec);
|
|
BOOL res = m_BasePlatform->QueryPerfCounter(counter);
|
|
fcall.SetResult(*counter, res);
|
|
PopFunc(&frec);
|
|
return res;
|
|
}
|
|
|
|
BOOL CRecordingEngExtInterceptor::QueryPerfFreq(LARGE_INTEGER* counter)
|
|
{
|
|
CQueryPerfFreqCall fcall; CRecorderFuncCall frec(&fcall);
|
|
PushFunc(&frec);
|
|
BOOL res = m_BasePlatform->QueryPerfFreq(counter);
|
|
fcall.SetResult(*counter, res);
|
|
PopFunc(&frec);
|
|
return res;
|
|
}
|
|
|
|
DWORD CRecordingEngExtInterceptor::GetTickCount()
|
|
{
|
|
CGetTickCountCall fcall; CRecorderFuncCall frec(&fcall);
|
|
PushFunc(&frec);
|
|
DWORD res = m_BasePlatform->GetTickCount();
|
|
fcall.SetResult(res);
|
|
PopFunc(&frec);
|
|
return res;
|
|
}
|
|
|
|
void CRecordingEngExtInterceptor::GetLocalTime(LPSYSTEMTIME time)
|
|
{
|
|
CGetLocalTimeCall fcall; CRecorderFuncCall frec(&fcall);
|
|
PushFunc(&frec);
|
|
m_BasePlatform->GetLocalTime(time);
|
|
fcall.SetResult(time);
|
|
PopFunc(&frec);
|
|
}
|
|
|
|
void CRecordingEngExtInterceptor::GetSystemTime(LPSYSTEMTIME time)
|
|
{
|
|
CGetSystemTimeCall fcall; CRecorderFuncCall frec(&fcall);
|
|
PushFunc(&frec);
|
|
m_BasePlatform->GetSystemTime(time);
|
|
fcall.SetResult(time);
|
|
PopFunc(&frec);
|
|
}
|
|
|
|
void CRecordingEngExtInterceptor::GetTimeZoneInfo(LPTIME_ZONE_INFORMATION zinfo)
|
|
{
|
|
CGetTimeZoneInfoCall fcall; CRecorderFuncCall frec(&fcall);
|
|
PushFunc(&frec);
|
|
m_BasePlatform->GetTimeZoneInfo(zinfo);
|
|
fcall.SetResult(zinfo);
|
|
PopFunc(&frec);
|
|
}
|
|
|
|
BOOL CRecordingEngExtInterceptor::GetProcessTimes(HANDLE hProcess, LPFILETIME lpCreationTime, LPFILETIME lpExitTime, LPFILETIME lpKernelTime, LPFILETIME lpUserTime)
|
|
{
|
|
CGetProcessTimesCall fcall; CRecorderFuncCall frec(&fcall);
|
|
PushFunc(&frec);
|
|
BOOL res = m_BasePlatform->GetProcessTimes(hProcess, lpCreationTime, lpExitTime, lpKernelTime, lpUserTime);
|
|
fcall.setResult(res, lpCreationTime, lpExitTime, lpKernelTime, lpUserTime);
|
|
PopFunc(&frec);
|
|
return res;
|
|
}
|
|
|
|
void CRecordingEngExtInterceptor::GetSystemTimeAsFileTime(LPFILETIME lpSystemTimeAsFileTime)
|
|
{
|
|
CGetSystemTimeAsFileTimeCall fcall; CRecorderFuncCall frec(&fcall);
|
|
PushFunc(&frec);
|
|
m_BasePlatform->GetSystemTimeAsFileTime(lpSystemTimeAsFileTime);
|
|
fcall.setResult(lpSystemTimeAsFileTime);
|
|
PopFunc(&frec);
|
|
}
|
|
|
|
SOCKET CRecordingEngExtInterceptor::socket(int af, int type, int protocol)
|
|
{
|
|
CSocketCall fcall(af, type, protocol); CRecorderFuncCall frec(&fcall);
|
|
PushFunc(&frec);
|
|
SOCKET s = m_BasePlatform->socket(af, type, protocol);
|
|
fcall.setResult(s);
|
|
PopFunc(&frec);
|
|
return s;
|
|
}
|
|
|
|
int CRecordingEngExtInterceptor::ioctlsocket(SOCKET s, long cmd, u_long *argp)
|
|
{
|
|
CIoCtlSocketCall fcall(s, cmd, *argp); CRecorderFuncCall frec(&fcall);
|
|
PushFunc(&frec);
|
|
int res = m_BasePlatform->ioctlsocket(s, cmd, argp);
|
|
fcall.setResult(*argp, res);
|
|
PopFunc(&frec);
|
|
return res;
|
|
}
|
|
|
|
int CRecordingEngExtInterceptor::setsockopt(SOCKET s, int level, int optname, const char* optval, int optlen)
|
|
{
|
|
CSetSockOptCall fcall(s, level, optname, optval, optlen); CRecorderFuncCall frec(&fcall);
|
|
PushFunc(&frec);
|
|
int res = m_BasePlatform->setsockopt(s, level, optname, optval, optlen);
|
|
fcall.setResult(res);
|
|
PopFunc(&frec);
|
|
return res;
|
|
}
|
|
|
|
int CRecordingEngExtInterceptor::closesocket(SOCKET s)
|
|
{
|
|
CCloseSocketCall fcall(s); CRecorderFuncCall frec(&fcall);
|
|
PushFunc(&frec);
|
|
int res = m_BasePlatform->closesocket(s);
|
|
fcall.setResult(s);
|
|
PopFunc(&frec);
|
|
return res;
|
|
}
|
|
|
|
int CRecordingEngExtInterceptor::recvfrom(SOCKET s, char* buf, int len, int flags, struct sockaddr* from, socklen_t *fromlen)
|
|
{
|
|
CRecvFromCall fcall(s, len, flags, *fromlen); CRecorderFuncCall frec(&fcall);
|
|
PushFunc(&frec);
|
|
int res = m_BasePlatform->recvfrom(s, buf, len, flags, from, fromlen);
|
|
fcall.setResult(buf, from, *fromlen, res);
|
|
PopFunc(&frec);
|
|
return res;
|
|
}
|
|
|
|
int CRecordingEngExtInterceptor::sendto(SOCKET s, const char* buf, int len, int flags, const struct sockaddr* to, int tolen)
|
|
{
|
|
CSendToCall fcall(s, buf, len, flags, to, tolen); CRecorderFuncCall frec(&fcall);
|
|
PushFunc(&frec);
|
|
int res = m_BasePlatform->sendto(s, buf, len, flags, to, tolen);
|
|
fcall.setResult(res);
|
|
PopFunc(&frec);
|
|
return res;
|
|
}
|
|
|
|
int CRecordingEngExtInterceptor::bind(SOCKET s, const struct sockaddr* addr, int namelen)
|
|
{
|
|
CBindCall fcall(s, addr, namelen); CRecorderFuncCall frec(&fcall);
|
|
PushFunc(&frec);
|
|
int res = m_BasePlatform->bind(s, addr, namelen);
|
|
fcall.setResult(res);
|
|
PopFunc(&frec);
|
|
return res;
|
|
}
|
|
|
|
int CRecordingEngExtInterceptor::getsockname(SOCKET s, struct sockaddr* name, socklen_t* namelen)
|
|
{
|
|
CGetSockNameCall fcall(s, *namelen); CRecorderFuncCall frec(&fcall);
|
|
PushFunc(&frec);
|
|
int res = m_BasePlatform->getsockname(s, name, namelen);
|
|
fcall.setResult(name, *namelen, res);
|
|
PopFunc(&frec);
|
|
return res;
|
|
}
|
|
|
|
int CRecordingEngExtInterceptor::WSAGetLastError()
|
|
{
|
|
CWSAGetLastErrorCall fcall; CRecorderFuncCall frec(&fcall);
|
|
PushFunc(&frec);
|
|
int res = m_BasePlatform->WSAGetLastError();
|
|
fcall.setResult(res);
|
|
PopFunc(&frec);
|
|
return res;
|
|
}
|
|
|
|
struct hostent* CRecordingEngExtInterceptor::gethostbyname(const char *name)
|
|
{
|
|
CGetHostByNameCall fcall(name); CRecorderFuncCall frec(&fcall);
|
|
PushFunc(&frec);
|
|
struct hostent* res = m_BasePlatform->gethostbyname(name);
|
|
fcall.setResult(res);
|
|
PopFunc(&frec);
|
|
return res;
|
|
}
|
|
|
|
int CRecordingEngExtInterceptor::gethostname(char *name, int namelen)
|
|
{
|
|
CGetHostNameCall fcall(namelen); CRecorderFuncCall frec(&fcall);
|
|
PushFunc(&frec);
|
|
int res = m_BasePlatform->gethostname(name, namelen);
|
|
fcall.setResult(name, res);
|
|
PopFunc(&frec);
|
|
return res;
|
|
}
|
|
|
|
|
|
CSteamCallbackRecordingWrapper* CRecordingEngExtInterceptor::getOrCreateCallbackWrapper(CCallbackBase *pCallback)
|
|
{
|
|
auto itr = m_SteamCallbacks.find(pCallback);
|
|
if (itr == m_SteamCallbacks.end())
|
|
{
|
|
CSteamCallbackRecordingWrapper* wrappee = new CSteamCallbackRecordingWrapper(this, pCallback, m_SteamCallbacksCounter++);
|
|
m_SteamCallbacks[pCallback] = wrappee;
|
|
return wrappee;
|
|
}
|
|
else
|
|
{
|
|
return (*itr).second;
|
|
}
|
|
}
|
|
|
|
void CRecordingEngExtInterceptor::SteamAPI_RegisterCallback(CCallbackBase *pCallback, int iCallback)
|
|
{
|
|
CSteamCallbackRecordingWrapper* wrappee = getOrCreateCallbackWrapper(pCallback);
|
|
|
|
if (wrappee->GetFlags() != pCallback->GetFlags()) regamedll_syserror("%s: flags desync", __FUNCTION__);
|
|
//if (wrappee->GetICallback() != pCallback->GetICallback()) regamedll_syserror("%s: flags desync", __FUNCTION__);
|
|
|
|
CSteamApiRegisterCallbackCall fcall(wrappee->getRegamedllCallbackId(), iCallback, wrappee); CRecorderFuncCall frec(&fcall);
|
|
PushFunc(&frec);
|
|
m_BasePlatform->SteamAPI_RegisterCallback(wrappee, iCallback);
|
|
|
|
fcall.setResult(wrappee);
|
|
pCallback->SetFlags(wrappee->GetFlags());
|
|
pCallback->SetICallback(wrappee->GetICallback());
|
|
|
|
PopFunc(&frec);
|
|
}
|
|
|
|
bool CRecordingEngExtInterceptor::SteamAPI_Init()
|
|
{
|
|
CSteamApiInitCall fcall; CRecorderFuncCall frec(&fcall);
|
|
PushFunc(&frec);
|
|
bool res = m_BasePlatform->SteamAPI_Init();
|
|
fcall.setResult(res);
|
|
PopFunc(&frec);
|
|
return res;
|
|
}
|
|
|
|
void CRecordingEngExtInterceptor::SteamAPI_UnregisterCallResult(class CCallbackBase *pCallback, SteamAPICall_t hAPICall)
|
|
{
|
|
CSteamCallbackRecordingWrapper* wrappee = getOrCreateCallbackWrapper(pCallback);
|
|
|
|
if (wrappee->GetFlags() != pCallback->GetFlags()) regamedll_syserror("%s: flags desync", __FUNCTION__);
|
|
if (wrappee->GetICallback() != pCallback->GetICallback()) regamedll_syserror("%s: flags desync", __FUNCTION__);
|
|
|
|
CSteamApiUnrigestierCallResultCall fcall(wrappee->getRegamedllCallbackId(), hAPICall, wrappee); CRecorderFuncCall frec(&fcall);
|
|
|
|
PushFunc(&frec);
|
|
|
|
m_BasePlatform->SteamAPI_UnregisterCallResult(wrappee, hAPICall);
|
|
|
|
fcall.setResult(wrappee);
|
|
pCallback->SetFlags(wrappee->GetFlags());
|
|
pCallback->SetICallback(wrappee->GetICallback());
|
|
|
|
PopFunc(&frec);
|
|
}
|
|
|
|
ISteamApps* CRecordingEngExtInterceptor::SteamApps()
|
|
{
|
|
CSteamAppsCall fcall; CRecorderFuncCall frec(&fcall);
|
|
PushFunc(&frec);
|
|
if (m_SteamAppsWrapper == NULL)
|
|
{
|
|
ISteamApps* orig = m_BasePlatform->SteamApps();
|
|
fcall.setReturnNull(orig == NULL);
|
|
if (orig != NULL)
|
|
m_SteamAppsWrapper = new CSteamAppsRecordingWrapper(orig, this);
|
|
}
|
|
else
|
|
{
|
|
m_BasePlatform->SteamApps();
|
|
fcall.setReturnNull(false);
|
|
}
|
|
|
|
PopFunc(&frec);
|
|
return m_SteamAppsWrapper;
|
|
}
|
|
|
|
bool CRecordingEngExtInterceptor::SteamGameServer_Init(uint32 unIP, uint16 usSteamPort, uint16 usGamePort, uint16 usQueryPort, EServerMode eServerMode, const char *pchVersionString)
|
|
{
|
|
CSteamGameServerInitCall fcall(unIP, usSteamPort, usGamePort, usQueryPort, eServerMode, pchVersionString); CRecorderFuncCall frec(&fcall);
|
|
PushFunc(&frec);
|
|
bool res = m_BasePlatform->SteamGameServer_Init(unIP, usSteamPort, usGamePort, usQueryPort, eServerMode, pchVersionString);
|
|
fcall.setResult(res);
|
|
PopFunc(&frec);
|
|
return res;
|
|
}
|
|
|
|
ISteamGameServer* CRecordingEngExtInterceptor::SteamGameServer()
|
|
{
|
|
CSteamGameServerCall fcall; CRecorderFuncCall frec(&fcall);
|
|
PushFunc(&frec);
|
|
|
|
if (m_GameServerWrapper == NULL)
|
|
{
|
|
ISteamGameServer* orig = m_BasePlatform->SteamGameServer();
|
|
fcall.setReturnNull(orig == NULL);
|
|
if (orig != NULL)
|
|
m_GameServerWrapper = new CSteamGameServerRecordingWrapper(orig, this);
|
|
}
|
|
else
|
|
{
|
|
fcall.setReturnNull(false);
|
|
m_BasePlatform->SteamGameServer();
|
|
}
|
|
|
|
PopFunc(&frec);
|
|
return m_GameServerWrapper;
|
|
}
|
|
|
|
void CRecordingEngExtInterceptor::SteamAPI_SetBreakpadAppID(uint32 unAppID)
|
|
{
|
|
CSteamApiSetBreakpadAppIdCall fcall(unAppID); CRecorderFuncCall frec(&fcall);
|
|
PushFunc(&frec);
|
|
m_BasePlatform->SteamAPI_SetBreakpadAppID(unAppID);
|
|
PopFunc(&frec);
|
|
}
|
|
|
|
void CRecordingEngExtInterceptor::SteamAPI_UseBreakpadCrashHandler(char const *pchVersion, char const *pchDate, char const *pchTime, bool bFullMemoryDumps, void *pvContext, PFNPreMinidumpCallback m_pfnPreMinidumpCallback)
|
|
{
|
|
m_BasePlatform->SteamAPI_UseBreakpadCrashHandler(pchVersion, pchDate, pchTime, bFullMemoryDumps, pvContext, m_pfnPreMinidumpCallback);
|
|
}
|
|
|
|
void CRecordingEngExtInterceptor::SteamGameServer_RunCallbacks()
|
|
{
|
|
CSteamGameServerRunCallbacksCall fcall; CRecorderFuncCall frec(&fcall);
|
|
PushFunc(&frec);
|
|
m_BasePlatform->SteamGameServer_RunCallbacks();
|
|
PopFunc(&frec);
|
|
}
|
|
|
|
void CRecordingEngExtInterceptor::SteamAPI_RunCallbacks()
|
|
{
|
|
CSteamApiRunCallbacksCall fcall; CRecorderFuncCall frec(&fcall);
|
|
PushFunc(&frec);
|
|
m_BasePlatform->SteamAPI_RunCallbacks();
|
|
PopFunc(&frec);
|
|
}
|
|
|
|
void CRecordingEngExtInterceptor::SteamGameServer_Shutdown()
|
|
{
|
|
CSteamGameServerShutdownCall fcall; CRecorderFuncCall frec(&fcall);
|
|
PushFunc(&frec);
|
|
m_BasePlatform->SteamGameServer_Shutdown();
|
|
m_GameServerWrapper = NULL;
|
|
PopFunc(&frec);
|
|
}
|
|
|
|
void CRecordingEngExtInterceptor::SteamAPI_UnregisterCallback(CCallbackBase *pCallback)
|
|
{
|
|
CSteamCallbackRecordingWrapper* wrappee = getOrCreateCallbackWrapper(pCallback);
|
|
|
|
if (wrappee->GetFlags() != pCallback->GetFlags()) regamedll_syserror("%s: flags desync", __FUNCTION__);
|
|
if (wrappee->GetICallback() != pCallback->GetICallback()) regamedll_syserror("%s: flags desync", __FUNCTION__);
|
|
|
|
CSteamApiUnregisterCallbackCall fcall(wrappee->getRegamedllCallbackId(), wrappee); CRecorderFuncCall frec(&fcall);
|
|
PushFunc(&frec);
|
|
m_BasePlatform->SteamAPI_UnregisterCallback(wrappee);
|
|
|
|
fcall.setResult(wrappee);
|
|
pCallback->SetFlags(wrappee->GetFlags());
|
|
pCallback->SetICallback(wrappee->GetICallback());
|
|
|
|
PopFunc(&frec);
|
|
} |