mirror of
https://github.com/s1lentq/ReGameDLL_CS.git
synced 2025-01-16 00:28:15 +03:00
1101 lines
50 KiB
C++
1101 lines
50 KiB
C++
#include "precompiled.h"
|
|
|
|
CPlayingEngExtInterceptor::CPlayingEngExtInterceptor(const char* fname, bool strictChecks)
|
|
{
|
|
for (int i = 0; i < TESTPLAYER_FUNCTREE_DEPTH; i++)
|
|
{
|
|
m_FuncCalls[i] = &m_FuncCallBuffer[i * TESTPLAYER_FUNCCALL_MAXSIZE];
|
|
m_FuncCallsFree[i] = true;
|
|
}
|
|
|
|
m_InStream.exceptions(std::ios::badbit | std::ios::failbit | std::ios::eofbit);
|
|
m_InStream.open(fname, std::ios::in | std::ios::binary);
|
|
|
|
m_InStream.seekg(0, std::ios_base::end);
|
|
m_inStreamSize = m_InStream.tellg();
|
|
m_InStream.seekg(0, std::ios_base::beg);
|
|
m_bLastRead = false;
|
|
|
|
m_bStrictChecks = strictChecks;
|
|
|
|
m_ServerSocket = INVALID_SOCKET;
|
|
m_SteamCallbacksCounter = 0;
|
|
m_SteamAppsWrapper = NULL;
|
|
m_GameServerWrapper = NULL;
|
|
m_SteamBreakpadContext = NULL;
|
|
|
|
m_HeartBeatInterval = 10000000;
|
|
m_PrevHeartBeat = 0;
|
|
|
|
uint32 cmdlineLen = 0;
|
|
char cmdLine[2048];
|
|
|
|
uint16 versionMajor = 0;
|
|
uint16 versionMinor = 0;
|
|
|
|
m_InStream.read((char*)&versionMinor, 2).read((char*)&versionMajor, 2);
|
|
|
|
if (versionMajor != TESTSUITE_PROTOCOL_VERSION_MAJOR) {
|
|
regamedll_syserror("%s: protocol major version mismatch; need %d, got %d", __FUNCTION__, TESTSUITE_PROTOCOL_VERSION_MAJOR, versionMajor);
|
|
}
|
|
|
|
if (versionMinor > TESTSUITE_PROTOCOL_VERSION_MINOR) {
|
|
regamedll_syserror("%s: protocol minor version mismatch; need <= %d, got %d", __FUNCTION__, TESTSUITE_PROTOCOL_VERSION_MINOR, versionMinor);
|
|
}
|
|
|
|
m_InStream.read((char*)&cmdlineLen, 4);
|
|
if (cmdlineLen > sizeof(cmdLine)) {
|
|
regamedll_syserror("%s: too long cmdline", __FUNCTION__);
|
|
}
|
|
|
|
m_InStream.read(cmdLine, cmdlineLen);
|
|
printf("Playing testsuite\nrecorders's cmdline: %s\n", cmdLine);
|
|
|
|
m_StartTick = ::GetTickCount();
|
|
m_NumFrames = 0;
|
|
}
|
|
|
|
void* CPlayingEngExtInterceptor::allocFuncCall()
|
|
{
|
|
for (int i = 0; i < TESTPLAYER_FUNCTREE_DEPTH; i++)
|
|
{
|
|
if (m_FuncCallsFree[i])
|
|
{
|
|
m_FuncCallsFree[i] = false;
|
|
return m_FuncCalls[i];
|
|
}
|
|
}
|
|
|
|
regamedll_syserror("%s: running out of free slots", __FUNCTION__);
|
|
return NULL;
|
|
}
|
|
|
|
void CPlayingEngExtInterceptor::freeFuncCall(void* fcall)
|
|
{
|
|
for (int i = 0; i < TESTPLAYER_FUNCTREE_DEPTH; i++)
|
|
{
|
|
if (m_FuncCalls[i] == fcall)
|
|
{
|
|
m_FuncCallsFree[i] = true;
|
|
return;
|
|
}
|
|
}
|
|
|
|
regamedll_syserror("%s: invalid pointer provided: %p", __FUNCTION__, fcall);
|
|
}
|
|
|
|
bool CPlayingEngExtInterceptor::readFuncCall() {
|
|
if (m_InStream.tellg() >= m_inStreamSize)
|
|
{
|
|
if (m_bLastRead) return false;
|
|
|
|
m_bLastRead = true;
|
|
IEngExtCall* callFunc = new(allocFuncCall()) CEndRecordCall();
|
|
m_CommandsQueue.push(callFunc);
|
|
return true;
|
|
}
|
|
|
|
uint16 opc;
|
|
m_InStream.read((char*)&opc, 2);
|
|
|
|
bool startFlag = (opc & (1 << 15)) != 0;
|
|
bool endFlag = (opc & (1 << 14)) != 0;
|
|
opc &= 0x3FFF;
|
|
|
|
if (startFlag)
|
|
{
|
|
IEngExtCall* callFunc = IEngExtCallFactory::createByOpcode((ExtCallFuncs)opc, allocFuncCall(), TESTPLAYER_FUNCCALL_MAXSIZE);
|
|
callFunc->readPrologue(m_InStream);
|
|
m_CommandsQueue.push(callFunc);
|
|
callFunc->m_Start = true;
|
|
}
|
|
|
|
if (endFlag)
|
|
{
|
|
IEngExtCall* callFunc = IEngExtCallFactory::createByOpcode((ExtCallFuncs)opc, allocFuncCall(), TESTPLAYER_FUNCCALL_MAXSIZE);
|
|
callFunc->readEpilogue(m_InStream);
|
|
m_CommandsQueue.push(callFunc);
|
|
callFunc->m_End = true;
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
IEngExtCall* CPlayingEngExtInterceptor::getNextCallInternal(bool peek) {
|
|
if (m_CommandsQueue.empty()) {
|
|
readFuncCall();
|
|
}
|
|
|
|
if (m_CommandsQueue.empty()) {
|
|
regamedll_syserror("%s: command queue is empty!", __FUNCTION__);
|
|
}
|
|
|
|
IEngExtCall* next = m_CommandsQueue.front();
|
|
if (!peek) {
|
|
m_CommandsQueue.pop();
|
|
}
|
|
|
|
return next;
|
|
}
|
|
|
|
IEngExtCall* CPlayingEngExtInterceptor::getNextCall(bool peek, bool processCallbacks, ExtCallFuncs expectedOpcode, bool needStart, const char* callSource) {
|
|
int size = (int)m_InStream.tellg();
|
|
int sizeLeft = m_inStreamSize - size;
|
|
maybeHeartBeat(size);
|
|
IEngExtCall* cmd = getNextCallInternal(peek);
|
|
if (peek) {
|
|
return cmd;
|
|
}
|
|
|
|
if (cmd->getOpcode() == ECF_NONE) {
|
|
DWORD endTick = ::GetTickCount();
|
|
FILE* fl = fopen("regamedll_demo_stats.xml", "w");
|
|
if (fl) {
|
|
fprintf(fl, "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n");
|
|
fprintf(fl, "<DemoStats>\n");
|
|
fprintf(fl, " <Duration>%u</Duration>\n", (endTick - m_StartTick));
|
|
fprintf(fl, " <NumFrames>%u</NumFrames>\n", m_NumFrames);
|
|
fprintf(fl, "</DemoStats>\n");
|
|
fclose(fl);
|
|
}
|
|
TerminateProcess(GetCurrentProcess(), 777);
|
|
}
|
|
|
|
IEngCallbackCall* callback = dynamic_cast<IEngCallbackCall*>(cmd);
|
|
if (callback != NULL && callback->m_Start) {
|
|
if (!processCallbacks) {
|
|
regamedll_syserror("%s: read a callback, but it's not allowed here", __FUNCTION__);
|
|
return NULL;
|
|
}
|
|
|
|
while (callback != NULL && callback->m_Start) {
|
|
playCallback(callback);
|
|
cmd = getNextCallInternal(false);
|
|
callback = (IEngCallbackCall*)cmd;
|
|
}
|
|
}
|
|
|
|
if (cmd->getOpcode() != expectedOpcode) {
|
|
regamedll_syserror("%s: bad opcode; expected %d got %d; size left: %d", __FUNCTION__, expectedOpcode, cmd->getOpcode(), sizeLeft);
|
|
}
|
|
if (needStart) {
|
|
if (!cmd->m_Start) regamedll_syserror("%s: bad fcall %d; expected start flag", __FUNCTION__, cmd->getOpcode());
|
|
}
|
|
else {
|
|
if (!cmd->m_End) regamedll_syserror("%s: bad fcall %d; expected end flag", __FUNCTION__, cmd->getOpcode());
|
|
}
|
|
|
|
return cmd;
|
|
}
|
|
|
|
void CPlayingEngExtInterceptor::playCallback(IEngCallbackCall* cb) {
|
|
switch (cb->getOpcode()) {
|
|
|
|
case ECF_STEAM_CALLBACK_CALL_1:
|
|
playSteamCallback1((CSteamCallbackCall1*)cb);
|
|
return;
|
|
|
|
case ECF_STEAM_CALLBACK_CALL_2:
|
|
playSteamCallback2((CSteamCallbackCall2*)cb);
|
|
return;
|
|
|
|
default:
|
|
regamedll_syserror("%s: unknown callback", __FUNCTION__);
|
|
}
|
|
}
|
|
|
|
void CPlayingEngExtInterceptor::playSteamCallback1(CSteamCallbackCall1* cb) {
|
|
auto itr = m_SteamCallbacks.find(cb->m_CallbackId);
|
|
if (itr == m_SteamCallbacks.end()) regamedll_syserror("%s: callback %d not found", __FUNCTION__, cb->m_CallbackId);
|
|
CCallbackBase* steamCallback = (*itr).second;
|
|
|
|
if (steamCallback->GetFlags() != cb->m_InState.m_nCallbackFlags) regamedll_syserror("%s: PRE flags desync", __FUNCTION__);
|
|
if (steamCallback->GetICallback() != cb->m_InState.m_iCallback) regamedll_syserror("%s: PRE flags desync", __FUNCTION__);
|
|
|
|
steamCallback->Run(cb->m_Data);
|
|
|
|
CSteamCallbackCall1* endCallback = (CSteamCallbackCall1*)getNextCall(false, true, cb->getOpcode(), false, __FUNCTION__);
|
|
|
|
if (steamCallback->GetFlags() != endCallback->m_OutState.m_nCallbackFlags) regamedll_syserror("%s: POST flags desync", __FUNCTION__);
|
|
if (steamCallback->GetICallback() != endCallback->m_OutState.m_iCallback) regamedll_syserror("%s: POST flags desync", __FUNCTION__);
|
|
freeFuncCall(cb);
|
|
freeFuncCall(endCallback);
|
|
}
|
|
|
|
void CPlayingEngExtInterceptor::playSteamCallback2(CSteamCallbackCall2* cb) {
|
|
auto itr = m_SteamCallbacks.find(cb->m_CallbackId);
|
|
if (itr == m_SteamCallbacks.end()) regamedll_syserror("%s: callback %d not found", __FUNCTION__, cb->m_CallbackId);
|
|
CCallbackBase* steamCallback = (*itr).second;
|
|
|
|
if (steamCallback->GetFlags() != cb->m_InState.m_nCallbackFlags) regamedll_syserror("%s: PRE flags desync", __FUNCTION__);
|
|
if (steamCallback->GetICallback() != cb->m_InState.m_iCallback) regamedll_syserror("%s: PRE flags desync", __FUNCTION__);
|
|
|
|
steamCallback->Run(cb->m_Data, cb->m_bIOFailure, cb->m_SteamAPICall);
|
|
|
|
CSteamCallbackCall2* endCallback = (CSteamCallbackCall2*)getNextCall(false, true, cb->getOpcode(), false, __FUNCTION__);
|
|
|
|
if (steamCallback->GetFlags() != endCallback->m_OutState.m_nCallbackFlags) regamedll_syserror("%s: POST flags desync", __FUNCTION__);
|
|
if (steamCallback->GetICallback() != endCallback->m_OutState.m_iCallback) regamedll_syserror("%s: POST flags desync", __FUNCTION__);
|
|
freeFuncCall(cb);
|
|
freeFuncCall(endCallback);
|
|
}
|
|
|
|
int CPlayingEngExtInterceptor::getOrRegisterSteamCallback(CCallbackBase* cb) {
|
|
auto itr = m_SteamCallbacksReverse.find(cb);
|
|
if (itr != m_SteamCallbacksReverse.end()) {
|
|
return (*itr).second;
|
|
}
|
|
|
|
int id = m_SteamCallbacksCounter++;
|
|
m_SteamCallbacksReverse[cb] = id;
|
|
m_SteamCallbacks[id] = cb;
|
|
|
|
return id;
|
|
}
|
|
|
|
void CPlayingEngExtInterceptor::maybeHeartBeat(int readPos) {
|
|
if (m_PrevHeartBeat + m_HeartBeatInterval <= readPos) {
|
|
m_PrevHeartBeat = readPos;
|
|
printf2("%s: readPos=%u\n", __FUNCTION__, readPos);
|
|
}
|
|
}
|
|
|
|
uint32 CPlayingEngExtInterceptor::time(uint32* pTime)
|
|
{
|
|
CStdTimeCall* playCall = dynamic_cast<CStdTimeCall*>(getNextCall(false, false, ECF_CSTD_TIME, true, __FUNCTION__));
|
|
CStdTimeCall(pTime).ensureArgsAreEqual(playCall, m_bStrictChecks, __FUNCTION__);
|
|
CStdTimeCall* playEndCall = dynamic_cast<CStdTimeCall*>(getNextCall(false, true, ECF_CSTD_TIME, false, __FUNCTION__));
|
|
|
|
uint32 res = playEndCall->m_Res;
|
|
if (pTime != NULL) *pTime = res;
|
|
|
|
freeFuncCall(playCall); freeFuncCall(playEndCall);
|
|
|
|
return res;
|
|
}
|
|
|
|
struct tm* CPlayingEngExtInterceptor::localtime(uint32 time)
|
|
{
|
|
CStdLocalTimeCall* playCall = dynamic_cast<CStdLocalTimeCall*>(getNextCall(false, false, ECF_CSTD_LOCALTIME, true, __FUNCTION__));
|
|
CStdLocalTimeCall(time).ensureArgsAreEqual(playCall, m_bStrictChecks, __FUNCTION__);
|
|
CStdLocalTimeCall* playEndCall = dynamic_cast<CStdLocalTimeCall*>(getNextCall(false, true, ECF_CSTD_LOCALTIME, false, __FUNCTION__));
|
|
|
|
setCurrentTm(&playEndCall->m_Res);
|
|
|
|
freeFuncCall(playCall); freeFuncCall(playEndCall);
|
|
|
|
return &m_CurrentTm;
|
|
}
|
|
|
|
void CPlayingEngExtInterceptor::srand(uint32 seed)
|
|
{
|
|
CStdSrandCall* playCall = dynamic_cast<CStdSrandCall*>(getNextCall(false, false, ECF_CSTD_SRAND_CALL, true, __FUNCTION__));
|
|
CStdSrandCall(seed).ensureArgsAreEqual(playCall, m_bStrictChecks, __FUNCTION__);
|
|
CStdSrandCall* playEndCall = dynamic_cast<CStdSrandCall*>(getNextCall(false, true, ECF_CSTD_SRAND_CALL, false, __FUNCTION__));
|
|
|
|
freeFuncCall(playCall); freeFuncCall(playEndCall);
|
|
}
|
|
|
|
int CPlayingEngExtInterceptor::rand()
|
|
{
|
|
CStdRandCall* playCall = dynamic_cast<CStdRandCall*>(getNextCall(false, false, ECF_CSTD_RAND_CALL, true, __FUNCTION__));
|
|
CStdRandCall* playEndCall = dynamic_cast<CStdRandCall*>(getNextCall(false, true, ECF_CSTD_RAND_CALL, false, __FUNCTION__));
|
|
|
|
int res = playEndCall->m_Res;
|
|
|
|
freeFuncCall(playCall); freeFuncCall(playEndCall);
|
|
|
|
return res;
|
|
}
|
|
|
|
void CPlayingEngExtInterceptor::Sleep(DWORD msec) {
|
|
CSleepExtCall* playCall = dynamic_cast<CSleepExtCall*>(getNextCall(false, false, ECF_SLEEP, true, __FUNCTION__));
|
|
CSleepExtCall(msec).ensureArgsAreEqual(playCall, m_bStrictChecks, __FUNCTION__);
|
|
CSleepExtCall* playEndCall = dynamic_cast<CSleepExtCall*>(getNextCall(false, true, ECF_SLEEP, false, __FUNCTION__));
|
|
|
|
freeFuncCall(playCall); freeFuncCall(playEndCall);
|
|
}
|
|
|
|
BOOL CPlayingEngExtInterceptor::QueryPerfCounter(LARGE_INTEGER* counter) {
|
|
CQueryPerfCounterCall* playCall = dynamic_cast<CQueryPerfCounterCall*>(getNextCall(false, false, ECF_QUERY_PERF_COUNTER, true, __FUNCTION__));
|
|
CQueryPerfCounterCall* playEndCall = dynamic_cast<CQueryPerfCounterCall*>(getNextCall(false, true, ECF_QUERY_PERF_COUNTER, false, __FUNCTION__));
|
|
|
|
counter->QuadPart = playEndCall->m_Counter;
|
|
BOOL res = playEndCall->m_Res;
|
|
freeFuncCall(playCall); freeFuncCall(playEndCall);
|
|
|
|
return res;
|
|
}
|
|
|
|
BOOL CPlayingEngExtInterceptor::QueryPerfFreq(LARGE_INTEGER* freq) {
|
|
CQueryPerfFreqCall* playCall = dynamic_cast<CQueryPerfFreqCall*>(getNextCall(false, false, ECF_QUERY_PERF_FREQ, true, __FUNCTION__));
|
|
CQueryPerfFreqCall* playEndCall = dynamic_cast<CQueryPerfFreqCall*>(getNextCall(false, true, ECF_QUERY_PERF_FREQ, false, __FUNCTION__));
|
|
|
|
freq->QuadPart = playEndCall->m_Freq;
|
|
BOOL res = playEndCall->m_Res;
|
|
freeFuncCall(playCall); freeFuncCall(playEndCall);
|
|
|
|
return res;
|
|
}
|
|
|
|
DWORD CPlayingEngExtInterceptor::GetTickCount() {
|
|
CGetTickCountCall* playCall = dynamic_cast<CGetTickCountCall*>(getNextCall(false, false, ECF_GET_TICK_COUNT, true, __FUNCTION__));
|
|
CGetTickCountCall* playEndCall = dynamic_cast<CGetTickCountCall*>(getNextCall(false, true, ECF_GET_TICK_COUNT, false, __FUNCTION__));
|
|
|
|
DWORD res = playEndCall->m_Res;
|
|
freeFuncCall(playCall); freeFuncCall(playEndCall);
|
|
|
|
return res;
|
|
}
|
|
|
|
void CPlayingEngExtInterceptor::GetLocalTime(LPSYSTEMTIME time) {
|
|
CGetLocalTimeCall* playCall = dynamic_cast<CGetLocalTimeCall*>(getNextCall(false, false, ECF_GET_LOCAL_TIME, true, __FUNCTION__));
|
|
CGetLocalTimeCall* playEndCall = dynamic_cast<CGetLocalTimeCall*>(getNextCall(false, true, ECF_GET_LOCAL_TIME, false, __FUNCTION__));
|
|
|
|
memcpy(time, &playEndCall->m_Res, sizeof(SYSTEMTIME));
|
|
freeFuncCall(playCall); freeFuncCall(playEndCall);
|
|
}
|
|
|
|
void CPlayingEngExtInterceptor::GetSystemTime(LPSYSTEMTIME time) {
|
|
CGetSystemTimeCall* playCall = dynamic_cast<CGetSystemTimeCall*>(getNextCall(false, false, ECF_GET_SYSTEM_TIME, true, __FUNCTION__));
|
|
CGetSystemTimeCall* playEndCall = dynamic_cast<CGetSystemTimeCall*>(getNextCall(false, true, ECF_GET_SYSTEM_TIME, false, __FUNCTION__));
|
|
|
|
memcpy(time, &playEndCall->m_Res, sizeof(SYSTEMTIME));
|
|
freeFuncCall(playCall); freeFuncCall(playEndCall);
|
|
}
|
|
|
|
void CPlayingEngExtInterceptor::GetTimeZoneInfo(LPTIME_ZONE_INFORMATION zinfo) {
|
|
CGetTimeZoneInfoCall* playCall = dynamic_cast<CGetTimeZoneInfoCall*>(getNextCall(false, false, ECF_GET_TIMEZONE_INFO, true, __FUNCTION__));
|
|
CGetTimeZoneInfoCall* playEndCall = dynamic_cast<CGetTimeZoneInfoCall*>(getNextCall(false, true, ECF_GET_TIMEZONE_INFO, false, __FUNCTION__));
|
|
|
|
memcpy(zinfo, &playEndCall->m_Res, sizeof(TIME_ZONE_INFORMATION));
|
|
freeFuncCall(playCall); freeFuncCall(playEndCall);
|
|
}
|
|
|
|
BOOL CPlayingEngExtInterceptor::GetProcessTimes(HANDLE hProcess, LPFILETIME lpCreationTime, LPFILETIME lpExitTime, LPFILETIME lpKernelTime, LPFILETIME lpUserTime)
|
|
{
|
|
CGetProcessTimesCall* playCall = dynamic_cast<CGetProcessTimesCall*>(getNextCall(false, false, ECF_GET_PROCESS_TIMES, true, __FUNCTION__));
|
|
CGetProcessTimesCall* playEndCall = dynamic_cast<CGetProcessTimesCall*>(getNextCall(false, true, ECF_GET_PROCESS_TIMES, false, __FUNCTION__));
|
|
|
|
BOOL res = playEndCall->m_Res;
|
|
memcpy(lpCreationTime, &playEndCall->m_CreationTime, sizeof(FILETIME));
|
|
memcpy(lpExitTime, &playEndCall->m_ExitTime, sizeof(FILETIME));
|
|
memcpy(lpKernelTime, &playEndCall->m_KernelTime, sizeof(FILETIME));
|
|
memcpy(lpUserTime, &playEndCall->m_UserTime, sizeof(FILETIME));
|
|
freeFuncCall(playCall); freeFuncCall(playEndCall);
|
|
|
|
return res;
|
|
}
|
|
|
|
void CPlayingEngExtInterceptor::GetSystemTimeAsFileTime(LPFILETIME lpSystemTimeAsFileTime)
|
|
{
|
|
CGetSystemTimeAsFileTimeCall* playCall = dynamic_cast<CGetSystemTimeAsFileTimeCall*>(getNextCall(false, false, ECF_GET_SYSTEM_TIME_AS_FILE_TIME, true, __FUNCTION__));
|
|
CGetSystemTimeAsFileTimeCall* playEndCall = dynamic_cast<CGetSystemTimeAsFileTimeCall*>(getNextCall(false, true, ECF_GET_SYSTEM_TIME_AS_FILE_TIME, false, __FUNCTION__));
|
|
|
|
memcpy(lpSystemTimeAsFileTime, &playEndCall->m_SystemTime, sizeof(FILETIME));
|
|
freeFuncCall(playCall); freeFuncCall(playEndCall);
|
|
}
|
|
|
|
|
|
SOCKET CPlayingEngExtInterceptor::socket(int af, int type, int protocol) {
|
|
CSocketCall* playCall = dynamic_cast<CSocketCall*>(getNextCall(false, false, ECF_SOCKET, true, __FUNCTION__));
|
|
CSocketCall(af, type, protocol).ensureArgsAreEqual(playCall, m_bStrictChecks, __FUNCTION__);
|
|
CSocketCall* playEndCall = dynamic_cast<CSocketCall*>(getNextCall(false, true, ECF_SOCKET, false, __FUNCTION__));
|
|
|
|
SOCKET res = playEndCall->m_Res;
|
|
freeFuncCall(playCall); freeFuncCall(playEndCall);
|
|
|
|
return res;
|
|
}
|
|
|
|
int CPlayingEngExtInterceptor::ioctlsocket(SOCKET s, long cmd, u_long *argp) {
|
|
CIoCtlSocketCall* playCall = dynamic_cast<CIoCtlSocketCall*>(getNextCall(false, false, ECF_IOCTL_SOCKET, true, __FUNCTION__));
|
|
CIoCtlSocketCall(s, cmd, *argp).ensureArgsAreEqual(playCall, m_bStrictChecks, __FUNCTION__);
|
|
CIoCtlSocketCall* playEndCall = dynamic_cast<CIoCtlSocketCall*>(getNextCall(false, true, ECF_IOCTL_SOCKET, false, __FUNCTION__));
|
|
|
|
int res = playEndCall->m_Res;
|
|
*argp = playEndCall->m_OutValue;
|
|
freeFuncCall(playCall); freeFuncCall(playEndCall);
|
|
|
|
return res;
|
|
}
|
|
|
|
int CPlayingEngExtInterceptor::setsockopt(SOCKET s, int level, int optname, const char* optval, int optlen) {
|
|
CSetSockOptCall* playCall = dynamic_cast<CSetSockOptCall*>(getNextCall(false, false, ECF_SET_SOCK_OPT, true, __FUNCTION__));
|
|
CSetSockOptCall(s, level, optname, optval, optlen).ensureArgsAreEqual(playCall, m_bStrictChecks, __FUNCTION__);
|
|
CSetSockOptCall* playEndCall = dynamic_cast<CSetSockOptCall*>(getNextCall(false, true, ECF_SET_SOCK_OPT, false, __FUNCTION__));
|
|
|
|
int res = playEndCall->m_Res;
|
|
freeFuncCall(playCall); freeFuncCall(playEndCall);
|
|
|
|
return res;
|
|
}
|
|
|
|
int CPlayingEngExtInterceptor::closesocket(SOCKET s) {
|
|
CCloseSocketCall* playCall = dynamic_cast<CCloseSocketCall*>(getNextCall(false, false, ECF_CLOSE_SOCKET, true, __FUNCTION__));
|
|
CCloseSocketCall(s).ensureArgsAreEqual(playCall, m_bStrictChecks, __FUNCTION__);
|
|
CCloseSocketCall* playEndCall = dynamic_cast<CCloseSocketCall*>(getNextCall(false, true, ECF_CLOSE_SOCKET, false, __FUNCTION__));
|
|
|
|
int res = playEndCall->m_Res;
|
|
freeFuncCall(playCall); freeFuncCall(playEndCall);
|
|
|
|
return res;
|
|
}
|
|
|
|
int CPlayingEngExtInterceptor::recvfrom(SOCKET s, char* buf, int len, int flags, struct sockaddr* from, socklen_t *fromlen) {
|
|
CRecvFromCall* playCall = dynamic_cast<CRecvFromCall*>(getNextCall(false, false, ECF_RECVFROM, true, __FUNCTION__));
|
|
CRecvFromCall(s, len, flags, *fromlen).ensureArgsAreEqual(playCall, m_bStrictChecks, __FUNCTION__);
|
|
CRecvFromCall* playEndCall = dynamic_cast<CRecvFromCall*>(getNextCall(false, true, ECF_RECVFROM, false, __FUNCTION__));
|
|
|
|
int res = playEndCall->m_Res;
|
|
*fromlen = playEndCall->m_FromLenOut;
|
|
if (res >= 0) {
|
|
memcpy(buf, playEndCall->m_Data, res);
|
|
memcpy(from, playEndCall->m_From, playEndCall->m_FromLenOut);
|
|
}
|
|
|
|
freeFuncCall(playCall); freeFuncCall(playEndCall);
|
|
|
|
if (res == -1) {
|
|
m_NumFrames++;
|
|
}
|
|
|
|
return res;
|
|
}
|
|
|
|
int CPlayingEngExtInterceptor::sendto(SOCKET s, const char* buf, int len, int flags, const struct sockaddr* to, int tolen) {
|
|
CSendToCall* playCall = dynamic_cast<CSendToCall*>(getNextCall(false, false, ECF_SENDTO, true, __FUNCTION__));
|
|
CSendToCall(s, buf, len, flags, to, tolen).ensureArgsAreEqual(playCall, m_bStrictChecks, __FUNCTION__);
|
|
CSendToCall* playEndCall = dynamic_cast<CSendToCall*>(getNextCall(false, true, ECF_SENDTO, false, __FUNCTION__));
|
|
|
|
int res = playEndCall->m_Res;
|
|
freeFuncCall(playCall); freeFuncCall(playEndCall);
|
|
|
|
return res;
|
|
}
|
|
|
|
int CPlayingEngExtInterceptor::bind(SOCKET s, const struct sockaddr* addr, int namelen) {
|
|
CBindCall* playCall = dynamic_cast<CBindCall*>(getNextCall(false, false, ECF_BIND, true, __FUNCTION__));
|
|
CBindCall(s, addr, namelen).ensureArgsAreEqual(playCall, m_bStrictChecks, __FUNCTION__);
|
|
CBindCall* playEndCall = dynamic_cast<CBindCall*>(getNextCall(false, true, ECF_BIND, false, __FUNCTION__));
|
|
|
|
int res = playEndCall->m_Res;
|
|
freeFuncCall(playCall); freeFuncCall(playEndCall);
|
|
|
|
return res;
|
|
}
|
|
|
|
int CPlayingEngExtInterceptor::getsockname(SOCKET s, struct sockaddr* name, socklen_t* namelen) {
|
|
CGetSockNameCall* playCall = dynamic_cast<CGetSockNameCall*>(getNextCall(false, false, ECF_GET_SOCK_NAME, true, __FUNCTION__));
|
|
CGetSockNameCall(s, *namelen).ensureArgsAreEqual(playCall, m_bStrictChecks, __FUNCTION__);
|
|
CGetSockNameCall* playEndCall = dynamic_cast<CGetSockNameCall*>(getNextCall(false, true, ECF_GET_SOCK_NAME, false, __FUNCTION__));
|
|
|
|
int res = playEndCall->m_Res;
|
|
*namelen = playEndCall->m_AddrLenOut;
|
|
if (res >= 0) {
|
|
memcpy(name, playEndCall->m_Addr, playEndCall->m_AddrLenOut);
|
|
}
|
|
|
|
freeFuncCall(playCall); freeFuncCall(playEndCall);
|
|
|
|
return res;
|
|
}
|
|
|
|
int CPlayingEngExtInterceptor::WSAGetLastError() {
|
|
CWSAGetLastErrorCall* playCall = dynamic_cast<CWSAGetLastErrorCall*>(getNextCall(false, false, ECF_WSA_GET_LAST_ERROR, true, __FUNCTION__));
|
|
CWSAGetLastErrorCall* playEndCall = dynamic_cast<CWSAGetLastErrorCall*>(getNextCall(false, true, ECF_WSA_GET_LAST_ERROR, false, __FUNCTION__));
|
|
|
|
int res = playEndCall->m_Res;
|
|
freeFuncCall(playCall); freeFuncCall(playEndCall);
|
|
|
|
return res;
|
|
}
|
|
|
|
struct hostent* CPlayingEngExtInterceptor::gethostbyname(const char *name) {
|
|
CGetHostByNameCall* playCall = dynamic_cast<CGetHostByNameCall*>(getNextCall(false, false, ECF_GET_HOST_BY_NAME, true, __FUNCTION__));
|
|
CGetHostByNameCall(name).ensureArgsAreEqual(playCall, m_bStrictChecks, __FUNCTION__);
|
|
CGetHostByNameCall* playEndCall = dynamic_cast<CGetHostByNameCall*>(getNextCall(false, true, ECF_GET_HOST_BY_NAME, false, __FUNCTION__));
|
|
|
|
setCurrentHostent(&playEndCall->m_HostentData);
|
|
|
|
freeFuncCall(playCall); freeFuncCall(playEndCall);
|
|
|
|
return &m_CurrentHostent;
|
|
}
|
|
|
|
int CPlayingEngExtInterceptor::gethostname(char *name, int namelen) {
|
|
CGetHostNameCall* playCall = dynamic_cast<CGetHostNameCall*>(getNextCall(false, false, ECF_GET_HOST_NAME, true, __FUNCTION__));
|
|
CGetHostNameCall(namelen).ensureArgsAreEqual(playCall, m_bStrictChecks, __FUNCTION__);
|
|
CGetHostNameCall* playEndCall = dynamic_cast<CGetHostNameCall*>(getNextCall(false, true, ECF_GET_HOST_NAME, false, __FUNCTION__));
|
|
|
|
int res = playEndCall->m_Res;
|
|
strcpy(name, playEndCall->m_Name);
|
|
|
|
freeFuncCall(playCall); freeFuncCall(playEndCall);
|
|
|
|
return res;
|
|
}
|
|
|
|
void CPlayingEngExtInterceptor::setCurrentHostent(hostent_data_t* data) {
|
|
memcpy(&m_CurrentHostentData, data, sizeof(m_CurrentHostentData));
|
|
for (int i = 0; i < m_CurrentHostentData.numAliases; i++) {
|
|
m_CurrentHostentData.preparedAliases[i] = m_CurrentHostentData.aliases[i];
|
|
m_CurrentHostentData.preparedAliases[i + 1] = NULL;
|
|
}
|
|
|
|
for (int i = 0; i < m_CurrentHostentData.numAddrs; i++) {
|
|
m_CurrentHostentData.preparedAddrs[i] = m_CurrentHostentData.addrs[i];
|
|
m_CurrentHostentData.preparedAddrs[i + 1] = NULL;
|
|
}
|
|
|
|
m_CurrentHostent.h_addr_list = m_CurrentHostentData.preparedAddrs;
|
|
m_CurrentHostent.h_addrtype = m_CurrentHostentData.addrtype;
|
|
m_CurrentHostent.h_aliases = m_CurrentHostentData.preparedAliases;
|
|
m_CurrentHostent.h_length = m_CurrentHostentData.addrLen;
|
|
m_CurrentHostent.h_name = m_CurrentHostentData.hostName;
|
|
}
|
|
|
|
void CPlayingEngExtInterceptor::setCurrentTm(struct tm* t) {
|
|
memcpy(&m_CurrentTm, t, sizeof(m_CurrentTm));
|
|
}
|
|
|
|
void CPlayingEngExtInterceptor::SteamAPI_SetBreakpadAppID(uint32 unAppID) {
|
|
CSteamApiSetBreakpadAppIdCall* playCall = dynamic_cast<CSteamApiSetBreakpadAppIdCall*>(getNextCall(false, false, ECF_STEAM_API_SET_BREAKPAD_APP_ID, true, __FUNCTION__));
|
|
CSteamApiSetBreakpadAppIdCall(unAppID).ensureArgsAreEqual(playCall, m_bStrictChecks, __FUNCTION__);
|
|
CSteamApiSetBreakpadAppIdCall* playEndCall = dynamic_cast<CSteamApiSetBreakpadAppIdCall*>(getNextCall(false, true, ECF_STEAM_API_SET_BREAKPAD_APP_ID, false, __FUNCTION__));
|
|
|
|
freeFuncCall(playCall); freeFuncCall(playEndCall);
|
|
}
|
|
|
|
void CPlayingEngExtInterceptor::SteamAPI_UseBreakpadCrashHandler(char const *pchVersion, char const *pchDate, char const *pchTime, bool bFullMemoryDumps, void *pvContext, PFNPreMinidumpCallback m_pfnPreMinidumpCallback) {
|
|
//do nothing for now
|
|
}
|
|
|
|
void CPlayingEngExtInterceptor::SteamAPI_RegisterCallback(CCallbackBase *pCallback, int iCallback) {
|
|
int regamedllId = getOrRegisterSteamCallback(pCallback);
|
|
|
|
CSteamApiRegisterCallbackCall* playCall = dynamic_cast<CSteamApiRegisterCallbackCall*>(getNextCall(false, false, ECF_STEAM_API_REGISTER_CALLBACK, true, __FUNCTION__));
|
|
CSteamApiRegisterCallbackCall(regamedllId, iCallback, pCallback).ensureArgsAreEqual(playCall, m_bStrictChecks, __FUNCTION__);
|
|
CSteamApiRegisterCallbackCall* playEndCall = dynamic_cast<CSteamApiRegisterCallbackCall*>(getNextCall(false, true, ECF_STEAM_API_REGISTER_CALLBACK, false, __FUNCTION__));
|
|
|
|
pCallback->SetFlags(playEndCall->m_OutState.m_nCallbackFlags);
|
|
pCallback->SetICallback(playEndCall->m_OutState.m_iCallback);
|
|
freeFuncCall(playCall); freeFuncCall(playEndCall);
|
|
}
|
|
|
|
bool CPlayingEngExtInterceptor::SteamAPI_Init() {
|
|
CSteamApiInitCall* playCall = dynamic_cast<CSteamApiInitCall*>(getNextCall(false, false, ECF_STEAM_API_INIT, true, __FUNCTION__));
|
|
CSteamApiInitCall* playEndCall = dynamic_cast<CSteamApiInitCall*>(getNextCall(false, true, ECF_STEAM_API_INIT, false, __FUNCTION__));
|
|
|
|
bool res = playEndCall->m_Res;
|
|
freeFuncCall(playCall); freeFuncCall(playEndCall);
|
|
|
|
return res;
|
|
}
|
|
|
|
void CPlayingEngExtInterceptor::SteamAPI_UnregisterCallResult(class CCallbackBase *pCallback, SteamAPICall_t hAPICall) {
|
|
int regamedllId = getOrRegisterSteamCallback(pCallback);
|
|
|
|
CSteamApiUnrigestierCallResultCall* playCall = dynamic_cast<CSteamApiUnrigestierCallResultCall*>(getNextCall(false, false, ECF_STEAM_API_UNREGISTER_CALL_RESULT, true, __FUNCTION__));
|
|
CSteamApiUnrigestierCallResultCall(regamedllId, hAPICall, pCallback).ensureArgsAreEqual(playCall, m_bStrictChecks, __FUNCTION__);
|
|
CSteamApiUnrigestierCallResultCall* playEndCall = dynamic_cast<CSteamApiUnrigestierCallResultCall*>(getNextCall(false, true, ECF_STEAM_API_UNREGISTER_CALL_RESULT, false, __FUNCTION__));
|
|
|
|
pCallback->SetFlags(playEndCall->m_OutState.m_nCallbackFlags);
|
|
pCallback->SetICallback(playEndCall->m_OutState.m_iCallback);
|
|
freeFuncCall(playCall); freeFuncCall(playEndCall);
|
|
}
|
|
|
|
ISteamApps* CPlayingEngExtInterceptor::SteamApps() {
|
|
CSteamAppsCall* playCall = (CSteamAppsCall*)getNextCall(false, false, ECF_STEAMAPPS, true, __FUNCTION__);
|
|
CSteamAppsCall* playEndCall = (CSteamAppsCall*)getNextCall(false, true, ECF_STEAMAPPS, false, __FUNCTION__);
|
|
|
|
ISteamApps* res = NULL;
|
|
if (!playEndCall->m_ReturnNull) {
|
|
if (m_SteamAppsWrapper == NULL) m_SteamAppsWrapper = new CSteamAppsPlayingWrapper(this);
|
|
res = m_SteamAppsWrapper;
|
|
}
|
|
freeFuncCall(playCall); freeFuncCall(playEndCall);
|
|
|
|
return res;
|
|
}
|
|
|
|
bool CPlayingEngExtInterceptor::SteamGameServer_Init(uint32 unIP, uint16 usSteamPort, uint16 usGamePort, uint16 usQueryPort, EServerMode eServerMode, const char *pchVersionString) {
|
|
CSteamGameServerInitCall* playCall = dynamic_cast<CSteamGameServerInitCall*>(getNextCall(false, false, ECF_STEAMGAMESERVER_INIT, true, __FUNCTION__));
|
|
CSteamGameServerInitCall(unIP, usSteamPort, usGamePort, usQueryPort, eServerMode, pchVersionString).ensureArgsAreEqual(playCall, m_bStrictChecks, __FUNCTION__);
|
|
CSteamGameServerInitCall* playEndCall = dynamic_cast<CSteamGameServerInitCall*>(getNextCall(false, true, ECF_STEAMGAMESERVER_INIT, false, __FUNCTION__));
|
|
|
|
bool res = playEndCall->m_Res;
|
|
freeFuncCall(playCall); freeFuncCall(playEndCall);
|
|
|
|
return res;
|
|
}
|
|
|
|
ISteamGameServer* CPlayingEngExtInterceptor::SteamGameServer() {
|
|
CSteamGameServerCall* playCall = dynamic_cast<CSteamGameServerCall*>(getNextCall(false, false, ECF_STEAMGAMESERVER, true, __FUNCTION__));
|
|
CSteamGameServerCall* playEndCall = dynamic_cast<CSteamGameServerCall*>(getNextCall(false, true, ECF_STEAMGAMESERVER, false, __FUNCTION__));
|
|
|
|
ISteamGameServer* res = NULL;
|
|
if (!playEndCall->m_ReturnNull) {
|
|
if (m_GameServerWrapper == NULL) m_GameServerWrapper = new CSteamGameServerPlayingWrapper(this);
|
|
res = m_GameServerWrapper;
|
|
}
|
|
freeFuncCall(playCall); freeFuncCall(playEndCall);
|
|
|
|
return res;
|
|
}
|
|
|
|
void CPlayingEngExtInterceptor::SteamGameServer_RunCallbacks() {
|
|
CSteamGameServerRunCallbacksCall* playCall = dynamic_cast<CSteamGameServerRunCallbacksCall*>(getNextCall(false, false, ECF_STEAMGAMESERVER_RUN_CALLBACKS, true, __FUNCTION__));
|
|
CSteamGameServerRunCallbacksCall* playEndCall = dynamic_cast<CSteamGameServerRunCallbacksCall*>(getNextCall(false, true, ECF_STEAMGAMESERVER_RUN_CALLBACKS, false, __FUNCTION__));
|
|
|
|
freeFuncCall(playCall); freeFuncCall(playEndCall);
|
|
}
|
|
|
|
void CPlayingEngExtInterceptor::SteamAPI_RunCallbacks() {
|
|
CSteamApiRunCallbacksCall* playCall = dynamic_cast<CSteamApiRunCallbacksCall*>(getNextCall(false, false, ECF_STEAM_API_RUN_CALLBACKS, true, __FUNCTION__));
|
|
CSteamApiRunCallbacksCall* playEndCall = dynamic_cast<CSteamApiRunCallbacksCall*>(getNextCall(false, true, ECF_STEAM_API_RUN_CALLBACKS, false, __FUNCTION__));
|
|
|
|
freeFuncCall(playCall); freeFuncCall(playEndCall);
|
|
}
|
|
|
|
void CPlayingEngExtInterceptor::SteamGameServer_Shutdown()
|
|
{
|
|
CSteamGameServerShutdownCall* playCall = dynamic_cast<CSteamGameServerShutdownCall*>(getNextCall(false, false, ECF_STEAMGAMESERVER_SHUTDOWN, true, __FUNCTION__));
|
|
CSteamGameServerShutdownCall* playEndCall = dynamic_cast<CSteamGameServerShutdownCall*>(getNextCall(false, true, ECF_STEAMGAMESERVER_SHUTDOWN, false, __FUNCTION__));
|
|
|
|
freeFuncCall(playCall); freeFuncCall(playEndCall);
|
|
}
|
|
|
|
|
|
void CPlayingEngExtInterceptor::SteamAPI_UnregisterCallback(CCallbackBase *pCallback) {
|
|
int regamedllId = getOrRegisterSteamCallback(pCallback);
|
|
|
|
CSteamApiUnregisterCallbackCall* playCall = dynamic_cast<CSteamApiUnregisterCallbackCall*>(getNextCall(false, false, ECF_STEAM_API_UNREGISTER_CALLBACK, true, __FUNCTION__));
|
|
CSteamApiUnregisterCallbackCall(regamedllId, pCallback).ensureArgsAreEqual(playCall, m_bStrictChecks, __FUNCTION__);
|
|
CSteamApiUnregisterCallbackCall* playEndCall = dynamic_cast<CSteamApiUnregisterCallbackCall*>(getNextCall(false, true, ECF_STEAM_API_UNREGISTER_CALLBACK, false, __FUNCTION__));
|
|
|
|
pCallback->SetFlags(playEndCall->m_OutState.m_nCallbackFlags);
|
|
pCallback->SetICallback(playEndCall->m_OutState.m_iCallback);
|
|
freeFuncCall(playCall); freeFuncCall(playEndCall);
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
CSteamGameServerPlayingWrapper::CSteamGameServerPlayingWrapper(CPlayingEngExtInterceptor* player) {
|
|
m_Player = player;
|
|
m_bStrictChecks = player->m_bStrictChecks;
|
|
}
|
|
|
|
bool CSteamGameServerPlayingWrapper::InitGameServer(uint32 unIP, uint16 usGamePort, uint16 usQueryPort, uint32 unFlags, AppId_t nGameAppId, const char *pchVersionString) {
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return false;
|
|
}
|
|
|
|
void CSteamGameServerPlayingWrapper::SetProduct(const char *pszProduct) {
|
|
CGameServerSetProductCall* playCall = dynamic_cast<CGameServerSetProductCall*>(m_Player->getNextCall(false, false, ECF_GS_SET_PRODUCT, true, __FUNCTION__));
|
|
CGameServerSetProductCall(pszProduct).ensureArgsAreEqual(playCall, m_bStrictChecks, __FUNCTION__);
|
|
CGameServerSetProductCall* playEndCall = dynamic_cast<CGameServerSetProductCall*>(m_Player->getNextCall(false, true, ECF_GS_SET_PRODUCT, false, __FUNCTION__));
|
|
|
|
m_Player->freeFuncCall(playCall); m_Player->freeFuncCall(playEndCall);
|
|
}
|
|
|
|
void CSteamGameServerPlayingWrapper::SetGameDescription(const char *pszGameDescription) {
|
|
CGameServerSetGameDescCall* playCall = dynamic_cast<CGameServerSetGameDescCall*>(m_Player->getNextCall(false, false, ECF_GS_SET_GAME_DESC, true, __FUNCTION__));
|
|
CGameServerSetGameDescCall(pszGameDescription).ensureArgsAreEqual(playCall, m_bStrictChecks, __FUNCTION__);
|
|
CGameServerSetGameDescCall* playEndCall = dynamic_cast<CGameServerSetGameDescCall*>(m_Player->getNextCall(false, true, ECF_GS_SET_GAME_DESC, false, __FUNCTION__));
|
|
|
|
m_Player->freeFuncCall(playCall); m_Player->freeFuncCall(playEndCall);
|
|
}
|
|
|
|
void CSteamGameServerPlayingWrapper::SetModDir(const char *pszModDir) {
|
|
CGameServerSetModDirCall* playCall = dynamic_cast<CGameServerSetModDirCall*>(m_Player->getNextCall(false, false, ECF_GS_SET_GAME_DIR, true, __FUNCTION__));
|
|
CGameServerSetModDirCall(pszModDir).ensureArgsAreEqual(playCall, m_bStrictChecks, __FUNCTION__);
|
|
CGameServerSetModDirCall* playEndCall = dynamic_cast<CGameServerSetModDirCall*>(m_Player->getNextCall(false, true, ECF_GS_SET_GAME_DIR, false, __FUNCTION__));
|
|
|
|
m_Player->freeFuncCall(playCall); m_Player->freeFuncCall(playEndCall);
|
|
}
|
|
|
|
void CSteamGameServerPlayingWrapper::SetDedicatedServer(bool bDedicated) {
|
|
CGameServerSetDedicatedServerCall* playCall = dynamic_cast<CGameServerSetDedicatedServerCall*>(m_Player->getNextCall(false, false, ECF_GS_SET_DEDICATED_SERVER, true, __FUNCTION__));
|
|
CGameServerSetDedicatedServerCall(bDedicated).ensureArgsAreEqual(playCall, m_bStrictChecks, __FUNCTION__);
|
|
CGameServerSetDedicatedServerCall* playEndCall = dynamic_cast<CGameServerSetDedicatedServerCall*>(m_Player->getNextCall(false, true, ECF_GS_SET_DEDICATED_SERVER, false, __FUNCTION__));
|
|
|
|
m_Player->freeFuncCall(playCall); m_Player->freeFuncCall(playEndCall);
|
|
}
|
|
|
|
void CSteamGameServerPlayingWrapper::LogOn(const char *pszAccountName, const char *pszPassword) {
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
}
|
|
|
|
void CSteamGameServerPlayingWrapper::LogOnAnonymous() {
|
|
CGameServerLogOnAnonymousCall* playCall = dynamic_cast<CGameServerLogOnAnonymousCall*>(m_Player->getNextCall(false, false, ECF_GS_LOG_ON_ANONYMOUS, true, __FUNCTION__));
|
|
CGameServerLogOnAnonymousCall* playEndCall = dynamic_cast<CGameServerLogOnAnonymousCall*>(m_Player->getNextCall(false, true, ECF_GS_LOG_ON_ANONYMOUS, false, __FUNCTION__));
|
|
|
|
m_Player->freeFuncCall(playCall); m_Player->freeFuncCall(playEndCall);
|
|
}
|
|
|
|
void CSteamGameServerPlayingWrapper::LogOff() {
|
|
CGameServerLogOffCall* playCall = dynamic_cast<CGameServerLogOffCall*>(m_Player->getNextCall(false, false, ECF_GS_LOGOFF, true, __FUNCTION__));
|
|
CGameServerLogOffCall* playEndCall = dynamic_cast<CGameServerLogOffCall*>(m_Player->getNextCall(false, true, ECF_GS_LOGOFF, false, __FUNCTION__));
|
|
|
|
m_Player->freeFuncCall(playCall); m_Player->freeFuncCall(playEndCall);
|
|
}
|
|
|
|
bool CSteamGameServerPlayingWrapper::BLoggedOn() {
|
|
CGameServerBLoggedOnCall* playCall = dynamic_cast<CGameServerBLoggedOnCall*>(m_Player->getNextCall(false, false, ECF_GS_BLOGGEDON, true, __FUNCTION__));
|
|
CGameServerBLoggedOnCall* playEndCall = dynamic_cast<CGameServerBLoggedOnCall*>(m_Player->getNextCall(false, true, ECF_GS_BLOGGEDON, false, __FUNCTION__));
|
|
|
|
bool res = playEndCall->m_Res;
|
|
m_Player->freeFuncCall(playCall); m_Player->freeFuncCall(playEndCall);
|
|
|
|
return res;
|
|
}
|
|
|
|
bool CSteamGameServerPlayingWrapper::BSecure() {
|
|
CGameServerBSecureCall* playCall = dynamic_cast<CGameServerBSecureCall*>(m_Player->getNextCall(false, false, ECF_GS_BSECURE, true, __FUNCTION__));
|
|
CGameServerBSecureCall* playEndCall = dynamic_cast<CGameServerBSecureCall*>(m_Player->getNextCall(false, true, ECF_GS_BSECURE, false, __FUNCTION__));
|
|
|
|
bool res = playEndCall->m_Res;
|
|
m_Player->freeFuncCall(playCall); m_Player->freeFuncCall(playEndCall);
|
|
|
|
return res;
|
|
}
|
|
|
|
CSteamID CSteamGameServerPlayingWrapper::GetSteamID() {
|
|
CGameServerGetSteamIdCall* playCall = dynamic_cast<CGameServerGetSteamIdCall*>(m_Player->getNextCall(false, false, ECF_GS_GET_STEAM_ID, true, __FUNCTION__));
|
|
CGameServerGetSteamIdCall* playEndCall = dynamic_cast<CGameServerGetSteamIdCall*>(m_Player->getNextCall(false, true, ECF_GS_GET_STEAM_ID, false, __FUNCTION__));
|
|
|
|
CSteamID res(playEndCall->m_SteamId);
|
|
m_Player->freeFuncCall(playCall); m_Player->freeFuncCall(playEndCall);
|
|
|
|
return res;
|
|
}
|
|
|
|
bool CSteamGameServerPlayingWrapper::WasRestartRequested() {
|
|
CGameServerWasRestartRequestedCall* playCall = dynamic_cast<CGameServerWasRestartRequestedCall*>(m_Player->getNextCall(false, false, ECF_GS_WAS_RESTART_REQUESTED, true, __FUNCTION__));
|
|
CGameServerWasRestartRequestedCall* playEndCall = dynamic_cast<CGameServerWasRestartRequestedCall*>(m_Player->getNextCall(false, true, ECF_GS_WAS_RESTART_REQUESTED, false, __FUNCTION__));
|
|
|
|
bool res = playEndCall->m_Result;
|
|
m_Player->freeFuncCall(playCall); m_Player->freeFuncCall(playEndCall);
|
|
|
|
return res;
|
|
}
|
|
|
|
void CSteamGameServerPlayingWrapper::SetMaxPlayerCount(int cPlayersMax) {
|
|
CGameServerSetMaxPlayersCall* playCall = dynamic_cast<CGameServerSetMaxPlayersCall*>(m_Player->getNextCall(false, false, ECF_GS_SET_MAX_PLAYERS_COUNT, true, __FUNCTION__));
|
|
CGameServerSetMaxPlayersCall(cPlayersMax).ensureArgsAreEqual(playCall, m_bStrictChecks, __FUNCTION__);
|
|
CGameServerSetMaxPlayersCall* playEndCall = dynamic_cast<CGameServerSetMaxPlayersCall*>(m_Player->getNextCall(false, true, ECF_GS_SET_MAX_PLAYERS_COUNT, false, __FUNCTION__));
|
|
|
|
m_Player->freeFuncCall(playCall); m_Player->freeFuncCall(playEndCall);
|
|
}
|
|
|
|
void CSteamGameServerPlayingWrapper::SetBotPlayerCount(int cBotplayers) {
|
|
CGameServerSetBotCountCall* playCall = dynamic_cast<CGameServerSetBotCountCall*>(m_Player->getNextCall(false, false, ECF_GS_SET_BOT_PLAYERS_COUNT, true, __FUNCTION__));
|
|
CGameServerSetBotCountCall(cBotplayers).ensureArgsAreEqual(playCall, m_bStrictChecks, __FUNCTION__);
|
|
CGameServerSetBotCountCall* playEndCall = dynamic_cast<CGameServerSetBotCountCall*>(m_Player->getNextCall(false, true, ECF_GS_SET_BOT_PLAYERS_COUNT, false, __FUNCTION__));
|
|
|
|
m_Player->freeFuncCall(playCall); m_Player->freeFuncCall(playEndCall);
|
|
}
|
|
|
|
void CSteamGameServerPlayingWrapper::SetServerName(const char *pszServerName) {
|
|
CGameServerSetServerNameCall* playCall = dynamic_cast<CGameServerSetServerNameCall*>(m_Player->getNextCall(false, false, ECF_GS_SET_SERVER_NAME, true, __FUNCTION__));
|
|
CGameServerSetServerNameCall(pszServerName).ensureArgsAreEqual(playCall, m_bStrictChecks, __FUNCTION__);
|
|
CGameServerSetServerNameCall* playEndCall = dynamic_cast<CGameServerSetServerNameCall*>(m_Player->getNextCall(false, true, ECF_GS_SET_SERVER_NAME, false, __FUNCTION__));
|
|
|
|
m_Player->freeFuncCall(playCall); m_Player->freeFuncCall(playEndCall);
|
|
}
|
|
|
|
void CSteamGameServerPlayingWrapper::SetMapName(const char *pszMapName) {
|
|
CGameServerSetMapNameCall* playCall = dynamic_cast<CGameServerSetMapNameCall*>(m_Player->getNextCall(false, false, ECF_GS_SET_MAP_NAME, true, __FUNCTION__));
|
|
CGameServerSetMapNameCall(pszMapName).ensureArgsAreEqual(playCall, m_bStrictChecks, __FUNCTION__);
|
|
CGameServerSetMapNameCall* playEndCall = dynamic_cast<CGameServerSetMapNameCall*>(m_Player->getNextCall(false, true, ECF_GS_SET_MAP_NAME, false, __FUNCTION__));
|
|
|
|
m_Player->freeFuncCall(playCall); m_Player->freeFuncCall(playEndCall);
|
|
}
|
|
|
|
void CSteamGameServerPlayingWrapper::SetPasswordProtected(bool bPasswordProtected) {
|
|
CGameServerSetPasswordProtectedCall* playCall = dynamic_cast<CGameServerSetPasswordProtectedCall*>(m_Player->getNextCall(false, false, ECF_GS_SET_PASSWORD_PROTECTED, true, __FUNCTION__));
|
|
CGameServerSetPasswordProtectedCall(bPasswordProtected).ensureArgsAreEqual(playCall, m_bStrictChecks, __FUNCTION__);
|
|
CGameServerSetPasswordProtectedCall* playEndCall = dynamic_cast<CGameServerSetPasswordProtectedCall*>(m_Player->getNextCall(false, true, ECF_GS_SET_PASSWORD_PROTECTED, false, __FUNCTION__));
|
|
|
|
m_Player->freeFuncCall(playCall); m_Player->freeFuncCall(playEndCall);
|
|
}
|
|
|
|
void CSteamGameServerPlayingWrapper::SetSpectatorPort(uint16 unSpectatorPort) {
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
}
|
|
|
|
void CSteamGameServerPlayingWrapper::SetSpectatorServerName(const char *pszSpectatorServerName) {
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
}
|
|
|
|
void CSteamGameServerPlayingWrapper::ClearAllKeyValues() {
|
|
CGameServerClearAllKVsCall* playCall = dynamic_cast<CGameServerClearAllKVsCall*>(m_Player->getNextCall(false, false, ECF_GS_CLEAR_ALL_KEY_VALUES, true, __FUNCTION__));
|
|
CGameServerClearAllKVsCall* playEndCall = dynamic_cast<CGameServerClearAllKVsCall*>(m_Player->getNextCall(false, true, ECF_GS_CLEAR_ALL_KEY_VALUES, false, __FUNCTION__));
|
|
|
|
m_Player->freeFuncCall(playCall); m_Player->freeFuncCall(playEndCall);
|
|
}
|
|
|
|
void CSteamGameServerPlayingWrapper::SetKeyValue(const char *pKey, const char *pValue) {
|
|
CGameServerSetKeyValueCall* playCall = dynamic_cast<CGameServerSetKeyValueCall*>(m_Player->getNextCall(false, false, ECF_GS_SET_KEY_VALUE, true, __FUNCTION__));
|
|
CGameServerSetKeyValueCall(pKey, pValue).ensureArgsAreEqual(playCall, m_bStrictChecks, __FUNCTION__);
|
|
CGameServerSetKeyValueCall* playEndCall = dynamic_cast<CGameServerSetKeyValueCall*>(m_Player->getNextCall(false, true, ECF_GS_SET_KEY_VALUE, false, __FUNCTION__));
|
|
|
|
m_Player->freeFuncCall(playCall); m_Player->freeFuncCall(playEndCall);
|
|
}
|
|
|
|
void CSteamGameServerPlayingWrapper::SetGameTags(const char *pchGameTags) {
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
}
|
|
|
|
void CSteamGameServerPlayingWrapper::SetGameData(const char *pchGameData) {
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
}
|
|
|
|
void CSteamGameServerPlayingWrapper::SetRegion(const char *pszRegion) {
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
}
|
|
|
|
bool CSteamGameServerPlayingWrapper::SendUserConnectAndAuthenticate(uint32 unIPClient, const void *pvAuthBlob, uint32 cubAuthBlobSize, CSteamID *pSteamIDUser) {
|
|
CGameServerSendUserConnectAndAuthenticateCall* playCall = dynamic_cast<CGameServerSendUserConnectAndAuthenticateCall*>(m_Player->getNextCall(false, false, ECF_GS_SEND_USER_CONNECT_AND_AUTHENTICATE, true, __FUNCTION__));
|
|
CGameServerSendUserConnectAndAuthenticateCall(unIPClient, pvAuthBlob, cubAuthBlobSize).ensureArgsAreEqual(playCall, m_bStrictChecks, __FUNCTION__);
|
|
CGameServerSendUserConnectAndAuthenticateCall* playEndCall = dynamic_cast<CGameServerSendUserConnectAndAuthenticateCall*>(m_Player->getNextCall(false, true, ECF_GS_SEND_USER_CONNECT_AND_AUTHENTICATE, false, __FUNCTION__));
|
|
|
|
bool res = playEndCall->m_Res;
|
|
*pSteamIDUser = CSteamID(playEndCall->m_OutSteamId);
|
|
m_Player->freeFuncCall(playCall); m_Player->freeFuncCall(playEndCall);
|
|
|
|
return res;
|
|
}
|
|
|
|
CSteamID CSteamGameServerPlayingWrapper::CreateUnauthenticatedUserConnection() {
|
|
CGameServerCreateUnauthUserConnectionCall* playCall = dynamic_cast<CGameServerCreateUnauthUserConnectionCall*>(m_Player->getNextCall(false, false, ECF_GS_CREATE_UNAUTH_USER_CONNECTION, true, __FUNCTION__));
|
|
CGameServerCreateUnauthUserConnectionCall* playEndCall = dynamic_cast<CGameServerCreateUnauthUserConnectionCall*>(m_Player->getNextCall(false, true, ECF_GS_CREATE_UNAUTH_USER_CONNECTION, false, __FUNCTION__));
|
|
|
|
CSteamID res = playEndCall->m_SteamId;
|
|
m_Player->freeFuncCall(playCall); m_Player->freeFuncCall(playEndCall);
|
|
|
|
return res;
|
|
}
|
|
|
|
void CSteamGameServerPlayingWrapper::SendUserDisconnect(CSteamID steamIDUser) {
|
|
CGameServerSendUserDisconnectCall* playCall = dynamic_cast<CGameServerSendUserDisconnectCall*>(m_Player->getNextCall(false, false, ECF_GS_SEND_USER_DISCONNECT, true, __FUNCTION__));
|
|
CGameServerSendUserDisconnectCall(steamIDUser).ensureArgsAreEqual(playCall, m_bStrictChecks, __FUNCTION__);
|
|
CGameServerSendUserDisconnectCall* playEndCall = dynamic_cast<CGameServerSendUserDisconnectCall*>(m_Player->getNextCall(false, true, ECF_GS_SEND_USER_DISCONNECT, false, __FUNCTION__));
|
|
|
|
m_Player->freeFuncCall(playCall); m_Player->freeFuncCall(playEndCall);
|
|
}
|
|
|
|
bool CSteamGameServerPlayingWrapper::BUpdateUserData(CSteamID steamIDUser, const char *pchPlayerName, uint32 uScore) {
|
|
CGameServerBUpdateUserDataCall* playCall = dynamic_cast<CGameServerBUpdateUserDataCall*>(m_Player->getNextCall(false, false, ECF_GS_BUPDATE_USER_DATA, true, __FUNCTION__));
|
|
CGameServerBUpdateUserDataCall(steamIDUser, pchPlayerName, uScore).ensureArgsAreEqual(playCall, m_bStrictChecks, __FUNCTION__);
|
|
CGameServerBUpdateUserDataCall* playEndCall = dynamic_cast<CGameServerBUpdateUserDataCall*>(m_Player->getNextCall(false, true, ECF_GS_BUPDATE_USER_DATA, false, __FUNCTION__));
|
|
|
|
bool res = playEndCall->m_Res;
|
|
m_Player->freeFuncCall(playCall); m_Player->freeFuncCall(playEndCall);
|
|
|
|
return res;
|
|
}
|
|
|
|
HAuthTicket CSteamGameServerPlayingWrapper::GetAuthSessionTicket(void *pTicket, int cbMaxTicket, uint32 *pcbTicket) {
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return k_HAuthTicketInvalid;
|
|
}
|
|
|
|
EBeginAuthSessionResult CSteamGameServerPlayingWrapper::BeginAuthSession(const void *pAuthTicket, int cbAuthTicket, CSteamID steamID) {
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return k_EBeginAuthSessionResultInvalidTicket;
|
|
}
|
|
|
|
void CSteamGameServerPlayingWrapper::EndAuthSession(CSteamID steamID) {
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
}
|
|
|
|
void CSteamGameServerPlayingWrapper::CancelAuthTicket(HAuthTicket hAuthTicket) {
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
}
|
|
|
|
EUserHasLicenseForAppResult CSteamGameServerPlayingWrapper::UserHasLicenseForApp(CSteamID steamID, AppId_t appID) {
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return k_EUserHasLicenseResultHasLicense;
|
|
}
|
|
|
|
bool CSteamGameServerPlayingWrapper::RequestUserGroupStatus(CSteamID steamIDUser, CSteamID steamIDGroup) {
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return false;
|
|
}
|
|
|
|
void CSteamGameServerPlayingWrapper::GetGameplayStats() {
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
}
|
|
|
|
SteamAPICall_t CSteamGameServerPlayingWrapper::GetServerReputation() {
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return k_uAPICallInvalid;
|
|
}
|
|
|
|
uint32 CSteamGameServerPlayingWrapper::GetPublicIP() {
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return 0;
|
|
}
|
|
|
|
bool CSteamGameServerPlayingWrapper::HandleIncomingPacket(const void *pData, int cbData, uint32 srcIP, uint16 srcPort) {
|
|
CGameServerHandleIncomingPacketCall* playCall = dynamic_cast<CGameServerHandleIncomingPacketCall*>(m_Player->getNextCall(false, false, ECF_GS_HANDLE_INCOMING_PACKET, true, __FUNCTION__));
|
|
CGameServerHandleIncomingPacketCall(pData, cbData, srcIP, srcPort).ensureArgsAreEqual(playCall, m_bStrictChecks, __FUNCTION__);
|
|
CGameServerHandleIncomingPacketCall* playEndCall = dynamic_cast<CGameServerHandleIncomingPacketCall*>(m_Player->getNextCall(false, true, ECF_GS_HANDLE_INCOMING_PACKET, false, __FUNCTION__));
|
|
|
|
bool res = playEndCall->m_Res;
|
|
m_Player->freeFuncCall(playCall); m_Player->freeFuncCall(playEndCall);
|
|
|
|
return res;
|
|
}
|
|
|
|
int CSteamGameServerPlayingWrapper::GetNextOutgoingPacket(void *pOut, int cbMaxOut, uint32 *pNetAdr, uint16 *pPort) {
|
|
CGameServerGetNextOutgoingPacketCall* playCall = dynamic_cast<CGameServerGetNextOutgoingPacketCall*>(m_Player->getNextCall(false, false, ECF_GS_GET_NEXT_OUTGOING_PACKET, true, __FUNCTION__));
|
|
CGameServerGetNextOutgoingPacketCall(cbMaxOut).ensureArgsAreEqual(playCall, m_bStrictChecks, __FUNCTION__);
|
|
CGameServerGetNextOutgoingPacketCall* playEndCall = dynamic_cast<CGameServerGetNextOutgoingPacketCall*>(m_Player->getNextCall(false, true, ECF_GS_GET_NEXT_OUTGOING_PACKET, false, __FUNCTION__));
|
|
|
|
int res = playEndCall->m_Result;
|
|
*pNetAdr = playEndCall->m_Addr;
|
|
*pPort = playEndCall->m_Port;
|
|
memcpy(pOut, playEndCall->m_Buf, playEndCall->m_BufLen);
|
|
m_Player->freeFuncCall(playCall); m_Player->freeFuncCall(playEndCall);
|
|
|
|
return res;
|
|
}
|
|
|
|
void CSteamGameServerPlayingWrapper::EnableHeartbeats(bool bActive) {
|
|
CGameServerEnableHeartbeatsCall* playCall = dynamic_cast<CGameServerEnableHeartbeatsCall*>(m_Player->getNextCall(false, false, ECF_GS_ENABLE_HEARTBEATS, true, __FUNCTION__));
|
|
CGameServerEnableHeartbeatsCall(bActive).ensureArgsAreEqual(playCall, m_bStrictChecks, __FUNCTION__);
|
|
CGameServerEnableHeartbeatsCall* playEndCall = dynamic_cast<CGameServerEnableHeartbeatsCall*>(m_Player->getNextCall(false, true, ECF_GS_ENABLE_HEARTBEATS, false, __FUNCTION__));
|
|
|
|
m_Player->freeFuncCall(playCall); m_Player->freeFuncCall(playEndCall);
|
|
}
|
|
|
|
void CSteamGameServerPlayingWrapper::SetHeartbeatInterval(int iHeartbeatInterval) {
|
|
CGameServerSetHeartbeatIntervalCall* playCall = dynamic_cast<CGameServerSetHeartbeatIntervalCall*>(m_Player->getNextCall(false, false, ECF_GS_SET_HEARTBEATS_INTERVAL, true, __FUNCTION__));
|
|
CGameServerSetHeartbeatIntervalCall(iHeartbeatInterval).ensureArgsAreEqual(playCall, m_bStrictChecks, __FUNCTION__);
|
|
CGameServerSetHeartbeatIntervalCall* playEndCall = dynamic_cast<CGameServerSetHeartbeatIntervalCall*>(m_Player->getNextCall(false, true, ECF_GS_SET_HEARTBEATS_INTERVAL, false, __FUNCTION__));
|
|
|
|
m_Player->freeFuncCall(playCall); m_Player->freeFuncCall(playEndCall);
|
|
}
|
|
|
|
void CSteamGameServerPlayingWrapper::ForceHeartbeat() {
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
}
|
|
|
|
SteamAPICall_t CSteamGameServerPlayingWrapper::AssociateWithClan(CSteamID steamIDClan) {
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return k_uAPICallInvalid;
|
|
}
|
|
|
|
SteamAPICall_t CSteamGameServerPlayingWrapper::ComputeNewPlayerCompatibility(CSteamID steamIDNewPlayer) {
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return k_uAPICallInvalid;
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
CSteamAppsPlayingWrapper::CSteamAppsPlayingWrapper(CPlayingEngExtInterceptor* player) {
|
|
m_Player = player;
|
|
m_bStrictChecks = player->m_bStrictChecks;
|
|
}
|
|
|
|
bool CSteamAppsPlayingWrapper::BIsSubscribed() {
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return false;
|
|
}
|
|
|
|
bool CSteamAppsPlayingWrapper::BIsLowViolence() {
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return false;
|
|
}
|
|
|
|
bool CSteamAppsPlayingWrapper::BIsCybercafe() {
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return false;
|
|
}
|
|
|
|
bool CSteamAppsPlayingWrapper::BIsVACBanned() {
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return false;
|
|
}
|
|
|
|
const char* CSteamAppsPlayingWrapper::GetCurrentGameLanguage() {
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return "";
|
|
}
|
|
|
|
const char* CSteamAppsPlayingWrapper::GetAvailableGameLanguages() {
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return "";
|
|
}
|
|
|
|
bool CSteamAppsPlayingWrapper::BIsSubscribedApp(AppId_t appID) {
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return false;
|
|
}
|
|
|
|
bool CSteamAppsPlayingWrapper::BIsDlcInstalled(AppId_t appID) {
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return false;
|
|
}
|
|
|
|
uint32 CSteamAppsPlayingWrapper::GetEarliestPurchaseUnixTime(AppId_t nAppID) {
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return 0;
|
|
}
|
|
|
|
bool CSteamAppsPlayingWrapper::BIsSubscribedFromFreeWeekend() {
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return false;
|
|
}
|
|
|
|
int CSteamAppsPlayingWrapper::GetDLCCount() {
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return 0;
|
|
}
|
|
|
|
bool CSteamAppsPlayingWrapper::BGetDLCDataByIndex(int iDLC, AppId_t *pAppID, bool *pbAvailable, char *pchName, int cchNameBufferSize) {
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return false;
|
|
}
|
|
|
|
void CSteamAppsPlayingWrapper::InstallDLC(AppId_t nAppID) {
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
}
|
|
|
|
void CSteamAppsPlayingWrapper::UninstallDLC(AppId_t nAppID) {
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
}
|
|
|
|
void CSteamAppsPlayingWrapper::RequestAppProofOfPurchaseKey(AppId_t nAppID) {
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
}
|
|
|
|
bool CSteamAppsPlayingWrapper::GetCurrentBetaName(char *pchName, int cchNameBufferSize) {
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return false;
|
|
}
|
|
|
|
bool CSteamAppsPlayingWrapper::MarkContentCorrupt(bool bMissingFilesOnly) {
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return false;
|
|
}
|
|
|
|
uint32 CSteamAppsPlayingWrapper::GetInstalledDepots(DepotId_t *pvecDepots, uint32 cMaxDepots) {
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return 0;
|
|
}
|
|
|
|
uint32 CSteamAppsPlayingWrapper::GetAppInstallDir(AppId_t appID, char *pchFolder, uint32 cchFolderBufferSize) {
|
|
regamedll_syserror("%s: not implemented", __FUNCTION__);
|
|
return 0;
|
|
}
|