diff --git a/regamedll/dlls/API/CSPlayerItem.cpp b/regamedll/dlls/API/CSPlayerItem.cpp index 2cd0ec35b..68523ef64 100644 --- a/regamedll/dlls/API/CSPlayerItem.cpp +++ b/regamedll/dlls/API/CSPlayerItem.cpp @@ -32,3 +32,9 @@ EXT_FUNC void CCSPlayerItem::SetItemInfo(ItemInfo *pInfo) { Q_memcpy(&m_ItemInfo, pInfo, sizeof(m_ItemInfo)); } + +EXT_FUNC int CCSPlayerItem::GetItemInfo(ItemInfo *pInfo) +{ + Q_memcpy(pInfo, &m_ItemInfo, sizeof(*pInfo)); + return 1; +} diff --git a/regamedll/dlls/client.cpp b/regamedll/dlls/client.cpp index f20e18851..c9b803ebc 100644 --- a/regamedll/dlls/client.cpp +++ b/regamedll/dlls/client.cpp @@ -4783,7 +4783,12 @@ int EXT_FUNC GetWeaponData(edict_t *pEdict, struct weapon_data_s *info) // Get The ID ItemInfo II; Q_memset(&II, 0, sizeof(II)); + +#ifdef REGAMEDLL_API + pPlayerItem->CSPlayerItem()->GetItemInfo(&II); +#else weapon->GetItemInfo(&II); +#endif if (II.iId >= 0 && II.iId < MAX_WEAPONS) { @@ -4916,7 +4921,13 @@ void EXT_FUNC UpdateClientData(const edict_t *ent, int sendweapons, struct clien Q_memset(&II, 0, sizeof(II)); CBasePlayerWeapon *weapon = (CBasePlayerWeapon *)pPlayer->m_pActiveItem->GetWeaponPtr(); - if (weapon && weapon->UseDecrement() && weapon->GetItemInfo(&II)) + if (weapon && weapon->UseDecrement() && +#ifdef REGAMEDLL_API + weapon->CSPlayerItem()->GetItemInfo(&II) +#else + weapon->GetItemInfo(&II) +#endif + ) { cd->m_iId = II.iId; diff --git a/regamedll/dlls/player.cpp b/regamedll/dlls/player.cpp index a78afef72..94d565751 100644 --- a/regamedll/dlls/player.cpp +++ b/regamedll/dlls/player.cpp @@ -1383,7 +1383,11 @@ void CBasePlayer::PackDeadPlayerItems() ItemInfo info; if (pPlayerItem->iItemSlot() < KNIFE_SLOT && !bShieldDropped) { +#ifdef REGAMEDLL_API + if (pPlayerItem->CSPlayerItem()->GetItemInfo(&info)) +#else if (pPlayerItem->GetItemInfo(&info)) +#endif { if (info.iWeight > nBestWeight) { diff --git a/regamedll/public/regamedll/API/CSPlayerItem.h b/regamedll/public/regamedll/API/CSPlayerItem.h index 8c47d6e50..50b56a5c1 100644 --- a/regamedll/public/regamedll/API/CSPlayerItem.h +++ b/regamedll/public/regamedll/API/CSPlayerItem.h @@ -38,6 +38,7 @@ class CCSPlayerItem: public CCSAnimating } virtual void SetItemInfo(ItemInfo *pInfo); + virtual int GetItemInfo(ItemInfo *pInfo); CBasePlayerItem *BasePlayerItem() const;