Regamedll API WIP: Added new interfaces-objects

Removed some useless code in CBasePlayerWeapon::GetNextAttackDelay
Removed the allocation of the entity CSoundEnt, because it is useless for CS 1.6 also removed UpdatePlayerSound
This commit is contained in:
s1lentq 2016-03-17 23:44:52 +06:00
parent 7b227c0edb
commit 9b955f2672
96 changed files with 2879 additions and 554 deletions

View File

@ -12,8 +12,7 @@ TYPEDESCRIPTION CAirtank::m_SaveData[] =
#endif #endif
LINK_ENTITY_TO_CLASS(item_airtank, CAirtank); LINK_ENTITY_TO_CLASS(item_airtank, CAirtank, CCSAirtank);
LINK_CLASS_TO_WRAP(CAirtank, CCSAirtank);
IMPLEMENT_SAVERESTORE(CAirtank, CGrenade); IMPLEMENT_SAVERESTORE(CAirtank, CGrenade);
void CAirtank::__MAKE_VHOOK(Spawn)() void CAirtank::__MAKE_VHOOK(Spawn)()

View File

@ -35,7 +35,6 @@
class CAirtank: public CGrenade class CAirtank: public CGrenade
{ {
public: public:
CAirtank();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual int Save(CSave &save); virtual int Save(CSave &save);

View File

@ -24,8 +24,7 @@ BOOL C9MMAmmo::__MAKE_VHOOK(AddAmmo)(CBaseEntity *pOther)
return TRUE; return TRUE;
} }
LINK_ENTITY_TO_CLASS(ammo_9mm, C9MMAmmo); LINK_ENTITY_TO_CLASS(ammo_9mm, C9MMAmmo, CCS9MMAmmo);
LINK_CLASS_TO_WRAP(C9MMAmmo, CCS9MMAmmo);
void CBuckShotAmmo::__MAKE_VHOOK(Spawn)() void CBuckShotAmmo::__MAKE_VHOOK(Spawn)()
{ {
@ -51,8 +50,7 @@ BOOL CBuckShotAmmo::__MAKE_VHOOK(AddAmmo)(CBaseEntity *pOther)
return TRUE; return TRUE;
} }
LINK_ENTITY_TO_CLASS(ammo_buckshot, CBuckShotAmmo); LINK_ENTITY_TO_CLASS(ammo_buckshot, CBuckShotAmmo, CCSBuckShotAmmo);
LINK_CLASS_TO_WRAP(CBuckShotAmmo, CCSBuckShotAmmo);
void C556NatoAmmo::__MAKE_VHOOK(Spawn)() void C556NatoAmmo::__MAKE_VHOOK(Spawn)()
{ {
@ -78,8 +76,7 @@ BOOL C556NatoAmmo::__MAKE_VHOOK(AddAmmo)(CBaseEntity *pOther)
return TRUE; return TRUE;
} }
LINK_ENTITY_TO_CLASS(ammo_556nato, C556NatoAmmo); LINK_ENTITY_TO_CLASS(ammo_556nato, C556NatoAmmo, CCS556NatoAmmo);
LINK_CLASS_TO_WRAP(C556NatoAmmo, CCS556NatoAmmo);
void C556NatoBoxAmmo::__MAKE_VHOOK(Spawn)() void C556NatoBoxAmmo::__MAKE_VHOOK(Spawn)()
{ {
@ -105,8 +102,7 @@ BOOL C556NatoBoxAmmo::__MAKE_VHOOK(AddAmmo)(CBaseEntity *pOther)
return TRUE; return TRUE;
} }
LINK_ENTITY_TO_CLASS(ammo_556natobox, C556NatoBoxAmmo); LINK_ENTITY_TO_CLASS(ammo_556natobox, C556NatoBoxAmmo, CCS556NatoBoxAmmo);
LINK_CLASS_TO_WRAP(C556NatoBoxAmmo, CCS556NatoBoxAmmo);
void C762NatoAmmo::__MAKE_VHOOK(Spawn)() void C762NatoAmmo::__MAKE_VHOOK(Spawn)()
{ {
@ -132,8 +128,7 @@ BOOL C762NatoAmmo::__MAKE_VHOOK(AddAmmo)(CBaseEntity *pOther)
return TRUE; return TRUE;
} }
LINK_ENTITY_TO_CLASS(ammo_762nato, C762NatoAmmo); LINK_ENTITY_TO_CLASS(ammo_762nato, C762NatoAmmo, CCS762NatoAmmo);
LINK_CLASS_TO_WRAP(C762NatoAmmo, CCS762NatoAmmo);
void C45ACPAmmo::__MAKE_VHOOK(Spawn)() void C45ACPAmmo::__MAKE_VHOOK(Spawn)()
{ {
@ -159,8 +154,7 @@ BOOL C45ACPAmmo::__MAKE_VHOOK(AddAmmo)(CBaseEntity *pOther)
return TRUE; return TRUE;
} }
LINK_ENTITY_TO_CLASS(ammo_45acp, C45ACPAmmo); LINK_ENTITY_TO_CLASS(ammo_45acp, C45ACPAmmo, CCS45ACPAmmo);
LINK_CLASS_TO_WRAP(C45ACPAmmo, CCS45ACPAmmo);
void C50AEAmmo::__MAKE_VHOOK(Spawn)() void C50AEAmmo::__MAKE_VHOOK(Spawn)()
{ {
@ -186,8 +180,7 @@ BOOL C50AEAmmo::__MAKE_VHOOK(AddAmmo)(CBaseEntity *pOther)
return TRUE; return TRUE;
} }
LINK_ENTITY_TO_CLASS(ammo_50ae, C50AEAmmo); LINK_ENTITY_TO_CLASS(ammo_50ae, C50AEAmmo, CCS50AEAmmo);
LINK_CLASS_TO_WRAP(C50AEAmmo, CCS50AEAmmo);
void C338MagnumAmmo::__MAKE_VHOOK(Spawn)() void C338MagnumAmmo::__MAKE_VHOOK(Spawn)()
{ {
@ -213,8 +206,7 @@ BOOL C338MagnumAmmo::__MAKE_VHOOK(AddAmmo)(CBaseEntity *pOther)
return TRUE; return TRUE;
} }
LINK_ENTITY_TO_CLASS(ammo_338magnum, C338MagnumAmmo); LINK_ENTITY_TO_CLASS(ammo_338magnum, C338MagnumAmmo, CCS338MagnumAmmo);
LINK_CLASS_TO_WRAP(C338MagnumAmmo, CCS338MagnumAmmo);
void C57MMAmmo::__MAKE_VHOOK(Spawn)() void C57MMAmmo::__MAKE_VHOOK(Spawn)()
{ {
@ -240,8 +232,7 @@ BOOL C57MMAmmo::__MAKE_VHOOK(AddAmmo)(CBaseEntity *pOther)
return TRUE; return TRUE;
} }
LINK_ENTITY_TO_CLASS(ammo_57mm, C57MMAmmo); LINK_ENTITY_TO_CLASS(ammo_57mm, C57MMAmmo, CCS57MMAmmo);
LINK_CLASS_TO_WRAP(C57MMAmmo, CCS57MMAmmo);
void C357SIGAmmo::__MAKE_VHOOK(Spawn)() void C357SIGAmmo::__MAKE_VHOOK(Spawn)()
{ {
@ -267,5 +258,4 @@ BOOL C357SIGAmmo::__MAKE_VHOOK(AddAmmo)(CBaseEntity *pOther)
return TRUE; return TRUE;
} }
LINK_ENTITY_TO_CLASS(ammo_357sig, C357SIGAmmo); LINK_ENTITY_TO_CLASS(ammo_357sig, C357SIGAmmo, CCS357SIGAmmo);
LINK_CLASS_TO_WRAP(C357SIGAmmo, CCS357SIGAmmo);

View File

