From 687db96b38112ba455d21fab5515e94600236942 Mon Sep 17 00:00:00 2001 From: Ruben Gonzalez Date: Wed, 4 Oct 2017 18:20:06 -0400 Subject: [PATCH] Make CS:GO specific natives exist only on CS:GO --- extensions/cstrike/natives.cpp | 73 +++++++++++++--------------------- 1 file changed, 27 insertions(+), 46 deletions(-) diff --git a/extensions/cstrike/natives.cpp b/extensions/cstrike/natives.cpp index 626347cb..e0ed38bb 100644 --- a/extensions/cstrike/natives.cpp +++ b/extensions/cstrike/natives.cpp @@ -807,42 +807,6 @@ static cell_t CS_GetMVPCount(IPluginContext *pContext, const cell_t *params) return GetPlayerVar(pContext, params, "MVPs"); } -static cell_t CS_SetClientContributionScore(IPluginContext *pContext, const cell_t *params) -{ -#if SOURCE_ENGINE == SE_CSGO - return SetPlayerVar(pContext, params, "CScore"); -#else - return pContext->ThrowNativeError("SetClientContributionScore is not supported on this game"); -#endif -} - -static cell_t CS_GetClientContributionScore(IPluginContext *pContext, const cell_t *params) -{ -#if SOURCE_ENGINE == SE_CSGO - return GetPlayerVar(pContext, params, "CScore"); -#else - return pContext->ThrowNativeError("GetClientContributionScore is not supported on this game"); -#endif -} - -static cell_t CS_SetClientAssists(IPluginContext *pContext, const cell_t *params) -{ -#if SOURCE_ENGINE == SE_CSGO - return SetPlayerVar(pContext, params, "Assists"); -#else - return pContext->ThrowNativeError("SetClientAssists is not supported on this game"); -#endif -} - -static cell_t CS_GetClientAssists(IPluginContext *pContext, const cell_t *params) -{ -#if SOURCE_ENGINE == SE_CSGO - return GetPlayerVar(pContext, params, "Assists"); -#else - return pContext->ThrowNativeError("GetClientAssists is not supported on this game"); -#endif -} - static cell_t CS_UpdateClientModel(IPluginContext *pContext, const cell_t *params) { static ICallWrapper *pWrapper = NULL; @@ -863,33 +827,48 @@ static cell_t CS_UpdateClientModel(IPluginContext *pContext, const cell_t *param return 1; } +//CS:GO only natives below this. +#if SOURCE_ENGINE == SE_CSGO +static cell_t CS_SetClientContributionScore(IPluginContext *pContext, const cell_t *params) +{ + return SetPlayerVar(pContext, params, "CScore"); +} + +static cell_t CS_GetClientContributionScore(IPluginContext *pContext, const cell_t *params) +{ + return GetPlayerVar(pContext, params, "CScore"); +} + +static cell_t CS_SetClientAssists(IPluginContext *pContext, const cell_t *params) +{ + return SetPlayerVar(pContext, params, "Assists"); +} + +static cell_t CS_GetClientAssists(IPluginContext *pContext, const cell_t *params) +{ + return GetPlayerVar(pContext, params, "Assists"); +} + static cell_t CS_ItemDefIndexToID(IPluginContext *pContext, const cell_t *params) { -#if SOURCE_ENGINE == SE_CSGO ItemIndexMap::Result res = g_mapDefIdxToClass.find((uint16_t)params[1]); if (!res.found()) return pContext->ThrowNativeError("Invalid item definition passed."); return res->value.m_iWeaponID; -#else - return pContext->ThrowNativeError("CS_ItemDefIndexToID is not supported on this game"); -#endif } static cell_t CS_WeaponIDToItemDefIndex(IPluginContext *pContext, const cell_t *params) { -#if SOURCE_ENGINE == SE_CSGO WeaponIDMap::Result res = g_mapWeaponIDToDefIdx.find((SMCSWeapon)params[1]); if (!res.found()) return pContext->ThrowNativeError("Invalid weapon id passed."); return res->value.m_iDefIdx; -#else - return pContext->ThrowNativeError("CS_WeaponIDToItemDefIndex is not supported on this game"); -#endif } +#endif sp_nativeinfo_t g_CSNatives[] = { @@ -907,14 +886,16 @@ sp_nativeinfo_t g_CSNatives[] = {"CS_GetMVPCount", CS_GetMVPCount}, {"CS_SetMVPCount", CS_SetMVPCount}, {"CS_WeaponIDToAlias", CS_WeaponIDToAlias}, + {"CS_UpdateClientModel", CS_UpdateClientModel}, + {"CS_IsValidWeaponID", CS_IsValidWeaponID}, +#if SOURCE_ENGINE == SE_CSGO {"CS_GetClientContributionScore", CS_GetClientContributionScore}, {"CS_SetClientContributionScore", CS_SetClientContributionScore}, {"CS_GetClientAssists", CS_GetClientAssists}, {"CS_SetClientAssists", CS_SetClientAssists}, - {"CS_UpdateClientModel", CS_UpdateClientModel}, - {"CS_IsValidWeaponID", CS_IsValidWeaponID}, {"CS_ItemDefIndexToID", CS_ItemDefIndexToID}, {"CS_WeaponIDToItemDefIndex", CS_WeaponIDToItemDefIndex}, +#endif {NULL, NULL} };