Use new GetIServer call and updated IServerTools calls on Blade Symphony.
This commit is contained in:
parent
68c8857410
commit
9e083ec668
@ -183,6 +183,7 @@ void CHalfLife2::InitLogicalEntData()
|
|||||||
|| SOURCE_ENGINE == SE_CSS \
|
|| SOURCE_ENGINE == SE_CSS \
|
||||||
|| SOURCE_ENGINE == SE_SDK2013 \
|
|| SOURCE_ENGINE == SE_SDK2013 \
|
||||||
|| SOURCE_ENGINE == SE_BMS \
|
|| SOURCE_ENGINE == SE_BMS \
|
||||||
|
|| SOURCE_ENGINE == SE_BLADE \
|
||||||
|| SOURCE_ENGINE == SE_NUCLEARDAWN
|
|| SOURCE_ENGINE == SE_NUCLEARDAWN
|
||||||
|
|
||||||
if (g_SMAPI->GetServerFactory(false)("VSERVERTOOLS003", nullptr))
|
if (g_SMAPI->GetServerFactory(false)("VSERVERTOOLS003", nullptr))
|
||||||
|
@ -2066,7 +2066,8 @@ void CPlayer::Initialize(const char *name, const char *ip, edict_t *pEntity)
|
|||||||
|| SOURCE_ENGINE == SE_HL2DM \
|
|| SOURCE_ENGINE == SE_HL2DM \
|
||||||
|| SOURCE_ENGINE == SE_BMS \
|
|| SOURCE_ENGINE == SE_BMS \
|
||||||
|| SOURCE_ENGINE == SE_INSURGENCY \
|
|| SOURCE_ENGINE == SE_INSURGENCY \
|
||||||
|| SOURCE_ENGINE == SE_DOI
|
|| SOURCE_ENGINE == SE_DOI \
|
||||||
|
|| SOURCE_ENGINE == SE_BLADE
|
||||||
m_pIClient = engine->GetIServer()->GetClient(m_iIndex - 1);
|
m_pIClient = engine->GetIServer()->GetClient(m_iIndex - 1);
|
||||||
#else
|
#else
|
||||||
#if SOURCE_ENGINE == SE_SDK2013
|
#if SOURCE_ENGINE == SE_SDK2013
|
||||||
|
@ -291,6 +291,7 @@ void TempEntityManager::Initialize()
|
|||||||
|| SOURCE_ENGINE == SE_CSS \
|
|| SOURCE_ENGINE == SE_CSS \
|
||||||
|| SOURCE_ENGINE == SE_SDK2013 \
|
|| SOURCE_ENGINE == SE_SDK2013 \
|
||||||
|| SOURCE_ENGINE == SE_BMS \
|
|| SOURCE_ENGINE == SE_BMS \
|
||||||
|
|| SOURCE_ENGINE == SE_BLADE \
|
||||||
|| SOURCE_ENGINE == SE_NUCLEARDAWN
|
|| SOURCE_ENGINE == SE_NUCLEARDAWN
|
||||||
|
|
||||||
if (g_SMAPI->GetServerFactory(false)("VSERVERTOOLS003", nullptr))
|
if (g_SMAPI->GetServerFactory(false)("VSERVERTOOLS003", nullptr))
|
||||||
|
@ -229,11 +229,12 @@ void GetIServer()
|
|||||||
|| SOURCE_ENGINE == SE_SDK2013 \
|
|| SOURCE_ENGINE == SE_SDK2013 \
|
||||||
|| SOURCE_ENGINE == SE_BMS \
|
|| SOURCE_ENGINE == SE_BMS \
|
||||||
|| SOURCE_ENGINE == SE_DOI \
|
|| SOURCE_ENGINE == SE_DOI \
|
||||||
|
|| SOURCE_ENGINE == SE_BLADE \
|
||||||
|| SOURCE_ENGINE == SE_INSURGENCY
|
|| SOURCE_ENGINE == SE_INSURGENCY
|
||||||
|
|
||||||
#if SOURCE_ENGINE != SE_INSURGENCY && SOURCE_ENGINE != SE_DOI
|
#if SOURCE_ENGINE == SE_SDK2013
|
||||||
if (g_SMAPI->GetEngineFactory(false)("VEngineServer022", nullptr))
|
if (g_SMAPI->GetEngineFactory(false)("VEngineServer022", nullptr))
|
||||||
#endif // !SE_INSURGENCY
|
#endif // SE_SDK2013
|
||||||
{
|
{
|
||||||
iserver = engine->GetIServer();
|
iserver = engine->GetIServer();
|
||||||
return;
|
return;
|
||||||
|
@ -617,6 +617,7 @@ CEntityFactoryDictionary *GetEntityFactoryDictionary()
|
|||||||
|| SOURCE_ENGINE == SE_HL2DM \
|
|| SOURCE_ENGINE == SE_HL2DM \
|
||||||
|| SOURCE_ENGINE == SE_SDK2013 \
|
|| SOURCE_ENGINE == SE_SDK2013 \
|
||||||
|| SOURCE_ENGINE == SE_BMS \
|
|| SOURCE_ENGINE == SE_BMS \
|
||||||
|
|| SOURCE_ENGINE == SE_BLADE \
|
||||||
|| SOURCE_ENGINE == SE_NUCLEARDAWN
|
|| SOURCE_ENGINE == SE_NUCLEARDAWN
|
||||||
dict = (CEntityFactoryDictionary *) servertools->GetEntityFactoryDictionary();
|
dict = (CEntityFactoryDictionary *) servertools->GetEntityFactoryDictionary();
|
||||||
#else
|
#else
|
||||||
|
@ -910,6 +910,7 @@ static cell_t FindEntityByClassname(IPluginContext *pContext, const cell_t *para
|
|||||||
|| SOURCE_ENGINE == SE_CSS \
|
|| SOURCE_ENGINE == SE_CSS \
|
||||||
|| SOURCE_ENGINE == SE_BMS \
|
|| SOURCE_ENGINE == SE_BMS \
|
||||||
|| SOURCE_ENGINE == SE_SDK2013 \
|
|| SOURCE_ENGINE == SE_SDK2013 \
|
||||||
|
|| SOURCE_ENGINE == SE_BLADE \
|
||||||
|| SOURCE_ENGINE == SE_NUCLEARDAWN
|
|| SOURCE_ENGINE == SE_NUCLEARDAWN
|
||||||
|
|
||||||
static bool bHasServerTools3 = !!g_SMAPI->GetServerFactory(false)("VSERVERTOOLS003", nullptr);
|
static bool bHasServerTools3 = !!g_SMAPI->GetServerFactory(false)("VSERVERTOOLS003", nullptr);
|
||||||
|
@ -33,11 +33,6 @@
|
|||||||
{
|
{
|
||||||
"Offsets"
|
"Offsets"
|
||||||
{
|
{
|
||||||
/* Offset into CBaseTempEntity constructor */
|
|
||||||
"s_pTempEntities"
|
|
||||||
{
|
|
||||||
"windows" "19"
|
|
||||||
}
|
|
||||||
"GetTEName"
|
"GetTEName"
|
||||||
{
|
{
|
||||||
"windows" "4"
|
"windows" "4"
|
||||||
@ -60,125 +55,6 @@
|
|||||||
"mac64" "0"
|
"mac64" "0"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
"Signatures"
|
|
||||||
{
|
|
||||||
"CBaseTempEntity"
|
|
||||||
{
|
|
||||||
"library" "server"
|
|
||||||
"windows" "\x55\x8B\xEC\x8B\xC1\x8B\x4D\x08\xC7\x00\x2A\x2A\x2A\x2A\x89\x48\x2A\x8B"
|
|
||||||
}
|
|
||||||
"s_pTempEntities"
|
|
||||||
{
|
|
||||||
"library" "server"
|
|
||||||
"linux" "@_ZN15CBaseTempEntity15s_pTempEntitiesE"
|
|
||||||
"mac" "@_ZN15CBaseTempEntity15s_pTempEntitiesE"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* CGlobalEntityList */
|
|
||||||
"#default"
|
|
||||||
{
|
|
||||||
"Signatures"
|
|
||||||
{
|
|
||||||
/* Functions in CGlobalEntityList */
|
|
||||||
"FindEntityByClassname"
|
|
||||||
{
|
|
||||||
"library" "server"
|
|
||||||
"windows" "\x55\x8B\xEC\x53\x56\x8B\xF1\x8B\x4D\x08\x57\x85\xC9\x74\x2A\x8B\x01\x8B\x50\x08\xFF\xD2\x8B\x00\x83\xF8\xFF\x75\x2A\xB8\xFF\x1F\x00\x00\x8D\x04\x40\x8B\x74\xC6\x2A\xEB"
|
|
||||||
"linux" "@_ZN17CGlobalEntityList21FindEntityByClassnameEP11CBaseEntityPKc"
|
|
||||||
"mac" "@_ZN17CGlobalEntityList21FindEntityByClassnameEP11CBaseEntityPKc"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* General GameRules */
|
|
||||||
"#default"
|
|
||||||
{
|
|
||||||
"Offsets"
|
|
||||||
{
|
|
||||||
/* Offset into CreateGameRulesObject */
|
|
||||||
"g_pGameRules"
|
|
||||||
{
|
|
||||||
"windows" "2"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
"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"
|
|
||||||
}
|
|
||||||
"g_pGameRules"
|
|
||||||
{
|
|
||||||
"library" "server"
|
|
||||||
"linux" "@g_pGameRules"
|
|
||||||
"mac" "@g_pGameRules"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* IServer interface pointer */
|
|
||||||
"#default"
|
|
||||||
{
|
|
||||||
"Keys"
|
|
||||||
{
|
|
||||||
/* Signature for the beginning of IVEngineServer::CreateFakeClient.
|
|
||||||
*
|
|
||||||
* 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\x2A\x2A\x2A\x2A\x85\xC0\x75"
|
|
||||||
}
|
|
||||||
|
|
||||||
"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 */
|
/* CBaseEntityOutput::FireOutput */
|
||||||
|
Loading…
Reference in New Issue
Block a user