@ -35,7 +35,6 @@
class C9MMAmmo: public CBasePlayerAmmo class C9MMAmmo: public CBasePlayerAmmo
{ {
public: public:
C9MMAmmo();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual BOOL AddAmmo(CBaseEntity *pOther); virtual BOOL AddAmmo(CBaseEntity *pOther);
@ -53,7 +52,6 @@ public:
class CBuckShotAmmo: public CBasePlayerAmmo class CBuckShotAmmo: public CBasePlayerAmmo
{ {
public: public:
CBuckShotAmmo();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual BOOL AddAmmo(CBaseEntity *pOther); virtual BOOL AddAmmo(CBaseEntity *pOther);
@ -71,7 +69,6 @@ public:
class C556NatoAmmo: public CBasePlayerAmmo class C556NatoAmmo: public CBasePlayerAmmo
{ {
public: public:
C556NatoAmmo();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual BOOL AddAmmo(CBaseEntity *pOther); virtual BOOL AddAmmo(CBaseEntity *pOther);
@ -89,7 +86,6 @@ public:
class C556NatoBoxAmmo: public CBasePlayerAmmo class C556NatoBoxAmmo: public CBasePlayerAmmo
{ {
public: public:
C556NatoBoxAmmo();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual BOOL AddAmmo(CBaseEntity *pOther); virtual BOOL AddAmmo(CBaseEntity *pOther);
@ -107,7 +103,6 @@ public:
class C762NatoAmmo: public CBasePlayerAmmo class C762NatoAmmo: public CBasePlayerAmmo
{ {
public: public:
C762NatoAmmo();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual BOOL AddAmmo(CBaseEntity *pOther); virtual BOOL AddAmmo(CBaseEntity *pOther);
@ -125,7 +120,6 @@ public:
class C45ACPAmmo: public CBasePlayerAmmo class C45ACPAmmo: public CBasePlayerAmmo
{ {
public: public:
C45ACPAmmo();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual BOOL AddAmmo(CBaseEntity *pOther); virtual BOOL AddAmmo(CBaseEntity *pOther);
@ -143,7 +137,6 @@ public:
class C50AEAmmo: public CBasePlayerAmmo class C50AEAmmo: public CBasePlayerAmmo
{ {
public: public:
C50AEAmmo();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual BOOL AddAmmo(CBaseEntity *pOther); virtual BOOL AddAmmo(CBaseEntity *pOther);
@ -161,7 +154,6 @@ public:
class C338MagnumAmmo: public CBasePlayerAmmo class C338MagnumAmmo: public CBasePlayerAmmo
{ {
public: public:
C338MagnumAmmo();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual BOOL AddAmmo(CBaseEntity *pOther); virtual BOOL AddAmmo(CBaseEntity *pOther);
@ -179,7 +171,6 @@ public:
class C57MMAmmo: public CBasePlayerAmmo class C57MMAmmo: public CBasePlayerAmmo
{ {
public: public:
C57MMAmmo();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual BOOL AddAmmo(CBaseEntity *pOther); virtual BOOL AddAmmo(CBaseEntity *pOther);
@ -196,7 +187,6 @@ public:
class C357SIGAmmo: public CBasePlayerAmmo class C357SIGAmmo: public CBasePlayerAmmo
{ {
public: public:
C357SIGAmmo();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual BOOL AddAmmo(CBaseEntity *pOther); virtual BOOL AddAmmo(CBaseEntity *pOther);

View File

@ -31,11 +31,10 @@ TYPEDESCRIPTION CPendulum::m_SaveData[] =
// BModelOrigin - calculates origin of a bmodel from absmin/size because all bmodel origins are 0 0 0 // BModelOrigin - calculates origin of a bmodel from absmin/size because all bmodel origins are 0 0 0
Vector VecBModelOrigin(entvars_t *pevBModel) Vector VecBModelOrigin(entvars_t *pevBModel)
{ {
return pevBModel->absmin + (pevBModel->size * 0.5); return pevBModel->absmin + (pevBModel->size * 0.5f);
} }
LINK_ENTITY_TO_CLASS(func_wall, CFuncWall); LINK_ENTITY_TO_CLASS(func_wall, CFuncWall, CCSFuncWall);
LINK_CLASS_TO_WRAP(CFuncWall, CCSFuncWall);
void CFuncWall::__MAKE_VHOOK(Spawn)() void CFuncWall::__MAKE_VHOOK(Spawn)()
{ {
@ -59,8 +58,7 @@ void CFuncWall::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCaller,
} }
} }
LINK_ENTITY_TO_CLASS(func_wall_toggle, CFuncWallToggle); LINK_ENTITY_TO_CLASS(func_wall_toggle, CFuncWallToggle, CCSFuncWallToggle);
LINK_CLASS_TO_WRAP(CFuncWallToggle, CCSFuncWallToggle);
void CFuncWallToggle::__MAKE_VHOOK(Spawn)() void CFuncWallToggle::__MAKE_VHOOK(Spawn)()
{ {
@ -109,8 +107,7 @@ void CFuncWallToggle::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pC
} }
} }
LINK_ENTITY_TO_CLASS(func_conveyor, CFuncConveyor); LINK_ENTITY_TO_CLASS(func_conveyor, CFuncConveyor, CCSFuncConveyor);
LINK_CLASS_TO_WRAP(CFuncConveyor, CCSFuncConveyor);
void CFuncConveyor::__MAKE_VHOOK(Spawn)() void CFuncConveyor::__MAKE_VHOOK(Spawn)()
{ {
@ -157,8 +154,7 @@ void CFuncConveyor::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCal
UpdateSpeed(pev->speed); UpdateSpeed(pev->speed);
} }
LINK_ENTITY_TO_CLASS(func_illusionary, CFuncIllusionary); LINK_ENTITY_TO_CLASS(func_illusionary, CFuncIllusionary, CCSFuncIllusionary);
LINK_CLASS_TO_WRAP(CFuncIllusionary, CCSFuncIllusionary);
void CFuncIllusionary::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd) void CFuncIllusionary::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
{ {
@ -188,8 +184,7 @@ void CFuncIllusionary::__MAKE_VHOOK(Spawn)()
// MAKE_STATIC(ENT(pev)); // MAKE_STATIC(ENT(pev));
} }
LINK_ENTITY_TO_CLASS(func_monsterclip, CFuncMonsterClip); LINK_ENTITY_TO_CLASS(func_monsterclip, CFuncMonsterClip, CCSFuncMonsterClip);
LINK_CLASS_TO_WRAP(CFuncMonsterClip, CCSFuncMonsterClip);
void CFuncMonsterClip::__MAKE_VHOOK(Spawn)() void CFuncMonsterClip::__MAKE_VHOOK(Spawn)()
{ {
@ -203,8 +198,7 @@ void CFuncMonsterClip::__MAKE_VHOOK(Spawn)()
pev->flags |= FL_MONSTERCLIP; pev->flags |= FL_MONSTERCLIP;
} }
LINK_ENTITY_TO_CLASS(func_rotating, CFuncRotating); LINK_ENTITY_TO_CLASS(func_rotating, CFuncRotating, CCSFuncRotating);
LINK_CLASS_TO_WRAP(CFuncRotating, CCSFuncRotating);
IMPLEMENT_SAVERESTORE(CFuncRotating, CBaseEntity); IMPLEMENT_SAVERESTORE(CFuncRotating, CBaseEntity);
void CFuncRotating::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd) void CFuncRotating::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
@ -607,8 +601,7 @@ void CFuncRotating::__MAKE_VHOOK(Blocked)(CBaseEntity *pOther)
pOther->TakeDamage(pev, pev, pev->dmg, DMG_CRUSH); pOther->TakeDamage(pev, pev, pev->dmg, DMG_CRUSH);
} }
LINK_ENTITY_TO_CLASS(func_pendulum, CPendulum); LINK_ENTITY_TO_CLASS(func_pendulum, CPendulum, CCSPendulum);
LINK_CLASS_TO_WRAP(CPendulum, CCSPendulum);
IMPLEMENT_SAVERESTORE(CPendulum, CBaseEntity); IMPLEMENT_SAVERESTORE(CPendulum, CBaseEntity);
void CPendulum::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd) void CPendulum::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)

View File

@ -59,7 +59,6 @@
class CFuncWall: public CBaseEntity class CFuncWall: public CBaseEntity
{ {
public: public:
CFuncWall();
virtual void Spawn(); virtual void Spawn();
// Bmodels don't go across transitions // Bmodels don't go across transitions
@ -78,7 +77,6 @@ public:
class CFuncWallToggle: public CFuncWall class CFuncWallToggle: public CFuncWall
{ {
public: public:
CFuncWallToggle();
virtual void Spawn(); virtual void Spawn();
virtual void Use(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value); virtual void Use(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value);
@ -98,7 +96,6 @@ public:
class CFuncConveyor: public CFuncWall class CFuncConveyor: public CFuncWall
{ {
public: public:
CFuncConveyor();
virtual void Spawn(); virtual void Spawn();
virtual void Use(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value); virtual void Use(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value);
@ -117,7 +114,6 @@ public:
class CFuncIllusionary: public CBaseToggle class CFuncIllusionary: public CBaseToggle
{ {
public: public:
CFuncIllusionary();
virtual void Spawn(); virtual void Spawn();
virtual void KeyValue(KeyValueData *pkvd); virtual void KeyValue(KeyValueData *pkvd);
virtual int ObjectCaps() { return CBaseEntity::ObjectCaps() & ~FCAP_ACROSS_TRANSITION; } virtual int ObjectCaps() { return CBaseEntity::ObjectCaps() & ~FCAP_ACROSS_TRANSITION; }
@ -143,7 +139,6 @@ public:
class CFuncMonsterClip: public CFuncWall class CFuncMonsterClip: public CFuncWall
{ {
public: public:
CFuncMonsterClip();
virtual void Spawn(); virtual void Spawn();
// Clear out func_wall's use function // Clear out func_wall's use function
@ -161,7 +156,6 @@ public:
class CFuncRotating: public CBaseEntity class CFuncRotating: public CBaseEntity
{ {
public: public:
CFuncRotating();
// basic functions // basic functions
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
@ -203,7 +197,6 @@ public:
class CPendulum: public CBaseEntity class CPendulum: public CBaseEntity
{ {
public: public:
CPendulum();
virtual void Spawn(); virtual void Spawn();
virtual void KeyValue(KeyValueData *pkvd); virtual void KeyValue(KeyValueData *pkvd);
virtual int Save(CSave &save); virtual int Save(CSave &save);

View File

@ -68,7 +68,7 @@ bool CCSBot::__MAKE_VHOOK(Jump)(bool mustJump)
// NOTE: We dont want to directly call Attack() here, or the bots will have super-human reaction times when injured // NOTE: We dont want to directly call Attack() here, or the bots will have super-human reaction times when injured
int CCSBot::__MAKE_VHOOK(TakeDamage)(entvars_t *pevInflictor, entvars_t *pevAttacker, float flDamage, int bitsDamageType) int CCSBot::__MAKE_VHOOK(TakeDamage)(entvars_t *pevInflictor, entvars_t *pevAttacker, float flDamage, int bitsDamageType)
{ {
CBaseEntity *attacker = GetClassPtr((CBaseEntity *)pevInflictor); CBaseEntity *attacker = GetClassPtr<CCSEntity>((CBaseEntity *)pevInflictor);
// if we were attacked by a teammate, rebuke // if we were attacked by a teammate, rebuke
if (attacker->IsPlayer()) if (attacker->IsPlayer())

View File

@ -421,8 +421,6 @@ class CCSBot: public CBot
{ {
public: public:
CCSBot(); // constructor initializes all values to zero CCSBot(); // constructor initializes all values to zero
public:
virtual int TakeDamage(entvars_t *pevInflictor, entvars_t *pevAttacker, float flDamage, int bitsDamageType); // invoked when injured by something (EXTEND) - returns the amount of damage inflicted virtual int TakeDamage(entvars_t *pevInflictor, entvars_t *pevAttacker, float flDamage, int bitsDamageType); // invoked when injured by something (EXTEND) - returns the amount of damage inflicted
virtual void Killed(entvars_t *pevAttacker, int iGib); // invoked when killed (EXTEND) virtual void Killed(entvars_t *pevAttacker, int iGib); // invoked when killed (EXTEND)
virtual void RoundRespawn(); virtual void RoundRespawn();

View File

@ -347,7 +347,7 @@ void CCSBotManager::__MAKE_VHOOK(ClientDisconnect)(CBasePlayer *pPlayer)
FREE_PRIVATE(pPlayer->edict()); FREE_PRIVATE(pPlayer->edict());
CBasePlayer *player = GetClassPtr((CBasePlayer *)temp); CBasePlayer *player = GetClassPtr<CCSPlayer>((CBasePlayer *)temp);
AddEntityHashValue(player->pev, STRING(player->pev->classname), CLASSNAME); AddEntityHashValue(player->pev, STRING(player->pev->classname), CLASSNAME);
player->pev->flags = FL_DORMANT; player->pev->flags = FL_DORMANT;
} }
@ -681,7 +681,7 @@ void CCSBotManager::__MAKE_VHOOK(ServerCommand)(const char *pcmd)
if ((pEntity->pev->flags & FL_DORMANT) == FL_DORMANT) if ((pEntity->pev->flags & FL_DORMANT) == FL_DORMANT)
continue; continue;
CBasePlayer *playerOrBot = GetClassPtr((CBasePlayer *)pEntity->pev); CBasePlayer *playerOrBot = GetClassPtr<CCSPlayer>((CBasePlayer *)pEntity->pev);
if (playerOrBot->IsBot()) if (playerOrBot->IsBot())
{ {
@ -1189,7 +1189,7 @@ bool CCSBotManager::AddBot(const BotProfile *profile, BotProfileTeamType team)
return false; return false;
} }
CCSBot *pBot = CreateBot<CCSBot>(profile); CCSBot *pBot = CreateBot<CCSBot, CAPI_CSBot>(profile);
if (pBot == NULL) if (pBot == NULL)
{ {
return false; return false;

View File

@ -53,8 +53,7 @@ TYPEDESCRIPTION CEnvSpark::m_SaveData[] =
#endif // HOOK_GAMEDLL #endif // HOOK_GAMEDLL
IMPLEMENT_SAVERESTORE(CEnvGlobal, CBaseEntity); IMPLEMENT_SAVERESTORE(CEnvGlobal, CBaseEntity);
LINK_ENTITY_TO_CLASS(env_global, CEnvGlobal); LINK_ENTITY_TO_CLASS(env_global, CEnvGlobal, CCSEnvGlobal);
LINK_CLASS_TO_WRAP(CEnvGlobal, CCSEnvGlobal);
void CEnvGlobal::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd) void CEnvGlobal::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
{ {
@ -136,8 +135,7 @@ void CEnvGlobal::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCaller
} }
IMPLEMENT_SAVERESTORE(CMultiSource, CBaseEntity); IMPLEMENT_SAVERESTORE(CMultiSource, CBaseEntity);
LINK_ENTITY_TO_CLASS(multisource, CMultiSource); LINK_ENTITY_TO_CLASS(multisource, CMultiSource, CCSMultiSource);
LINK_CLASS_TO_WRAP(CMultiSource, CCSMultiSource);
// Cache user-entity-field values until spawn is called. // Cache user-entity-field values until spawn is called.
void CMultiSource::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd) void CMultiSource::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
@ -427,8 +425,7 @@ int CBaseButton::__MAKE_VHOOK(TakeDamage)(entvars_t *pevInflictor, entvars_t *pe
// 1) wooden clunk // 1) wooden clunk
// 2) metallic click // 2) metallic click
// 3) in-out // 3) in-out
LINK_ENTITY_TO_CLASS(func_button, CBaseButton); LINK_ENTITY_TO_CLASS(func_button, CBaseButton, CCSButton);
LINK_CLASS_TO_WRAP(CBaseButton, CCSButton);
void CBaseButton::__MAKE_VHOOK(Spawn)() void CBaseButton::__MAKE_VHOOK(Spawn)()
{ {
@ -792,8 +789,7 @@ void CBaseButton::ButtonBackHome()
} }
} }
LINK_ENTITY_TO_CLASS(func_rot_button, CRotButton); LINK_ENTITY_TO_CLASS(func_rot_button, CRotButton, CCSRotButton);
LINK_CLASS_TO_WRAP(CRotButton, CCSRotButton);
void CRotButton::__MAKE_VHOOK(Spawn)() void CRotButton::__MAKE_VHOOK(Spawn)()
{ {
@ -860,8 +856,7 @@ void CRotButton::__MAKE_VHOOK(Spawn)()
} }
IMPLEMENT_SAVERESTORE(CMomentaryRotButton, CBaseToggle); IMPLEMENT_SAVERESTORE(CMomentaryRotButton, CBaseToggle);
LINK_ENTITY_TO_CLASS(momentary_rot_button, CMomentaryRotButton); LINK_ENTITY_TO_CLASS(momentary_rot_button, CMomentaryRotButton, CCSMomentaryRotButton);
LINK_CLASS_TO_WRAP(CMomentaryRotButton, CCSMomentaryRotButton);
void CMomentaryRotButton::__MAKE_VHOOK(Spawn)() void CMomentaryRotButton::__MAKE_VHOOK(Spawn)()
{ {
@ -1076,9 +1071,8 @@ void CMomentaryRotButton::UpdateSelfReturn(float value)
} }
IMPLEMENT_SAVERESTORE(CEnvSpark, CBaseEntity); IMPLEMENT_SAVERESTORE(CEnvSpark, CBaseEntity);
LINK_ENTITY_TO_CLASS(env_spark, CEnvSpark); LINK_ENTITY_TO_CLASS(env_spark, CEnvSpark, CCSEnvSpark);
LINK_ENTITY_TO_CLASS(env_debris, CEnvSpark); LINK_ENTITY_TO_CLASS(env_debris, CEnvSpark, CCSEnvSpark);
LINK_CLASS_TO_WRAP(CEnvSpark, CCSEnvSpark);
void CEnvSpark::__MAKE_VHOOK(Spawn)() void CEnvSpark::__MAKE_VHOOK(Spawn)()
{ {
@ -1160,8 +1154,7 @@ void CEnvSpark::SparkStop(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYP
SetThink(NULL); SetThink(NULL);
} }
LINK_ENTITY_TO_CLASS(button_target, CButtonTarget); LINK_ENTITY_TO_CLASS(button_target, CButtonTarget, CCSButtonTarget);
LINK_CLASS_TO_WRAP(CButtonTarget, CCSButtonTarget);
void CButtonTarget::__MAKE_VHOOK(Spawn)() void CButtonTarget::__MAKE_VHOOK(Spawn)()
{ {

View File

@ -57,7 +57,6 @@
class CEnvGlobal: public CPointEntity class CEnvGlobal: public CPointEntity
{ {
public: public:
CEnvGlobal();
virtual void Spawn(); virtual void Spawn();
virtual void KeyValue(KeyValueData *pkvd); virtual void KeyValue(KeyValueData *pkvd);
virtual int Save(CSave &save); virtual int Save(CSave &save);
@ -85,7 +84,6 @@ public:
class CRotButton: public CBaseButton class CRotButton: public CBaseButton
{ {
public: public:
CRotButton();
virtual void Spawn(); virtual void Spawn();
#ifdef HOOK_GAMEDLL #ifdef HOOK_GAMEDLL
@ -98,7 +96,6 @@ public:
class CMomentaryRotButton: public CBaseToggle class CMomentaryRotButton: public CBaseToggle
{ {
public: public:
CMomentaryRotButton();
virtual void Spawn(); virtual void Spawn();
virtual void KeyValue(KeyValueData *pkvd); virtual void KeyValue(KeyValueData *pkvd);
virtual int Save(CSave &save); virtual int Save(CSave &save);
@ -150,7 +147,6 @@ public:
class CEnvSpark: public CBaseEntity class CEnvSpark: public CBaseEntity
{ {
public: public:
CEnvSpark();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual void KeyValue(KeyValueData *pkvd); virtual void KeyValue(KeyValueData *pkvd);
@ -180,7 +176,6 @@ public:
class CButtonTarget: public CBaseEntity class CButtonTarget: public CBaseEntity
{ {
public: public:
CButtonTarget();
virtual void Spawn(); virtual void Spawn();
virtual int ObjectCaps(); virtual int ObjectCaps();
virtual int TakeDamage(entvars_t *pevInflictor, entvars_t *pevAttacker, float flDamage, int bitsDamageType); virtual int TakeDamage(entvars_t *pevInflictor, entvars_t *pevAttacker, float flDamage, int bitsDamageType);

View File

@ -83,8 +83,6 @@ BOOL gTouchDisabled = FALSE;
#endif // HOOK_GAMEDLL #endif // HOOK_GAMEDLL
const std::type_info *g_typeInfo = NULL;
int CaseInsensitiveHash(const char *string, int iBounds) int CaseInsensitiveHash(const char *string, int iBounds)
{ {
unsigned int hash = 0; unsigned int hash = 0;
@ -1086,5 +1084,3 @@ void OnFreeEntPrivateData(edict_t *pEnt)
RemoveEntityHashValue(pEntity->pev, STRING(pEntity->pev->classname), CLASSNAME); RemoveEntityHashValue(pEntity->pev, STRING(pEntity->pev->classname), CLASSNAME);
Regamedll_FreeEntities(pEntity); Regamedll_FreeEntities(pEntity);
} }
//LINK_CLASS_TO_WRAP(CBaseEntity, CCSEntity);

View File

@ -358,12 +358,7 @@ public:
#endif #endif
public: public:
void *operator new(size_t stAllocateBlock, entvars_t *pevnew) void *operator new(size_t stAllocateBlock, entvars_t *pevnew) { return ALLOC_PRIVATE(ENT(pevnew), stAllocateBlock); }
{
CBaseEntity *ent = (CBaseEntity *)ALLOC_PRIVATE(ENT(pevnew), stAllocateBlock);
ent->pev = pevnew;
return ent;
}
void operator delete(void *pMem, entvars_t *pevnew) { pevnew->flags |= FL_KILLME; } void operator delete(void *pMem, entvars_t *pevnew) { pevnew->flags |= FL_KILLME; }
void UpdateOnRemove(); void UpdateOnRemove();
void EXPORT SUB_Remove(); void EXPORT SUB_Remove();
@ -453,7 +448,6 @@ inline int FNullEnt(EHANDLE hent) { return (hent == NULL || FNullEnt(OFFSET(hent
class CPointEntity: public CBaseEntity class CPointEntity: public CBaseEntity
{ {
public: public:
CPointEntity();
virtual void Spawn(); virtual void Spawn();
virtual int ObjectCaps() { return (CBaseEntity::ObjectCaps() & ~FCAP_ACROSS_TRANSITION); } virtual int ObjectCaps() { return (CBaseEntity::ObjectCaps() & ~FCAP_ACROSS_TRANSITION); }
@ -468,7 +462,6 @@ public:
class CMultiSource: public CPointEntity class CMultiSource: public CPointEntity
{ {
public: public:
CMultiSource();
virtual void Spawn(); virtual void Spawn();
virtual void KeyValue(KeyValueData *pkvd); virtual void KeyValue(KeyValueData *pkvd);
virtual int Save(CSave &save); virtual int Save(CSave &save);
@ -503,7 +496,6 @@ public:
class CBaseDelay: public CBaseEntity class CBaseDelay: public CBaseEntity
{ {
public: public:
CBaseDelay();
virtual void KeyValue(KeyValueData *pkvd); virtual void KeyValue(KeyValueData *pkvd);
virtual int Save(CSave &save); virtual int Save(CSave &save);
virtual int Restore(CRestore &restore); virtual int Restore(CRestore &restore);
@ -636,7 +628,6 @@ class CBaseButton: public CBaseToggle
BUTTON_RETURN BUTTON_RETURN
}; };
public: public:
CBaseButton();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual void KeyValue(KeyValueData *pkvd); virtual void KeyValue(KeyValueData *pkvd);
@ -696,7 +687,6 @@ public:
class CWorld: public CBaseEntity class CWorld: public CBaseEntity
{ {
public: public:
CWorld();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual void KeyValue(KeyValueData *pkvd); virtual void KeyValue(KeyValueData *pkvd);
@ -711,26 +701,11 @@ public:
}; };
extern const std::type_info *g_typeInfo; #ifdef REGAMEDLL_SELF
extern class CCSEntity **g_GameEntities; extern class CCSEntity **g_GameEntities;
#endif
template <class T> template <class TWrap, class T>
T *GetClassPtrWrap(CBaseEntity *a)
{
// yet not allocated?
if (g_GameEntities == NULL)
return NULL;
// to ignore constructor classes invoked by inheritance
if (!g_typeInfo || g_typeInfo != &typeid(*a))
return NULL;
int index = a->entindex();
g_GameEntities[index] = new T (a);
return reinterpret_cast<T *>(g_GameEntities[index]);
}
template <class T>
T *GetClassPtr(T *a) T *GetClassPtr(T *a)
{ {
entvars_t *pev = (entvars_t *)a; entvars_t *pev = (entvars_t *)a;
@ -739,14 +714,16 @@ T *GetClassPtr(T *a)
a = (T *)GET_PRIVATE(ENT(pev)); a = (T *)GET_PRIVATE(ENT(pev));
if (!a) if (!a)
{ {
g_typeInfo = &typeid(T);
a = new(pev) T; a = new(pev) T;
g_typeInfo = NULL; a->pev = pev;
#ifdef REGAMEDLL_SELF
g_GameEntities[a->entindex()] = new TWrap (a);
#endif
#if defined(HOOK_GAMEDLL) && defined(_WIN32) && !defined(REGAMEDLL_UNIT_TESTS) #if defined(HOOK_GAMEDLL) && defined(_WIN32) && !defined(REGAMEDLL_UNIT_TESTS)
VirtualTableInit((void *)a, stripClass(typeid(T).name())); VirtualTableInit((void *)a, stripClass(typeid(T).name()));
#endif #endif
} }
return a; return a;

View File

@ -176,7 +176,7 @@ void respawn(entvars_t *pev, BOOL fCopyCorpse)
if (CSGameRules()->m_iTotalRoundsPlayed > 0) if (CSGameRules()->m_iTotalRoundsPlayed > 0)
CSGameRules()->MarkSpawnSkipped(); CSGameRules()->MarkSpawnSkipped();
CBasePlayer *pPlayer = GetClassPtr((CBasePlayer *)pev); CBasePlayer *pPlayer = GetClassPtr<CCSPlayer>((CBasePlayer *)pev);
if (CSGameRules()->IsCareer() && CSGameRules()->ShouldSkipSpawn() && pPlayer->IsAlive()) if (CSGameRules()->IsCareer() && CSGameRules()->ShouldSkipSpawn() && pPlayer->IsAlive())
g_skipCareerInitialSpawn = true; g_skipCareerInitialSpawn = true;
@ -257,7 +257,7 @@ NOXREF int CountTeams()
if (FNullEnt(pPlayer->edict())) if (FNullEnt(pPlayer->edict()))
break; break;
CBasePlayer *player = GetClassPtr((CBasePlayer *)pPlayer->pev); CBasePlayer *player = GetClassPtr<CCSPlayer>((CBasePlayer *)pPlayer->pev);
if (player->m_iTeam == UNASSIGNED) if (player->m_iTeam == UNASSIGNED)
continue; continue;
@ -292,7 +292,7 @@ void ListPlayers(CBasePlayer *current)
if (pPlayer->pev->flags & FL_DORMANT) if (pPlayer->pev->flags & FL_DORMANT)
continue; continue;
CBasePlayer *player = GetClassPtr((CBasePlayer *)pPlayer->pev); CBasePlayer *player = GetClassPtr<CCSPlayer>((CBasePlayer *)pPlayer->pev);
int iUserID = GETPLAYERUSERID(ENT(player->pev)); int iUserID = GETPLAYERUSERID(ENT(player->pev));
Q_sprintf(cNumber, "%d", iUserID); Q_sprintf(cNumber, "%d", iUserID);
@ -320,7 +320,7 @@ int CountTeamPlayers(int iTeam)
if (pPlayer->pev->flags & FL_DORMANT) if (pPlayer->pev->flags & FL_DORMANT)
continue; continue;
if (GetClassPtr((CBasePlayer *)pPlayer->pev)->m_iTeam == iTeam) if (GetClassPtr<CCSPlayer>((CBasePlayer *)pPlayer->pev)->m_iTeam == iTeam)
++i; ++i;
} }
@ -353,7 +353,7 @@ void ProcessKickVote(CBasePlayer *pVotingPlayer, CBasePlayer *pKickPlayer)
if (FNullEnt(pTempEntity->edict())) if (FNullEnt(pTempEntity->edict()))
break; break;
pTempPlayer = GetClassPtr((CBasePlayer *)pTempEntity->pev); pTempPlayer = GetClassPtr<CCSPlayer>((CBasePlayer *)pTempEntity->pev);
if (!pTempPlayer || pTempPlayer->m_iTeam == UNASSIGNED) if (!pTempPlayer || pTempPlayer->m_iTeam == UNASSIGNED)
continue; continue;
@ -382,7 +382,7 @@ void ProcessKickVote(CBasePlayer *pVotingPlayer, CBasePlayer *pKickPlayer)
if (FNullEnt(pTempEntity->edict())) if (FNullEnt(pTempEntity->edict()))
break; break;
pTempPlayer = GetClassPtr((CBasePlayer *)pTempEntity->pev); pTempPlayer = GetClassPtr<CCSPlayer>((CBasePlayer *)pTempEntity->pev);
if (!pTempPlayer || pTempPlayer->m_iTeam == UNASSIGNED) if (!pTempPlayer || pTempPlayer->m_iTeam == UNASSIGNED)
continue; continue;
@ -473,7 +473,7 @@ void CheckStartMoney()
void EXT_FUNC ClientPutInServer(edict_t *pEntity) void EXT_FUNC ClientPutInServer(edict_t *pEntity)
{ {
entvars_t *pev = &pEntity->v; entvars_t *pev = &pEntity->v;
CBasePlayer *pPlayer = GetClassPtr((CBasePlayer *)pev); CBasePlayer *pPlayer = GetClassPtr<CCSPlayer>((CBasePlayer *)pev);
pPlayer->SetCustomDecalFrames(-1); pPlayer->SetCustomDecalFrames(-1);
pPlayer->SetPrefsFromUserinfo(GET_INFO_BUFFER(pEntity)); pPlayer->SetPrefsFromUserinfo(GET_INFO_BUFFER(pEntity));
@ -607,7 +607,7 @@ void Host_Say(edict_t *pEntity, int teamonly)
bool bSenderDead = false; bool bSenderDead = false;
entvars_t *pev = &pEntity->v; entvars_t *pev = &pEntity->v;
CBasePlayer *player = GetClassPtr((CBasePlayer *)pev); CBasePlayer *player = GetClassPtr<CCSPlayer>((CBasePlayer *)pev);
if (player->m_flLastTalk != 0.0f && gpGlobals->time - player->m_flLastTalk < 0.66f) if (player->m_flLastTalk != 0.0f && gpGlobals->time - player->m_flLastTalk < 0.66f)
return; return;
@ -2522,7 +2522,7 @@ CBaseEntity *EntityFromUserID(int userID)
if (FNullEnt(pTempEntity->edict())) if (FNullEnt(pTempEntity->edict()))
break; break;
CBasePlayer *pTempPlayer = GetClassPtr((CBasePlayer *)pTempEntity->pev); CBasePlayer *pTempPlayer = GetClassPtr<CCSPlayer>((CBasePlayer *)pTempEntity->pev);
if (pTempPlayer->m_iTeam != UNASSIGNED && userID == GETPLAYERUSERID(pTempEntity->edict())) if (pTempPlayer->m_iTeam != UNASSIGNED && userID == GETPLAYERUSERID(pTempEntity->edict()))
{ {
@ -2543,7 +2543,7 @@ NOXREF int CountPlayersInServer()
if (FNullEnt(pTempEntity->edict())) if (FNullEnt(pTempEntity->edict()))
break; break;
CBasePlayer *pTempPlayer = GetClassPtr((CBasePlayer *)pTempEntity->pev); CBasePlayer *pTempPlayer = GetClassPtr<CCSPlayer>((CBasePlayer *)pTempEntity->pev);
if (pTempPlayer->m_iTeam != UNASSIGNED) if (pTempPlayer->m_iTeam != UNASSIGNED)
{ {
@ -2824,7 +2824,7 @@ void EXT_FUNC ClientCommand(edict_t *pEntity)
return; return;
entvars_t *pev = &pEntity->v; entvars_t *pev = &pEntity->v;
CBasePlayer *player = GetClassPtr((CBasePlayer *)pev); CBasePlayer *player = GetClassPtr<CCSPlayer>((CBasePlayer *)pev);
if (FStrEq(pcmd, "say")) if (FStrEq(pcmd, "say"))
{ {
@ -2899,7 +2899,7 @@ void EXT_FUNC ClientCommand(edict_t *pEntity)
CBaseEntity *pKickEntity = EntityFromUserID(iVoteID); CBaseEntity *pKickEntity = EntityFromUserID(iVoteID);
if (pKickEntity != NULL) if (pKickEntity != NULL)
{ {
CBasePlayer *pKickPlayer = GetClassPtr((CBasePlayer *)pKickEntity->pev); CBasePlayer *pKickPlayer = GetClassPtr<CCSPlayer>((CBasePlayer *)pKickEntity->pev);
if (pKickPlayer->m_iTeam != player->m_iTeam) if (pKickPlayer->m_iTeam != player->m_iTeam)
{ {
@ -3460,12 +3460,12 @@ void EXT_FUNC ClientCommand(edict_t *pEntity)
} }
else else
{ {
if (g_pGameRules->ClientCommand_DeadOrAlive(GetClassPtr((CBasePlayer *)pev), pcmd)) if (g_pGameRules->ClientCommand_DeadOrAlive(GetClassPtr<CCSPlayer>((CBasePlayer *)pev), pcmd))
return; return;
if (TheBots != NULL) if (TheBots != NULL)
{ {
if (TheBots->ClientCommand(GetClassPtr((CBasePlayer *)pev), pcmd)) if (TheBots->ClientCommand(GetClassPtr<CCSPlayer>((CBasePlayer *)pev), pcmd))
return; return;
} }
@ -3613,22 +3613,22 @@ void EXT_FUNC ClientCommand(edict_t *pEntity)
{ {
#if 0 #if 0
if (g_flWeaponCheat && CMD_ARGC() > 1) if (g_flWeaponCheat && CMD_ARGC() > 1)
GetClassPtr((CBasePlayer *)pev)->m_iFOV = Q_atoi(CMD_ARGV(1)); GetClassPtr<CCSPlayer>((CBasePlayer *)pev)->m_iFOV = Q_atoi(CMD_ARGV(1));
else else
CLIENT_PRINTF(pEntity, print_console, UTIL_VarArgs("\"fov\" is \"%d\"\n", int(GetClassPtr((CBasePlayer *)pev)->m_iFOV))); CLIENT_PRINTF(pEntity, print_console, UTIL_VarArgs("\"fov\" is \"%d\"\n", int(GetClassPtr<CCSPlayer>((CBasePlayer *)pev)->m_iFOV)));
#endif #endif
} }
else if (FStrEq(pcmd, "use")) else if (FStrEq(pcmd, "use"))
{ {
GetClassPtr((CBasePlayer *)pev)->SelectItem(CMD_ARGV_(1)); GetClassPtr<CCSPlayer>((CBasePlayer *)pev)->SelectItem(CMD_ARGV_(1));
} }
else if (((pstr = Q_strstr(pcmd, "weapon_")) != NULL) && (pstr == pcmd)) else if (((pstr = Q_strstr(pcmd, "weapon_")) != NULL) && (pstr == pcmd))
{ {
GetClassPtr((CBasePlayer *)pev)->SelectItem(pcmd); GetClassPtr<CCSPlayer>((CBasePlayer *)pev)->SelectItem(pcmd);
} }
else if (FStrEq(pcmd, "lastinv")) else if (FStrEq(pcmd, "lastinv"))
{ {
GetClassPtr((CBasePlayer *)pev)->SelectLastItem(); GetClassPtr<CCSPlayer>((CBasePlayer *)pev)->SelectLastItem();
} }
else if (FStrEq(pcmd, "buyammo1")) else if (FStrEq(pcmd, "buyammo1"))
{ {
@ -3749,7 +3749,7 @@ void EXT_FUNC ClientCommand(edict_t *pEntity)
if (HandleRadioAliasCommands(player, pcmd)) if (HandleRadioAliasCommands(player, pcmd))
return; return;
if (!g_pGameRules->ClientCommand(GetClassPtr((CBasePlayer *)pev), pcmd)) if (!g_pGameRules->ClientCommand(GetClassPtr<CCSPlayer>((CBasePlayer *)pev), pcmd))
{ {
// tell the user they entered an unknown command // tell the user they entered an unknown command
char command[128]; char command[128];
@ -3820,7 +3820,7 @@ void EXT_FUNC ClientUserInfoChanged(edict_t *pEntity, char *infobuffer)
} }
} }
g_pGameRules->ClientUserInfoChanged(GetClassPtr((CBasePlayer *)&pEntity->v), infobuffer); g_pGameRules->ClientUserInfoChanged(GetClassPtr<CCSPlayer>((CBasePlayer *)&pEntity->v), infobuffer);
} }
void EXT_FUNC ServerDeactivate() void EXT_FUNC ServerDeactivate()

View File

@ -25,7 +25,7 @@ NOXREF void CGib::SpawnStickyGibs(entvars_t *pevVictim, Vector vecOrigin, int cG
for (i = 0; i < cGibs; ++i) for (i = 0; i < cGibs; ++i)
{ {
CGib *pGib = GetClassPtr((CGib *)NULL); CGib *pGib = GetClassPtr<CCSGib>((CGib *)NULL);
pGib->Spawn("models/stickygib.mdl"); pGib->Spawn("models/stickygib.mdl");
pGib->pev->body = RANDOM_LONG(0, 2); pGib->pev->body = RANDOM_LONG(0, 2);
@ -78,7 +78,7 @@ NOXREF void CGib::SpawnStickyGibs(entvars_t *pevVictim, Vector vecOrigin, int cG
void CGib::SpawnHeadGib(entvars_t *pevVictim) void CGib::SpawnHeadGib(entvars_t *pevVictim)
{ {
CGib *pGib = GetClassPtr((CGib *)NULL); CGib *pGib = GetClassPtr<CCSGib>((CGib *)NULL);
if (g_Language == LANGUAGE_GERMAN) if (g_Language == LANGUAGE_GERMAN)
{ {
@ -139,9 +139,9 @@ void CGib::SpawnHeadGib(entvars_t *pevVictim)
void CGib::SpawnRandomGibs(entvars_t *pevVictim, int cGibs, int human) void CGib::SpawnRandomGibs(entvars_t *pevVictim, int cGibs, int human)
{ {
int cSplat; int cSplat;
for (cSplat = 0; cSplat < cGibs; cSplat++) for (cSplat = 0; cSplat < cGibs; ++cSplat)
{ {
CGib *pGib = GetClassPtr((CGib *)NULL); CGib *pGib = GetClassPtr<CCSGib>((CGib *)NULL);
if (g_Language == LANGUAGE_GERMAN) if (g_Language == LANGUAGE_GERMAN)
{ {
@ -1468,7 +1468,7 @@ void CBaseEntity::FireBullets(ULONG cShots, Vector vecSrc, Vector vecDirShooting
ClearMultiDamage(); ClearMultiDamage();
gMultiDamage.type = (DMG_BULLET | DMG_NEVERGIB); gMultiDamage.type = (DMG_BULLET | DMG_NEVERGIB);
for (ULONG iShot = 1; iShot <= cShots; iShot++) for (ULONG iShot = 1; iShot <= cShots; ++iShot)
{ {
int spark = 0; int spark = 0;

View File

@ -187,11 +187,10 @@ void CBaseDoor::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
// 2) base // 2) base
// 3) stone chain // 3) stone chain
// 4) screechy metal // 4) screechy metal
LINK_ENTITY_TO_CLASS(func_door, CBaseDoor); LINK_ENTITY_TO_CLASS(func_door, CBaseDoor, CCSDoor);
// func_water - same as a door. // func_water - same as a door.
LINK_ENTITY_TO_CLASS(func_water, CBaseDoor); LINK_ENTITY_TO_CLASS(func_water, CBaseDoor, CCSDoor);
LINK_CLASS_TO_WRAP(CBaseDoor, CCSDoor);
void CBaseDoor::__MAKE_VHOOK(Spawn)() void CBaseDoor::__MAKE_VHOOK(Spawn)()
{ {
@ -768,7 +767,7 @@ void CBaseDoor::__MAKE_VHOOK(Blocked)(CBaseEntity *pOther)
if (FClassnameIs(pentTarget, "func_door") || FClassnameIs(pentTarget, "func_door_rotating")) if (FClassnameIs(pentTarget, "func_door") || FClassnameIs(pentTarget, "func_door_rotating"))
{ {
pDoor = GetClassPtr((CBaseDoor *)VARS(pentTarget)); pDoor = GetClassPtr<CCSDoor>((CBaseDoor *)VARS(pentTarget));
if (pDoor->m_flWait >= 0) if (pDoor->m_flWait >= 0)
{ {
@ -841,8 +840,7 @@ void CBaseDoor::__MAKE_VHOOK(Blocked)(CBaseEntity *pOther)
// 2) base // 2) base
// 3) stone chain // 3) stone chain
// 4) screechy metal // 4) screechy metal
LINK_ENTITY_TO_CLASS(func_door_rotating, CRotDoor); LINK_ENTITY_TO_CLASS(func_door_rotating, CRotDoor, CCSRotDoor);
LINK_CLASS_TO_WRAP(CRotDoor, CCSRotDoor);
void CRotDoor::__MAKE_VHOOK(Restart)() void CRotDoor::__MAKE_VHOOK(Restart)()
{ {
@ -940,8 +938,7 @@ void CRotDoor::__MAKE_VHOOK(SetToggleState)(int state)
UTIL_SetOrigin(pev, pev->origin); UTIL_SetOrigin(pev, pev->origin);
} }
LINK_ENTITY_TO_CLASS(momentary_door, CMomentaryDoor); LINK_ENTITY_TO_CLASS(momentary_door, CMomentaryDoor, CCSMomentaryDoor);
LINK_CLASS_TO_WRAP(CMomentaryDoor, CCSMomentaryDoor);
IMPLEMENT_SAVERESTORE(CMomentaryDoor, CBaseToggle); IMPLEMENT_SAVERESTORE(CMomentaryDoor, CBaseToggle);
void CMomentaryDoor::__MAKE_VHOOK(Spawn)() void CMomentaryDoor::__MAKE_VHOOK(Spawn)()

View File

@ -51,7 +51,6 @@
class CBaseDoor: public CBaseToggle class CBaseDoor: public CBaseToggle
{ {
public: public:
CBaseDoor();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual void Restart(); virtual void Restart();
@ -113,7 +112,6 @@ public:
class CRotDoor: public CBaseDoor class CRotDoor: public CBaseDoor
{ {
public: public:
CRotDoor();
virtual void Spawn(); virtual void Spawn();
virtual void Restart(); virtual void Restart();
virtual void SetToggleState(int state); virtual void SetToggleState(int state);
@ -131,7 +129,6 @@ public:
class CMomentaryDoor: public CBaseToggle class CMomentaryDoor: public CBaseToggle
{ {
public: public:
CMomentaryDoor();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual void KeyValue(KeyValueData *pkvd); virtual void KeyValue(KeyValueData *pkvd);

View File

@ -61,12 +61,8 @@ TYPEDESCRIPTION CGibShooter::m_SaveData[] =
#endif // HOOK_GAMEDLL #endif // HOOK_GAMEDLL
LINK_ENTITY_TO_CLASS(info_target, CPointEntity); LINK_ENTITY_TO_CLASS(info_target, CPointEntity, CCSPointEntity);
LINK_CLASS_TO_WRAP(CPointEntity, CCSPointEntity); LINK_ENTITY_TO_CLASS(env_bubbles, CBubbling, CCSBubbling);
LINK_ENTITY_TO_CLASS(env_bubbles, CBubbling);
LINK_CLASS_TO_WRAP(CBubbling, CCSBubbling);
IMPLEMENT_SAVERESTORE(CBubbling, CBaseEntity); IMPLEMENT_SAVERESTORE(CBubbling, CBaseEntity);
void CBubbling::__MAKE_VHOOK(Spawn)() void CBubbling::__MAKE_VHOOK(Spawn)()
@ -158,8 +154,7 @@ void CBubbling::FizzThink()
pev->nextthink = gpGlobals->time + 2.5f - (0.1f * m_frequency); pev->nextthink = gpGlobals->time + 2.5f - (0.1f * m_frequency);
} }
LINK_ENTITY_TO_CLASS(beam, CBeam); LINK_ENTITY_TO_CLASS(beam, CBeam, CCSBeam);
LINK_CLASS_TO_WRAP(CBeam, CCSBeam);
void CBeam::__MAKE_VHOOK(Spawn)() void CBeam::__MAKE_VHOOK(Spawn)()
{ {
@ -223,7 +218,7 @@ const Vector &CBeam::GetEndPos()
CBeam *CBeam::BeamCreate(const char *pSpriteName, int width) CBeam *CBeam::BeamCreate(const char *pSpriteName, int width)
{ {
// Create a new entity with CBeam private data // Create a new entity with CBeam private data
CBeam *pBeam = GetClassPtr((CBeam *)NULL); CBeam *pBeam = GetClassPtr<CCSBeam>((CBeam *)NULL);
MAKE_STRING_CLASS("beam", pBeam->pev); MAKE_STRING_CLASS("beam", pBeam->pev);
pBeam->BeamInit(pSpriteName, width); pBeam->BeamInit(pSpriteName, width);
@ -355,10 +350,8 @@ void CBeam::DoSparks(const Vector &start, const Vector &end)
} }
} }
LINK_ENTITY_TO_CLASS(env_lightning, CLightning); LINK_ENTITY_TO_CLASS(env_lightning, CLightning, CCSLightning);
LINK_ENTITY_TO_CLASS(env_beam, CLightning); LINK_ENTITY_TO_CLASS(env_beam, CLightning, CCSLightning);
LINK_CLASS_TO_WRAP(CLightning, CCSLightning);
IMPLEMENT_SAVERESTORE(CLightning, CBeam); IMPLEMENT_SAVERESTORE(CLightning, CBeam);
void CLightning::__MAKE_VHOOK(Spawn)() void CLightning::__MAKE_VHOOK(Spawn)()
@ -853,8 +846,7 @@ void CLightning::BeamUpdateVars()
} }
} }
LINK_ENTITY_TO_CLASS(env_laser, CLaser); LINK_ENTITY_TO_CLASS(env_laser, CLaser, CCSLaser);
LINK_CLASS_TO_WRAP(CLaser, CCSLaser);
IMPLEMENT_SAVERESTORE(CLaser, CBeam); IMPLEMENT_SAVERESTORE(CLaser, CBeam);
void CLaser::__MAKE_VHOOK(Spawn)() void CLaser::__MAKE_VHOOK(Spawn)()
@ -1013,8 +1005,7 @@ void CLaser::StrikeThink()
pev->nextthink = gpGlobals->time + 0.1f; pev->nextthink = gpGlobals->time + 0.1f;
} }
LINK_ENTITY_TO_CLASS(env_glow, CGlow); LINK_ENTITY_TO_CLASS(env_glow, CGlow, CCSGlow);
LINK_CLASS_TO_WRAP(CGlow, CCSGlow);
IMPLEMENT_SAVERESTORE(CGlow, CPointEntity); IMPLEMENT_SAVERESTORE(CGlow, CPointEntity);
void CGlow::__MAKE_VHOOK(Spawn)() void CGlow::__MAKE_VHOOK(Spawn)()
@ -1053,8 +1044,7 @@ void CGlow::Animate(float frames)
} }
} }
LINK_ENTITY_TO_CLASS(env_bombglow, CBombGlow); LINK_ENTITY_TO_CLASS(env_bombglow, CBombGlow, CCSBombGlow);
LINK_CLASS_TO_WRAP(CBombGlow, CCSBombGlow);
void CBombGlow::__MAKE_VHOOK(Spawn)() void CBombGlow::__MAKE_VHOOK(Spawn)()
{ {
@ -1106,8 +1096,7 @@ void CBombGlow::__MAKE_VHOOK(Think)()
pev->nextthink = gpGlobals->time + 0.05f; pev->nextthink = gpGlobals->time + 0.05f;
} }
LINK_ENTITY_TO_CLASS(env_sprite, CSprite); LINK_ENTITY_TO_CLASS(env_sprite, CSprite, CCSSprite);
LINK_CLASS_TO_WRAP(CSprite, CCSSprite);
IMPLEMENT_SAVERESTORE(CSprite, CPointEntity); IMPLEMENT_SAVERESTORE(CSprite, CPointEntity);
void CSprite::__MAKE_VHOOK(Spawn)() void CSprite::__MAKE_VHOOK(Spawn)()
@ -1171,7 +1160,7 @@ void CSprite::SpriteInit(const char *pSpriteName, const Vector &origin)
CSprite *CSprite::SpriteCreate(const char *pSpriteName, const Vector &origin, BOOL animate) CSprite *CSprite::SpriteCreate(const char *pSpriteName, const Vector &origin, BOOL animate)
{ {
CSprite *pSprite = GetClassPtr((CSprite *)NULL); CSprite *pSprite = GetClassPtr<CCSSprite>((CSprite *)NULL);
pSprite->SpriteInit(pSpriteName, origin); pSprite->SpriteInit(pSpriteName, origin);
MAKE_STRING_CLASS("env_sprite", pSprite->pev); MAKE_STRING_CLASS("env_sprite", pSprite->pev);
@ -1284,8 +1273,7 @@ void CSprite::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCaller, U
} }
IMPLEMENT_SAVERESTORE(CGibShooter, CBaseDelay); IMPLEMENT_SAVERESTORE(CGibShooter, CBaseDelay);
LINK_ENTITY_TO_CLASS(gibshooter, CGibShooter); LINK_ENTITY_TO_CLASS(gibshooter, CGibShooter, CCSGibShooter);
LINK_CLASS_TO_WRAP(CGibShooter, CCSGibShooter);
void CGibShooter::__MAKE_VHOOK(Precache)() void CGibShooter::__MAKE_VHOOK(Precache)()
{ {
@ -1357,7 +1345,7 @@ CGib *CGibShooter::__MAKE_VHOOK(CreateGib)()
if (CVAR_GET_FLOAT("violence_hgibs") == 0) if (CVAR_GET_FLOAT("violence_hgibs") == 0)
return NULL; return NULL;
CGib *pGib = GetClassPtr((CGib *)NULL); CGib *pGib = GetClassPtr<CCSGib>((CGib *)NULL);
pGib->Spawn("models/hgibs.mdl"); pGib->Spawn("models/hgibs.mdl");
pGib->m_bloodColor = BLOOD_COLOR_RED; pGib->m_bloodColor = BLOOD_COLOR_RED;
@ -1437,8 +1425,7 @@ void CGibShooter::ShootThink()
} }
} }
LINK_ENTITY_TO_CLASS(env_shooter, CEnvShooter); LINK_ENTITY_TO_CLASS(env_shooter, CEnvShooter, CCSEnvShooter);
LINK_CLASS_TO_WRAP(CEnvShooter, CCSEnvShooter);
void CEnvShooter::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd) void CEnvShooter::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
{ {
@ -1487,7 +1474,7 @@ void CEnvShooter::__MAKE_VHOOK(Precache)()
CGib *CEnvShooter::__MAKE_VHOOK(CreateGib)() CGib *CEnvShooter::__MAKE_VHOOK(CreateGib)()
{ {
CGib *pGib = GetClassPtr((CGib *)NULL); CGib *pGib = GetClassPtr<CCSGib>((CGib *)NULL);
pGib->Spawn(STRING(pev->model)); pGib->Spawn(STRING(pev->model));
@ -1510,8 +1497,7 @@ CGib *CEnvShooter::__MAKE_VHOOK(CreateGib)()
return pGib; return pGib;
} }
LINK_ENTITY_TO_CLASS(test_effect, CTestEffect); LINK_ENTITY_TO_CLASS(test_effect, CTestEffect, CCSTestEffect);
LINK_CLASS_TO_WRAP(CTestEffect, CCSTestEffect);
void CTestEffect::__MAKE_VHOOK(Spawn)() void CTestEffect::__MAKE_VHOOK(Spawn)()
{ {
@ -1585,8 +1571,7 @@ void CTestEffect::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCalle
m_flStartTime = gpGlobals->time; m_flStartTime = gpGlobals->time;
} }
LINK_ENTITY_TO_CLASS(env_blood, CBlood); LINK_ENTITY_TO_CLASS(env_blood, CBlood, CCSBlood);
LINK_CLASS_TO_WRAP(CBlood, CCSBlood);
void CBlood::__MAKE_VHOOK(Spawn)() void CBlood::__MAKE_VHOOK(Spawn)()
{ {
@ -1674,8 +1659,7 @@ void CBlood::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCaller, US
} }
} }
LINK_ENTITY_TO_CLASS(env_shake, CShake); LINK_ENTITY_TO_CLASS(env_shake, CShake, CCSShake);
LINK_CLASS_TO_WRAP(CShake, CCSShake);
void CShake::__MAKE_VHOOK(Spawn)() void CShake::__MAKE_VHOOK(Spawn)()
{ {
@ -1719,8 +1703,7 @@ void CShake::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCaller, US
UTIL_ScreenShake(pev->origin, Amplitude(), Frequency(), Duration(), Radius()); UTIL_ScreenShake(pev->origin, Amplitude(), Frequency(), Duration(), Radius());
} }
LINK_ENTITY_TO_CLASS(env_fade, CFade); LINK_ENTITY_TO_CLASS(env_fade, CFade, CCSFade);
LINK_CLASS_TO_WRAP(CFade, CCSFade);
void CFade::__MAKE_VHOOK(Spawn)() void CFade::__MAKE_VHOOK(Spawn)()
{ {
@ -1769,8 +1752,7 @@ void CFade::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCaller, USE
SUB_UseTargets(this, USE_TOGGLE, 0); SUB_UseTargets(this, USE_TOGGLE, 0);
} }
LINK_ENTITY_TO_CLASS(env_message, CMessage); LINK_ENTITY_TO_CLASS(env_message, CMessage, CCSMessage);
LINK_CLASS_TO_WRAP(CMessage, CCSMessage);
void CMessage::__MAKE_VHOOK(Spawn)() void CMessage::__MAKE_VHOOK(Spawn)()
{ {
@ -1863,8 +1845,7 @@ void CMessage::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCaller,
SUB_UseTargets(this, USE_TOGGLE, 0); SUB_UseTargets(this, USE_TOGGLE, 0);
} }
LINK_ENTITY_TO_CLASS(env_funnel, CEnvFunnel); LINK_ENTITY_TO_CLASS(env_funnel, CEnvFunnel, CCSEnvFunnel);
LINK_CLASS_TO_WRAP(CEnvFunnel, CCSEnvFunnel);
void CEnvFunnel::__MAKE_VHOOK(Precache)() void CEnvFunnel::__MAKE_VHOOK(Precache)()
{ {
@ -1910,8 +1891,7 @@ void CEnvBeverage::__MAKE_VHOOK(Precache)()
PRECACHE_SOUND("weapons/g_bounce3.wav"); PRECACHE_SOUND("weapons/g_bounce3.wav");
} }
LINK_ENTITY_TO_CLASS(env_beverage, CEnvBeverage); LINK_ENTITY_TO_CLASS(env_beverage, CEnvBeverage, CCSEnvBeverage);
LINK_CLASS_TO_WRAP(CEnvBeverage, CCSEnvBeverage);
void CEnvBeverage::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value) void CEnvBeverage::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value)
{ {
@ -1953,8 +1933,7 @@ void CItemSoda::__MAKE_VHOOK(Precache)()
; ;
} }
LINK_ENTITY_TO_CLASS(item_sodacan, CItemSoda); LINK_ENTITY_TO_CLASS(item_sodacan, CItemSoda, CCSItemSoda);
LINK_CLASS_TO_WRAP(CItemSoda, CCSItemSoda);
void CItemSoda::__MAKE_VHOOK(Spawn)() void CItemSoda::__MAKE_VHOOK(Spawn)()
{ {

View File

@ -71,7 +71,6 @@
class CSprite: public CPointEntity class CSprite: public CPointEntity
{ {
public: public:
CSprite();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual void Restart(); virtual void Restart();
@ -157,7 +156,6 @@ private:
class CBeam: public CBaseEntity class CBeam: public CBaseEntity
{ {
public: public:
CBeam();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual int ObjectCaps() virtual int ObjectCaps()
@ -240,7 +238,6 @@ public:
class CLaser: public CBeam class CLaser: public CBeam
{ {
public: public:
CLaser();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual void KeyValue(KeyValueData *pkvd); virtual void KeyValue(KeyValueData *pkvd);
@ -278,7 +275,6 @@ public:
class CBubbling: public CBaseEntity class CBubbling: public CBaseEntity
{ {
public: public:
CBubbling();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual void KeyValue(KeyValueData *pkvd); virtual void KeyValue(KeyValueData *pkvd);
@ -313,7 +309,6 @@ public:
class CLightning: public CBeam class CLightning: public CBeam
{ {
public: public:
CLightning();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual void KeyValue(KeyValueData *pkvd); virtual void KeyValue(KeyValueData *pkvd);
@ -371,7 +366,6 @@ public:
class CGlow: public CPointEntity class CGlow: public CPointEntity
{ {
public: public:
CGlow();
virtual void Spawn(); virtual void Spawn();
virtual int Save(CSave &save); virtual int Save(CSave &save);
virtual int Restore(CRestore &restore); virtual int Restore(CRestore &restore);
@ -398,7 +392,6 @@ public:
class CBombGlow: public CSprite class CBombGlow: public CSprite
{ {
public: public:
CBombGlow();
virtual void Spawn(); virtual void Spawn();
virtual void Think(); virtual void Think();
@ -418,7 +411,6 @@ public:
class CGibShooter: public CBaseDelay class CGibShooter: public CBaseDelay
{ {
public: public:
CGibShooter();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual void KeyValue(KeyValueData *pkvd); virtual void KeyValue(KeyValueData *pkvd);
@ -458,7 +450,6 @@ public:
class CEnvShooter: public CGibShooter class CEnvShooter: public CGibShooter
{ {
public: public:
CEnvShooter();
virtual void Precache(); virtual void Precache();
virtual void KeyValue(KeyValueData *pkvd); virtual void KeyValue(KeyValueData *pkvd);
virtual CGib *CreateGib(); virtual CGib *CreateGib();
@ -478,7 +469,6 @@ public:
class CTestEffect: public CBaseDelay class CTestEffect: public CBaseDelay
{ {
public: public:
CTestEffect();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual void Use(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value); virtual void Use(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value);
@ -507,7 +497,6 @@ public:
class CBlood: public CPointEntity class CBlood: public CPointEntity
{ {
public: public:
CBlood();
virtual void Spawn(); virtual void Spawn();
virtual void KeyValue(KeyValueData *pkvd); virtual void KeyValue(KeyValueData *pkvd);
virtual void Use(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value); virtual void Use(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value);
@ -535,7 +524,6 @@ public:
class CShake: public CPointEntity class CShake: public CPointEntity
{ {
public: public:
CShake();
virtual void Spawn(); virtual void Spawn();
virtual void KeyValue(KeyValueData *pkvd); virtual void KeyValue(KeyValueData *pkvd);
virtual void Use(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value); virtual void Use(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value);
@ -563,7 +551,6 @@ public:
class CFade: public CPointEntity class CFade: public CPointEntity
{ {
public: public:
CFade();
virtual void Spawn(); virtual void Spawn();
virtual void KeyValue(KeyValueData *pkvd); virtual void KeyValue(KeyValueData *pkvd);
virtual void Use(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value); virtual void Use(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value);
@ -587,7 +574,6 @@ public:
class CMessage: public CPointEntity class CMessage: public CPointEntity
{ {
public: public:
CMessage();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual void KeyValue(KeyValueData *pkvd); virtual void KeyValue(KeyValueData *pkvd);
@ -607,7 +593,6 @@ public:
class CEnvFunnel: public CBaseDelay class CEnvFunnel: public CBaseDelay
{ {
public: public:
CEnvFunnel();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual void Use(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value); virtual void Use(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value);
@ -627,7 +612,6 @@ public:
class CEnvBeverage: public CBaseDelay class CEnvBeverage: public CBaseDelay
{ {
public: public:
CEnvBeverage();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual void Use(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value); virtual void Use(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value);
@ -645,7 +629,6 @@ public:
class CItemSoda: public CBaseEntity class CItemSoda: public CBaseEntity
{ {
public: public:
CItemSoda();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();

View File

@ -13,8 +13,7 @@ TYPEDESCRIPTION CEnvExplosion::m_SaveData[] =
#endif #endif
LINK_ENTITY_TO_CLASS(spark_shower, CShower); LINK_ENTITY_TO_CLASS(spark_shower, CShower, CCSShower);
LINK_CLASS_TO_WRAP(CShower, CCSShower);
void CShower::__MAKE_VHOOK(Spawn)() void CShower::__MAKE_VHOOK(Spawn)()
{ {
@ -69,8 +68,7 @@ void CShower::__MAKE_VHOOK(Touch)(CBaseEntity *pOther)
} }
IMPLEMENT_SAVERESTORE(CEnvExplosion, CBaseMonster); IMPLEMENT_SAVERESTORE(CEnvExplosion, CBaseMonster);
LINK_ENTITY_TO_CLASS(env_explosion, CEnvExplosion); LINK_ENTITY_TO_CLASS(env_explosion, CEnvExplosion, CCSEnvExplosion);
LINK_CLASS_TO_WRAP(CEnvExplosion, CCSEnvExplosion);
void CEnvExplosion::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd) void CEnvExplosion::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
{ {

View File

@ -42,7 +42,6 @@
class CShower: public CBaseEntity class CShower: public CBaseEntity
{ {
public: public:
CShower();
virtual void Spawn(); virtual void Spawn();
virtual int ObjectCaps() { return FCAP_DONT_SAVE; } virtual int ObjectCaps() { return FCAP_DONT_SAVE; }
virtual void Think(); virtual void Think();
@ -61,7 +60,6 @@ public:
class CEnvExplosion: public CBaseMonster class CEnvExplosion: public CBaseMonster
{ {
public: public:
CEnvExplosion();
virtual void Spawn(); virtual void Spawn();
virtual void KeyValue(KeyValueData *pkvd); virtual void KeyValue(KeyValueData *pkvd);
virtual int Save(CSave &save); virtual int Save(CSave &save);

View File

@ -169,8 +169,7 @@ void CBreakable::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
CBaseDelay::KeyValue(pkvd); CBaseDelay::KeyValue(pkvd);
} }
LINK_ENTITY_TO_CLASS(func_breakable, CBreakable); LINK_ENTITY_TO_CLASS(func_breakable, CBreakable, CCSBreakable);
LINK_CLASS_TO_WRAP(CBreakable, CCSBreakable);
IMPLEMENT_SAVERESTORE(CBreakable, CBaseEntity); IMPLEMENT_SAVERESTORE(CBreakable, CBaseEntity);
void CBreakable::__MAKE_VHOOK(Spawn)() void CBreakable::__MAKE_VHOOK(Spawn)()
@ -849,8 +848,7 @@ int CBreakable::__MAKE_VHOOK(DamageDecal)(int bitsDamageType)
return CBaseEntity::DamageDecal(bitsDamageType); return CBaseEntity::DamageDecal(bitsDamageType);
} }
LINK_ENTITY_TO_CLASS(func_pushable, CPushable); LINK_ENTITY_TO_CLASS(func_pushable, CPushable, CCSPushable);
LINK_CLASS_TO_WRAP(CPushable, CCSPushable);
IMPLEMENT_SAVERESTORE(CPushable, CBreakable); IMPLEMENT_SAVERESTORE(CPushable, CBreakable);
void CPushable::__MAKE_VHOOK(Spawn)() void CPushable::__MAKE_VHOOK(Spawn)()

View File

@ -70,7 +70,6 @@ typedef enum
class CBreakable: public CBaseDelay class CBreakable: public CBaseDelay
{ {
public: public:
CBreakable();
// basic functions // basic functions
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
@ -144,7 +143,6 @@ public:
class CPushable: public CBreakable class CPushable: public CBreakable
{ {
public: public:
CPushable();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual void KeyValue(KeyValueData *pkvd); virtual void KeyValue(KeyValueData *pkvd);

View File

@ -60,7 +60,6 @@ Vector gTankSpread[] =
const int MAX_FIRING_SPREADS = ARRAYSIZE(gTankSpread); const int MAX_FIRING_SPREADS = ARRAYSIZE(gTankSpread);
IMPLEMENT_SAVERESTORE(CFuncTank, CBaseEntity); IMPLEMENT_SAVERESTORE(CFuncTank, CBaseEntity);
LINK_CLASS_TO_WRAP(CFuncTank, CCSFuncTank);
void CFuncTank::__MAKE_VHOOK(Spawn)() void CFuncTank::__MAKE_VHOOK(Spawn)()
{ {
@ -655,8 +654,7 @@ void CFuncTank::StopRotSound()
pev->spawnflags &= ~SF_TANK_SOUNDON; pev->spawnflags &= ~SF_TANK_SOUNDON;
} }
LINK_ENTITY_TO_CLASS(func_tank, CFuncTankGun); LINK_ENTITY_TO_CLASS(func_tank, CFuncTankGun, CCSFuncTankGun);
LINK_CLASS_TO_WRAP(CFuncTankGun, CCSFuncTankGun);
void CFuncTankGun::__MAKE_VHOOK(Fire)(const Vector &barrelEnd, const Vector &forward, entvars_t *pevAttacker) void CFuncTankGun::__MAKE_VHOOK(Fire)(const Vector &barrelEnd, const Vector &forward, entvars_t *pevAttacker)
{ {
@ -695,8 +693,7 @@ void CFuncTankGun::__MAKE_VHOOK(Fire)(const Vector &barrelEnd, const Vector &for
CFuncTank::Fire(barrelEnd, forward, pevAttacker); CFuncTank::Fire(barrelEnd, forward, pevAttacker);
} }
LINK_ENTITY_TO_CLASS(func_tanklaser, CFuncTankLaser); LINK_ENTITY_TO_CLASS(func_tanklaser, CFuncTankLaser, CCSFuncTankLaser);
LINK_CLASS_TO_WRAP(CFuncTankLaser, CCSFuncTankLaser);
IMPLEMENT_SAVERESTORE(CFuncTankLaser, CFuncTank); IMPLEMENT_SAVERESTORE(CFuncTankLaser, CFuncTank);
void CFuncTankLaser::__MAKE_VHOOK(Activate)() void CFuncTankLaser::__MAKE_VHOOK(Activate)()
@ -792,8 +789,7 @@ void CFuncTankLaser::__MAKE_VHOOK(Fire)(const Vector &barrelEnd, const Vector &f
} }
} }
LINK_ENTITY_TO_CLASS(func_tankrocket, CFuncTankRocket); LINK_ENTITY_TO_CLASS(func_tankrocket, CFuncTankRocket, CCSFuncTankRocket);
LINK_CLASS_TO_WRAP(CFuncTankRocket, CCSFuncTankRocket);
void CFuncTankRocket::__MAKE_VHOOK(Precache)() void CFuncTankRocket::__MAKE_VHOOK(Precache)()
{ {
@ -823,8 +819,7 @@ void CFuncTankRocket::__MAKE_VHOOK(Fire)(const Vector &barrelEnd, const Vector &
CFuncTank::Fire(barrelEnd, forward, pev); CFuncTank::Fire(barrelEnd, forward, pev);
} }
LINK_ENTITY_TO_CLASS(func_tankmortar, CFuncTankMortar); LINK_ENTITY_TO_CLASS(func_tankmortar, CFuncTankMortar, CCSFuncTankMortar);
LINK_CLASS_TO_WRAP(CFuncTankMortar, CCSFuncTankMortar);
void CFuncTankMortar::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd) void CFuncTankMortar::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
{ {
@ -852,9 +847,7 @@ void CFuncTankMortar::__MAKE_VHOOK(Fire)(const Vector &barrelEnd, const Vector &
UTIL_MakeAimVectors(pev->angles); UTIL_MakeAimVectors(pev->angles);
TankTrace(barrelEnd, forward, gTankSpread[m_spread], tr); TankTrace(barrelEnd, forward, gTankSpread[m_spread], tr);
ExplosionCreate(tr.vecEndPos, pev->angles, edict(), pev->impulse, TRUE); ExplosionCreate(tr.vecEndPos, pev->angles, edict(), pev->impulse, TRUE);
CFuncTank::Fire(barrelEnd, forward, pev); CFuncTank::Fire(barrelEnd, forward, pev);
} }
} }
@ -862,8 +855,7 @@ void CFuncTankMortar::__MAKE_VHOOK(Fire)(const Vector &barrelEnd, const Vector &
CFuncTank::Fire(barrelEnd, forward, pev); CFuncTank::Fire(barrelEnd, forward, pev);
} }
LINK_ENTITY_TO_CLASS(func_tankcontrols, CFuncTankControls); LINK_ENTITY_TO_CLASS(func_tankcontrols, CFuncTankControls, CCSFuncTankControls);
LINK_CLASS_TO_WRAP(CFuncTankControls, CCSFuncTankControls);
IMPLEMENT_SAVERESTORE(CFuncTankControls, CBaseEntity); IMPLEMENT_SAVERESTORE(CFuncTankControls, CBaseEntity);
void CFuncTankControls::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value) void CFuncTankControls::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value)

View File

@ -51,7 +51,6 @@ enum TANKBULLET
class CFuncTank: public CBaseEntity class CFuncTank: public CBaseEntity
{ {
public: public:
CFuncTank();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual void KeyValue(KeyValueData *pkvd); virtual void KeyValue(KeyValueData *pkvd);
@ -160,7 +159,6 @@ protected:
class CFuncTankGun: public CFuncTank class CFuncTankGun: public CFuncTank
{ {
public: public:
CFuncTankGun();
virtual void Fire(const Vector &barrelEnd, const Vector &forward, entvars_t *pevAttacker); virtual void Fire(const Vector &barrelEnd, const Vector &forward, entvars_t *pevAttacker);
#ifdef HOOK_GAMEDLL #ifdef HOOK_GAMEDLL
@ -172,7 +170,6 @@ public:
class CFuncTankLaser: public CFuncTank class CFuncTankLaser: public CFuncTank
{ {
public: public:
CFuncTankLaser();
virtual void KeyValue(KeyValueData *pkvd); virtual void KeyValue(KeyValueData *pkvd);
virtual int Save(CSave &save); virtual int Save(CSave &save);
virtual int Restore(CRestore &restore); virtual int Restore(CRestore &restore);
@ -204,7 +201,6 @@ private:
class CFuncTankRocket: public CFuncTank class CFuncTankRocket: public CFuncTank
{ {
public: public:
CFuncTankRocket();
virtual void Precache(); virtual void Precache();
virtual void Fire(const Vector &barrelEnd, const Vector &forward, entvars_t *pevAttacker); virtual void Fire(const Vector &barrelEnd, const Vector &forward, entvars_t *pevAttacker);
@ -220,7 +216,6 @@ public:
class CFuncTankMortar: public CFuncTank class CFuncTankMortar: public CFuncTank
{ {
public: public:
CFuncTankMortar();
virtual void KeyValue(KeyValueData *pkvd); virtual void KeyValue(KeyValueData *pkvd);
virtual void Fire(const Vector &barrelEnd, const Vector &forward, entvars_t *pevAttacker); virtual void Fire(const Vector &barrelEnd, const Vector &forward, entvars_t *pevAttacker);
@ -236,7 +231,6 @@ public:
class CFuncTankControls: public CBaseEntity class CFuncTankControls: public CBaseEntity
{ {
public: public:
CFuncTankControls();
virtual void Spawn(); virtual void Spawn();
virtual int Save(CSave &save); virtual int Save(CSave &save);
virtual int Restore(CRestore &restore); virtual int Restore(CRestore &restore);

View File

@ -563,6 +563,16 @@ public:
bool IsMatchStarted() { return (m_fTeamCount != 0.0f || m_fCareerRoundMenuTime != 0.0f || m_fCareerMatchMenuTime != 0.0f); } bool IsMatchStarted() { return (m_fTeamCount != 0.0f || m_fCareerRoundMenuTime != 0.0f || m_fCareerMatchMenuTime != 0.0f); }
void SendMOTDToClient(edict_t *client); void SendMOTDToClient(edict_t *client);
// allow the mode of fire on a friendly player (FFA)
inline bool IsFriendlyFireAttack() const
{
#ifdef REGAMEDLL_ADD
if (friendlyfire.string[0] == '2')
return true;
#endif
return false;
}
private: private:
bool HasRoundTimeExpired(); bool HasRoundTimeExpired();
bool IsBombPlanted(); bool IsBombPlanted();

View File

@ -26,8 +26,7 @@ TYPEDESCRIPTION CGrenade::m_SaveData[] =
#endif #endif
LINK_ENTITY_TO_CLASS(grenade, CGrenade); LINK_ENTITY_TO_CLASS(grenade, CGrenade, CCSGrenade);
LINK_CLASS_TO_WRAP(CGrenade, CCSGrenade);
void CGrenade::Explode(Vector vecSrc, Vector vecAim) void CGrenade::Explode(Vector vecSrc, Vector vecAim)
{ {
@ -823,7 +822,7 @@ void CGrenade::__MAKE_VHOOK(Spawn)()
NOXREF CGrenade *CGrenade::ShootContact(entvars_t *pevOwner, Vector vecStart, Vector vecVelocity) NOXREF CGrenade *CGrenade::ShootContact(entvars_t *pevOwner, Vector vecStart, Vector vecVelocity)
{ {
CGrenade *pGrenade = GetClassPtr((CGrenade *)NULL); CGrenade *pGrenade = GetClassPtr<CCSGrenade>((CGrenade *)NULL);
pGrenade->Spawn(); pGrenade->Spawn();
// contact grenades arc lower // contact grenades arc lower
@ -851,7 +850,7 @@ NOXREF CGrenade *CGrenade::ShootContact(entvars_t *pevOwner, Vector vecStart, Ve
CGrenade *CGrenade::ShootTimed2(entvars_t *pevOwner, Vector vecStart, Vector vecVelocity, float time, int iTeam, unsigned short usEvent) CGrenade *CGrenade::ShootTimed2(entvars_t *pevOwner, Vector vecStart, Vector vecVelocity, float time, int iTeam, unsigned short usEvent)
{ {
CGrenade *pGrenade = GetClassPtr((CGrenade *)NULL); CGrenade *pGrenade = GetClassPtr<CCSGrenade>((CGrenade *)NULL);
pGrenade->Spawn(); pGrenade->Spawn();
UTIL_SetOrigin(pGrenade->pev, vecStart); UTIL_SetOrigin(pGrenade->pev, vecStart);
@ -885,7 +884,7 @@ CGrenade *CGrenade::ShootTimed2(entvars_t *pevOwner, Vector vecStart, Vector vec
CGrenade *CGrenade::ShootTimed(entvars_t *pevOwner, Vector vecStart, Vector vecVelocity, float time) CGrenade *CGrenade::ShootTimed(entvars_t *pevOwner, Vector vecStart, Vector vecVelocity, float time)
{ {
CGrenade *pGrenade = GetClassPtr((CGrenade *)NULL); CGrenade *pGrenade = GetClassPtr<CCSGrenade>((CGrenade *)NULL);
pGrenade->Spawn(); pGrenade->Spawn();
UTIL_SetOrigin(pGrenade->pev, vecStart); UTIL_SetOrigin(pGrenade->pev, vecStart);
@ -929,7 +928,7 @@ void CGrenade::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCaller,
if (!m_bIsC4) if (!m_bIsC4)
return; return;
CBasePlayer *player = GetClassPtr((CBasePlayer *)pActivator->pev); CBasePlayer *player = GetClassPtr<CCSPlayer>((CBasePlayer *)pActivator->pev);
// For CTs to defuse the c4 // For CTs to defuse the c4
if (player->m_iTeam != CT) if (player->m_iTeam != CT)
@ -1003,7 +1002,7 @@ void CGrenade::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCaller,
CGrenade *CGrenade::ShootSatchelCharge(entvars_t *pevOwner, Vector vecStart, Vector vecAngles) CGrenade *CGrenade::ShootSatchelCharge(entvars_t *pevOwner, Vector vecStart, Vector vecAngles)
{ {
CGrenade *pGrenade = GetClassPtr((CGrenade *)NULL); CGrenade *pGrenade = GetClassPtr<CCSGrenade>((CGrenade *)NULL);
pGrenade->pev->movetype = MOVETYPE_TOSS; pGrenade->pev->movetype = MOVETYPE_TOSS;
MAKE_STRING_CLASS("grenade", pGrenade->pev); MAKE_STRING_CLASS("grenade", pGrenade->pev);
@ -1057,7 +1056,7 @@ CGrenade *CGrenade::ShootSatchelCharge(entvars_t *pevOwner, Vector vecStart, Vec
CGrenade *CGrenade::ShootSmokeGrenade(entvars_t *pevOwner, Vector vecStart, Vector vecVelocity, float time, unsigned short usEvent) CGrenade *CGrenade::ShootSmokeGrenade(entvars_t *pevOwner, Vector vecStart, Vector vecVelocity, float time, unsigned short usEvent)
{ {
CGrenade *pGrenade = GetClassPtr((CGrenade *)NULL); CGrenade *pGrenade = GetClassPtr<CCSGrenade>((CGrenade *)NULL);
pGrenade->Spawn(); pGrenade->Spawn();
UTIL_SetOrigin(pGrenade->pev, vecStart); UTIL_SetOrigin(pGrenade->pev, vecStart);

View File

@ -17,8 +17,7 @@ TYPEDESCRIPTION CRecharge::m_SaveData[] =
#endif #endif
IMPLEMENT_SAVERESTORE(CRecharge, CBaseEntity); IMPLEMENT_SAVERESTORE(CRecharge, CBaseEntity);
LINK_ENTITY_TO_CLASS(func_recharge, CRecharge); LINK_ENTITY_TO_CLASS(func_recharge, CRecharge, CCSRecharge);
LINK_CLASS_TO_WRAP(CRecharge, CCSRecharge);
void CRecharge::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd) void CRecharge::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
{ {

View File

@ -35,7 +35,6 @@
class CRecharge: public CBaseToggle class CRecharge: public CBaseToggle
{ {
public: public:
CRecharge();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual void KeyValue(KeyValueData *pkvd); virtual void KeyValue(KeyValueData *pkvd);

View File

@ -25,18 +25,14 @@ TYPEDESCRIPTION CWreckage::m_SaveData[] =
#endif #endif
IMPLEMENT_SAVERESTORE(CCycler, CBaseToggle); IMPLEMENT_SAVERESTORE(CCycler, CBaseToggle);
LINK_CLASS_TO_WRAP(CCycler, CCSCycler);
void CGenericCycler::__MAKE_VHOOK(Spawn)() void CGenericCycler::__MAKE_VHOOK(Spawn)()
{ {
GenericCyclerSpawn((char *)STRING(pev->model), Vector(-16, -16, 0), Vector(16, 16, 72)); GenericCyclerSpawn((char *)STRING(pev->model), Vector(-16, -16, 0), Vector(16, 16, 72));
} }
LINK_ENTITY_TO_CLASS(cycler, CGenericCycler); LINK_ENTITY_TO_CLASS(cycler, CGenericCycler, CCSGenericCycler);
LINK_CLASS_TO_WRAP(CGenericCycler, CCSGenericCycler); LINK_ENTITY_TO_CLASS(cycler_prdroid, CCyclerProbe, CCSCyclerProbe);
LINK_ENTITY_TO_CLASS(cycler_prdroid, CCyclerProbe);
LINK_CLASS_TO_WRAP(CCyclerProbe, CCSCyclerProbe);
void CCyclerProbe::__MAKE_VHOOK(Spawn)() void CCyclerProbe::__MAKE_VHOOK(Spawn)()
{ {
@ -165,8 +161,7 @@ int CCycler::__MAKE_VHOOK(TakeDamage)(entvars_t *pevInflictor, entvars_t *pevAtt
return 0; return 0;
} }
LINK_ENTITY_TO_CLASS(cycler_sprite, CCyclerSprite); LINK_ENTITY_TO_CLASS(cycler_sprite, CCyclerSprite, CCSCyclerSprite);
LINK_CLASS_TO_WRAP(CCyclerSprite, CCSCyclerSprite);
IMPLEMENT_SAVERESTORE(CCyclerSprite, CBaseEntity); IMPLEMENT_SAVERESTORE(CCyclerSprite, CBaseEntity);
void CCyclerSprite::__MAKE_VHOOK(Spawn)() void CCyclerSprite::__MAKE_VHOOK(Spawn)()
@ -247,8 +242,7 @@ void CCyclerSprite::Animate(float frames)
} }
} }
LINK_ENTITY_TO_CLASS(cycler_weapon, CWeaponCycler); LINK_ENTITY_TO_CLASS(cycler_weapon, CWeaponCycler, CCSWeaponCycler);
LINK_CLASS_TO_WRAP(CWeaponCycler, CCSWeaponCycler);
void CWeaponCycler::__MAKE_VHOOK(Spawn)() void CWeaponCycler::__MAKE_VHOOK(Spawn)()
{ {
@ -309,8 +303,7 @@ void CWeaponCycler::__MAKE_VHOOK(SecondaryAttack)()
} }
IMPLEMENT_SAVERESTORE(CWreckage, CBaseToggle); IMPLEMENT_SAVERESTORE(CWreckage, CBaseToggle);
LINK_ENTITY_TO_CLASS(cycler_wreckage, CWreckage); LINK_ENTITY_TO_CLASS(cycler_wreckage, CWreckage, CCSWreckage);
LINK_CLASS_TO_WRAP(CWreckage, CCSWreckage);
void CWreckage::__MAKE_VHOOK(Spawn)() void CWreckage::__MAKE_VHOOK(Spawn)()
{ {

View File

@ -35,7 +35,6 @@
class CCycler: public CBaseMonster class CCycler: public CBaseMonster
{ {
public: public:
CCycler();
virtual void Spawn(); virtual void Spawn();
virtual int Save(CSave &save); virtual int Save(CSave &save);
virtual int Restore(CRestore &restore); virtual int Restore(CRestore &restore);
@ -71,7 +70,6 @@ public:
class CGenericCycler: public CCycler class CGenericCycler: public CCycler
{ {
public: public:
CGenericCycler();
virtual void Spawn(); virtual void Spawn();
#ifdef HOOK_GAMEDLL #ifdef HOOK_GAMEDLL
@ -86,7 +84,6 @@ public:
class CCyclerProbe: public CCycler class CCyclerProbe: public CCycler
{ {
public: public:
CCyclerProbe();
virtual void Spawn(); virtual void Spawn();
#ifdef HOOK_GAMEDLL #ifdef HOOK_GAMEDLL
@ -100,7 +97,6 @@ public:
class CCyclerSprite: public CBaseEntity class CCyclerSprite: public CBaseEntity
{ {
public: public:
CCyclerSprite();
virtual void Spawn(); virtual void Spawn();
virtual void Restart(); virtual void Restart();
virtual int Save(CSave &save); virtual int Save(CSave &save);
@ -141,7 +137,6 @@ public:
class CWeaponCycler: public CBasePlayerWeapon class CWeaponCycler: public CBasePlayerWeapon
{ {
public: public:
CWeaponCycler();
virtual void Spawn(); virtual void Spawn();
virtual int GetItemInfo(ItemInfo *p) { return 0; } virtual int GetItemInfo(ItemInfo *p) { return 0; }
virtual BOOL Deploy(); virtual BOOL Deploy();
@ -169,7 +164,6 @@ public:
class CWreckage: public CBaseMonster class CWreckage: public CBaseMonster
{ {
public: public:
CWreckage();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual int Save(CSave &save); virtual int Save(CSave &save);

View File

@ -16,8 +16,7 @@ TYPEDESCRIPTION CWallHealth::m_SaveData[] =
#endif #endif
LINK_ENTITY_TO_CLASS(item_healthkit, CHealthKit); LINK_ENTITY_TO_CLASS(item_healthkit, CHealthKit, CCSHealthKit);
LINK_CLASS_TO_WRAP(CHealthKit, CCSHealthKit);
void CHealthKit::__MAKE_VHOOK(Spawn)() void CHealthKit::__MAKE_VHOOK(Spawn)()
{ {
@ -55,7 +54,7 @@ BOOL CHealthKit::__MAKE_VHOOK(MyTouch)(CBasePlayer *pPlayer)
} }
IMPLEMENT_SAVERESTORE(CWallHealth, CBaseEntity); IMPLEMENT_SAVERESTORE(CWallHealth, CBaseEntity);
LINK_ENTITY_TO_CLASS(func_healthcharger, CWallHealth); LINK_ENTITY_TO_CLASS(func_healthcharger, CWallHealth, CCSWallHealth);
void CWallHealth::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd) void CWallHealth::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
{ {

View File

@ -35,7 +35,6 @@
class CHealthKit: public CItem class CHealthKit: public CItem
{ {
public: public:
CHealthKit();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual BOOL MyTouch(CBasePlayer *pPlayer); virtual BOOL MyTouch(CBasePlayer *pPlayer);

View File

@ -13,8 +13,8 @@ int g_iHostageNumber = 0;
#endif #endif
LINK_ENTITY_TO_CLASS(hostage_entity, CHostage); LINK_ENTITY_TO_CLASS(hostage_entity, CHostage, CCSHostage);
LINK_ENTITY_TO_CLASS(monster_scientist, CHostage); LINK_ENTITY_TO_CLASS(monster_scientist, CHostage, CCSHostage);
void CHostage::__MAKE_VHOOK(Spawn)() void CHostage::__MAKE_VHOOK(Spawn)()
{ {
@ -229,7 +229,7 @@ void CHostage::IdleThink()
player = (CBasePlayer *)m_improv->GetFollowLeader(); player = (CBasePlayer *)m_improv->GetFollowLeader();
} }
else else
player = GetClassPtr((CBasePlayer *)m_hTargetEnt->pev); player = GetClassPtr<CCSPlayer>((CBasePlayer *)m_hTargetEnt->pev);
if (player == NULL || player->m_iTeam == CT) if (player == NULL || player->m_iTeam == CT)
{ {
@ -428,7 +428,7 @@ int CHostage::__MAKE_VHOOK(TakeDamage)(entvars_t *pevInflictor, entvars_t *pevAt
if (pevAttacker != NULL) if (pevAttacker != NULL)
{ {
CBaseEntity *pAttackingEnt = GetClassPtr((CBaseEntity *)pevAttacker); CBaseEntity *pAttackingEnt = GetClassPtr<CCSEntity>((CBaseEntity *)pevAttacker);
if (pAttackingEnt->Classify() == CLASS_VEHICLE) if (pAttackingEnt->Classify() == CLASS_VEHICLE)
{ {
@ -442,7 +442,7 @@ int CHostage::__MAKE_VHOOK(TakeDamage)(entvars_t *pevInflictor, entvars_t *pevAt
if (pAttackingEnt->IsPlayer()) if (pAttackingEnt->IsPlayer())
{ {
pAttacker = GetClassPtr((CBasePlayer *)pevAttacker); pAttacker = GetClassPtr<CCSPlayer>((CBasePlayer *)pevAttacker);
} }
} }
@ -820,7 +820,7 @@ void CHostage::DoFollow()
return; return;
} }
pFollowing = GetClassPtr((CBaseEntity *)m_hTargetEnt->pev); pFollowing = GetClassPtr<CCSEntity>((CBaseEntity *)m_hTargetEnt->pev);
m_LocalNav->SetTargetEnt(pFollowing); m_LocalNav->SetTargetEnt(pFollowing);
vecDest = pFollowing->pev->origin; vecDest = pFollowing->pev->origin;
@ -913,7 +913,7 @@ void CHostage::MoveToward(const Vector &vecLoc)
Vector vecAng; Vector vecAng;
float_precision flDist; float_precision flDist;
pFollowing = GetClassPtr((CBaseEntity *)m_hTargetEnt->pev); pFollowing = GetClassPtr<CCSEntity>((CBaseEntity *)m_hTargetEnt->pev);
vecMove = vecLoc - pev->origin; vecMove = vecLoc - pev->origin;
vecAng = UTIL_VecToAngles(vecMove); vecAng = UTIL_VecToAngles(vecMove);
vecAng = Vector(0, vecAng.y, 0); vecAng = Vector(0, vecAng.y, 0);
@ -976,7 +976,7 @@ void CHostage::NavReady()
return; return;
} }
pFollowing = GetClassPtr((CBaseEntity *)m_hTargetEnt->pev); pFollowing = GetClassPtr<CCSEntity>((CBaseEntity *)m_hTargetEnt->pev);
vecDest = pFollowing->pev->origin; vecDest = pFollowing->pev->origin;
if (!(pFollowing->pev->flags & FL_ONGROUND)) if (!(pFollowing->pev->flags & FL_ONGROUND))
@ -1035,7 +1035,7 @@ void CHostage::SendHostagePositionMsg()
if (pEntity->pev->flags == FL_DORMANT) if (pEntity->pev->flags == FL_DORMANT)
continue; continue;
CBasePlayer *pTempPlayer = GetClassPtr((CBasePlayer *)pEntity->pev); CBasePlayer *pTempPlayer = GetClassPtr<CCSPlayer>((CBasePlayer *)pEntity->pev);
if (pTempPlayer->pev->deadflag == DEAD_NO && pTempPlayer->m_iTeam == CT) if (pTempPlayer->pev->deadflag == DEAD_NO && pTempPlayer->m_iTeam == CT)
{ {
@ -1065,7 +1065,7 @@ void CHostage::SendHostageEventMsg()
if (pEntity->pev->flags == FL_DORMANT) if (pEntity->pev->flags == FL_DORMANT)
continue; continue;
CBasePlayer *pTempPlayer = GetClassPtr((CBasePlayer *)pEntity->pev); CBasePlayer *pTempPlayer = GetClassPtr<CCSPlayer>((CBasePlayer *)pEntity->pev);
if (pTempPlayer->pev->deadflag == DEAD_NO && pTempPlayer->m_iTeam == CT) if (pTempPlayer->pev->deadflag == DEAD_NO && pTempPlayer->m_iTeam == CT)
{ {

View File

@ -801,7 +801,7 @@ void CLocalNav::Think()
if (hCallback) if (hCallback)
{ {
CHostage *pHostage = GetClassPtr((CHostage *)hCallback->pev); CHostage *pHostage = GetClassPtr<CCSHostage>((CHostage *)hCallback->pev);
if (++qptr == MAX_HOSTAGES_NAV) if (++qptr == MAX_HOSTAGES_NAV)
qptr = 0; qptr = 0;
@ -830,7 +830,7 @@ void CLocalNav::RequestNav(CHostage *pCaller)
for (int i = 0; i < tot_inqueue; ++i) for (int i = 0; i < tot_inqueue; ++i)
{ {
CHostage *pQueueItem = GetClassPtr((CHostage *)_queue[curr]->pev); CHostage *pQueueItem = GetClassPtr<CCSHostage>((CHostage *)_queue[curr]->pev);
if (pQueueItem == pCaller) if (pQueueItem == pCaller)
return; return;
@ -859,7 +859,7 @@ void CLocalNav::HostagePrethink()
{ {
if (hostages[ iCount ] != NULL) if (hostages[ iCount ] != NULL)
{ {
GetClassPtr((CHostage *)hostages[ iCount ]->pev)->PreThink(); GetClassPtr<CCSHostage>((CHostage *)hostages[ iCount ]->pev)->PreThink();
} }
} }
} }

View File

@ -1,7 +1,6 @@
#include "precompiled.h" #include "precompiled.h"
LINK_ENTITY_TO_CLASS(world_items, CWorldItem); LINK_ENTITY_TO_CLASS(world_items, CWorldItem, CCSWorldItem);
LINK_CLASS_TO_WRAP(CWorldItem, CCSWorldItem);
void CWorldItem::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd) void CWorldItem::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
{ {
@ -46,8 +45,6 @@ void CWorldItem::__MAKE_VHOOK(Spawn)()
REMOVE_ENTITY(edict()); REMOVE_ENTITY(edict());
} }
LINK_CLASS_TO_WRAP(CItem, CCSItem);
void CItem::__MAKE_VHOOK(Spawn)() void CItem::__MAKE_VHOOK(Spawn)()
{ {
pev->movetype = MOVETYPE_TOSS; pev->movetype = MOVETYPE_TOSS;
@ -145,8 +142,7 @@ BOOL CItemSuit::__MAKE_VHOOK(MyTouch)(CBasePlayer *pPlayer)
return TRUE; return TRUE;
} }
LINK_ENTITY_TO_CLASS(item_suit, CItemSuit); LINK_ENTITY_TO_CLASS(item_suit, CItemSuit, CCSItemSuit);
LINK_CLASS_TO_WRAP(CItemSuit, CCSItemSuit);
void CItemBattery::__MAKE_VHOOK(Spawn)() void CItemBattery::__MAKE_VHOOK(Spawn)()
{ {
@ -193,8 +189,7 @@ BOOL CItemBattery::__MAKE_VHOOK(MyTouch)(CBasePlayer *pPlayer)
return FALSE; return FALSE;
} }
LINK_ENTITY_TO_CLASS(item_battery, CItemBattery); LINK_ENTITY_TO_CLASS(item_battery, CItemBattery, CCSItemBattery);
LINK_CLASS_TO_WRAP(CItemBattery, CCSItemBattery);
void CItemAntidote::__MAKE_VHOOK(Spawn)() void CItemAntidote::__MAKE_VHOOK(Spawn)()
{ {
@ -216,8 +211,7 @@ BOOL CItemAntidote::__MAKE_VHOOK(MyTouch)(CBasePlayer *pPlayer)
return TRUE; return TRUE;
} }
LINK_ENTITY_TO_CLASS(item_antidote, CItemAntidote); LINK_ENTITY_TO_CLASS(item_antidote, CItemAntidote, CCSItemAntidote);
LINK_CLASS_TO_WRAP(CItemAntidote, CCSItemAntidote);
void CItemSecurity::__MAKE_VHOOK(Spawn)() void CItemSecurity::__MAKE_VHOOK(Spawn)()
{ {
@ -237,8 +231,7 @@ BOOL CItemSecurity::__MAKE_VHOOK(MyTouch)(CBasePlayer *pPlayer)
return TRUE; return TRUE;
} }
LINK_ENTITY_TO_CLASS(item_security, CItemSecurity); LINK_ENTITY_TO_CLASS(item_security, CItemSecurity, CCSItemSecurity);
LINK_CLASS_TO_WRAP(CItemSecurity, CCSItemSecurity);
void CItemLongJump::__MAKE_VHOOK(Spawn)() void CItemLongJump::__MAKE_VHOOK(Spawn)()
{ {
@ -275,8 +268,7 @@ BOOL CItemLongJump::__MAKE_VHOOK(MyTouch)(CBasePlayer *pPlayer)
return FALSE; return FALSE;
} }
LINK_ENTITY_TO_CLASS(item_longjump, CItemLongJump); LINK_ENTITY_TO_CLASS(item_longjump, CItemLongJump, CCSItemLongJump);
LINK_CLASS_TO_WRAP(CItemLongJump, CCSItemLongJump);
void CItemKevlar::__MAKE_VHOOK(Spawn)() void CItemKevlar::__MAKE_VHOOK(Spawn)()
{ {
@ -314,8 +306,7 @@ BOOL CItemKevlar::__MAKE_VHOOK(MyTouch)(CBasePlayer *pPlayer)
return TRUE; return TRUE;
} }
LINK_ENTITY_TO_CLASS(item_kevlar, CItemKevlar); LINK_ENTITY_TO_CLASS(item_kevlar, CItemKevlar, CCSItemKevlar);
LINK_CLASS_TO_WRAP(CItemKevlar, CCSItemKevlar);
void CItemAssaultSuit::__MAKE_VHOOK(Spawn)() void CItemAssaultSuit::__MAKE_VHOOK(Spawn)()
{ {
@ -352,8 +343,7 @@ BOOL CItemAssaultSuit::__MAKE_VHOOK(MyTouch)(CBasePlayer *pPlayer)
return TRUE; return TRUE;
} }
LINK_ENTITY_TO_CLASS(item_assaultsuit, CItemAssaultSuit); LINK_ENTITY_TO_CLASS(item_assaultsuit, CItemAssaultSuit, CCSItemAssaultSuit);
LINK_CLASS_TO_WRAP(CItemAssaultSuit, CCSItemAssaultSuit);
void CItemThighPack::__MAKE_VHOOK(Spawn)() void CItemThighPack::__MAKE_VHOOK(Spawn)()
{ {
@ -396,5 +386,4 @@ BOOL CItemThighPack::__MAKE_VHOOK(MyTouch)(CBasePlayer *pPlayer)
return TRUE; return TRUE;
} }
LINK_ENTITY_TO_CLASS(item_thighpack, CItemThighPack); LINK_ENTITY_TO_CLASS(item_thighpack, CItemThighPack, CCSItemThighPack);
LINK_CLASS_TO_WRAP(CItemThighPack, CCSItemThighPack);

View File

@ -42,7 +42,6 @@
class CItem: public CBaseEntity class CItem: public CBaseEntity
{ {
public: public:
CItem();
virtual void Spawn(); virtual void Spawn();
virtual CBaseEntity *Respawn(); virtual CBaseEntity *Respawn();
virtual BOOL MyTouch(CBasePlayer *pPlayer) { return FALSE; } virtual BOOL MyTouch(CBasePlayer *pPlayer) { return FALSE; }
@ -62,7 +61,6 @@ public:
class CWorldItem: public CBaseEntity class CWorldItem: public CBaseEntity
{ {
public: public:
CWorldItem();
virtual void Spawn(); virtual void Spawn();
virtual void KeyValue(KeyValueData *pkvd); virtual void KeyValue(KeyValueData *pkvd);
@ -80,7 +78,6 @@ public:
class CItemSuit: public CItem class CItemSuit: public CItem
{ {
public: public:
CItemSuit();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual BOOL MyTouch(CBasePlayer *pPlayer); virtual BOOL MyTouch(CBasePlayer *pPlayer);
@ -98,7 +95,6 @@ public:
class CItemBattery: public CItem class CItemBattery: public CItem
{ {
public: public:
CItemBattery();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual BOOL MyTouch(CBasePlayer *pPlayer); virtual BOOL MyTouch(CBasePlayer *pPlayer);
@ -116,7 +112,6 @@ public:
class CItemAntidote: public CItem class CItemAntidote: public CItem
{ {
public: public:
CItemAntidote();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual BOOL MyTouch(CBasePlayer *pPlayer); virtual BOOL MyTouch(CBasePlayer *pPlayer);
@ -134,7 +129,6 @@ public:
class CItemSecurity: public CItem class CItemSecurity: public CItem
{ {
public: public:
CItemSecurity();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual BOOL MyTouch(CBasePlayer *pPlayer); virtual BOOL MyTouch(CBasePlayer *pPlayer);
@ -152,7 +146,6 @@ public:
class CItemLongJump: public CItem class CItemLongJump: public CItem
{ {
public: public:
CItemLongJump();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual BOOL MyTouch(CBasePlayer *pPlayer); virtual BOOL MyTouch(CBasePlayer *pPlayer);
@ -170,7 +163,6 @@ public:
class CItemKevlar: public CItem class CItemKevlar: public CItem
{ {
public: public:
CItemKevlar();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual BOOL MyTouch(CBasePlayer *pPlayer); virtual BOOL MyTouch(CBasePlayer *pPlayer);
@ -188,7 +180,6 @@ public:
class CItemAssaultSuit: public CItem class CItemAssaultSuit: public CItem
{ {
public: public:
CItemAssaultSuit();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual BOOL MyTouch(CBasePlayer *pPlayer); virtual BOOL MyTouch(CBasePlayer *pPlayer);
@ -206,7 +197,6 @@ public:
class CItemThighPack: public CItem class CItemThighPack: public CItem
{ {
public: public:
CItemThighPack();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual BOOL MyTouch(CBasePlayer *pPlayer); virtual BOOL MyTouch(CBasePlayer *pPlayer);

View File

@ -13,7 +13,7 @@ TYPEDESCRIPTION CLight::m_SaveData[] =
#endif #endif
LINK_ENTITY_TO_CLASS(light, CLight); LINK_ENTITY_TO_CLASS(light, CLight, CCSLight);
IMPLEMENT_SAVERESTORE(CLight, CPointEntity); IMPLEMENT_SAVERESTORE(CLight, CPointEntity);
// Cache user-entity-field values until spawn is called. // Cache user-entity-field values until spawn is called.
@ -106,8 +106,8 @@ void CLight::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCaller, US
} }
} }
LINK_ENTITY_TO_CLASS(light_spot, CLight); LINK_ENTITY_TO_CLASS(light_spot, CLight, CCSLight);
LINK_ENTITY_TO_CLASS(light_environment, CEnvLight); LINK_ENTITY_TO_CLASS(light_environment, CEnvLight, CCSEnvLight);
void CEnvLight::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd) void CEnvLight::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
{ {

View File

@ -39,9 +39,9 @@ class CLight: public CPointEntity
public: public:
virtual void Spawn(); virtual void Spawn();
virtual void Restart(); virtual void Restart();
virtual void KeyValue(KeyValueData *pkvd);
virtual int Save(CSave &save); virtual int Save(CSave &save);
virtual int Restore(CRestore &restore); virtual int Restore(CRestore &restore);
virtual void KeyValue(KeyValueData *pkvd);
virtual void Use(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value); virtual void Use(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value);
#ifdef HOOK_GAMEDLL #ifdef HOOK_GAMEDLL

View File

@ -73,7 +73,7 @@ void CRuleBrushEntity::__MAKE_VHOOK(Spawn)()
CRuleEntity::Spawn(); CRuleEntity::Spawn();
} }
LINK_ENTITY_TO_CLASS(game_score, CGameScore); LINK_ENTITY_TO_CLASS(game_score, CGameScore, CCSGameScore);
void CGameScore::__MAKE_VHOOK(Spawn)() void CGameScore::__MAKE_VHOOK(Spawn)()
{ {
@ -110,7 +110,7 @@ void CGameScore::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCaller
} }
} }
LINK_ENTITY_TO_CLASS(game_end, CGameEnd); LINK_ENTITY_TO_CLASS(game_end, CGameEnd, CCSGameEnd);
void CGameEnd::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value) void CGameEnd::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value)
{ {
@ -120,7 +120,7 @@ void CGameEnd::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCaller,
g_pGameRules->EndMultiplayerGame(); g_pGameRules->EndMultiplayerGame();
} }
LINK_ENTITY_TO_CLASS(game_text, CGameText); LINK_ENTITY_TO_CLASS(game_text, CGameText, CCSGameText);
IMPLEMENT_SAVERESTORE(CGameText, CRulePointEntity); IMPLEMENT_SAVERESTORE(CGameText, CRulePointEntity);
void CGameText::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd) void CGameText::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
@ -211,7 +211,7 @@ void CGameText::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCaller,
} }
} }
LINK_ENTITY_TO_CLASS(game_team_master, CGameTeamMaster); LINK_ENTITY_TO_CLASS(game_team_master, CGameTeamMaster, CCSGameTeamMaster);
void CGameTeamMaster::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd) void CGameTeamMaster::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
{ {
@ -301,7 +301,7 @@ BOOL CGameTeamMaster::TeamMatch(CBaseEntity *pActivator)
return UTIL_TeamsMatch(pActivator->TeamID(), TeamID()); return UTIL_TeamsMatch(pActivator->TeamID(), TeamID());
} }
LINK_ENTITY_TO_CLASS(game_team_set, CGameTeamSet); LINK_ENTITY_TO_CLASS(game_team_set, CGameTeamSet, CCSGameTeamSet);
void CGameTeamSet::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value) void CGameTeamSet::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value)
{ {
@ -323,7 +323,7 @@ void CGameTeamSet::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCall
} }
} }
LINK_ENTITY_TO_CLASS(game_zone_player, CGamePlayerZone); LINK_ENTITY_TO_CLASS(game_zone_player, CGamePlayerZone, CCSGamePlayerZone);
IMPLEMENT_SAVERESTORE(CGamePlayerZone, CRuleBrushEntity); IMPLEMENT_SAVERESTORE(CGamePlayerZone, CRuleBrushEntity);
void CGamePlayerZone::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd) void CGamePlayerZone::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
@ -410,7 +410,7 @@ void CGamePlayerZone::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pC
} }
LINK_ENTITY_TO_CLASS(game_player_hurt, CGamePlayerHurt); LINK_ENTITY_TO_CLASS(game_player_hurt, CGamePlayerHurt, CCSGamePlayerHurt);
void CGamePlayerHurt::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value) void CGamePlayerHurt::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value)
{ {
@ -433,7 +433,7 @@ void CGamePlayerHurt::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pC
} }
} }
LINK_ENTITY_TO_CLASS(game_counter, CGameCounter); LINK_ENTITY_TO_CLASS(game_counter, CGameCounter, CCSGameCounter);
void CGameCounter::__MAKE_VHOOK(Spawn)() void CGameCounter::__MAKE_VHOOK(Spawn)()
{ {
@ -479,7 +479,7 @@ void CGameCounter::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCall
} }
} }
LINK_ENTITY_TO_CLASS(game_counter_set, CGameCounterSet); LINK_ENTITY_TO_CLASS(game_counter_set, CGameCounterSet, CCSGameCounterSet);
void CGameCounterSet::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value) void CGameCounterSet::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value)
{ {
@ -494,7 +494,7 @@ void CGameCounterSet::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pC
} }
} }
LINK_ENTITY_TO_CLASS(game_player_equip, CGamePlayerEquip); LINK_ENTITY_TO_CLASS(game_player_equip, CGamePlayerEquip, CCSGamePlayerEquip);
void CGamePlayerEquip::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd) void CGamePlayerEquip::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
{ {
@ -560,7 +560,7 @@ void CGamePlayerEquip::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *p
EquipPlayer(pActivator); EquipPlayer(pActivator);
} }
LINK_ENTITY_TO_CLASS(game_player_team, CGamePlayerTeam); LINK_ENTITY_TO_CLASS(game_player_team, CGamePlayerTeam, CCSGamePlayerTeam);
const char *CGamePlayerTeam::TargetTeamName(const char *pszTargetName) const char *CGamePlayerTeam::TargetTeamName(const char *pszTargetName)
{ {

View File

@ -17,7 +17,7 @@ TYPEDESCRIPTION CFuncMortarField::m_SaveData[] =
#endif #endif
LINK_ENTITY_TO_CLASS(func_mortar_field, CFuncMortarField); LINK_ENTITY_TO_CLASS(func_mortar_field, CFuncMortarField, CCSFuncMortarField);
IMPLEMENT_SAVERESTORE(CFuncMortarField, CBaseToggle); IMPLEMENT_SAVERESTORE(CFuncMortarField, CBaseToggle);
void CFuncMortarField::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd) void CFuncMortarField::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
@ -152,7 +152,7 @@ void CFuncMortarField::FieldUse(CBaseEntity *pActivator, CBaseEntity *pCaller, U
} }
} }
LINK_ENTITY_TO_CLASS(monster_mortar, CMortar); LINK_ENTITY_TO_CLASS(monster_mortar, CMortar, CCSMortar);
void CMortar::__MAKE_VHOOK(Spawn)() void CMortar::__MAKE_VHOOK(Spawn)()
{ {

View File

@ -191,7 +191,7 @@ void CMapInfo::__MAKE_VHOOK(Spawn)()
pev->effects |= EF_NODRAW; pev->effects |= EF_NODRAW;
} }
LINK_ENTITY_TO_CLASS(info_map_parameters, CMapInfo); LINK_ENTITY_TO_CLASS(info_map_parameters, CMapInfo, CCSMapInfo);
bool CCStrikeGameMgrHelper::__MAKE_VHOOK(CanPlayerHearPlayer)(CBasePlayer *pListener, CBasePlayer *pSender) bool CCStrikeGameMgrHelper::__MAKE_VHOOK(CanPlayerHearPlayer)(CBasePlayer *pListener, CBasePlayer *pSender)
{ {
@ -775,7 +775,7 @@ void CHalfLifeMultiplay::__MAKE_VHOOK(GiveC4)()
if (pPlayer->pev->flags == FL_DORMANT) if (pPlayer->pev->flags == FL_DORMANT)
continue; continue;
CBasePlayer *player = GetClassPtr((CBasePlayer *)pPlayer->pev); CBasePlayer *player = GetClassPtr<CCSPlayer>((CBasePlayer *)pPlayer->pev);
if (player->pev->deadflag != DEAD_NO || player->m_iTeam != TERRORIST || (giveToHumans && player->IsBot())) if (player->pev->deadflag != DEAD_NO || player->m_iTeam != TERRORIST || (giveToHumans && player->IsBot()))
continue; continue;
@ -813,7 +813,7 @@ void CHalfLifeMultiplay::__MAKE_VHOOK(GiveC4)()
if (pPlayer->pev->flags == FL_DORMANT) if (pPlayer->pev->flags == FL_DORMANT)
continue; continue;
CBasePlayer *player = GetClassPtr((CBasePlayer *)pPlayer->pev); CBasePlayer *player = GetClassPtr<CCSPlayer>((CBasePlayer *)pPlayer->pev);
if (player->pev->deadflag != DEAD_NO || player->m_iTeam != TERRORIST) if (player->pev->deadflag != DEAD_NO || player->m_iTeam != TERRORIST)
continue; continue;
@ -1010,7 +1010,7 @@ void CHalfLifeMultiplay::InitializePlayerCounts(int &NumAliveTerrorist, int &Num
break; break;
} }
CBasePlayer *player = GetClassPtr((CBasePlayer *)pPlayer->pev); CBasePlayer *player = GetClassPtr<CCSPlayer>((CBasePlayer *)pPlayer->pev);
if (pPlayer->pev->flags == FL_DORMANT) if (pPlayer->pev->flags == FL_DORMANT)
{ {
@ -1487,7 +1487,7 @@ void CHalfLifeMultiplay::SwapAllPlayers()
if (pPlayer->pev->flags == FL_DORMANT) if (pPlayer->pev->flags == FL_DORMANT)
continue; continue;
CBasePlayer *player = GetClassPtr((CBasePlayer *)pPlayer->pev); CBasePlayer *player = GetClassPtr<CCSPlayer>((CBasePlayer *)pPlayer->pev);
player->SwitchTeam(); player->SwitchTeam();
} }
@ -1576,7 +1576,7 @@ void CHalfLifeMultiplay::BalanceTeams()
if (pPlayer->pev->flags == FL_DORMANT) if (pPlayer->pev->flags == FL_DORMANT)
continue; continue;
CBasePlayer *player = GetClassPtr((CBasePlayer *)pPlayer->pev); CBasePlayer *player = GetClassPtr<CCSPlayer>((CBasePlayer *)pPlayer->pev);
if (player->m_iTeam == iTeamToSwap && GETPLAYERUSERID(player->edict()) > iHighestUserID && m_pVIP != player) if (player->m_iTeam == iTeamToSwap && GETPLAYERUSERID(player->edict()) > iHighestUserID && m_pVIP != player)
{ {
@ -1939,7 +1939,7 @@ void CHalfLifeMultiplay::__MAKE_VHOOK(RestartRound)()
if (pPlayer->pev->flags == FL_DORMANT) if (pPlayer->pev->flags == FL_DORMANT)
continue; continue;
CBasePlayer *player = GetClassPtr((CBasePlayer *)pPlayer->pev); CBasePlayer *player = GetClassPtr<CCSPlayer>((CBasePlayer *)pPlayer->pev);
player->m_iNumSpawns = 0; player->m_iNumSpawns = 0;
player->m_bTeamChanged = false; player->m_bTeamChanged = false;
@ -2249,9 +2249,7 @@ void CHalfLifeMultiplay::PickNextVIP()
// If it's been the same VIP for 3 rounds already.. then randomly pick a new one // If it's been the same VIP for 3 rounds already.. then randomly pick a new one
else if (m_iConsecutiveVIP >= 3) else if (m_iConsecutiveVIP >= 3)
{ {
++m_iLastPick; if (++m_iLastPick > m_iNumCT)
if (m_iLastPick > m_iNumCT)
m_iLastPick = 1; m_iLastPick = 1;
int iCount = 1; int iCount = 1;
@ -2266,7 +2264,7 @@ void CHalfLifeMultiplay::PickNextVIP()
{ {
if (!(pPlayer->pev->flags & FL_DORMANT)) if (!(pPlayer->pev->flags & FL_DORMANT))
{ {
player = GetClassPtr((CBasePlayer *)pPlayer->pev); player = GetClassPtr<CCSPlayer>((CBasePlayer *)pPlayer->pev);
if (player->m_iTeam == CT && iCount == m_iLastPick) if (player->m_iTeam == CT && iCount == m_iLastPick)
{ {
@ -2305,7 +2303,7 @@ void CHalfLifeMultiplay::PickNextVIP()
{ {
if (pPlayer->pev->flags != FL_DORMANT) if (pPlayer->pev->flags != FL_DORMANT)
{ {
player = GetClassPtr((CBasePlayer *)pPlayer->pev); player = GetClassPtr<CCSPlayer>((CBasePlayer *)pPlayer->pev);
if (player->m_iTeam == CT) if (player->m_iTeam == CT)
{ {
@ -2756,7 +2754,7 @@ void CHalfLifeMultiplay::CheckRoundTimeExpired()
if (!C4->m_bJustBlew) if (!C4->m_bJustBlew)
flEndRoundTime = C4->m_flC4Blow; flEndRoundTime = C4->m_flC4Blow;
else else
flEndRoundTime = gpGlobals->time + 5.0; flEndRoundTime = gpGlobals->time + 5.0f;
} }
#endif #endif
@ -3549,13 +3547,8 @@ void CHalfLifeMultiplay::__MAKE_VHOOK(PlayerKilled)(CBasePlayer *pVictim, entvar
else if (peKiller && peKiller->IsPlayer()) else if (peKiller && peKiller->IsPlayer())
{ {
// if a player dies in a deathmatch game and the killer is a client, award the killer some points // if a player dies in a deathmatch game and the killer is a client, award the killer some points
CBasePlayer *killer = GetClassPtr((CBasePlayer *)pKiller); CBasePlayer *killer = GetClassPtr<CCSPlayer>((CBasePlayer *)pKiller);
bool killedByFFA = false; bool killedByFFA = CSGameRules()->IsFriendlyFireAttack();
#ifdef REGAMEDLL_ADD
if (friendlyfire.string[0] == '2')
killedByFFA = true;
#endif
if (killer->m_iTeam == pVictim->m_iTeam && !killedByFFA) if (killer->m_iTeam == pVictim->m_iTeam && !killedByFFA)
{ {
@ -3932,8 +3925,8 @@ int CHalfLifeMultiplay::__MAKE_VHOOK(PlayerRelationship)(CBasePlayer *pPlayer, C
return GR_NOTTEAMMATE; return GR_NOTTEAMMATE;
} }
CBasePlayer *player = GetClassPtr((CBasePlayer *)pPlayer->pev); CBasePlayer *player = GetClassPtr<CCSPlayer>((CBasePlayer *)pPlayer->pev);
CBasePlayer *target = GetClassPtr((CBasePlayer *)pTarget->pev); CBasePlayer *target = GetClassPtr<CCSPlayer>((CBasePlayer *)pTarget->pev);
if (player->m_iTeam != target->m_iTeam) if (player->m_iTeam != target->m_iTeam)
{ {
@ -4348,7 +4341,7 @@ void CHalfLifeMultiplay::ResetAllMapVotes()
if (FNullEnt(pTempEntity->edict())) if (FNullEnt(pTempEntity->edict()))
break; break;
CBasePlayer *pTempPlayer = GetClassPtr((CBasePlayer *)pTempEntity->pev); CBasePlayer *pTempPlayer = GetClassPtr<CCSPlayer>((CBasePlayer *)pTempEntity->pev);
if (pTempPlayer->m_iTeam != UNASSIGNED) if (pTempPlayer->m_iTeam != UNASSIGNED)
{ {
@ -4448,7 +4441,7 @@ void CHalfLifeMultiplay::ProcessMapVote(CBasePlayer *player, int iVote)
if (FNullEnt(pTempEntity->edict())) if (FNullEnt(pTempEntity->edict()))
break; break;
CBasePlayer *pTempPlayer = GetClassPtr((CBasePlayer *)pTempEntity->pev); CBasePlayer *pTempPlayer = GetClassPtr<CCSPlayer>((CBasePlayer *)pTempEntity->pev);
if (pTempPlayer->m_iTeam != UNASSIGNED) if (pTempPlayer->m_iTeam != UNASSIGNED)
{ {

View File

@ -21,7 +21,7 @@ TYPEDESCRIPTION CPathTrack::m_SaveData[] =
#endif #endif
LINK_ENTITY_TO_CLASS(path_corner, CPathCorner); LINK_ENTITY_TO_CLASS(path_corner, CPathCorner, CCSPathCorner);
IMPLEMENT_SAVERESTORE(CPathCorner, CPointEntity); IMPLEMENT_SAVERESTORE(CPathCorner, CPointEntity);
void CPathCorner::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd) void CPathCorner::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
@ -41,7 +41,7 @@ void CPathCorner::__MAKE_VHOOK(Spawn)()
} }
IMPLEMENT_SAVERESTORE(CPathTrack, CBaseEntity); IMPLEMENT_SAVERESTORE(CPathTrack, CBaseEntity);
LINK_ENTITY_TO_CLASS(path_track, CPathTrack); LINK_ENTITY_TO_CLASS(path_track, CPathTrack, CCSPathTrack);
void CPathTrack::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd) void CPathTrack::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
{ {

View File

@ -232,7 +232,7 @@ void CFuncPlat::CallHitBottom()
HitBottom(); HitBottom();
} }
LINK_ENTITY_TO_CLASS(func_plat, CFuncPlat); LINK_ENTITY_TO_CLASS(func_plat, CFuncPlat, CCSFuncPlat);
#define noiseMovement noise #define noiseMovement noise
#define noiseStopMoving noise1 #define noiseStopMoving noise1
@ -325,7 +325,7 @@ void CFuncPlat::__MAKE_VHOOK(Spawn)()
void PlatSpawnInsideTrigger(entvars_t *pevPlatform) void PlatSpawnInsideTrigger(entvars_t *pevPlatform)
{ {
GetClassPtr((CPlatTrigger *)NULL)->SpawnInsideTrigger(GetClassPtr((CFuncPlat *)pevPlatform)); GetClassPtr<CCSPlatTrigger>((CPlatTrigger *)NULL)->SpawnInsideTrigger(GetClassPtr<CCSFuncPlat>((CFuncPlat *)pevPlatform));
} }
// Create a trigger entity for a platform. // Create a trigger entity for a platform.
@ -511,7 +511,7 @@ void CFuncPlat::__MAKE_VHOOK(Blocked)(CBaseEntity *pOther)
} }
} }
LINK_ENTITY_TO_CLASS(func_platrot, CFuncPlatRot); LINK_ENTITY_TO_CLASS(func_platrot, CFuncPlatRot, CCSFuncPlatRot);
IMPLEMENT_SAVERESTORE(CFuncPlatRot, CFuncPlat); IMPLEMENT_SAVERESTORE(CFuncPlatRot, CFuncPlat);
void CFuncPlatRot::SetupRotation() void CFuncPlatRot::SetupRotation()
@ -588,7 +588,7 @@ void CFuncPlatRot::RotMove(Vector &destAngle, float time)
} }
} }
LINK_ENTITY_TO_CLASS(func_train, CFuncTrain); LINK_ENTITY_TO_CLASS(func_train, CFuncTrain, CCSFuncTrain);
IMPLEMENT_SAVERESTORE(CFuncTrain, CBasePlatTrain); IMPLEMENT_SAVERESTORE(CFuncTrain, CBasePlatTrain);
void CFuncTrain::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd) void CFuncTrain::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
@ -885,7 +885,7 @@ void CFuncTrain::__MAKE_VHOOK(OverrideReset)()
} }
IMPLEMENT_SAVERESTORE(CFuncTrackTrain, CBaseEntity); IMPLEMENT_SAVERESTORE(CFuncTrackTrain, CBaseEntity);
LINK_ENTITY_TO_CLASS(func_tracktrain, CFuncTrackTrain); LINK_ENTITY_TO_CLASS(func_tracktrain, CFuncTrackTrain, CCSFuncTrackTrain);
void CFuncTrackTrain::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd) void CFuncTrackTrain::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
{ {
@ -1546,7 +1546,7 @@ void CFuncTrackTrain::__MAKE_VHOOK(Precache)()
m_usAdjustPitch = PRECACHE_EVENT(1, "events/train.sc"); m_usAdjustPitch = PRECACHE_EVENT(1, "events/train.sc");
} }
LINK_ENTITY_TO_CLASS(func_traincontrols, CFuncTrainControls); LINK_ENTITY_TO_CLASS(func_traincontrols, CFuncTrainControls, CCSFuncTrainControls);
void CFuncTrainControls::Find() void CFuncTrainControls::Find()
{ {
@ -1587,7 +1587,7 @@ BOOL CFuncTrackChange::__MAKE_VHOOK(IsTogglePlat)()
return TRUE; return TRUE;
} }
LINK_ENTITY_TO_CLASS(func_trackchange, CFuncTrackChange); LINK_ENTITY_TO_CLASS(func_trackchange, CFuncTrackChange, CCSFuncTrackChange);
IMPLEMENT_SAVERESTORE(CFuncTrackChange, CFuncPlatRot); IMPLEMENT_SAVERESTORE(CFuncTrackChange, CFuncPlatRot);
void CFuncTrackChange::__MAKE_VHOOK(Spawn)() void CFuncTrackChange::__MAKE_VHOOK(Spawn)()
@ -1924,7 +1924,7 @@ void CFuncTrackChange::__MAKE_VHOOK(HitTop)()
EnableUse(); EnableUse();
} }
LINK_ENTITY_TO_CLASS(func_trackautochange, CFuncTrackAuto); LINK_ENTITY_TO_CLASS(func_trackautochange, CFuncTrackAuto, CCSFuncTrackAuto);
// Auto track change // Auto track change
void CFuncTrackAuto::__MAKE_VHOOK(UpdateAutoTargets)(int toggleState) void CFuncTrackAuto::__MAKE_VHOOK(UpdateAutoTargets)(int toggleState)
@ -2015,7 +2015,7 @@ void CFuncTrackAuto::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCa
} }
} }
LINK_ENTITY_TO_CLASS(func_guntarget, CGunTarget); LINK_ENTITY_TO_CLASS(func_guntarget, CGunTarget, CCSGunTarget);
IMPLEMENT_SAVERESTORE(CGunTarget, CBaseMonster); IMPLEMENT_SAVERESTORE(CGunTarget, CBaseMonster);
void CGunTarget::__MAKE_VHOOK(Spawn)() void CGunTarget::__MAKE_VHOOK(Spawn)()

View File

@ -234,8 +234,8 @@ public:
virtual void EXPORT GoUp(); virtual void EXPORT GoUp();
virtual void EXPORT GoDown(); virtual void EXPORT GoDown();
virtual void HitBottom();
virtual void HitTop(); virtual void HitTop();
virtual void HitBottom();
virtual void UpdateAutoTargets(int toggleState); virtual void UpdateAutoTargets(int toggleState);
#ifdef HOOK_GAMEDLL #ifdef HOOK_GAMEDLL

View File

@ -323,8 +323,7 @@ void WriteSigonMessages()
} }
} }
LINK_ENTITY_TO_CLASS(player, CBasePlayer); LINK_ENTITY_TO_CLASS(player, CBasePlayer, CCSPlayer);
LINK_CLASS_TO_WRAP(CBasePlayer, CCSPlayer);
void SendItemStatus(CBasePlayer *pPlayer) void SendItemStatus(CBasePlayer *pPlayer)
{ {
@ -482,7 +481,7 @@ CBasePlayer *CBasePlayer::GetNextRadioRecipient(CBasePlayer *pStartPlayer)
break; break;
bool bSend = false; bool bSend = false;
CBasePlayer *pPlayer = GetClassPtr((CBasePlayer *)pEntity->pev); CBasePlayer *pPlayer = GetClassPtr<CCSPlayer>((CBasePlayer *)pEntity->pev);
if (pEntity->IsPlayer()) if (pEntity->IsPlayer())
{ {
@ -536,7 +535,7 @@ void CBasePlayer::Radio(const char *msg_id, const char *msg_verbose, short pitch
break; break;
bool bSend = false; bool bSend = false;
CBasePlayer *pPlayer = GetClassPtr((CBasePlayer *)pEntity->pev); CBasePlayer *pPlayer = GetClassPtr<CCSPlayer>((CBasePlayer *)pEntity->pev);
if (pPlayer == NULL) if (pPlayer == NULL)
continue; continue;
@ -982,20 +981,15 @@ int CBasePlayer::__MAKE_VHOOK(TakeDamage)(entvars_t *pevInflictor, entvars_t *pe
if (bitsDamageType & DMG_EXPLOSION) if (bitsDamageType & DMG_EXPLOSION)
{ {
CBaseEntity *temp = GetClassPtr((CBaseEntity *)pevInflictor); CBaseEntity *temp = GetClassPtr<CCSEntity>((CBaseEntity *)pevInflictor);
if (!Q_strcmp(STRING(temp->pev->classname), "grenade")) if (!Q_strcmp(STRING(temp->pev->classname), "grenade"))
{ {
CGrenade *pGrenade = GetClassPtr((CGrenade *)pevInflictor); CGrenade *pGrenade = GetClassPtr<CCSGrenade>((CGrenade *)pevInflictor);
if (CVAR_GET_FLOAT("mp_friendlyfire")) if (CVAR_GET_FLOAT("mp_friendlyfire"))
{ {
#ifdef REGAMEDLL_ADD if (!CSGameRules()->IsFriendlyFireAttack() && pGrenade->m_iTeam == m_iTeam)
if (friendlyfire.string[0] == '2')
bTeamAttack = FALSE;
else
#endif
if (pGrenade->m_iTeam == m_iTeam)
bTeamAttack = TRUE; bTeamAttack = TRUE;
pAttack = dynamic_cast<CBasePlayer *>(CBasePlayer::Instance(pevAttacker)); pAttack = dynamic_cast<CBasePlayer *>(CBasePlayer::Instance(pevAttacker));
@ -1147,17 +1141,13 @@ int CBasePlayer::__MAKE_VHOOK(TakeDamage)(entvars_t *pevInflictor, entvars_t *pe
if (!IsAlive()) if (!IsAlive())
return 0; return 0;
pAttacker = GetClassPtr((CBaseEntity *)pevAttacker); pAttacker = GetClassPtr<CCSEntity>((CBaseEntity *)pevAttacker);
if (pAttacker->IsPlayer()) if (pAttacker->IsPlayer())
{ {
pAttack = GetClassPtr((CBasePlayer *)pevAttacker); pAttack = GetClassPtr<CCSPlayer>((CBasePlayer *)pevAttacker);
bool bAttackFFA = false; bool bAttackFFA = CSGameRules()->IsFriendlyFireAttack();
#ifdef REGAMEDLL_ADD
if (friendlyfire.string[0] == '2')
bAttackFFA = true;
#endif
// warn about team attacks // warn about team attacks
if (pAttack != this && pAttack->m_iTeam == m_iTeam && !bAttackFFA) if (pAttack != this && pAttack->m_iTeam == m_iTeam && !bAttackFFA)
@ -1186,7 +1176,7 @@ int CBasePlayer::__MAKE_VHOOK(TakeDamage)(entvars_t *pevInflictor, entvars_t *pe
if (FNullEnt(pBasePlayer->edict())) if (FNullEnt(pBasePlayer->edict()))
break; break;
CBasePlayer *basePlayer = GetClassPtr((CBasePlayer *)pBasePlayer->pev); CBasePlayer *basePlayer = GetClassPtr<CCSPlayer>((CBasePlayer *)pBasePlayer->pev);
if (basePlayer->m_iTeam == m_iTeam) if (basePlayer->m_iTeam == m_iTeam)
{ {
@ -1606,7 +1596,7 @@ void CBasePlayer::SetProgressBarTime(int time)
if (FNullEnt(pPlayer->edict())) if (FNullEnt(pPlayer->edict()))
break; break;
CBasePlayer *player = GetClassPtr((CBasePlayer *)pPlayer->pev); CBasePlayer *player = GetClassPtr<CCSPlayer>((CBasePlayer *)pPlayer->pev);
if (player->IsObserver() == OBS_IN_EYE && player->pev->iuser2 == myIndex) if (player->IsObserver() == OBS_IN_EYE && player->pev->iuser2 == myIndex)
{ {
@ -1646,7 +1636,7 @@ void CBasePlayer::SetProgressBarTime2(int time, float timeElapsed)
if (FNullEnt(pPlayer->edict())) if (FNullEnt(pPlayer->edict()))
break; break;
CBasePlayer *player = GetClassPtr((CBasePlayer *)pPlayer->pev); CBasePlayer *player = GetClassPtr<CCSPlayer>((CBasePlayer *)pPlayer->pev);
if (player->IsObserver() == OBS_IN_EYE && player->pev->iuser2 == myIndex) if (player->IsObserver() == OBS_IN_EYE && player->pev->iuser2 == myIndex)
{ {
@ -2859,7 +2849,7 @@ NOXREF void CBasePlayer::ThrowWeapon(char *pszItemName)
} }
} }
LINK_ENTITY_TO_CLASS(weapon_shield, CWShield); LINK_ENTITY_TO_CLASS(weapon_shield, CWShield, CCSShield);
void CWShield::__MAKE_VHOOK(Spawn)() void CWShield::__MAKE_VHOOK(Spawn)()
{ {
@ -4725,7 +4715,11 @@ void CBasePlayer::__MAKE_VHOOK(PostThink)()
StudioFrameAdvance(); StudioFrameAdvance();
CheckPowerups(); CheckPowerups();
// s1lent: this is useless for CS 1.6
#ifndef REGAMEDLL_FIXES
UpdatePlayerSound(); UpdatePlayerSound();
#endif
pt_end: pt_end:
#ifdef CLIENT_WEAPONS #ifdef CLIENT_WEAPONS
@ -5655,7 +5649,7 @@ void CSprayCan::Spawn(entvars_t *pevOwner)
pev->owner = ENT(pevOwner); pev->owner = ENT(pevOwner);
pev->frame = 0; pev->frame = 0;
pev->nextthink = gpGlobals->time + 0.1; pev->nextthink = gpGlobals->time + 0.1f;
EMIT_SOUND(ENT(pev), CHAN_VOICE, "player/sprayer.wav", VOL_NORM, ATTN_NORM); EMIT_SOUND(ENT(pev), CHAN_VOICE, "player/sprayer.wav", VOL_NORM, ATTN_NORM);
} }
@ -5693,7 +5687,7 @@ void CSprayCan::__MAKE_VHOOK(Think)()
UTIL_Remove(this); UTIL_Remove(this);
} }
pev->nextthink = gpGlobals->time + 0.1; pev->nextthink = gpGlobals->time + 0.1f;
} }
void CBloodSplat::Spawn(entvars_t *pevOwner) void CBloodSplat::Spawn(entvars_t *pevOwner)
@ -5703,7 +5697,7 @@ void CBloodSplat::Spawn(entvars_t *pevOwner)
pev->owner = ENT(pevOwner); pev->owner = ENT(pevOwner);
SetThink(&CBloodSplat::Spray); SetThink(&CBloodSplat::Spray);
pev->nextthink = gpGlobals->time + 0.1; pev->nextthink = gpGlobals->time + 0.1f;
} }
void CBloodSplat::Spray() void CBloodSplat::Spray()
@ -5717,7 +5711,7 @@ void CBloodSplat::Spray()
} }
SetThink(&CBloodSplat::SUB_Remove); SetThink(&CBloodSplat::SUB_Remove);
pev->nextthink = gpGlobals->time + 0.1; pev->nextthink = gpGlobals->time + 0.1f;
} }
void CBasePlayer::GiveNamedItem(const char *pszName) void CBasePlayer::GiveNamedItem(const char *pszName)
@ -5864,7 +5858,7 @@ void CBasePlayer::__MAKE_VHOOK(ImpulseCommands)()
{ {
// line hit something, so paint a decal // line hit something, so paint a decal
m_flNextDecalTime = gpGlobals->time + CVAR_GET_FLOAT("decalfrequency"); m_flNextDecalTime = gpGlobals->time + CVAR_GET_FLOAT("decalfrequency");
CSprayCan *pCan = GetClassPtr((CSprayCan *)NULL); CSprayCan *pCan = GetClassPtr<CCSSprayCan>((CSprayCan *)NULL);
pCan->Spawn(pev); pCan->Spawn(pev);
} }
break; break;
@ -6006,7 +6000,7 @@ void CBasePlayer::CheatImpulseCommands(int iImpulse)
if (tr.flFraction != 1.0f) if (tr.flFraction != 1.0f)
{ {
// line hit something, so paint a decal // line hit something, so paint a decal
CBloodSplat *pBlood = GetClassPtr((CBloodSplat *)NULL); CBloodSplat *pBlood = GetClassPtr<CCSBloodSplat>((CBloodSplat *)NULL);
pBlood->Spawn(pev); pBlood->Spawn(pev);
} }
break; break;
@ -6772,7 +6766,7 @@ void CBasePlayer::__MAKE_VHOOK(UpdateClientData)()
if (!pEntity || i == entindex()) if (!pEntity || i == entindex())
continue; continue;
CBasePlayer *pPlayer = GetClassPtr((CBasePlayer *)pEntity->pev); CBasePlayer *pPlayer = GetClassPtr<CCSPlayer>((CBasePlayer *)pEntity->pev);
if (pPlayer->pev->flags == FL_DORMANT) if (pPlayer->pev->flags == FL_DORMANT)
continue; continue;
@ -7200,7 +7194,7 @@ void CBasePlayer::DropPlayerItem(const char *pszItemName)
if (pEntity->pev->flags != FL_DORMANT) if (pEntity->pev->flags != FL_DORMANT)
{ {
CBasePlayer *pOther = GetClassPtr((CBasePlayer *)pEntity->pev); CBasePlayer *pOther = GetClassPtr<CCSPlayer>((CBasePlayer *)pEntity->pev);
if (pOther->pev->deadflag == DEAD_NO && pOther->m_iTeam == TERRORIST) if (pOther->pev->deadflag == DEAD_NO && pOther->m_iTeam == TERRORIST)
{ {
@ -7545,7 +7539,7 @@ void CDeadHEV::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
CBaseMonster::KeyValue(pkvd); CBaseMonster::KeyValue(pkvd);
} }
LINK_ENTITY_TO_CLASS(monster_hevsuit_dead, CDeadHEV); LINK_ENTITY_TO_CLASS(monster_hevsuit_dead, CDeadHEV, CCSDeadHEV);
void CDeadHEV::__MAKE_VHOOK(Spawn)() void CDeadHEV::__MAKE_VHOOK(Spawn)()
{ {
@ -7572,7 +7566,7 @@ void CDeadHEV::__MAKE_VHOOK(Spawn)()
MonsterInitDead(); MonsterInitDead();
} }
LINK_ENTITY_TO_CLASS(player_weaponstrip, CStripWeapons); LINK_ENTITY_TO_CLASS(player_weaponstrip, CStripWeapons, CCSStripWeapons);
void CStripWeapons::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value) void CStripWeapons::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value)
{ {
@ -7593,7 +7587,7 @@ void CStripWeapons::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCal
} }
} }
LINK_ENTITY_TO_CLASS(player_loadsaved, CRevertSaved); LINK_ENTITY_TO_CLASS(player_loadsaved, CRevertSaved, CCSRevertSaved);
IMPLEMENT_SAVERESTORE(CRevertSaved, CPointEntity); IMPLEMENT_SAVERESTORE(CRevertSaved, CPointEntity);
void CRevertSaved::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd) void CRevertSaved::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
@ -7670,7 +7664,7 @@ void CInfoIntermission::__MAKE_VHOOK(Think)()
} }
} }
LINK_ENTITY_TO_CLASS(info_intermission, CInfoIntermission); LINK_ENTITY_TO_CLASS(info_intermission, CInfoIntermission, CCSInfoIntermission);
void CBasePlayer::StudioEstimateGait() void CBasePlayer::StudioEstimateGait()
{ {

View File

@ -352,7 +352,6 @@ public:
class CBasePlayer: public CBaseMonster class CBasePlayer: public CBaseMonster
{ {
public: public:
CBasePlayer();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual int Save(CSave &save); virtual int Save(CSave &save);

View File

@ -35,10 +35,10 @@
class CRevertSaved: public CPointEntity class CRevertSaved: public CPointEntity
{ {
public: public:
void KeyValue(KeyValueData *pkvd); virtual void KeyValue(KeyValueData *pkvd);
int Save(CSave &save); virtual int Save(CSave &save);
int Restore(CRestore &restore); virtual int Restore(CRestore &restore);
void Use(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value); virtual void Use(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value);
#ifdef HOOK_GAMEDLL #ifdef HOOK_GAMEDLL

View File

@ -76,7 +76,7 @@ char grgchTextureType[ CTEXTURESMAX ];
int fTextureTypeInit; int fTextureTypeInit;
int gcTextures; int gcTextures;
LINK_ENTITY_TO_CLASS(ambient_generic, CAmbientGeneric); LINK_ENTITY_TO_CLASS(ambient_generic, CAmbientGeneric, CCSAmbientGeneric);
IMPLEMENT_SAVERESTORE(CAmbientGeneric, CBaseEntity); IMPLEMENT_SAVERESTORE(CAmbientGeneric, CBaseEntity);
// -1 : "Default" // -1 : "Default"
@ -851,7 +851,7 @@ void CAmbientGeneric::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
CBaseEntity::KeyValue(pkvd); CBaseEntity::KeyValue(pkvd);
} }
LINK_ENTITY_TO_CLASS(env_sound, CEnvSound); LINK_ENTITY_TO_CLASS(env_sound, CEnvSound, CCSEnvSound);
IMPLEMENT_SAVERESTORE(CEnvSound, CBaseEntity); IMPLEMENT_SAVERESTORE(CEnvSound, CBaseEntity);
void CEnvSound::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd) void CEnvSound::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
@ -872,7 +872,7 @@ void CEnvSound::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
// and can see the given player entity (pevTarget) // and can see the given player entity (pevTarget)
BOOL FEnvSoundInRange(entvars_t *pev, entvars_t *pevTarget, float *pflRange) BOOL FEnvSoundInRange(entvars_t *pev, entvars_t *pevTarget, float *pflRange)
{ {
CEnvSound *pSound = GetClassPtr((CEnvSound *)pev); CEnvSound *pSound = GetClassPtr<CCSEnvSound>((CEnvSound *)pev);
Vector vecSpot1 = pev->origin + pev->view_ofs; Vector vecSpot1 = pev->origin + pev->view_ofs;
Vector vecSpot2 = pevTarget->origin + pevTarget->view_ofs; Vector vecSpot2 = pevTarget->origin + pevTarget->view_ofs;
Vector vecRange; Vector vecRange;
@ -922,7 +922,7 @@ void CEnvSound::__MAKE_VHOOK(Think)()
goto env_sound_Think_slow; goto env_sound_Think_slow;
} }
CBasePlayer *pPlayer = GetClassPtr((CBasePlayer *)VARS(pentPlayer)); CBasePlayer *pPlayer = GetClassPtr<CCSPlayer>((CBasePlayer *)VARS(pentPlayer));
float flRange; float flRange;
// check to see if this is the sound entity that is // check to see if this is the sound entity that is
@ -1809,7 +1809,7 @@ float TEXTURETYPE_PlaySound(TraceResult *ptr, Vector vecSrc, Vector vecEnd, int
return fvolbar; return fvolbar;
} }
LINK_ENTITY_TO_CLASS(speaker, CSpeaker); LINK_ENTITY_TO_CLASS(speaker, CSpeaker, CCSSpeaker);
IMPLEMENT_SAVERESTORE(CSpeaker, CBaseEntity); IMPLEMENT_SAVERESTORE(CSpeaker, CBaseEntity);
// ambient_generic - general-purpose user-defined static sound // ambient_generic - general-purpose user-defined static sound

View File

@ -1,8 +1,15 @@
#include "precompiled.h" #include "precompiled.h"
CSoundEnt *pSoundEnt; /*
* Globals initialization
*/
#ifndef HOOK_GAMEDLL
LINK_ENTITY_TO_CLASS(soundent, CSoundEnt); CSoundEnt *pSoundEnt = NULL;
#endif
LINK_ENTITY_TO_CLASS(soundent, CSoundEnt, CCSSoundEnt);
// CSound - Clear - zeros all fields for a sound // CSound - Clear - zeros all fields for a sound
void CSound::Clear() void CSound::Clear()

View File

@ -79,7 +79,6 @@ public:
class CSoundEnt: public CBaseEntity class CSoundEnt: public CBaseEntity
{ {
public: public:
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual int ObjectCaps() { return FCAP_DONT_SAVE; } virtual int ObjectCaps() { return FCAP_DONT_SAVE; }

View File

@ -50,15 +50,15 @@ void CNullEntity::__MAKE_VHOOK(Spawn)()
REMOVE_ENTITY(ENT(pev)); REMOVE_ENTITY(ENT(pev));
} }
LINK_ENTITY_TO_CLASS(info_null, CNullEntity); LINK_ENTITY_TO_CLASS(info_null, CNullEntity, CCSNullEntity);
// These are the new entry points to entities. // These are the new entry points to entities.
LINK_ENTITY_TO_CLASS(info_player_deathmatch, CBaseDMStart); LINK_ENTITY_TO_CLASS(info_player_deathmatch, CBaseDMStart, CCSDMStart);
LINK_ENTITY_TO_CLASS(info_player_start, CPointEntity); LINK_ENTITY_TO_CLASS(info_player_start, CPointEntity, CCSPointEntity);
LINK_ENTITY_TO_CLASS(info_vip_start, CBaseDMStart); LINK_ENTITY_TO_CLASS(info_vip_start, CBaseDMStart, CCSDMStart);
LINK_ENTITY_TO_CLASS(info_landmark, CPointEntity); LINK_ENTITY_TO_CLASS(info_landmark, CPointEntity, CCSPointEntity);
LINK_ENTITY_TO_CLASS(info_hostage_rescue, CPointEntity); LINK_ENTITY_TO_CLASS(info_hostage_rescue, CPointEntity, CCSPointEntity);
LINK_ENTITY_TO_CLASS(info_bomb_target, CPointEntity); LINK_ENTITY_TO_CLASS(info_bomb_target, CPointEntity, CCSPointEntity);
void CBaseDMStart::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd) void CBaseDMStart::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
{ {
@ -180,8 +180,7 @@ void FireTargets(const char *targetName, CBaseEntity *pActivator, CBaseEntity *p
} }
} }
LINK_ENTITY_TO_CLASS(DelayedUse, CBaseDelay); LINK_ENTITY_TO_CLASS(DelayedUse, CBaseDelay, CCSDelay);
LINK_CLASS_TO_WRAP(CBaseDelay, CCSDelay);
void CBaseDelay::SUB_UseTargets(CBaseEntity *pActivator, USE_TYPE useType, float value) void CBaseDelay::SUB_UseTargets(CBaseEntity *pActivator, USE_TYPE useType, float value)
{ {
@ -193,7 +192,7 @@ void CBaseDelay::SUB_UseTargets(CBaseEntity *pActivator, USE_TYPE useType, float
if (m_flDelay != 0) if (m_flDelay != 0)
{ {
// create a temp object to fire at a later time // create a temp object to fire at a later time
CBaseDelay *pTemp = GetClassPtr((CBaseDelay *)NULL); CBaseDelay *pTemp = GetClassPtr<CCSDelay>((CBaseDelay *)NULL);
MAKE_STRING_CLASS("DelayedUse", pTemp->pev); MAKE_STRING_CLASS("DelayedUse", pTemp->pev);

View File

@ -329,7 +329,7 @@ void CHalfLifeTraining::__MAKE_VHOOK(CheckWinConditions)()
} }
IMPLEMENT_SAVERESTORE(CBaseGrenCatch, CBaseEntity); IMPLEMENT_SAVERESTORE(CBaseGrenCatch, CBaseEntity);
LINK_ENTITY_TO_CLASS(func_grencatch, CBaseGrenCatch); LINK_ENTITY_TO_CLASS(func_grencatch, CBaseGrenCatch, CCSGrenCatch);
void CBaseGrenCatch::__MAKE_VHOOK(Spawn)() void CBaseGrenCatch::__MAKE_VHOOK(Spawn)()
{ {
@ -458,7 +458,7 @@ void CFuncWeaponCheck::__MAKE_VHOOK(Spawn)()
} }
IMPLEMENT_SAVERESTORE(CFuncWeaponCheck, CBaseEntity); IMPLEMENT_SAVERESTORE(CFuncWeaponCheck, CBaseEntity);
LINK_ENTITY_TO_CLASS(func_weaponcheck, CFuncWeaponCheck); LINK_ENTITY_TO_CLASS(func_weaponcheck, CFuncWeaponCheck, CCSFuncWeaponCheck);
void CFuncWeaponCheck::__MAKE_VHOOK(Touch)(CBaseEntity *pOther) void CFuncWeaponCheck::__MAKE_VHOOK(Touch)(CBaseEntity *pOther)
{ {

View File

@ -36,7 +36,6 @@ class CHalfLifeTraining: public CHalfLifeMultiplay
{ {
public: public:
CHalfLifeTraining(); CHalfLifeTraining();
virtual BOOL IsMultiplayer() { return FALSE; } virtual BOOL IsMultiplayer() { return FALSE; }
virtual BOOL IsDeathmatch(); virtual BOOL IsDeathmatch();
virtual void InitHUD(CBasePlayer *pl); virtual void InitHUD(CBasePlayer *pl);

View File

@ -68,7 +68,7 @@ TYPEDESCRIPTION CTriggerCamera::m_SaveData[] =
char st_szNextMap[cchMapNameMost]; char st_szNextMap[cchMapNameMost];
char st_szNextSpot[cchMapNameMost]; char st_szNextSpot[cchMapNameMost];
LINK_ENTITY_TO_CLASS(func_friction, CFrictionModifier); LINK_ENTITY_TO_CLASS(func_friction, CFrictionModifier, CCSFrictionModifier);
IMPLEMENT_SAVERESTORE(CFrictionModifier, CBaseEntity); IMPLEMENT_SAVERESTORE(CFrictionModifier, CBaseEntity);
void CFrictionModifier::__MAKE_VHOOK(Spawn)() void CFrictionModifier::__MAKE_VHOOK(Spawn)()
@ -103,7 +103,7 @@ void CFrictionModifier::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
CBaseEntity::KeyValue(pkvd); CBaseEntity::KeyValue(pkvd);
} }
LINK_ENTITY_TO_CLASS(trigger_auto, CAutoTrigger); LINK_ENTITY_TO_CLASS(trigger_auto, CAutoTrigger, CCSAutoTrigger);
IMPLEMENT_SAVERESTORE(CAutoTrigger, CBaseDelay); IMPLEMENT_SAVERESTORE(CAutoTrigger, CBaseDelay);
void CAutoTrigger::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd) void CAutoTrigger::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
@ -157,7 +157,7 @@ void CAutoTrigger::__MAKE_VHOOK(Think)()
} }
} }
LINK_ENTITY_TO_CLASS(trigger_relay, CTriggerRelay); LINK_ENTITY_TO_CLASS(trigger_relay, CTriggerRelay, CCSTriggerRelay);
IMPLEMENT_SAVERESTORE(CTriggerRelay, CBaseDelay); IMPLEMENT_SAVERESTORE(CTriggerRelay, CBaseDelay);
void CTriggerRelay::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd) void CTriggerRelay::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
@ -197,7 +197,7 @@ void CTriggerRelay::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCal
} }
} }
LINK_ENTITY_TO_CLASS(multi_manager, CMultiManager); LINK_ENTITY_TO_CLASS(multi_manager, CMultiManager, CCSMultiManager);
IMPLEMENT_SAVERESTORE(CMultiManager, CBaseToggle); IMPLEMENT_SAVERESTORE(CMultiManager, CBaseToggle);
void CMultiManager::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd) void CMultiManager::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
@ -336,7 +336,7 @@ void CMultiManager::ManagerThink()
CMultiManager *CMultiManager::Clone() CMultiManager *CMultiManager::Clone()
{ {
CMultiManager *pMulti = GetClassPtr((CMultiManager *)NULL); CMultiManager *pMulti = GetClassPtr<CCSMultiManager>((CMultiManager *)NULL);
edict_t *pEdict = pMulti->pev->pContainingEntity; edict_t *pEdict = pMulti->pev->pContainingEntity;
Q_memcpy(pMulti->pev, pev, sizeof(*pev)); Q_memcpy(pMulti->pev, pev, sizeof(*pev));
@ -374,7 +374,7 @@ void CMultiManager::ManagerUse(CBaseEntity *pActivator, CBaseEntity *pCaller, US
pev->nextthink = gpGlobals->time; pev->nextthink = gpGlobals->time;
} }
LINK_ENTITY_TO_CLASS(env_render, CRenderFxManager); LINK_ENTITY_TO_CLASS(env_render, CRenderFxManager, CCSRenderFxManager);
void CRenderFxManager::__MAKE_VHOOK(Spawn)() void CRenderFxManager::__MAKE_VHOOK(Spawn)()
{ {
@ -408,7 +408,7 @@ void CRenderFxManager::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *p
} }
} }
LINK_ENTITY_TO_CLASS(trigger, CBaseTrigger); LINK_ENTITY_TO_CLASS(trigger, CBaseTrigger, CCSTrigger);
void CBaseTrigger::InitTrigger() void CBaseTrigger::InitTrigger()
{ {
@ -453,8 +453,8 @@ void CBaseTrigger::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
CBaseToggle::KeyValue(pkvd); CBaseToggle::KeyValue(pkvd);
} }
LINK_ENTITY_TO_CLASS(trigger_hurt, CTriggerHurt); LINK_ENTITY_TO_CLASS(trigger_hurt, CTriggerHurt, CCSTriggerHurt);
LINK_ENTITY_TO_CLASS(trigger_monsterjump, CTriggerMonsterJump); LINK_ENTITY_TO_CLASS(trigger_monsterjump, CTriggerMonsterJump, CCSTriggerMonsterJump);
void CTriggerMonsterJump::__MAKE_VHOOK(Spawn)() void CTriggerMonsterJump::__MAKE_VHOOK(Spawn)()
{ {
@ -511,7 +511,7 @@ void CTriggerMonsterJump::__MAKE_VHOOK(Touch)(CBaseEntity *pOther)
pev->nextthink = gpGlobals->time; pev->nextthink = gpGlobals->time;
} }
LINK_ENTITY_TO_CLASS(trigger_cdaudio, CTriggerCDAudio); LINK_ENTITY_TO_CLASS(trigger_cdaudio, CTriggerCDAudio, CCSTriggerCDAudio);
// Changes tracks or stops CD when player touches // Changes tracks or stops CD when player touches
// HACK: overloaded HEALTH to avoid adding new field // HACK: overloaded HEALTH to avoid adding new field
@ -575,7 +575,7 @@ void CTriggerCDAudio::PlayTrack()
UTIL_Remove(this); UTIL_Remove(this);
} }
LINK_ENTITY_TO_CLASS(target_cdaudio, CTargetCDAudio); LINK_ENTITY_TO_CLASS(target_cdaudio, CTargetCDAudio, CCSTargetCDAudio);
void CTargetCDAudio::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd) void CTargetCDAudio::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
{ {
@ -693,7 +693,7 @@ void CTriggerHurt::RadiationThink()
// reset origin // reset origin
if (!FNullEnt(pentPlayer)) if (!FNullEnt(pentPlayer))
{ {
pPlayer = GetClassPtr((CBasePlayer *)VARS(pentPlayer)); pPlayer = GetClassPtr<CCSPlayer>((CBasePlayer *)VARS(pentPlayer));
pevTarget = VARS(pentPlayer); pevTarget = VARS(pentPlayer);
@ -852,7 +852,7 @@ void CBaseTrigger::HurtTouch(CBaseEntity *pOther)
} }
} }
LINK_ENTITY_TO_CLASS(trigger_multiple, CTriggerMultiple); LINK_ENTITY_TO_CLASS(trigger_multiple, CTriggerMultiple, CCSTriggerMultiple);
void CTriggerMultiple::__MAKE_VHOOK(Spawn)() void CTriggerMultiple::__MAKE_VHOOK(Spawn)()
{ {
@ -886,7 +886,7 @@ void CTriggerMultiple::__MAKE_VHOOK(Spawn)()
} }
} }
LINK_ENTITY_TO_CLASS(trigger_once, CTriggerOnce); LINK_ENTITY_TO_CLASS(trigger_once, CTriggerOnce, CCSTriggerOnce);
void CTriggerOnce::__MAKE_VHOOK(Spawn)() void CTriggerOnce::__MAKE_VHOOK(Spawn)()
{ {
@ -1007,7 +1007,7 @@ void CBaseTrigger::CounterUse(CBaseEntity *pActivator, CBaseEntity *pCaller, USE
ActivateMultiTrigger(m_hActivator); ActivateMultiTrigger(m_hActivator);
} }
LINK_ENTITY_TO_CLASS(trigger_counter, CTriggerCounter); LINK_ENTITY_TO_CLASS(trigger_counter, CTriggerCounter, CCSTriggerCounter);
void CTriggerCounter::__MAKE_VHOOK(Spawn)() void CTriggerCounter::__MAKE_VHOOK(Spawn)()
{ {
@ -1023,7 +1023,7 @@ void CTriggerCounter::__MAKE_VHOOK(Spawn)()
SetUse(&CTriggerCounter::CounterUse); SetUse(&CTriggerCounter::CounterUse);
} }
LINK_ENTITY_TO_CLASS(trigger_transition, CTriggerVolume); LINK_ENTITY_TO_CLASS(trigger_transition, CTriggerVolume, CCSTriggerVolume);
// Define space that travels across a level transition // Define space that travels across a level transition
void CTriggerVolume::__MAKE_VHOOK(Spawn)() void CTriggerVolume::__MAKE_VHOOK(Spawn)()
@ -1038,7 +1038,7 @@ void CTriggerVolume::__MAKE_VHOOK(Spawn)()
pev->modelindex = 0; pev->modelindex = 0;
} }
LINK_ENTITY_TO_CLASS(fireanddie, CFireAndDie); LINK_ENTITY_TO_CLASS(fireanddie, CFireAndDie, CCSFireAndDie);
void CFireAndDie::__MAKE_VHOOK(Spawn)() void CFireAndDie::__MAKE_VHOOK(Spawn)()
{ {
@ -1057,7 +1057,7 @@ void CFireAndDie::__MAKE_VHOOK(Think)()
UTIL_Remove(this); UTIL_Remove(this);
} }
LINK_ENTITY_TO_CLASS(trigger_changelevel, CChangeLevel); LINK_ENTITY_TO_CLASS(trigger_changelevel, CChangeLevel, CCSChangeLevel);
IMPLEMENT_SAVERESTORE(CChangeLevel, CBaseTrigger); IMPLEMENT_SAVERESTORE(CChangeLevel, CBaseTrigger);
// Cache user-entity-field values until spawn is called. // Cache user-entity-field values until spawn is called.
@ -1184,7 +1184,7 @@ void CChangeLevel::ChangeLevelNow(CBaseEntity *pActivator)
// Create an entity to fire the changetarget // Create an entity to fire the changetarget
if (m_changeTarget) if (m_changeTarget)
{ {
CFireAndDie *pFireAndDie = GetClassPtr((CFireAndDie *)NULL); CFireAndDie *pFireAndDie = GetClassPtr<CCSFireAndDie>((CFireAndDie *)NULL);
if (pFireAndDie) if (pFireAndDie)
{ {
@ -1324,7 +1324,7 @@ int CChangeLevel::ChangeList(LEVELLIST *pLevelList, int maxList)
while (!FNullEnt(pentChangelevel)) while (!FNullEnt(pentChangelevel))
{ {
CChangeLevel *pTrigger = GetClassPtr((CChangeLevel *)VARS(pentChangelevel)); CChangeLevel *pTrigger = GetClassPtr<CCSChangeLevel>((CChangeLevel *)VARS(pentChangelevel));
if (pTrigger != NULL) if (pTrigger != NULL)
{ {
@ -1426,11 +1426,11 @@ NOXREF void NextLevel()
if (FNullEnt(pent)) if (FNullEnt(pent))
{ {
gpGlobals->mapname = ALLOC_STRING("start"); gpGlobals->mapname = ALLOC_STRING("start");
pChange = GetClassPtr((CChangeLevel *)NULL); pChange = GetClassPtr<CCSChangeLevel>((CChangeLevel *)NULL);
Q_strcpy(pChange->m_szMapName, "start"); Q_strcpy(pChange->m_szMapName, "start");
} }
else else
pChange = GetClassPtr((CChangeLevel *)VARS(pent)); pChange = GetClassPtr<CCSChangeLevel>((CChangeLevel *)VARS(pent));
Q_strcpy(st_szNextMap, pChange->m_szMapName); Q_strcpy(st_szNextMap, pChange->m_szMapName);
g_fGameOver = TRUE; g_fGameOver = TRUE;
@ -1442,7 +1442,7 @@ NOXREF void NextLevel()
} }
} }
LINK_ENTITY_TO_CLASS(func_ladder, CLadder); LINK_ENTITY_TO_CLASS(func_ladder, CLadder, CCSLadder);
void CLadder::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd) void CLadder::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
{ {
@ -1474,7 +1474,7 @@ void CLadder::__MAKE_VHOOK(Spawn)()
pev->movetype = MOVETYPE_PUSH; pev->movetype = MOVETYPE_PUSH;
} }
LINK_ENTITY_TO_CLASS(trigger_push, CTriggerPush); LINK_ENTITY_TO_CLASS(trigger_push, CTriggerPush, CCSTriggerPush);
void CTriggerPush::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd) void CTriggerPush::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
{ {
@ -1615,7 +1615,7 @@ void CBaseTrigger::TeleportTouch(CBaseEntity *pOther)
pevToucher->velocity = pevToucher->basevelocity = g_vecZero; pevToucher->velocity = pevToucher->basevelocity = g_vecZero;
} }
LINK_ENTITY_TO_CLASS(trigger_teleport, CTriggerTeleport); LINK_ENTITY_TO_CLASS(trigger_teleport, CTriggerTeleport, CCSTriggerTeleport);
void CTriggerTeleport::__MAKE_VHOOK(Spawn)() void CTriggerTeleport::__MAKE_VHOOK(Spawn)()
{ {
@ -1623,8 +1623,8 @@ void CTriggerTeleport::__MAKE_VHOOK(Spawn)()
SetTouch(&CTriggerTeleport::TeleportTouch); SetTouch(&CTriggerTeleport::TeleportTouch);
} }
LINK_ENTITY_TO_CLASS(info_teleport_destination, CPointEntity); LINK_ENTITY_TO_CLASS(info_teleport_destination, CPointEntity, CCSPointEntity);
LINK_ENTITY_TO_CLASS(func_buyzone, CBuyZone); LINK_ENTITY_TO_CLASS(func_buyzone, CBuyZone, CCSBuyZone);
void CBuyZone::__MAKE_VHOOK(Spawn)() void CBuyZone::__MAKE_VHOOK(Spawn)()
{ {
@ -1651,7 +1651,7 @@ void CBuyZone::BuyTouch(CBaseEntity *pOther)
} }
} }
LINK_ENTITY_TO_CLASS(func_bomb_target, CBombTarget); LINK_ENTITY_TO_CLASS(func_bomb_target, CBombTarget, CCSBombTarget);
void CBombTarget::__MAKE_VHOOK(Spawn)() void CBombTarget::__MAKE_VHOOK(Spawn)()
{ {
@ -1680,7 +1680,7 @@ void CBombTarget::BombTargetUse(CBaseEntity *pActivator, CBaseEntity *pCaller, U
SUB_UseTargets(NULL, USE_TOGGLE, 0); SUB_UseTargets(NULL, USE_TOGGLE, 0);
} }
LINK_ENTITY_TO_CLASS(func_hostage_rescue, CHostageRescue); LINK_ENTITY_TO_CLASS(func_hostage_rescue, CHostageRescue, CCSHostageRescue);
void CHostageRescue::__MAKE_VHOOK(Spawn)() void CHostageRescue::__MAKE_VHOOK(Spawn)()
{ {
@ -1701,7 +1701,7 @@ void CHostageRescue::HostageRescueTouch(CBaseEntity *pOther)
} }
} }
LINK_ENTITY_TO_CLASS(func_escapezone, CEscapeZone); LINK_ENTITY_TO_CLASS(func_escapezone, CEscapeZone, CCSEscapeZone);
void CEscapeZone::__MAKE_VHOOK(Spawn)() void CEscapeZone::__MAKE_VHOOK(Spawn)()
{ {
@ -1746,7 +1746,7 @@ void CEscapeZone::EscapeTouch(CBaseEntity *pOther)
} }
} }
LINK_ENTITY_TO_CLASS(func_vip_safetyzone, CVIP_SafetyZone); LINK_ENTITY_TO_CLASS(func_vip_safetyzone, CVIP_SafetyZone, CCSVIP_SafetyZone);
void CVIP_SafetyZone::__MAKE_VHOOK(Spawn)() void CVIP_SafetyZone::__MAKE_VHOOK(Spawn)()
{ {
@ -1774,7 +1774,7 @@ void CVIP_SafetyZone::VIP_SafetyTouch(CBaseEntity *pOther)
} }
} }
LINK_ENTITY_TO_CLASS(trigger_autosave, CTriggerSave); LINK_ENTITY_TO_CLASS(trigger_autosave, CTriggerSave, CCSTriggerSave);
void CTriggerSave::__MAKE_VHOOK(Spawn)() void CTriggerSave::__MAKE_VHOOK(Spawn)()
{ {
@ -1802,7 +1802,7 @@ void CTriggerSave::SaveTouch(CBaseEntity *pOther)
SERVER_COMMAND("autosave\n"); SERVER_COMMAND("autosave\n");
} }
LINK_ENTITY_TO_CLASS(trigger_endsection, CTriggerEndSection); LINK_ENTITY_TO_CLASS(trigger_endsection, CTriggerEndSection, CCSTriggerEndSection);
void CTriggerEndSection::EndSectionUse(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value) void CTriggerEndSection::EndSectionUse(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value)
{ {
@ -1864,7 +1864,7 @@ void CTriggerEndSection::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
CBaseTrigger::KeyValue(pkvd); CBaseTrigger::KeyValue(pkvd);
} }
LINK_ENTITY_TO_CLASS(trigger_gravity, CTriggerGravity); LINK_ENTITY_TO_CLASS(trigger_gravity, CTriggerGravity, CCSTriggerGravity);
void CTriggerGravity::__MAKE_VHOOK(Spawn)() void CTriggerGravity::__MAKE_VHOOK(Spawn)()
{ {
@ -1881,7 +1881,7 @@ void CTriggerGravity::GravityTouch(CBaseEntity *pOther)
pOther->pev->gravity = pev->gravity; pOther->pev->gravity = pev->gravity;
} }
LINK_ENTITY_TO_CLASS(trigger_changetarget, CTriggerChangeTarget); LINK_ENTITY_TO_CLASS(trigger_changetarget, CTriggerChangeTarget, CCSTriggerChangeTarget);
IMPLEMENT_SAVERESTORE(CTriggerChangeTarget, CBaseDelay); IMPLEMENT_SAVERESTORE(CTriggerChangeTarget, CBaseDelay);
void CTriggerChangeTarget::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd) void CTriggerChangeTarget::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
@ -1917,7 +1917,7 @@ void CTriggerChangeTarget::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntit
} }
} }
LINK_ENTITY_TO_CLASS(trigger_camera, CTriggerCamera); LINK_ENTITY_TO_CLASS(trigger_camera, CTriggerCamera, CCSTriggerCamera);
IMPLEMENT_SAVERESTORE(CTriggerCamera, CBaseDelay); IMPLEMENT_SAVERESTORE(CTriggerCamera, CBaseDelay);
void CTriggerCamera::__MAKE_VHOOK(Spawn)() void CTriggerCamera::__MAKE_VHOOK(Spawn)()
@ -2185,10 +2185,10 @@ void CTriggerCamera::Move()
pev->velocity = ((pev->movedir * pev->speed) * fraction) + (pev->velocity * (1 - fraction)); pev->velocity = ((pev->movedir * pev->speed) * fraction) + (pev->velocity * (1 - fraction));
} }
LINK_ENTITY_TO_CLASS(env_snow, CWeather); LINK_ENTITY_TO_CLASS(env_snow, CWeather, CCSWeather);
LINK_ENTITY_TO_CLASS(func_snow, CWeather); LINK_ENTITY_TO_CLASS(func_snow, CWeather, CCSWeather);
LINK_ENTITY_TO_CLASS(env_rain, CWeather); LINK_ENTITY_TO_CLASS(env_rain, CWeather, CCSWeather);
LINK_ENTITY_TO_CLASS(func_rain, CWeather); LINK_ENTITY_TO_CLASS(func_rain, CWeather, CCSWeather);
void CWeather::__MAKE_VHOOK(Spawn)() void CWeather::__MAKE_VHOOK(Spawn)()
{ {
@ -2231,4 +2231,4 @@ void CClientFog::__MAKE_VHOOK(Spawn)()
pev->rendermode = kRenderTransTexture; pev->rendermode = kRenderTransTexture;
} }
LINK_ENTITY_TO_CLASS(env_fog, CClientFog); LINK_ENTITY_TO_CLASS(env_fog, CClientFog, CCSClientFog);

View File

@ -744,7 +744,7 @@ public:
}; };
void PlayCDTrack(int iTrack); void PlayCDTrack(int iTrack);
int BuildChangeList(LEVELLIST * pLevelList, int maxList); int BuildChangeList(LEVELLIST *pLevelList, int maxList);
void NextLevel(); void NextLevel();
#endif // TRIGGERS_H #endif // TRIGGERS_H

View File

@ -159,20 +159,14 @@ extern globalvars_t *gpGlobals;
#endif #endif
#define REGAMEDLL_ALLOC_FUNC #define REGAMEDLL_ALLOC_FUNC
#define LINK_ENTITY_TO_CLASS(mapClassName, DLLClassName)\ #define LINK_ENTITY_TO_CLASS(mapClassName, DLLClassName, DLLClassWrapName)\
C_DLLEXPORT void EXT_FUNC mapClassName(entvars_t *pev);\ C_DLLEXPORT void EXT_FUNC mapClassName(entvars_t *pev);\
void mapClassName(entvars_t *pev)\ void mapClassName(entvars_t *pev)\
{\ {\
REGAMEDLL_ALLOC_FUNC\ REGAMEDLL_ALLOC_FUNC\
GetClassPtr((DLLClassName *)pev);\ GetClassPtr<DLLClassWrapName>((DLLClassName *)pev);\
} }
#define LINK_CLASS_TO_WRAP(className, classNameWrap)\
className::className()\
{\
GetClassPtrWrap<classNameWrap>(this);\
}\
typedef enum typedef enum
{ {
ignore_monsters = 1, ignore_monsters = 1,

View File

@ -42,7 +42,7 @@ void FixupAngles2(Vector &v)
} }
IMPLEMENT_SAVERESTORE(CFuncVehicle, CBaseEntity); IMPLEMENT_SAVERESTORE(CFuncVehicle, CBaseEntity);
LINK_ENTITY_TO_CLASS(func_vehicle, CFuncVehicle); LINK_ENTITY_TO_CLASS(func_vehicle, CFuncVehicle, CCSFuncVehicle);
void CFuncVehicle::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd) void CFuncVehicle::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
{ {
@ -943,7 +943,7 @@ void CFuncVehicle::__MAKE_VHOOK(Precache)()
m_usAdjustPitch = PRECACHE_EVENT(1, "events/vehicle.sc"); m_usAdjustPitch = PRECACHE_EVENT(1, "events/vehicle.sc");
} }
LINK_ENTITY_TO_CLASS(func_vehiclecontrols, CFuncVehicleControls); LINK_ENTITY_TO_CLASS(func_vehiclecontrols, CFuncVehicleControls, CCSFuncVehicleControls);
void CFuncVehicleControls::Find() void CFuncVehicleControls::Find()
{ {

View File

@ -1491,6 +1491,7 @@ void CBasePlayerWeapon::__MAKE_VHOOK(RetireWeapon)()
// GetNextAttackDelay - An accurate way of calcualting the next attack time. // GetNextAttackDelay - An accurate way of calcualting the next attack time.
float CBasePlayerWeapon::GetNextAttackDelay(float delay) float CBasePlayerWeapon::GetNextAttackDelay(float delay)
{ {
#ifndef REGAMEDLL_FIXES
if (m_flLastFireTime == 0.0f || m_flNextPrimaryAttack == -1.0f) if (m_flLastFireTime == 0.0f || m_flNextPrimaryAttack == -1.0f)
{ {
// At this point, we are assuming that the client has stopped firing // At this point, we are assuming that the client has stopped firing
@ -1498,6 +1499,7 @@ float CBasePlayerWeapon::GetNextAttackDelay(float delay)
m_flPrevPrimaryAttack = delay; m_flPrevPrimaryAttack = delay;
m_flLastFireTime = gpGlobals->time; m_flLastFireTime = gpGlobals->time;
} }
#endif
#ifdef REGAMEDLL_BUILD_6153 #ifdef REGAMEDLL_BUILD_6153
@ -1529,8 +1531,7 @@ float CBasePlayerWeapon::GetNextAttackDelay(float delay)
return flNextAttack; return flNextAttack;
} }
LINK_ENTITY_TO_CLASS(weaponbox, CWeaponBox); LINK_ENTITY_TO_CLASS(weaponbox, CWeaponBox, CCSWeaponBox);
LINK_CLASS_TO_WRAP(CWeaponBox, CCSWeaponBox);
IMPLEMENT_SAVERESTORE(CWeaponBox, CBaseEntity); IMPLEMENT_SAVERESTORE(CWeaponBox, CBaseEntity);
void CWeaponBox::__MAKE_VHOOK(Precache)() void CWeaponBox::__MAKE_VHOOK(Precache)()
@ -1567,7 +1568,7 @@ void CWeaponBox::BombThink()
if (!pEntity->IsPlayer() || pEntity->IsDormant()) if (!pEntity->IsPlayer() || pEntity->IsDormant())
continue; continue;
CBasePlayer *pTempPlayer = GetClassPtr((CBasePlayer *)pEntity->pev); CBasePlayer *pTempPlayer = GetClassPtr<CCSPlayer>((CBasePlayer *)pEntity->pev);
if (pTempPlayer->pev->deadflag == DEAD_NO && pTempPlayer->m_iTeam == TERRORIST) if (pTempPlayer->pev->deadflag == DEAD_NO && pTempPlayer->m_iTeam == TERRORIST)
{ {
@ -1717,7 +1718,7 @@ void CWeaponBox::__MAKE_VHOOK(Touch)(CBaseEntity *pOther)
if (pEntity->pev->flags == FL_DORMANT) if (pEntity->pev->flags == FL_DORMANT)
continue; continue;
CBasePlayer *pTempPlayer = GetClassPtr((CBasePlayer *)pEntity->pev); CBasePlayer *pTempPlayer = GetClassPtr<CCSPlayer>((CBasePlayer *)pEntity->pev);
if (pTempPlayer->pev->deadflag == DEAD_NO && pTempPlayer->m_iTeam == TERRORIST) if (pTempPlayer->pev->deadflag == DEAD_NO && pTempPlayer->m_iTeam == TERRORIST)
{ {
@ -2270,4 +2271,4 @@ void CArmoury::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
CBaseEntity::KeyValue(pkvd); CBaseEntity::KeyValue(pkvd);
} }
LINK_ENTITY_TO_CLASS(armoury_entity, CArmoury); LINK_ENTITY_TO_CLASS(armoury_entity, CArmoury, CCSArmoury);

View File

@ -155,7 +155,6 @@ public:
class CGrenade: public CBaseMonster class CGrenade: public CBaseMonster
{ {
public: public:
CGrenade();
virtual void Spawn(); virtual void Spawn();
virtual int Save(CSave &save); virtual int Save(CSave &save);
virtual int Restore(CRestore &restore); virtual int Restore(CRestore &restore);
@ -458,7 +457,6 @@ public:
class CWeaponBox: public CBaseEntity class CWeaponBox: public CBaseEntity
{ {
public: public:
CWeaponBox();
virtual void Spawn(); virtual void Spawn();
virtual void Precache(); virtual void Precache();
virtual void KeyValue(KeyValueData *pkvd); virtual void KeyValue(KeyValueData *pkvd);
@ -555,7 +553,7 @@ public:
virtual int GetItemInfo(ItemInfo *p); virtual int GetItemInfo(ItemInfo *p);
virtual BOOL Deploy(); virtual BOOL Deploy();
virtual float GetMaxSpeed() { return MP5N_MAX_SPEED; } virtual float GetMaxSpeed() { return MP5N_MAX_SPEED; }
int iItemSlot() { return PRIMARY_WEAPON_SLOT; } virtual int iItemSlot() { return PRIMARY_WEAPON_SLOT; }
virtual void PrimaryAttack(); virtual void PrimaryAttack();
virtual void Reload(); virtual void Reload();
virtual void WeaponIdle(); virtual void WeaponIdle();

View File

@ -80,7 +80,7 @@ public:
void EXPORT TriggerDecal(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value); void EXPORT TriggerDecal(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value);
}; };
LINK_ENTITY_TO_CLASS(infodecal, CDecal); LINK_ENTITY_TO_CLASS(infodecal, CDecal, CCSDecal);
void CDecal::Spawn() void CDecal::Spawn()
{ {
@ -173,7 +173,7 @@ public:
virtual int ObjectCaps() { return FCAP_DONT_SAVE; } virtual int ObjectCaps() { return FCAP_DONT_SAVE; }
}; };
LINK_ENTITY_TO_CLASS(bodyque, CCorpse); LINK_ENTITY_TO_CLASS(bodyque, CCorpse, CCSCorpse);
static void InitBodyQue() static void InitBodyQue()
{ {
@ -413,8 +413,7 @@ void EXT_FUNC ResetGlobalState()
#pragma push_macro("REGAMEDLL_ALLOC_FUNC") #pragma push_macro("REGAMEDLL_ALLOC_FUNC")
#define REGAMEDLL_ALLOC_FUNC Regamedll_AllocEntities(gpGlobals->maxEntities); #define REGAMEDLL_ALLOC_FUNC Regamedll_AllocEntities(gpGlobals->maxEntities);
LINK_ENTITY_TO_CLASS(worldspawn, CWorld); LINK_ENTITY_TO_CLASS(worldspawn, CWorld, CCSWorld);
LINK_CLASS_TO_WRAP(CWorld, CCSWorld);
#pragma pop_macro("REGAMEDLL_ALLOC_FUNC") #pragma pop_macro("REGAMEDLL_ALLOC_FUNC")
@ -481,11 +480,13 @@ void CWorld::__MAKE_VHOOK(Precache)()
g_pGameRules = InstallGameRules(); g_pGameRules = InstallGameRules();
// s1lent: What is the essence of soundent in CS 1.6? I think this is for NPC monsters.
#ifndef REGAMEDLL_FIXES
// UNDONE why is there so much Spawn code in the Precache function? I'll just keep it here // UNDONE why is there so much Spawn code in the Precache function? I'll just keep it here
// LATER - do we want a sound ent in deathmatch? (sjb) // LATER - do we want a sound ent in deathmatch? (sjb)
//pSoundEnt = CBaseEntity::Create("soundent", g_vecZero, g_vecZero, edict()); //pSoundEnt = CBaseEntity::Create("soundent", g_vecZero, g_vecZero, edict());
pSoundEnt = GetClassPtr((CSoundEnt *)NULL); pSoundEnt = GetClassPtr<CCSSoundEnt>((CSoundEnt *)NULL);
if (pSoundEnt == NULL) if (pSoundEnt == NULL)
{ {
@ -495,7 +496,7 @@ void CWorld::__MAKE_VHOOK(Precache)()
{ {
pSoundEnt->Spawn(); pSoundEnt->Spawn();
} }
#endif
InitBodyQue(); InitBodyQue();
// init sentence group playback stuff from sentences.txt. // init sentence group playback stuff from sentences.txt.

View File

@ -1,6 +1,6 @@
#include "precompiled.h" #include "precompiled.h"
LINK_ENTITY_TO_CLASS(weapon_ak47, CAK47); LINK_ENTITY_TO_CLASS(weapon_ak47, CAK47, CCSAK47);
void CAK47::__MAKE_VHOOK(Spawn)() void CAK47::__MAKE_VHOOK(Spawn)()
{ {

View File

@ -1,6 +1,6 @@
#include "precompiled.h" #include "precompiled.h"
LINK_ENTITY_TO_CLASS(weapon_aug, CAUG); LINK_ENTITY_TO_CLASS(weapon_aug, CAUG, CCSAUG);
void CAUG::__MAKE_VHOOK(Spawn)() void CAUG::__MAKE_VHOOK(Spawn)()
{ {

View File

@ -1,6 +1,6 @@
#include "precompiled.h" #include "precompiled.h"
LINK_ENTITY_TO_CLASS(weapon_awp, CAWP); LINK_ENTITY_TO_CLASS(weapon_awp, CAWP, CCSAWP);
void CAWP::__MAKE_VHOOK(Spawn)() void CAWP::__MAKE_VHOOK(Spawn)()
{ {

View File

@ -1,6 +1,6 @@
#include "precompiled.h" #include "precompiled.h"
LINK_ENTITY_TO_CLASS(weapon_c4, CC4); LINK_ENTITY_TO_CLASS(weapon_c4, CC4, CCSC4);
void CC4::__MAKE_VHOOK(Spawn)() void CC4::__MAKE_VHOOK(Spawn)()
{ {

View File

@ -1,6 +1,6 @@
#include "precompiled.h" #include "precompiled.h"
LINK_ENTITY_TO_CLASS(weapon_deagle, CDEAGLE); LINK_ENTITY_TO_CLASS(weapon_deagle, CDEAGLE, CCSDEAGLE);
void CDEAGLE::__MAKE_VHOOK(Spawn)() void CDEAGLE::__MAKE_VHOOK(Spawn)()
{ {

View File

@ -1,6 +1,6 @@
#include "precompiled.h" #include "precompiled.h"
LINK_ENTITY_TO_CLASS(weapon_elite, CELITE); LINK_ENTITY_TO_CLASS(weapon_elite, CELITE, CCSELITE);
void CELITE::__MAKE_VHOOK(Spawn)() void CELITE::__MAKE_VHOOK(Spawn)()
{ {

View File

@ -1,6 +1,6 @@
#include "precompiled.h" #include "precompiled.h"
LINK_ENTITY_TO_CLASS(weapon_famas, CFamas); LINK_ENTITY_TO_CLASS(weapon_famas, CFamas, CCSFamas);
void CFamas::__MAKE_VHOOK(Spawn)() void CFamas::__MAKE_VHOOK(Spawn)()
{ {

View File

@ -1,6 +1,6 @@
#include "precompiled.h" #include "precompiled.h"
LINK_ENTITY_TO_CLASS(weapon_fiveseven, CFiveSeven); LINK_ENTITY_TO_CLASS(weapon_fiveseven, CFiveSeven, CCSFiveSeven);
void CFiveSeven::__MAKE_VHOOK(Spawn)() void CFiveSeven::__MAKE_VHOOK(Spawn)()
{ {

View File

@ -1,6 +1,6 @@
#include "precompiled.h" #include "precompiled.h"
LINK_ENTITY_TO_CLASS(weapon_flashbang, CFlashbang); LINK_ENTITY_TO_CLASS(weapon_flashbang, CFlashbang, CCSFlashbang);
void CFlashbang::__MAKE_VHOOK(Spawn)() void CFlashbang::__MAKE_VHOOK(Spawn)()
{ {

View File

@ -1,6 +1,6 @@
#include "precompiled.h" #include "precompiled.h"
LINK_ENTITY_TO_CLASS(weapon_g3sg1, CG3SG1); LINK_ENTITY_TO_CLASS(weapon_g3sg1, CG3SG1, CCSG3SG1);
void CG3SG1::__MAKE_VHOOK(Spawn)() void CG3SG1::__MAKE_VHOOK(Spawn)()
{ {

View File

@ -1,6 +1,6 @@
#include "precompiled.h" #include "precompiled.h"
LINK_ENTITY_TO_CLASS(weapon_galil, CGalil); LINK_ENTITY_TO_CLASS(weapon_galil, CGalil, CCSGalil);
void CGalil::__MAKE_VHOOK(Spawn)() void CGalil::__MAKE_VHOOK(Spawn)()
{ {

View File

@ -1,6 +1,6 @@
#include "precompiled.h" #include "precompiled.h"
LINK_ENTITY_TO_CLASS(weapon_glock18, CGLOCK18); LINK_ENTITY_TO_CLASS(weapon_glock18, CGLOCK18, CCSGLOCK18);
void CGLOCK18::__MAKE_VHOOK(Spawn)() void CGLOCK18::__MAKE_VHOOK(Spawn)()
{ {

View File

@ -1,6 +1,6 @@
#include "precompiled.h" #include "precompiled.h"
LINK_ENTITY_TO_CLASS(weapon_hegrenade, CHEGrenade); LINK_ENTITY_TO_CLASS(weapon_hegrenade, CHEGrenade, CCSHEGrenade);
void CHEGrenade::__MAKE_VHOOK(Spawn)() void CHEGrenade::__MAKE_VHOOK(Spawn)()
{ {

View File

@ -1,6 +1,6 @@
#include "precompiled.h" #include "precompiled.h"
LINK_ENTITY_TO_CLASS(weapon_knife, CKnife); LINK_ENTITY_TO_CLASS(weapon_knife, CKnife, CCSKnife);
void CKnife::__MAKE_VHOOK(Spawn)() void CKnife::__MAKE_VHOOK(Spawn)()
{ {

View File

@ -1,6 +1,6 @@
#include "precompiled.h" #include "precompiled.h"
LINK_ENTITY_TO_CLASS(weapon_m249, CM249); LINK_ENTITY_TO_CLASS(weapon_m249, CM249, CCSM249);
void CM249::__MAKE_VHOOK(Spawn)() void CM249::__MAKE_VHOOK(Spawn)()
{ {

View File

@ -1,6 +1,6 @@
#include "precompiled.h" #include "precompiled.h"
LINK_ENTITY_TO_CLASS(weapon_m3, CM3); LINK_ENTITY_TO_CLASS(weapon_m3, CM3, CCSM3);
void CM3::__MAKE_VHOOK(Spawn)() void CM3::__MAKE_VHOOK(Spawn)()
{ {

View File

@ -1,6 +1,6 @@
#include "precompiled.h" #include "precompiled.h"
LINK_ENTITY_TO_CLASS(weapon_m4a1, CM4A1); LINK_ENTITY_TO_CLASS(weapon_m4a1, CM4A1, CCSM4A1);
void CM4A1::__MAKE_VHOOK(Spawn)() void CM4A1::__MAKE_VHOOK(Spawn)()
{ {

View File

@ -1,6 +1,6 @@
#include "precompiled.h" #include "precompiled.h"
LINK_ENTITY_TO_CLASS(weapon_mac10, CMAC10); LINK_ENTITY_TO_CLASS(weapon_mac10, CMAC10, CCSMAC10);
void CMAC10::__MAKE_VHOOK(Spawn)() void CMAC10::__MAKE_VHOOK(Spawn)()
{ {

View File

@ -1,6 +1,6 @@
#include "precompiled.h" #include "precompiled.h"
LINK_ENTITY_TO_CLASS(weapon_mp5navy, CMP5N); LINK_ENTITY_TO_CLASS(weapon_mp5navy, CMP5N, CCSMP5N);
void CMP5N::__MAKE_VHOOK(Spawn)() void CMP5N::__MAKE_VHOOK(Spawn)()
{ {

View File

@ -1,6 +1,6 @@
#include "precompiled.h" #include "precompiled.h"
LINK_ENTITY_TO_CLASS(weapon_p228, CP228); LINK_ENTITY_TO_CLASS(weapon_p228, CP228, CCSP228);
void CP228::__MAKE_VHOOK(Spawn)() void CP228::__MAKE_VHOOK(Spawn)()
{ {

View File

@ -1,6 +1,6 @@
#include "precompiled.h" #include "precompiled.h"
LINK_ENTITY_TO_CLASS(weapon_p90, CP90); LINK_ENTITY_TO_CLASS(weapon_p90, CP90, CCSP90);
void CP90::__MAKE_VHOOK(Spawn)() void CP90::__MAKE_VHOOK(Spawn)()
{ {

View File

@ -1,6 +1,6 @@
#include "precompiled.h" #include "precompiled.h"
LINK_ENTITY_TO_CLASS(weapon_scout, CSCOUT); LINK_ENTITY_TO_CLASS(weapon_scout, CSCOUT, CCSSCOUT);
void CSCOUT::__MAKE_VHOOK(Spawn)() void CSCOUT::__MAKE_VHOOK(Spawn)()
{ {

View File

@ -1,6 +1,6 @@
#include "precompiled.h" #include "precompiled.h"
LINK_ENTITY_TO_CLASS(weapon_sg550, CSG550); LINK_ENTITY_TO_CLASS(weapon_sg550, CSG550, CCSSG550);
void CSG550::__MAKE_VHOOK(Spawn)() void CSG550::__MAKE_VHOOK(Spawn)()
{ {

View File

@ -1,6 +1,6 @@
#include "precompiled.h" #include "precompiled.h"
LINK_ENTITY_TO_CLASS(weapon_sg552, CSG552); LINK_ENTITY_TO_CLASS(weapon_sg552, CSG552, CCSSG552);
void CSG552::__MAKE_VHOOK(Spawn)() void CSG552::__MAKE_VHOOK(Spawn)()
{ {

View File

@ -1,6 +1,6 @@
#include "precompiled.h" #include "precompiled.h"
LINK_ENTITY_TO_CLASS(weapon_smokegrenade, CSmokeGrenade); LINK_ENTITY_TO_CLASS(weapon_smokegrenade, CSmokeGrenade, CCSSmokeGrenade);
void CSmokeGrenade::__MAKE_VHOOK(Spawn)() void CSmokeGrenade::__MAKE_VHOOK(Spawn)()
{ {

View File

@ -1,6 +1,6 @@
#include "precompiled.h" #include "precompiled.h"
LINK_ENTITY_TO_CLASS(weapon_tmp, CTMP); LINK_ENTITY_TO_CLASS(weapon_tmp, CTMP, CCSTMP);
void CTMP::__MAKE_VHOOK(Spawn)() void CTMP::__MAKE_VHOOK(Spawn)()
{ {

View File

@ -1,6 +1,6 @@
#include "precompiled.h" #include "precompiled.h"
LINK_ENTITY_TO_CLASS(weapon_ump45, CUMP45); LINK_ENTITY_TO_CLASS(weapon_ump45, CUMP45, CCSUMP45);
void CUMP45::__MAKE_VHOOK(Spawn)() void CUMP45::__MAKE_VHOOK(Spawn)()
{ {

View File

@ -1,9 +1,7 @@
#include "precompiled.h" #include "precompiled.h"
/* <2bb045> ../cstrike/dlls/wpn_shared/wpn_usp.cpp:68 */ LINK_ENTITY_TO_CLASS(weapon_usp, CUSP, CCSUSP);
LINK_ENTITY_TO_CLASS(weapon_usp, CUSP);
/* <2bad55> ../cstrike/dlls/wpn_shared/wpn_usp.cpp:70 */
void CUSP::__MAKE_VHOOK(Spawn)() void CUSP::__MAKE_VHOOK(Spawn)()
{ {
Precache(); Precache();
@ -38,7 +36,6 @@ void CUSP::__MAKE_VHOOK(Precache)()
m_usFireUSP = PRECACHE_EVENT(1, "events/usp.sc"); m_usFireUSP = PRECACHE_EVENT(1, "events/usp.sc");
} }
/* <2bacfb> ../cstrike/dlls/wpn_shared/wpn_usp.cpp:107 */
int CUSP::__MAKE_VHOOK(GetItemInfo)(ItemInfo *p) int CUSP::__MAKE_VHOOK(GetItemInfo)(ItemInfo *p)
{ {
p->pszName = STRING(pev->classname); p->pszName = STRING(pev->classname);
@ -60,7 +57,6 @@ int CUSP::__MAKE_VHOOK(GetItemInfo)(ItemInfo *p)
return 1; return 1;
} }
/* <2bad2e> ../cstrike/dlls/wpn_shared/wpn_usp.cpp:124 */
BOOL CUSP::__MAKE_VHOOK(Deploy)() BOOL CUSP::__MAKE_VHOOK(Deploy)()
{ {
m_iWeaponState &= ~WPNSTATE_SHIELD_DRAWN; m_iWeaponState &= ~WPNSTATE_SHIELD_DRAWN;
@ -81,7 +77,6 @@ BOOL CUSP::__MAKE_VHOOK(Deploy)()
return DefaultDeploy("models/v_usp.mdl", "models/p_usp.mdl", USP_UNSIL_DRAW, "onehanded", UseDecrement()); return DefaultDeploy("models/v_usp.mdl", "models/p_usp.mdl", USP_UNSIL_DRAW, "onehanded", UseDecrement());
} }
/* <2bae77> ../cstrike/dlls/wpn_shared/wpn_usp.cpp:147 */
void CUSP::__MAKE_VHOOK(SecondaryAttack)() void CUSP::__MAKE_VHOOK(SecondaryAttack)()
{ {
if (ShieldSecondaryFire(USP_SHIELD_UP, USP_SHIELD_DOWN)) if (ShieldSecondaryFire(USP_SHIELD_UP, USP_SHIELD_DOWN))
@ -108,7 +103,6 @@ void CUSP::__MAKE_VHOOK(SecondaryAttack)()
m_flNextPrimaryAttack = GetNextAttackDelay(3.0); m_flNextPrimaryAttack = GetNextAttackDelay(3.0);
} }
/* <2bb000> ../cstrike/dlls/wpn_shared/wpn_usp.cpp:173 */
void CUSP::__MAKE_VHOOK(PrimaryAttack)() void CUSP::__MAKE_VHOOK(PrimaryAttack)()
{ {
if (m_iWeaponState & WPNSTATE_USP_SILENCED) if (m_iWeaponState & WPNSTATE_USP_SILENCED)
@ -151,7 +145,6 @@ void CUSP::__MAKE_VHOOK(PrimaryAttack)()
} }
} }
/* <2bb10f> ../cstrike/dlls/wpn_shared/wpn_usp.cpp:200 */
void CUSP::USPFire(float flSpread, float flCycleTime, BOOL fUseSemi) void CUSP::USPFire(float flSpread, float flCycleTime, BOOL fUseSemi)
{ {
int flag; int flag;
@ -239,7 +232,6 @@ void CUSP::USPFire(float flSpread, float flCycleTime, BOOL fUseSemi)
ResetPlayerShieldAnim(); ResetPlayerShieldAnim();
} }
/* <2bae19> ../cstrike/dlls/wpn_shared/wpn_usp.cpp:297 */
void CUSP::__MAKE_VHOOK(Reload)() void CUSP::__MAKE_VHOOK(Reload)()
{ {
if (m_pPlayer->ammo_45acp <= 0) if (m_pPlayer->ammo_45acp <= 0)
@ -264,7 +256,6 @@ void CUSP::__MAKE_VHOOK(Reload)()
} }
} }
/* <2b9c2a> ../cstrike/dlls/wpn_shared/wpn_usp.cpp:318 */
void CUSP::__MAKE_VHOOK(WeaponIdle)() void CUSP::__MAKE_VHOOK(WeaponIdle)()
{ {
ResetEmptySound(); ResetEmptySound();

View File

@ -1,6 +1,6 @@
#include "precompiled.h" #include "precompiled.h"
LINK_ENTITY_TO_CLASS(weapon_xm1014, CXM1014); LINK_ENTITY_TO_CLASS(weapon_xm1014, CXM1014, CCSXM1014);
void CXM1014::__MAKE_VHOOK(Spawn)() void CXM1014::__MAKE_VHOOK(Spawn)()
{ {

View File

@ -34,7 +34,7 @@
class BotProfile; class BotProfile;
template <class T> template <class T, class TWrap>
T *CreateBot(const BotProfile *profile) T *CreateBot(const BotProfile *profile)
{ {
edict_t *pentBot; edict_t *pentBot;
@ -57,7 +57,7 @@ T *CreateBot(const BotProfile *profile)
{ {
T *pBot = NULL; T *pBot = NULL;
FREE_PRIVATE(pentBot); FREE_PRIVATE(pentBot);
pBot = GetClassPtr((T *)VARS(pentBot)); pBot = GetClassPtr<TWrap>((T *)VARS(pentBot));
pBot->Initialize(profile); pBot->Initialize(profile);
return pBot; return pBot;

View File

@ -111,6 +111,9 @@ float (*CLocalNav::pflLastThinkTime);
EHANDLE (*CLocalNav::phostages)[20]; EHANDLE (*CLocalNav::phostages)[20];
int (*CLocalNav::ptot_hostages); int (*CLocalNav::ptot_hostages);
// soundent
CSoundEnt *pSoundEnt;
// globals weapons // globals weapons
const char *g_pModelNameLaser; const char *g_pModelNameLaser;
ItemInfo IMPL_CLASS(CBasePlayerItem, ItemInfoArray)[32]; ItemInfo IMPL_CLASS(CBasePlayerItem, ItemInfoArray)[32];

View File

@ -91,7 +91,6 @@
#include <sys/types.h> #include <sys/types.h>
#include <sys/sysinfo.h> #include <sys/sysinfo.h>
#include <unistd.h> #include <unistd.h>
#include <typeinfo>
// Deail with stupid macro in kernel.h // Deail with stupid macro in kernel.h
#undef __FUNCTION__ #undef __FUNCTION__

File diff suppressed because it is too large Load Diff

View File

@ -40,11 +40,13 @@ void Regamedll_AllocEntities(int maxEdicts)
g_GameEntities = (CCSEntity **)Q_malloc(sizeof(CCSEntity *) * maxEdicts); g_GameEntities = (CCSEntity **)Q_malloc(sizeof(CCSEntity *) * maxEdicts);
Q_memset(g_GameEntities, 0, sizeof(CCSEntity *) * maxEdicts); Q_memset(g_GameEntities, 0, sizeof(CCSEntity *) * maxEdicts);
#ifdef _DEBUG
CONSOLE_ECHO(__FUNCTION__":: alloc entities!\n"); CONSOLE_ECHO(__FUNCTION__":: alloc entities!\n");
ADD_SERVER_COMMAND("check", [](){ ADD_SERVER_COMMAND("check_ent", [](){
Regamedll_MonitorEntities(); Regamedll_MonitorEntities();
}); });
#endif
} }
void Regamedll_FreeEntities(CBaseEntity *pEntity) void Regamedll_FreeEntities(CBaseEntity *pEntity)
@ -70,7 +72,9 @@ void Regamedll_FreeEntities(CBaseEntity *pEntity)
delete g_GameEntities[index]; delete g_GameEntities[index];
g_GameEntities[index] = NULL; g_GameEntities[index] = NULL;
#ifdef _DEBUG
CONSOLE_ECHO(__FUNCTION__ ":: Free on (#%d. %s)\n", index, STRING(pEntity->edict()->v.classname)); CONSOLE_ECHO(__FUNCTION__ ":: Free on (#%d. %s)\n", index, STRING(pEntity->edict()->v.classname));
#endif
} }
void Regamedll_MonitorEntities() void Regamedll_MonitorEntities()
@ -102,6 +106,12 @@ ICSPlayer *CBASE_TO_CSPLAYER(CBaseEntity *pEntity)
return reinterpret_cast<ICSPlayer *>(g_GameEntities[index]); return reinterpret_cast<ICSPlayer *>(g_GameEntities[index]);
} }
ICSPlayer *INDEX_TO_CSPLAYER(int iPlayerIndex)
{
CBaseEntity *pEntity = CBaseEntity::Instance(iPlayerIndex);
return CBASE_TO_CSPLAYER(pEntity);
}
ICSEntity *CBASE_TO_CSENTITY(CBaseEntity *pEntity) ICSEntity *CBASE_TO_CSENTITY(CBaseEntity *pEntity)
{ {
if (pEntity == NULL) if (pEntity == NULL)
@ -116,3 +126,9 @@ ICSEntity *CBASE_TO_CSENTITY(CBaseEntity *pEntity)
return g_GameEntities[index]; return g_GameEntities[index];
} }
ICSEntity *INDEX_TO_CSENTITY(int iEntityIndex)
{
CBaseEntity *pEntity = CBaseEntity::Instance(iEntityIndex);
return CBASE_TO_CSENTITY(pEntity);
}

File diff suppressed because it is too large Load Diff