/** * Do not edit this file. Any changes will be overwritten by the gamedata * updater or by upgrading your SourceMod install. * * To override data in this file, create a subdirectory named "custom" and * place your own gamedata file(s) inside of it. Such files will be parsed * after SM's own. * * For more information, see http://wiki.alliedmods.net/Gamedata_Updating_(SourceMod) */ "Games" { /* General Temp Entities */ "#default" { "#supported" { "game" "synergy" "game" "nmrih" "game" "empires" "game" "fof" } "Offsets" { /* Offset into CBaseTempEntity constructor */ "s_pTempEntities" { "windows" "19" "linux" "20" } "GetTEName" { "windows" "4" "linux" "4" "mac" "4" } "GetTENext" { "windows" "8" "linux" "8" "mac" "8" } "TE_GetServerClass" { "windows" "0" "linux" "0" "mac" "0" } } "Signatures" { "CBaseTempEntity" { "library" "server" "windows" "\x55\x8B\xEC\x8B\xC1\x8B\x4D\x2A\xC7\x00\x2A\x2A\x2A\x2A\x89\x48" "linux" "\x55\x89\xE5\x8B\x45\x08\x8B\x55\x0C\xC7\x2A\x2A\x2A\x2A\x2A\x89\x50\x04\x8B\x15\x2A\x2A\x2A\x2A\xA3" } "s_pTempEntities" { "library" "server" "mac" "@_ZN15CBaseTempEntity15s_pTempEntitiesE" } } } /* CGlobalEntityList */ "#default" { "#supported" { "game" "synergy" "game" "nmrih" "game" "empires" "game" "fof" } "Signatures" { /* Functions in CGlobalEntityList */ "FindEntityByClassname" { "library" "server" "windows" "\x55\x8B\xEC\x53\x56\x8B\xF1\x8B\x4D\x2A\x57\x85\xC9\x74\x2A\x8B\x01\x8B\x50\x2A\xFF\xD2\x8B\x00\x25\xFF\x0F\x00\x00\x40\x03\xC0\x8B\x3C\xC6\xEB\x2A\x8B" "linux" "\x55\x89\xE5\x57\x56\x53\x83\x2A\x2A\x8B\x2A\x2A\x8B\x2A\x2A\x85\xC0\x74\x2A\x8B\x10\x89\x04\x24\xFF\x52\x0C\x8B\x55\x08\x8B\x00\x25\xFF\x0F\x00\x00\xC1\xE0\x04\x8B\x2A\x2A\x2A\xEB\x15\x66" "mac" "@_ZN17CGlobalEntityList21FindEntityByClassnameEP11CBaseEntityPKc" } } } /* General GameRules */ "#default" { "#supported" { "game" "synergy" "game" "nmrih" "game" "empires" "game" "fof" } "Offsets" { /* Offset into CreateGameRulesObject */ "g_pGameRules" { "windows" "2" "linux" "1" } } "Signatures" { /* This signature sometimes has multiple matches, but this * does not matter as g_pGameRules is involved in all of them. * The same g_pGameRules offset applies to each match. * * Sometimes this block of bytes is at the beginning of the static * CreateGameRulesObject function and sometimes it is in the middle * of an entirely different function. This depends on the game. */ "CreateGameRulesObject" { "library" "server" "windows" "\x8B\x0D\x2A\x2A\x2A\x2A\x85\xC9\x74\x2A\x8B\x01\x8B\x50\x2A\x6A\x01\xFF\xD2" "linux" "\xA1\x2A\x2A\x2A\x2A\x8B\x5D\x08\x85\xC0\x74\x08\x8B\x10\x89" } "g_pGameRules" { "library" "server" "mac" "@g_pGameRules" } } } /* IServer interface pointer */ "#default" { "Keys" { /* Signature for the beginning of IVEngineServer::CreateFakeClientEx. * * The engine binary is not actually scanned in order to look for * this. SourceHook is used to used to determine the address of the * function and this signature is used to verify that it contains * the expected code. A pointer to sv (IServer interface) is used * here. */ "CreateFakeClient_Windows" "\x55\x8B\xEC\x8B\x2A\x2A\x50\xB9\x2A\x2A\x2A\x2A\xE8" } "Offsets" { /* Offset into IVEngineServer::CreateFakeClient */ "sv" { "windows" "8" } } "Signatures" { /* CBaseServer object for IServer interface */ "sv" { "library" "engine" "linux" "@sv" "mac" "@sv" } } } /* EntityFactoryDictionary function */ "#default" { "Signatures" { "EntityFactory" { "library" "server" "windows" "\xB8\x01\x00\x00\x00\x84\x2A\x2A\x2A\x2A\x2A\x75\x1D\x09\x2A\x2A\x2A\x2A\x2A\xB9\x2A\x2A\x2A\x2A\xE8\x2A\x2A\x2A\x2A\x68\x2A\x2A\x2A\x2A\xE8\x2A\x2A\x2A\x2A\x83\xC4\x04\xB8\x2A\x2A\x2A\x2A\xC3" "linux" "@_Z23EntityFactoryDictionaryv" "mac" "@_Z23EntityFactoryDictionaryv" } } } /* CBaseEntityOutput::FireOutput */ "#default" { "#supported" { "game" "synergy" "game" "empires" "game" "fof" } "Signatures" { "FireOutput" { "library" "server" "windows" "\x55\x8B\xEC\x81\x2A\x2A\x2A\x2A\x2A\xA1\x2A\x2A\x2A\x2A\x33\xC5\x89\x45\x2A\x8B\x45\x2A\x53\x56\x8B\x2A\x2A\x57\x8B\x2A\x2A\x89\x2A\x2A\x2A\x2A\x2A\x89\x2A\x2A\x2A\x2A\x2A\x89\x2A\x2A\x2A\x2A\x2A\xC7" "linux" "\x55\x89\xE5\x57\x56\x53\x81\xEC\x2A\x2A\x2A\x2A\x8B\x2A\x2A\x65\x2A\x2A\x2A\x2A\x2A\x89\x2A\x2A\x31\xC0\x8B\x2A\x2A\x8B\x2A\x2A\x8B\x2A\x2A\x8B\x2A\x2A\x89\x2A\x2A\x2A\x2A\x2A\x89\x2A\x2A\x2A\x2A\x2A\x89" "mac" "@_ZN17CBaseEntityOutput10FireOutputE9variant_tP11CBaseEntityS2_f" } } } /* SetUserInfo data */ "#default" { "Offsets" { /** * CBaseClient::SetUserCVar(char const*,char const*); * Linux offset straight from VTable dump. * Windows offset is crazy. Found the windows SetName function using string "(%d)%-0.*s" * Cross referenced back to the vtable and counted manually (SetUserCvar is 1 higher, offsets start from 1) */ "SetUserCvar" { "windows" "18" "linux" "58" "mac" "58" } /** * Offset into CBaseClient - Used by CBaseServer::UpdateUserSettings to determine when changes have been made. * Find CBaseClient::UpdateUserSettings (strings "net_maxroutable", "cl_updaterate" etc) and the offset is set to 0 near the end. * Linux: mov byte ptr [esi+98h], 0 * Win: mov byte ptr [esi+0A4h], 0 */ "InfoChanged" { "windows" "140" "linux" "140" "mac" "140" } } } }