mirror of
https://github.com/s1lentq/ReGameDLL_CS.git
synced 2025-01-14 15:48:01 +03:00
Regamedll API WIP: implemented interfaces some objects.
This commit is contained in:
parent
9fd5eaa043
commit
7b227c0edb
@ -32,7 +32,7 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
typedef enum
|
typedef enum Activity_s
|
||||||
{
|
{
|
||||||
ACT_INVALID = -1,
|
ACT_INVALID = -1,
|
||||||
|
|
||||||
|
@ -13,6 +13,7 @@ TYPEDESCRIPTION CAirtank::m_SaveData[] =
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(item_airtank, CAirtank);
|
LINK_ENTITY_TO_CLASS(item_airtank, CAirtank);
|
||||||
|
LINK_CLASS_TO_WRAP(CAirtank, CCSAirtank);
|
||||||
IMPLEMENT_SAVERESTORE(CAirtank, CGrenade);
|
IMPLEMENT_SAVERESTORE(CAirtank, CGrenade);
|
||||||
|
|
||||||
void CAirtank::__MAKE_VHOOK(Spawn)()
|
void CAirtank::__MAKE_VHOOK(Spawn)()
|
||||||
|
@ -35,6 +35,7 @@
|
|||||||
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);
|
||||||
|
@ -25,6 +25,7 @@ BOOL C9MMAmmo::__MAKE_VHOOK(AddAmmo)(CBaseEntity *pOther)
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(ammo_9mm, C9MMAmmo);
|
LINK_ENTITY_TO_CLASS(ammo_9mm, C9MMAmmo);
|
||||||
|
LINK_CLASS_TO_WRAP(C9MMAmmo, CCS9MMAmmo);
|
||||||
|
|
||||||
void CBuckShotAmmo::__MAKE_VHOOK(Spawn)()
|
void CBuckShotAmmo::__MAKE_VHOOK(Spawn)()
|
||||||
{
|
{
|
||||||
@ -51,6 +52,7 @@ BOOL CBuckShotAmmo::__MAKE_VHOOK(AddAmmo)(CBaseEntity *pOther)
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(ammo_buckshot, CBuckShotAmmo);
|
LINK_ENTITY_TO_CLASS(ammo_buckshot, CBuckShotAmmo);
|
||||||
|
LINK_CLASS_TO_WRAP(CBuckShotAmmo, CCSBuckShotAmmo);
|
||||||
|
|
||||||
void C556NatoAmmo::__MAKE_VHOOK(Spawn)()
|
void C556NatoAmmo::__MAKE_VHOOK(Spawn)()
|
||||||
{
|
{
|
||||||
@ -77,6 +79,7 @@ BOOL C556NatoAmmo::__MAKE_VHOOK(AddAmmo)(CBaseEntity *pOther)
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(ammo_556nato, C556NatoAmmo);
|
LINK_ENTITY_TO_CLASS(ammo_556nato, C556NatoAmmo);
|
||||||
|
LINK_CLASS_TO_WRAP(C556NatoAmmo, CCS556NatoAmmo);
|
||||||
|
|
||||||
void C556NatoBoxAmmo::__MAKE_VHOOK(Spawn)()
|
void C556NatoBoxAmmo::__MAKE_VHOOK(Spawn)()
|
||||||
{
|
{
|
||||||
@ -103,6 +106,7 @@ BOOL C556NatoBoxAmmo::__MAKE_VHOOK(AddAmmo)(CBaseEntity *pOther)
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(ammo_556natobox, C556NatoBoxAmmo);
|
LINK_ENTITY_TO_CLASS(ammo_556natobox, C556NatoBoxAmmo);
|
||||||
|
LINK_CLASS_TO_WRAP(C556NatoBoxAmmo, CCS556NatoBoxAmmo);
|
||||||
|
|
||||||
void C762NatoAmmo::__MAKE_VHOOK(Spawn)()
|
void C762NatoAmmo::__MAKE_VHOOK(Spawn)()
|
||||||
{
|
{
|
||||||
@ -129,6 +133,7 @@ BOOL C762NatoAmmo::__MAKE_VHOOK(AddAmmo)(CBaseEntity *pOther)
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(ammo_762nato, C762NatoAmmo);
|
LINK_ENTITY_TO_CLASS(ammo_762nato, C762NatoAmmo);
|
||||||
|
LINK_CLASS_TO_WRAP(C762NatoAmmo, CCS762NatoAmmo);
|
||||||
|
|
||||||
void C45ACPAmmo::__MAKE_VHOOK(Spawn)()
|
void C45ACPAmmo::__MAKE_VHOOK(Spawn)()
|
||||||
{
|
{
|
||||||
@ -155,6 +160,7 @@ BOOL C45ACPAmmo::__MAKE_VHOOK(AddAmmo)(CBaseEntity *pOther)
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(ammo_45acp, C45ACPAmmo);
|
LINK_ENTITY_TO_CLASS(ammo_45acp, C45ACPAmmo);
|
||||||
|
LINK_CLASS_TO_WRAP(C45ACPAmmo, CCS45ACPAmmo);
|
||||||
|
|
||||||
void C50AEAmmo::__MAKE_VHOOK(Spawn)()
|
void C50AEAmmo::__MAKE_VHOOK(Spawn)()
|
||||||
{
|
{
|
||||||
@ -181,6 +187,7 @@ BOOL C50AEAmmo::__MAKE_VHOOK(AddAmmo)(CBaseEntity *pOther)
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(ammo_50ae, C50AEAmmo);
|
LINK_ENTITY_TO_CLASS(ammo_50ae, C50AEAmmo);
|
||||||
|
LINK_CLASS_TO_WRAP(C50AEAmmo, CCS50AEAmmo);
|
||||||
|
|
||||||
void C338MagnumAmmo::__MAKE_VHOOK(Spawn)()
|
void C338MagnumAmmo::__MAKE_VHOOK(Spawn)()
|
||||||
{
|
{
|
||||||
@ -207,6 +214,7 @@ BOOL C338MagnumAmmo::__MAKE_VHOOK(AddAmmo)(CBaseEntity *pOther)
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(ammo_338magnum, C338MagnumAmmo);
|
LINK_ENTITY_TO_CLASS(ammo_338magnum, C338MagnumAmmo);
|
||||||
|
LINK_CLASS_TO_WRAP(C338MagnumAmmo, CCS338MagnumAmmo);
|
||||||
|
|
||||||
void C57MMAmmo::__MAKE_VHOOK(Spawn)()
|
void C57MMAmmo::__MAKE_VHOOK(Spawn)()
|
||||||
{
|
{
|
||||||
@ -233,6 +241,7 @@ BOOL C57MMAmmo::__MAKE_VHOOK(AddAmmo)(CBaseEntity *pOther)
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(ammo_57mm, C57MMAmmo);
|
LINK_ENTITY_TO_CLASS(ammo_57mm, C57MMAmmo);
|
||||||
|
LINK_CLASS_TO_WRAP(C57MMAmmo, CCS57MMAmmo);
|
||||||
|
|
||||||
void C357SIGAmmo::__MAKE_VHOOK(Spawn)()
|
void C357SIGAmmo::__MAKE_VHOOK(Spawn)()
|
||||||
{
|
{
|
||||||
@ -259,3 +268,4 @@ BOOL C357SIGAmmo::__MAKE_VHOOK(AddAmmo)(CBaseEntity *pOther)
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(ammo_357sig, C357SIGAmmo);
|
LINK_ENTITY_TO_CLASS(ammo_357sig, C357SIGAmmo);
|
||||||
|
LINK_CLASS_TO_WRAP(C357SIGAmmo, CCS357SIGAmmo);
|
||||||
|
@ -35,6 +35,7 @@
|
|||||||
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);
|
||||||
@ -52,6 +53,7 @@ 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);
|
||||||
@ -69,6 +71,7 @@ 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);
|
||||||
@ -86,6 +89,7 @@ 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);
|
||||||
@ -103,6 +107,7 @@ 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);
|
||||||
@ -120,6 +125,7 @@ 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);
|
||||||
@ -137,6 +143,7 @@ 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);
|
||||||
@ -154,6 +161,7 @@ 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);
|
||||||
@ -171,6 +179,7 @@ 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);
|
||||||
@ -187,6 +196,7 @@ 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);
|
||||||
|
@ -35,6 +35,7 @@ Vector VecBModelOrigin(entvars_t *pevBModel)
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(func_wall, CFuncWall);
|
LINK_ENTITY_TO_CLASS(func_wall, CFuncWall);
|
||||||
|
LINK_CLASS_TO_WRAP(CFuncWall, CCSFuncWall);
|
||||||
|
|
||||||
void CFuncWall::__MAKE_VHOOK(Spawn)()
|
void CFuncWall::__MAKE_VHOOK(Spawn)()
|
||||||
{
|
{
|
||||||
@ -59,6 +60,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);
|
||||||
|
LINK_CLASS_TO_WRAP(CFuncWallToggle, CCSFuncWallToggle);
|
||||||
|
|
||||||
void CFuncWallToggle::__MAKE_VHOOK(Spawn)()
|
void CFuncWallToggle::__MAKE_VHOOK(Spawn)()
|
||||||
{
|
{
|
||||||
@ -108,6 +110,7 @@ void CFuncWallToggle::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pC
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(func_conveyor, CFuncConveyor);
|
LINK_ENTITY_TO_CLASS(func_conveyor, CFuncConveyor);
|
||||||
|
LINK_CLASS_TO_WRAP(CFuncConveyor, CCSFuncConveyor);
|
||||||
|
|
||||||
void CFuncConveyor::__MAKE_VHOOK(Spawn)()
|
void CFuncConveyor::__MAKE_VHOOK(Spawn)()
|
||||||
{
|
{
|
||||||
@ -155,6 +158,7 @@ void CFuncConveyor::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCal
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(func_illusionary, CFuncIllusionary);
|
LINK_ENTITY_TO_CLASS(func_illusionary, CFuncIllusionary);
|
||||||
|
LINK_CLASS_TO_WRAP(CFuncIllusionary, CCSFuncIllusionary);
|
||||||
|
|
||||||
void CFuncIllusionary::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
|
void CFuncIllusionary::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
|
||||||
{
|
{
|
||||||
@ -185,6 +189,7 @@ void CFuncIllusionary::__MAKE_VHOOK(Spawn)()
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(func_monsterclip, CFuncMonsterClip);
|
LINK_ENTITY_TO_CLASS(func_monsterclip, CFuncMonsterClip);
|
||||||
|
LINK_CLASS_TO_WRAP(CFuncMonsterClip, CCSFuncMonsterClip);
|
||||||
|
|
||||||
void CFuncMonsterClip::__MAKE_VHOOK(Spawn)()
|
void CFuncMonsterClip::__MAKE_VHOOK(Spawn)()
|
||||||
{
|
{
|
||||||
@ -199,7 +204,7 @@ void CFuncMonsterClip::__MAKE_VHOOK(Spawn)()
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(func_rotating, CFuncRotating);
|
LINK_ENTITY_TO_CLASS(func_rotating, CFuncRotating);
|
||||||
|
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)
|
||||||
@ -603,6 +608,7 @@ void CFuncRotating::__MAKE_VHOOK(Blocked)(CBaseEntity *pOther)
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(func_pendulum, CPendulum);
|
LINK_ENTITY_TO_CLASS(func_pendulum, CPendulum);
|
||||||
|
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)
|
||||||
|
@ -59,6 +59,7 @@
|
|||||||
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
|
||||||
@ -77,6 +78,7 @@ 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);
|
||||||
|
|
||||||
@ -96,6 +98,7 @@ 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);
|
||||||
|
|
||||||
@ -114,6 +117,7 @@ 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; }
|
||||||
@ -139,6 +143,7 @@ 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
|
||||||
@ -156,6 +161,7 @@ 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();
|
||||||
@ -197,6 +203,7 @@ 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);
|
||||||
|
@ -54,6 +54,7 @@ TYPEDESCRIPTION CEnvSpark::m_SaveData[] =
|
|||||||
|
|
||||||
IMPLEMENT_SAVERESTORE(CEnvGlobal, CBaseEntity);
|
IMPLEMENT_SAVERESTORE(CEnvGlobal, CBaseEntity);
|
||||||
LINK_ENTITY_TO_CLASS(env_global, CEnvGlobal);
|
LINK_ENTITY_TO_CLASS(env_global, CEnvGlobal);
|
||||||
|
LINK_CLASS_TO_WRAP(CEnvGlobal, CCSEnvGlobal);
|
||||||
|
|
||||||
void CEnvGlobal::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
|
void CEnvGlobal::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
|
||||||
{
|
{
|
||||||
@ -136,6 +137,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);
|
||||||
|
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)
|
||||||
@ -426,6 +428,7 @@ int CBaseButton::__MAKE_VHOOK(TakeDamage)(entvars_t *pevInflictor, entvars_t *pe
|
|||||||
// 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);
|
||||||
|
LINK_CLASS_TO_WRAP(CBaseButton, CCSButton);
|
||||||
|
|
||||||
void CBaseButton::__MAKE_VHOOK(Spawn)()
|
void CBaseButton::__MAKE_VHOOK(Spawn)()
|
||||||
{
|
{
|
||||||
@ -790,6 +793,7 @@ void CBaseButton::ButtonBackHome()
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(func_rot_button, CRotButton);
|
LINK_ENTITY_TO_CLASS(func_rot_button, CRotButton);
|
||||||
|
LINK_CLASS_TO_WRAP(CRotButton, CCSRotButton);
|
||||||
|
|
||||||
void CRotButton::__MAKE_VHOOK(Spawn)()
|
void CRotButton::__MAKE_VHOOK(Spawn)()
|
||||||
{
|
{
|
||||||
@ -857,6 +861,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);
|
||||||
|
LINK_CLASS_TO_WRAP(CMomentaryRotButton, CCSMomentaryRotButton);
|
||||||
|
|
||||||
void CMomentaryRotButton::__MAKE_VHOOK(Spawn)()
|
void CMomentaryRotButton::__MAKE_VHOOK(Spawn)()
|
||||||
{
|
{
|
||||||
@ -1073,6 +1078,7 @@ 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);
|
||||||
LINK_ENTITY_TO_CLASS(env_debris, CEnvSpark);
|
LINK_ENTITY_TO_CLASS(env_debris, CEnvSpark);
|
||||||
|
LINK_CLASS_TO_WRAP(CEnvSpark, CCSEnvSpark);
|
||||||
|
|
||||||
void CEnvSpark::__MAKE_VHOOK(Spawn)()
|
void CEnvSpark::__MAKE_VHOOK(Spawn)()
|
||||||
{
|
{
|
||||||
@ -1155,6 +1161,7 @@ void CEnvSpark::SparkStop(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYP
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(button_target, CButtonTarget);
|
LINK_ENTITY_TO_CLASS(button_target, CButtonTarget);
|
||||||
|
LINK_CLASS_TO_WRAP(CButtonTarget, CCSButtonTarget);
|
||||||
|
|
||||||
void CButtonTarget::__MAKE_VHOOK(Spawn)()
|
void CButtonTarget::__MAKE_VHOOK(Spawn)()
|
||||||
{
|
{
|
||||||
|
@ -34,8 +34,8 @@
|
|||||||
|
|
||||||
#define SF_BUTTON_DONTMOVE 1
|
#define SF_BUTTON_DONTMOVE 1
|
||||||
#define SF_ROTBUTTON_NOTSOLID 1
|
#define SF_ROTBUTTON_NOTSOLID 1
|
||||||
#define SF_BUTTON_TOGGLE 32 // button stays pushed until reactivated
|
#define SF_BUTTON_TOGGLE 32 // button stays pushed until reactivated
|
||||||
#define SF_BUTTON_SPARK_IF_OFF 64 // button sparks in OFF state
|
#define SF_BUTTON_SPARK_IF_OFF 64 // button sparks in OFF state
|
||||||
#define SF_BUTTON_TOUCH_ONLY 256 // button only fires as a result of USE key.
|
#define SF_BUTTON_TOUCH_ONLY 256 // button only fires as a result of USE key.
|
||||||
|
|
||||||
#define SF_GLOBAL_SET 1 // Set global state to initial state on spawn
|
#define SF_GLOBAL_SET 1 // Set global state to initial state on spawn
|
||||||
@ -57,6 +57,7 @@
|
|||||||
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);
|
||||||
@ -84,6 +85,7 @@ public:
|
|||||||
class CRotButton: public CBaseButton
|
class CRotButton: public CBaseButton
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
CRotButton();
|
||||||
virtual void Spawn();
|
virtual void Spawn();
|
||||||
|
|
||||||
#ifdef HOOK_GAMEDLL
|
#ifdef HOOK_GAMEDLL
|
||||||
@ -96,6 +98,7 @@ 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);
|
||||||
@ -147,6 +150,7 @@ 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);
|
||||||
@ -170,13 +174,13 @@ public:
|
|||||||
|
|
||||||
public:
|
public:
|
||||||
static TYPEDESCRIPTION IMPL(m_SaveData)[1];
|
static TYPEDESCRIPTION IMPL(m_SaveData)[1];
|
||||||
|
|
||||||
float m_flDelay;
|
float m_flDelay;
|
||||||
};
|
};
|
||||||
|
|
||||||
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);
|
||||||
|
@ -62,6 +62,8 @@ static DLL_FUNCTIONS gFunctionTable =
|
|||||||
static NEW_DLL_FUNCTIONS gNewDLLFunctions
|
static NEW_DLL_FUNCTIONS gNewDLLFunctions
|
||||||
{
|
{
|
||||||
&OnFreeEntPrivateData,
|
&OnFreeEntPrivateData,
|
||||||
|
&GameDLLShutdown,
|
||||||
|
NULL,
|
||||||
NULL,
|
NULL,
|
||||||
NULL
|
NULL
|
||||||
};
|
};
|
||||||
@ -81,6 +83,8 @@ 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;
|
||||||
@ -1080,4 +1084,7 @@ void OnFreeEntPrivateData(edict_t *pEnt)
|
|||||||
|
|
||||||
pEntity->UpdateOnRemove();
|
pEntity->UpdateOnRemove();
|
||||||
RemoveEntityHashValue(pEntity->pev, STRING(pEntity->pev->classname), CLASSNAME);
|
RemoveEntityHashValue(pEntity->pev, STRING(pEntity->pev->classname), CLASSNAME);
|
||||||
|
Regamedll_FreeEntities(pEntity);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//LINK_CLASS_TO_WRAP(CBaseEntity, CCSEntity);
|
||||||
|
@ -358,7 +358,12 @@ public:
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
public:
|
public:
|
||||||
void *operator new(size_t stAllocateBlock, entvars_t *pevnew) { return ALLOC_PRIVATE(ENT(pevnew), stAllocateBlock); }
|
void *operator new(size_t stAllocateBlock, entvars_t *pevnew)
|
||||||
|
{
|
||||||
|
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();
|
||||||
@ -448,6 +453,7 @@ 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); }
|
||||||
|
|
||||||
@ -462,22 +468,23 @@ 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 void Use(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value);
|
|
||||||
virtual int ObjectCaps() { return (CPointEntity::ObjectCaps() | FCAP_MASTER); }
|
|
||||||
virtual BOOL IsTriggered(CBaseEntity *pActivator);
|
|
||||||
virtual int Save(CSave &save);
|
virtual int Save(CSave &save);
|
||||||
virtual int Restore(CRestore &restore);
|
virtual int Restore(CRestore &restore);
|
||||||
|
virtual int ObjectCaps() { return (CPointEntity::ObjectCaps() | FCAP_MASTER); }
|
||||||
|
virtual BOOL IsTriggered(CBaseEntity *pActivator);
|
||||||
|
virtual void Use(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value);
|
||||||
|
|
||||||
#ifdef HOOK_GAMEDLL
|
#ifdef HOOK_GAMEDLL
|
||||||
|
|
||||||
void Spawn_();
|
void Spawn_();
|
||||||
void KeyValue_(KeyValueData *pkvd);
|
void KeyValue_(KeyValueData *pkvd);
|
||||||
void Use_(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value);
|
|
||||||
BOOL IsTriggered_(CBaseEntity *pActivator);
|
|
||||||
int Save_(CSave &save);
|
int Save_(CSave &save);
|
||||||
int Restore_(CRestore &restore);
|
int Restore_(CRestore &restore);
|
||||||
|
BOOL IsTriggered_(CBaseEntity *pActivator);
|
||||||
|
void Use_(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -496,6 +503,7 @@ 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);
|
||||||
@ -628,7 +636,7 @@ 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);
|
||||||
@ -688,6 +696,7 @@ 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);
|
||||||
@ -702,6 +711,25 @@ public:
|
|||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
extern const std::type_info *g_typeInfo;
|
||||||
|
extern class CCSEntity **g_GameEntities;
|
||||||
|
|
||||||
|
template <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>
|
template <class T>
|
||||||
T *GetClassPtr(T *a)
|
T *GetClassPtr(T *a)
|
||||||
{
|
{
|
||||||
@ -711,8 +739,9 @@ 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;
|
||||||
a->pev = pev;
|
g_typeInfo = NULL;
|
||||||
|
|
||||||
#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()));
|
||||||
|
@ -142,6 +142,7 @@ BOOL EXT_FUNC ClientConnect(edict_t *pEntity, const char *pszName, const char *p
|
|||||||
void EXT_FUNC ClientDisconnect(edict_t *pEntity)
|
void EXT_FUNC ClientDisconnect(edict_t *pEntity)
|
||||||
{
|
{
|
||||||
CBasePlayer *pPlayer = dynamic_cast<CBasePlayer *>(CBaseEntity::Instance(pEntity));
|
CBasePlayer *pPlayer = dynamic_cast<CBasePlayer *>(CBaseEntity::Instance(pEntity));
|
||||||
|
CSPlayer(pPlayer)->OnClientDisconnected();
|
||||||
|
|
||||||
if (!g_fGameOver)
|
if (!g_fGameOver)
|
||||||
{
|
{
|
||||||
@ -476,6 +477,7 @@ void EXT_FUNC ClientPutInServer(edict_t *pEntity)
|
|||||||
|
|
||||||
pPlayer->SetCustomDecalFrames(-1);
|
pPlayer->SetCustomDecalFrames(-1);
|
||||||
pPlayer->SetPrefsFromUserinfo(GET_INFO_BUFFER(pEntity));
|
pPlayer->SetPrefsFromUserinfo(GET_INFO_BUFFER(pEntity));
|
||||||
|
CSPlayer(pPlayer)->OnClientConnected();
|
||||||
|
|
||||||
if (!g_pGameRules->IsMultiplayer())
|
if (!g_pGameRules->IsMultiplayer())
|
||||||
{
|
{
|
||||||
|
@ -191,6 +191,7 @@ LINK_ENTITY_TO_CLASS(func_door, CBaseDoor);
|
|||||||
|
|
||||||
// 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);
|
||||||
|
LINK_CLASS_TO_WRAP(CBaseDoor, CCSDoor);
|
||||||
|
|
||||||
void CBaseDoor::__MAKE_VHOOK(Spawn)()
|
void CBaseDoor::__MAKE_VHOOK(Spawn)()
|
||||||
{
|
{
|
||||||
@ -841,6 +842,7 @@ void CBaseDoor::__MAKE_VHOOK(Blocked)(CBaseEntity *pOther)
|
|||||||
// 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);
|
||||||
|
LINK_CLASS_TO_WRAP(CRotDoor, CCSRotDoor);
|
||||||
|
|
||||||
void CRotDoor::__MAKE_VHOOK(Restart)()
|
void CRotDoor::__MAKE_VHOOK(Restart)()
|
||||||
{
|
{
|
||||||
@ -939,6 +941,7 @@ void CRotDoor::__MAKE_VHOOK(SetToggleState)(int state)
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(momentary_door, CMomentaryDoor);
|
LINK_ENTITY_TO_CLASS(momentary_door, CMomentaryDoor);
|
||||||
|
LINK_CLASS_TO_WRAP(CMomentaryDoor, CCSMomentaryDoor);
|
||||||
IMPLEMENT_SAVERESTORE(CMomentaryDoor, CBaseToggle);
|
IMPLEMENT_SAVERESTORE(CMomentaryDoor, CBaseToggle);
|
||||||
|
|
||||||
void CMomentaryDoor::__MAKE_VHOOK(Spawn)()
|
void CMomentaryDoor::__MAKE_VHOOK(Spawn)()
|
||||||
|
@ -51,6 +51,7 @@
|
|||||||
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();
|
||||||
@ -112,6 +113,7 @@ 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);
|
||||||
@ -129,6 +131,7 @@ 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);
|
||||||
|
@ -62,7 +62,11 @@ TYPEDESCRIPTION CGibShooter::m_SaveData[] =
|
|||||||
#endif // HOOK_GAMEDLL
|
#endif // HOOK_GAMEDLL
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(info_target, CPointEntity);
|
LINK_ENTITY_TO_CLASS(info_target, CPointEntity);
|
||||||
|
LINK_CLASS_TO_WRAP(CPointEntity, CCSPointEntity);
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(env_bubbles, CBubbling);
|
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)()
|
||||||
@ -155,6 +159,7 @@ void CBubbling::FizzThink()
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(beam, CBeam);
|
LINK_ENTITY_TO_CLASS(beam, CBeam);
|
||||||
|
LINK_CLASS_TO_WRAP(CBeam, CCSBeam);
|
||||||
|
|
||||||
void CBeam::__MAKE_VHOOK(Spawn)()
|
void CBeam::__MAKE_VHOOK(Spawn)()
|
||||||
{
|
{
|
||||||
@ -352,6 +357,8 @@ void CBeam::DoSparks(const Vector &start, const Vector &end)
|
|||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(env_lightning, CLightning);
|
LINK_ENTITY_TO_CLASS(env_lightning, CLightning);
|
||||||
LINK_ENTITY_TO_CLASS(env_beam, CLightning);
|
LINK_ENTITY_TO_CLASS(env_beam, CLightning);
|
||||||
|
LINK_CLASS_TO_WRAP(CLightning, CCSLightning);
|
||||||
|
|
||||||
IMPLEMENT_SAVERESTORE(CLightning, CBeam);
|
IMPLEMENT_SAVERESTORE(CLightning, CBeam);
|
||||||
|
|
||||||
void CLightning::__MAKE_VHOOK(Spawn)()
|
void CLightning::__MAKE_VHOOK(Spawn)()
|
||||||
@ -847,6 +854,7 @@ void CLightning::BeamUpdateVars()
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(env_laser, CLaser);
|
LINK_ENTITY_TO_CLASS(env_laser, CLaser);
|
||||||
|
LINK_CLASS_TO_WRAP(CLaser, CCSLaser);
|
||||||
IMPLEMENT_SAVERESTORE(CLaser, CBeam);
|
IMPLEMENT_SAVERESTORE(CLaser, CBeam);
|
||||||
|
|
||||||
void CLaser::__MAKE_VHOOK(Spawn)()
|
void CLaser::__MAKE_VHOOK(Spawn)()
|
||||||
@ -1006,6 +1014,7 @@ void CLaser::StrikeThink()
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(env_glow, CGlow);
|
LINK_ENTITY_TO_CLASS(env_glow, CGlow);
|
||||||
|
LINK_CLASS_TO_WRAP(CGlow, CCSGlow);
|
||||||
IMPLEMENT_SAVERESTORE(CGlow, CPointEntity);
|
IMPLEMENT_SAVERESTORE(CGlow, CPointEntity);
|
||||||
|
|
||||||
void CGlow::__MAKE_VHOOK(Spawn)()
|
void CGlow::__MAKE_VHOOK(Spawn)()
|
||||||
@ -1045,6 +1054,7 @@ void CGlow::Animate(float frames)
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(env_bombglow, CBombGlow);
|
LINK_ENTITY_TO_CLASS(env_bombglow, CBombGlow);
|
||||||
|
LINK_CLASS_TO_WRAP(CBombGlow, CCSBombGlow);
|
||||||
|
|
||||||
void CBombGlow::__MAKE_VHOOK(Spawn)()
|
void CBombGlow::__MAKE_VHOOK(Spawn)()
|
||||||
{
|
{
|
||||||
@ -1097,6 +1107,7 @@ void CBombGlow::__MAKE_VHOOK(Think)()
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(env_sprite, CSprite);
|
LINK_ENTITY_TO_CLASS(env_sprite, CSprite);
|
||||||
|
LINK_CLASS_TO_WRAP(CSprite, CCSSprite);
|
||||||
IMPLEMENT_SAVERESTORE(CSprite, CPointEntity);
|
IMPLEMENT_SAVERESTORE(CSprite, CPointEntity);
|
||||||
|
|
||||||
void CSprite::__MAKE_VHOOK(Spawn)()
|
void CSprite::__MAKE_VHOOK(Spawn)()
|
||||||
@ -1274,6 +1285,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);
|
||||||
|
LINK_CLASS_TO_WRAP(CGibShooter, CCSGibShooter);
|
||||||
|
|
||||||
void CGibShooter::__MAKE_VHOOK(Precache)()
|
void CGibShooter::__MAKE_VHOOK(Precache)()
|
||||||
{
|
{
|
||||||
@ -1426,6 +1438,7 @@ void CGibShooter::ShootThink()
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(env_shooter, CEnvShooter);
|
LINK_ENTITY_TO_CLASS(env_shooter, CEnvShooter);
|
||||||
|
LINK_CLASS_TO_WRAP(CEnvShooter, CCSEnvShooter);
|
||||||
|
|
||||||
void CEnvShooter::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
|
void CEnvShooter::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
|
||||||
{
|
{
|
||||||
@ -1498,6 +1511,7 @@ CGib *CEnvShooter::__MAKE_VHOOK(CreateGib)()
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(test_effect, CTestEffect);
|
LINK_ENTITY_TO_CLASS(test_effect, CTestEffect);
|
||||||
|
LINK_CLASS_TO_WRAP(CTestEffect, CCSTestEffect);
|
||||||
|
|
||||||
void CTestEffect::__MAKE_VHOOK(Spawn)()
|
void CTestEffect::__MAKE_VHOOK(Spawn)()
|
||||||
{
|
{
|
||||||
@ -1572,6 +1586,7 @@ void CTestEffect::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCalle
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(env_blood, CBlood);
|
LINK_ENTITY_TO_CLASS(env_blood, CBlood);
|
||||||
|
LINK_CLASS_TO_WRAP(CBlood, CCSBlood);
|
||||||
|
|
||||||
void CBlood::__MAKE_VHOOK(Spawn)()
|
void CBlood::__MAKE_VHOOK(Spawn)()
|
||||||
{
|
{
|
||||||
@ -1660,6 +1675,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);
|
||||||
|
LINK_CLASS_TO_WRAP(CShake, CCSShake);
|
||||||
|
|
||||||
void CShake::__MAKE_VHOOK(Spawn)()
|
void CShake::__MAKE_VHOOK(Spawn)()
|
||||||
{
|
{
|
||||||
@ -1704,6 +1720,7 @@ void CShake::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCaller, US
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(env_fade, CFade);
|
LINK_ENTITY_TO_CLASS(env_fade, CFade);
|
||||||
|
LINK_CLASS_TO_WRAP(CFade, CCSFade);
|
||||||
|
|
||||||
void CFade::__MAKE_VHOOK(Spawn)()
|
void CFade::__MAKE_VHOOK(Spawn)()
|
||||||
{
|
{
|
||||||
@ -1753,6 +1770,7 @@ void CFade::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCaller, USE
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(env_message, CMessage);
|
LINK_ENTITY_TO_CLASS(env_message, CMessage);
|
||||||
|
LINK_CLASS_TO_WRAP(CMessage, CCSMessage);
|
||||||
|
|
||||||
void CMessage::__MAKE_VHOOK(Spawn)()
|
void CMessage::__MAKE_VHOOK(Spawn)()
|
||||||
{
|
{
|
||||||
@ -1846,6 +1864,7 @@ void CMessage::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCaller,
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(env_funnel, CEnvFunnel);
|
LINK_ENTITY_TO_CLASS(env_funnel, CEnvFunnel);
|
||||||
|
LINK_CLASS_TO_WRAP(CEnvFunnel, CCSEnvFunnel);
|
||||||
|
|
||||||
void CEnvFunnel::__MAKE_VHOOK(Precache)()
|
void CEnvFunnel::__MAKE_VHOOK(Precache)()
|
||||||
{
|
{
|
||||||
@ -1892,6 +1911,7 @@ void CEnvBeverage::__MAKE_VHOOK(Precache)()
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(env_beverage, CEnvBeverage);
|
LINK_ENTITY_TO_CLASS(env_beverage, CEnvBeverage);
|
||||||
|
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)
|
||||||
{
|
{
|
||||||
@ -1934,6 +1954,7 @@ void CItemSoda::__MAKE_VHOOK(Precache)()
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(item_sodacan, CItemSoda);
|
LINK_ENTITY_TO_CLASS(item_sodacan, CItemSoda);
|
||||||
|
LINK_CLASS_TO_WRAP(CItemSoda, CCSItemSoda);
|
||||||
|
|
||||||
void CItemSoda::__MAKE_VHOOK(Spawn)()
|
void CItemSoda::__MAKE_VHOOK(Spawn)()
|
||||||
{
|
{
|
||||||
|
@ -71,6 +71,7 @@
|
|||||||
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();
|
||||||
@ -156,6 +157,7 @@ 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()
|
||||||
@ -238,6 +240,7 @@ 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);
|
||||||
@ -275,6 +278,7 @@ 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);
|
||||||
@ -309,6 +313,7 @@ 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);
|
||||||
@ -366,6 +371,7 @@ 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);
|
||||||
@ -392,6 +398,7 @@ public:
|
|||||||
class CBombGlow: public CSprite
|
class CBombGlow: public CSprite
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
CBombGlow();
|
||||||
virtual void Spawn();
|
virtual void Spawn();
|
||||||
virtual void Think();
|
virtual void Think();
|
||||||
|
|
||||||
@ -411,6 +418,7 @@ 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);
|
||||||
@ -450,6 +458,7 @@ 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();
|
||||||
@ -469,6 +478,7 @@ 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);
|
||||||
@ -497,6 +507,7 @@ 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);
|
||||||
@ -524,6 +535,7 @@ 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);
|
||||||
@ -551,6 +563,7 @@ 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);
|
||||||
@ -574,6 +587,7 @@ 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);
|
||||||
@ -593,6 +607,7 @@ 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);
|
||||||
@ -612,6 +627,7 @@ 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);
|
||||||
@ -629,6 +645,7 @@ public:
|
|||||||
class CItemSoda: public CBaseEntity
|
class CItemSoda: public CBaseEntity
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
CItemSoda();
|
||||||
virtual void Spawn();
|
virtual void Spawn();
|
||||||
virtual void Precache();
|
virtual void Precache();
|
||||||
|
|
||||||
|
@ -175,7 +175,7 @@ inline void *GET_PRIVATE(edict_t *pent)
|
|||||||
#define DELTA_FINDFIELD (*g_engfuncs.pfnDeltaFindField)
|
#define DELTA_FINDFIELD (*g_engfuncs.pfnDeltaFindField)
|
||||||
#define DELTA_SETBYINDEX (*g_engfuncs.pfnDeltaSetFieldByIndex)
|
#define DELTA_SETBYINDEX (*g_engfuncs.pfnDeltaSetFieldByIndex)
|
||||||
#define DELTA_UNSETBYINDEX (*g_engfuncs.pfnDeltaUnsetFieldByIndex)
|
#define DELTA_UNSETBYINDEX (*g_engfuncs.pfnDeltaUnsetFieldByIndex)
|
||||||
#define REMOVE_KEY_VALUE (*g_engfuncs.pfnInfo_RemoveKey)
|
#define REMOVE_KEY_VALUE (*g_engfuncs.pfnInfo_RemoveKey)
|
||||||
#define SET_PHYSICS_KEY_VALUE (*g_engfuncs.pfnSetPhysicsKeyValue)
|
#define SET_PHYSICS_KEY_VALUE (*g_engfuncs.pfnSetPhysicsKeyValue)
|
||||||
#define ENGINE_GETPHYSINFO (*g_engfuncs.pfnGetPhysicsInfoString)
|
#define ENGINE_GETPHYSINFO (*g_engfuncs.pfnGetPhysicsInfoString)
|
||||||
#define ENGINE_SETGROUPMASK (*g_engfuncs.pfnSetGroupMask)
|
#define ENGINE_SETGROUPMASK (*g_engfuncs.pfnSetGroupMask)
|
||||||
|
@ -14,6 +14,7 @@ TYPEDESCRIPTION CEnvExplosion::m_SaveData[] =
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(spark_shower, CShower);
|
LINK_ENTITY_TO_CLASS(spark_shower, CShower);
|
||||||
|
LINK_CLASS_TO_WRAP(CShower, CCSShower);
|
||||||
|
|
||||||
void CShower::__MAKE_VHOOK(Spawn)()
|
void CShower::__MAKE_VHOOK(Spawn)()
|
||||||
{
|
{
|
||||||
@ -69,6 +70,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);
|
||||||
|
LINK_CLASS_TO_WRAP(CEnvExplosion, CCSEnvExplosion);
|
||||||
|
|
||||||
void CEnvExplosion::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
|
void CEnvExplosion::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
|
||||||
{
|
{
|
||||||
|
@ -42,6 +42,7 @@
|
|||||||
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();
|
||||||
@ -60,6 +61,7 @@ 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);
|
||||||
|
@ -170,6 +170,7 @@ void CBreakable::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(func_breakable, CBreakable);
|
LINK_ENTITY_TO_CLASS(func_breakable, CBreakable);
|
||||||
|
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,6 +850,7 @@ int CBreakable::__MAKE_VHOOK(DamageDecal)(int bitsDamageType)
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(func_pushable, CPushable);
|
LINK_ENTITY_TO_CLASS(func_pushable, CPushable);
|
||||||
|
LINK_CLASS_TO_WRAP(CPushable, CCSPushable);
|
||||||
IMPLEMENT_SAVERESTORE(CPushable, CBreakable);
|
IMPLEMENT_SAVERESTORE(CPushable, CBreakable);
|
||||||
|
|
||||||
void CPushable::__MAKE_VHOOK(Spawn)()
|
void CPushable::__MAKE_VHOOK(Spawn)()
|
||||||
|
@ -37,7 +37,7 @@
|
|||||||
|
|
||||||
// func breakable
|
// func breakable
|
||||||
#define SF_BREAK_TRIGGER_ONLY 1 // may only be broken by trigger
|
#define SF_BREAK_TRIGGER_ONLY 1 // may only be broken by trigger
|
||||||
#define SF_BREAK_TOUCH 2 // can be 'crashed through' by running player (plate glass)
|
#define SF_BREAK_TOUCH 2 // can be 'crashed through' by running player (plate glass)
|
||||||
#define SF_BREAK_PRESSURE 4 // can be broken by a player standing on it
|
#define SF_BREAK_PRESSURE 4 // can be broken by a player standing on it
|
||||||
#define SF_BREAK_CROWBAR 256 // instant break if hit with crowbar
|
#define SF_BREAK_CROWBAR 256 // instant break if hit with crowbar
|
||||||
|
|
||||||
@ -70,6 +70,7 @@ 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();
|
||||||
@ -143,6 +144,7 @@ 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);
|
||||||
|
@ -60,6 +60,7 @@ 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,6 +656,7 @@ void CFuncTank::StopRotSound()
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(func_tank, CFuncTankGun);
|
LINK_ENTITY_TO_CLASS(func_tank, CFuncTankGun);
|
||||||
|
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)
|
||||||
{
|
{
|
||||||
@ -694,6 +696,7 @@ void CFuncTankGun::__MAKE_VHOOK(Fire)(const Vector &barrelEnd, const Vector &for
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(func_tanklaser, CFuncTankLaser);
|
LINK_ENTITY_TO_CLASS(func_tanklaser, CFuncTankLaser);
|
||||||
|
LINK_CLASS_TO_WRAP(CFuncTankLaser, CCSFuncTankLaser);
|
||||||
IMPLEMENT_SAVERESTORE(CFuncTankLaser, CFuncTank);
|
IMPLEMENT_SAVERESTORE(CFuncTankLaser, CFuncTank);
|
||||||
|
|
||||||
void CFuncTankLaser::__MAKE_VHOOK(Activate)()
|
void CFuncTankLaser::__MAKE_VHOOK(Activate)()
|
||||||
@ -790,6 +793,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);
|
||||||
|
LINK_CLASS_TO_WRAP(CFuncTankRocket, CCSFuncTankRocket);
|
||||||
|
|
||||||
void CFuncTankRocket::__MAKE_VHOOK(Precache)()
|
void CFuncTankRocket::__MAKE_VHOOK(Precache)()
|
||||||
{
|
{
|
||||||
@ -820,6 +824,7 @@ void CFuncTankRocket::__MAKE_VHOOK(Fire)(const Vector &barrelEnd, const Vector &
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(func_tankmortar, CFuncTankMortar);
|
LINK_ENTITY_TO_CLASS(func_tankmortar, CFuncTankMortar);
|
||||||
|
LINK_CLASS_TO_WRAP(CFuncTankMortar, CCSFuncTankMortar);
|
||||||
|
|
||||||
void CFuncTankMortar::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
|
void CFuncTankMortar::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
|
||||||
{
|
{
|
||||||
@ -858,6 +863,7 @@ void CFuncTankMortar::__MAKE_VHOOK(Fire)(const Vector &barrelEnd, const Vector &
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(func_tankcontrols, CFuncTankControls);
|
LINK_ENTITY_TO_CLASS(func_tankcontrols, CFuncTankControls);
|
||||||
|
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)
|
||||||
|
@ -51,6 +51,7 @@ 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);
|
||||||
@ -159,12 +160,11 @@ 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
|
||||||
|
|
||||||
void Fire_(const Vector &barrelEnd, const Vector &forward, entvars_t *pevAttacker);
|
void Fire_(const Vector &barrelEnd, const Vector &forward, entvars_t *pevAttacker);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
};
|
};
|
||||||
@ -172,6 +172,7 @@ 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);
|
||||||
@ -203,6 +204,7 @@ 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);
|
||||||
|
|
||||||
@ -218,6 +220,7 @@ 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);
|
||||||
|
|
||||||
@ -233,6 +236,7 @@ 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);
|
||||||
@ -252,7 +256,6 @@ public:
|
|||||||
|
|
||||||
public:
|
public:
|
||||||
static TYPEDESCRIPTION IMPL(m_SaveData)[1];
|
static TYPEDESCRIPTION IMPL(m_SaveData)[1];
|
||||||
|
|
||||||
CFuncTank *m_pTank;
|
CFuncTank *m_pTank;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -233,3 +233,8 @@ void EXT_FUNC GameDLLInit()
|
|||||||
Tutor_RegisterCVars();
|
Tutor_RegisterCVars();
|
||||||
Hostage_RegisterCVars();
|
Hostage_RegisterCVars();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void EXT_FUNC GameDLLShutdown()
|
||||||
|
{
|
||||||
|
Regamedll_FreeEntities();
|
||||||
|
}
|
||||||
|
@ -139,5 +139,6 @@ extern cvar_t round_infinite;
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
void GameDLLInit();
|
void GameDLLInit();
|
||||||
|
void GameDLLShutdown();
|
||||||
|
|
||||||
#endif // GAME_H
|
#endif // GAME_H
|
||||||
|
@ -64,7 +64,7 @@
|
|||||||
#define MAX_MOTD_LENGTH 1536 // (MAX_MOTD_CHUNK * 4)
|
#define MAX_MOTD_LENGTH 1536 // (MAX_MOTD_CHUNK * 4)
|
||||||
|
|
||||||
// custom enum
|
// custom enum
|
||||||
#define WINNER_NONE 0
|
#define WINNER_NONE 0
|
||||||
#define WINNER_DRAW 1
|
#define WINNER_DRAW 1
|
||||||
|
|
||||||
enum
|
enum
|
||||||
|
@ -27,6 +27,7 @@ TYPEDESCRIPTION CGrenade::m_SaveData[] =
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(grenade, CGrenade);
|
LINK_ENTITY_TO_CLASS(grenade, CGrenade);
|
||||||
|
LINK_CLASS_TO_WRAP(CGrenade, CCSGrenade);
|
||||||
|
|
||||||
void CGrenade::Explode(Vector vecSrc, Vector vecAim)
|
void CGrenade::Explode(Vector vecSrc, Vector vecAim)
|
||||||
{
|
{
|
||||||
|
@ -18,6 +18,7 @@ TYPEDESCRIPTION CRecharge::m_SaveData[] =
|
|||||||
|
|
||||||
IMPLEMENT_SAVERESTORE(CRecharge, CBaseEntity);
|
IMPLEMENT_SAVERESTORE(CRecharge, CBaseEntity);
|
||||||
LINK_ENTITY_TO_CLASS(func_recharge, CRecharge);
|
LINK_ENTITY_TO_CLASS(func_recharge, CRecharge);
|
||||||
|
LINK_CLASS_TO_WRAP(CRecharge, CCSRecharge);
|
||||||
|
|
||||||
void CRecharge::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
|
void CRecharge::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
|
||||||
{
|
{
|
||||||
|
@ -35,6 +35,7 @@
|
|||||||
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);
|
||||||
|
@ -25,6 +25,7 @@ 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)()
|
||||||
{
|
{
|
||||||
@ -32,7 +33,10 @@ void CGenericCycler::__MAKE_VHOOK(Spawn)()
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(cycler, CGenericCycler);
|
LINK_ENTITY_TO_CLASS(cycler, CGenericCycler);
|
||||||
|
LINK_CLASS_TO_WRAP(CGenericCycler, CCSGenericCycler);
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(cycler_prdroid, CCyclerProbe);
|
LINK_ENTITY_TO_CLASS(cycler_prdroid, CCyclerProbe);
|
||||||
|
LINK_CLASS_TO_WRAP(CCyclerProbe, CCSCyclerProbe);
|
||||||
|
|
||||||
void CCyclerProbe::__MAKE_VHOOK(Spawn)()
|
void CCyclerProbe::__MAKE_VHOOK(Spawn)()
|
||||||
{
|
{
|
||||||
@ -162,6 +166,7 @@ int CCycler::__MAKE_VHOOK(TakeDamage)(entvars_t *pevInflictor, entvars_t *pevAtt
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(cycler_sprite, CCyclerSprite);
|
LINK_ENTITY_TO_CLASS(cycler_sprite, CCyclerSprite);
|
||||||
|
LINK_CLASS_TO_WRAP(CCyclerSprite, CCSCyclerSprite);
|
||||||
IMPLEMENT_SAVERESTORE(CCyclerSprite, CBaseEntity);
|
IMPLEMENT_SAVERESTORE(CCyclerSprite, CBaseEntity);
|
||||||
|
|
||||||
void CCyclerSprite::__MAKE_VHOOK(Spawn)()
|
void CCyclerSprite::__MAKE_VHOOK(Spawn)()
|
||||||
@ -243,6 +248,7 @@ void CCyclerSprite::Animate(float frames)
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(cycler_weapon, CWeaponCycler);
|
LINK_ENTITY_TO_CLASS(cycler_weapon, CWeaponCycler);
|
||||||
|
LINK_CLASS_TO_WRAP(CWeaponCycler, CCSWeaponCycler);
|
||||||
|
|
||||||
void CWeaponCycler::__MAKE_VHOOK(Spawn)()
|
void CWeaponCycler::__MAKE_VHOOK(Spawn)()
|
||||||
{
|
{
|
||||||
@ -304,6 +310,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);
|
||||||
|
LINK_CLASS_TO_WRAP(CWreckage, CCSWreckage);
|
||||||
|
|
||||||
void CWreckage::__MAKE_VHOOK(Spawn)()
|
void CWreckage::__MAKE_VHOOK(Spawn)()
|
||||||
{
|
{
|
||||||
|
@ -35,6 +35,7 @@
|
|||||||
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);
|
||||||
@ -70,6 +71,7 @@ public:
|
|||||||
class CGenericCycler: public CCycler
|
class CGenericCycler: public CCycler
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
CGenericCycler();
|
||||||
virtual void Spawn();
|
virtual void Spawn();
|
||||||
|
|
||||||
#ifdef HOOK_GAMEDLL
|
#ifdef HOOK_GAMEDLL
|
||||||
@ -84,6 +86,7 @@ public:
|
|||||||
class CCyclerProbe: public CCycler
|
class CCyclerProbe: public CCycler
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
CCyclerProbe();
|
||||||
virtual void Spawn();
|
virtual void Spawn();
|
||||||
|
|
||||||
#ifdef HOOK_GAMEDLL
|
#ifdef HOOK_GAMEDLL
|
||||||
@ -97,6 +100,7 @@ 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);
|
||||||
@ -137,6 +141,7 @@ 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();
|
||||||
@ -164,6 +169,7 @@ 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);
|
||||||
|
@ -17,6 +17,7 @@ TYPEDESCRIPTION CWallHealth::m_SaveData[] =
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(item_healthkit, CHealthKit);
|
LINK_ENTITY_TO_CLASS(item_healthkit, CHealthKit);
|
||||||
|
LINK_CLASS_TO_WRAP(CHealthKit, CCSHealthKit);
|
||||||
|
|
||||||
void CHealthKit::__MAKE_VHOOK(Spawn)()
|
void CHealthKit::__MAKE_VHOOK(Spawn)()
|
||||||
{
|
{
|
||||||
|
@ -35,6 +35,7 @@
|
|||||||
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);
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
#include "precompiled.h"
|
#include "precompiled.h"
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(world_items, CWorldItem);
|
LINK_ENTITY_TO_CLASS(world_items, CWorldItem);
|
||||||
|
LINK_CLASS_TO_WRAP(CWorldItem, CCSWorldItem);
|
||||||
|
|
||||||
void CWorldItem::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
|
void CWorldItem::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
|
||||||
{
|
{
|
||||||
@ -45,6 +46,8 @@ 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;
|
||||||
@ -143,6 +146,7 @@ BOOL CItemSuit::__MAKE_VHOOK(MyTouch)(CBasePlayer *pPlayer)
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(item_suit, CItemSuit);
|
LINK_ENTITY_TO_CLASS(item_suit, CItemSuit);
|
||||||
|
LINK_CLASS_TO_WRAP(CItemSuit, CCSItemSuit);
|
||||||
|
|
||||||
void CItemBattery::__MAKE_VHOOK(Spawn)()
|
void CItemBattery::__MAKE_VHOOK(Spawn)()
|
||||||
{
|
{
|
||||||
@ -190,6 +194,7 @@ BOOL CItemBattery::__MAKE_VHOOK(MyTouch)(CBasePlayer *pPlayer)
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(item_battery, CItemBattery);
|
LINK_ENTITY_TO_CLASS(item_battery, CItemBattery);
|
||||||
|
LINK_CLASS_TO_WRAP(CItemBattery, CCSItemBattery);
|
||||||
|
|
||||||
void CItemAntidote::__MAKE_VHOOK(Spawn)()
|
void CItemAntidote::__MAKE_VHOOK(Spawn)()
|
||||||
{
|
{
|
||||||
@ -212,6 +217,7 @@ BOOL CItemAntidote::__MAKE_VHOOK(MyTouch)(CBasePlayer *pPlayer)
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(item_antidote, CItemAntidote);
|
LINK_ENTITY_TO_CLASS(item_antidote, CItemAntidote);
|
||||||
|
LINK_CLASS_TO_WRAP(CItemAntidote, CCSItemAntidote);
|
||||||
|
|
||||||
void CItemSecurity::__MAKE_VHOOK(Spawn)()
|
void CItemSecurity::__MAKE_VHOOK(Spawn)()
|
||||||
{
|
{
|
||||||
@ -232,6 +238,7 @@ BOOL CItemSecurity::__MAKE_VHOOK(MyTouch)(CBasePlayer *pPlayer)
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(item_security, CItemSecurity);
|
LINK_ENTITY_TO_CLASS(item_security, CItemSecurity);
|
||||||
|
LINK_CLASS_TO_WRAP(CItemSecurity, CCSItemSecurity);
|
||||||
|
|
||||||
void CItemLongJump::__MAKE_VHOOK(Spawn)()
|
void CItemLongJump::__MAKE_VHOOK(Spawn)()
|
||||||
{
|
{
|
||||||
@ -269,6 +276,7 @@ BOOL CItemLongJump::__MAKE_VHOOK(MyTouch)(CBasePlayer *pPlayer)
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(item_longjump, CItemLongJump);
|
LINK_ENTITY_TO_CLASS(item_longjump, CItemLongJump);
|
||||||
|
LINK_CLASS_TO_WRAP(CItemLongJump, CCSItemLongJump);
|
||||||
|
|
||||||
void CItemKevlar::__MAKE_VHOOK(Spawn)()
|
void CItemKevlar::__MAKE_VHOOK(Spawn)()
|
||||||
{
|
{
|
||||||
@ -307,6 +315,7 @@ BOOL CItemKevlar::__MAKE_VHOOK(MyTouch)(CBasePlayer *pPlayer)
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(item_kevlar, CItemKevlar);
|
LINK_ENTITY_TO_CLASS(item_kevlar, CItemKevlar);
|
||||||
|
LINK_CLASS_TO_WRAP(CItemKevlar, CCSItemKevlar);
|
||||||
|
|
||||||
void CItemAssaultSuit::__MAKE_VHOOK(Spawn)()
|
void CItemAssaultSuit::__MAKE_VHOOK(Spawn)()
|
||||||
{
|
{
|
||||||
@ -344,6 +353,7 @@ BOOL CItemAssaultSuit::__MAKE_VHOOK(MyTouch)(CBasePlayer *pPlayer)
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(item_assaultsuit, CItemAssaultSuit);
|
LINK_ENTITY_TO_CLASS(item_assaultsuit, CItemAssaultSuit);
|
||||||
|
LINK_CLASS_TO_WRAP(CItemAssaultSuit, CCSItemAssaultSuit);
|
||||||
|
|
||||||
void CItemThighPack::__MAKE_VHOOK(Spawn)()
|
void CItemThighPack::__MAKE_VHOOK(Spawn)()
|
||||||
{
|
{
|
||||||
@ -387,3 +397,4 @@ BOOL CItemThighPack::__MAKE_VHOOK(MyTouch)(CBasePlayer *pPlayer)
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(item_thighpack, CItemThighPack);
|
LINK_ENTITY_TO_CLASS(item_thighpack, CItemThighPack);
|
||||||
|
LINK_CLASS_TO_WRAP(CItemThighPack, CCSItemThighPack);
|
||||||
|
@ -42,6 +42,7 @@
|
|||||||
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; }
|
||||||
@ -61,6 +62,7 @@ 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);
|
||||||
|
|
||||||
@ -78,6 +80,7 @@ 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);
|
||||||
@ -95,6 +98,7 @@ 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);
|
||||||
@ -112,6 +116,7 @@ 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);
|
||||||
@ -129,6 +134,7 @@ 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);
|
||||||
@ -146,6 +152,7 @@ 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);
|
||||||
@ -163,6 +170,7 @@ 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);
|
||||||
@ -180,6 +188,7 @@ 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);
|
||||||
@ -197,6 +206,7 @@ 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);
|
||||||
|
@ -32,7 +32,7 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
typedef struct
|
typedef struct MonsterEvent_s
|
||||||
{
|
{
|
||||||
int event;
|
int event;
|
||||||
char *options;
|
char *options;
|
||||||
|
@ -324,6 +324,7 @@ void WriteSigonMessages()
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(player, CBasePlayer);
|
LINK_ENTITY_TO_CLASS(player, CBasePlayer);
|
||||||
|
LINK_CLASS_TO_WRAP(CBasePlayer, CCSPlayer);
|
||||||
|
|
||||||
void SendItemStatus(CBasePlayer *pPlayer)
|
void SendItemStatus(CBasePlayer *pPlayer)
|
||||||
{
|
{
|
||||||
|
@ -352,6 +352,7 @@ 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);
|
||||||
|
@ -50,7 +50,7 @@
|
|||||||
|
|
||||||
#define SPEAKER_START_SILENT 1 // wait for trigger 'on' to start announcements
|
#define SPEAKER_START_SILENT 1 // wait for trigger 'on' to start announcements
|
||||||
|
|
||||||
#define LFO_SQUARE 1 // square
|
#define LFO_SQUARE 1 // square
|
||||||
#define LFO_TRIANGLE 2 // triangle
|
#define LFO_TRIANGLE 2 // triangle
|
||||||
#define LFO_RANDOM 3 // random
|
#define LFO_RANDOM 3 // random
|
||||||
|
|
||||||
|
@ -181,6 +181,7 @@ void FireTargets(const char *targetName, CBaseEntity *pActivator, CBaseEntity *p
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(DelayedUse, CBaseDelay);
|
LINK_ENTITY_TO_CLASS(DelayedUse, CBaseDelay);
|
||||||
|
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)
|
||||||
{
|
{
|
||||||
|
@ -39,14 +39,14 @@
|
|||||||
#define MAX_ENTITY 512 // We can only ever move 512 entities across a transition
|
#define MAX_ENTITY 512 // We can only ever move 512 entities across a transition
|
||||||
|
|
||||||
// triggers
|
// triggers
|
||||||
#define SF_TRIGGER_ALLOWMONSTERS 1 // monsters allowed to fire this trigger
|
#define SF_TRIGGER_ALLOWMONSTERS 1 // monsters allowed to fire this trigger
|
||||||
#define SF_TRIGGER_NOCLIENTS 2 // players not allowed to fire this trigger
|
#define SF_TRIGGER_NOCLIENTS 2 // players not allowed to fire this trigger
|
||||||
#define SF_TRIGGER_PUSHABLES 4 // only pushables can fire this trigger
|
#define SF_TRIGGER_PUSHABLES 4 // only pushables can fire this trigger
|
||||||
|
|
||||||
#define SF_TRIGGER_PUSH_START_OFF 2 // spawnflag that makes trigger_push spawn turned OFF
|
#define SF_TRIGGER_PUSH_START_OFF 2 // spawnflag that makes trigger_push spawn turned OFF
|
||||||
#define SF_TRIGGER_HURT_TARGETONCE 1 // Only fire hurt target once
|
#define SF_TRIGGER_HURT_TARGETONCE 1 // Only fire hurt target once
|
||||||
#define SF_TRIGGER_HURT_START_OFF 2 // spawnflag that makes trigger_push spawn turned OFF
|
#define SF_TRIGGER_HURT_START_OFF 2 // spawnflag that makes trigger_push spawn turned OFF
|
||||||
#define SF_TRIGGER_HURT_NO_CLIENTS 8 // spawnflag that makes trigger_push spawn turned OFF
|
#define SF_TRIGGER_HURT_NO_CLIENTS 8 // spawnflag that makes trigger_push spawn turned OFF
|
||||||
#define SF_TRIGGER_HURT_CLIENTONLYFIRE 16 // trigger hurt will only fire its target if it is hurting a client
|
#define SF_TRIGGER_HURT_CLIENTONLYFIRE 16 // trigger hurt will only fire its target if it is hurting a client
|
||||||
#define SF_TRIGGER_HURT_CLIENTONLYTOUCH 32 // only clients may touch this trigger.
|
#define SF_TRIGGER_HURT_CLIENTONLYTOUCH 32 // only clients may touch this trigger.
|
||||||
|
|
||||||
|
@ -123,7 +123,7 @@ extern globalvars_t *gpGlobals;
|
|||||||
#define SF_BRUSH_ROTATE_Z_AXIS 4
|
#define SF_BRUSH_ROTATE_Z_AXIS 4
|
||||||
#define SF_BRUSH_ROTATE_X_AXIS 8
|
#define SF_BRUSH_ROTATE_X_AXIS 8
|
||||||
#define SF_PENDULUM_AUTO_RETURN 16
|
#define SF_PENDULUM_AUTO_RETURN 16
|
||||||
#define SF_PENDULUM_PASSABLE 32
|
#define SF_PENDULUM_PASSABLE 32
|
||||||
|
|
||||||
#define SF_BRUSH_ROTATE_SMALLRADIUS 128
|
#define SF_BRUSH_ROTATE_SMALLRADIUS 128
|
||||||
#define SF_BRUSH_ROTATE_MEDIUMRADIUS 256
|
#define SF_BRUSH_ROTATE_MEDIUMRADIUS 256
|
||||||
@ -158,13 +158,21 @@ extern globalvars_t *gpGlobals;
|
|||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#define REGAMEDLL_ALLOC_FUNC
|
||||||
#define LINK_ENTITY_TO_CLASS(mapClassName, DLLClassName)\
|
#define LINK_ENTITY_TO_CLASS(mapClassName, DLLClassName)\
|
||||||
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\
|
||||||
GetClassPtr((DLLClassName *)pev);\
|
GetClassPtr((DLLClassName *)pev);\
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define LINK_CLASS_TO_WRAP(className, classNameWrap)\
|
||||||
|
className::className()\
|
||||||
|
{\
|
||||||
|
GetClassPtrWrap<classNameWrap>(this);\
|
||||||
|
}\
|
||||||
|
|
||||||
typedef enum
|
typedef enum
|
||||||
{
|
{
|
||||||
ignore_monsters = 1,
|
ignore_monsters = 1,
|
||||||
|
@ -1530,6 +1530,7 @@ float CBasePlayerWeapon::GetNextAttackDelay(float delay)
|
|||||||
}
|
}
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(weaponbox, CWeaponBox);
|
LINK_ENTITY_TO_CLASS(weaponbox, CWeaponBox);
|
||||||
|
LINK_CLASS_TO_WRAP(CWeaponBox, CCSWeaponBox);
|
||||||
IMPLEMENT_SAVERESTORE(CWeaponBox, CBaseEntity);
|
IMPLEMENT_SAVERESTORE(CWeaponBox, CBaseEntity);
|
||||||
|
|
||||||
void CWeaponBox::__MAKE_VHOOK(Precache)()
|
void CWeaponBox::__MAKE_VHOOK(Precache)()
|
||||||
|
@ -155,6 +155,7 @@ 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);
|
||||||
@ -457,6 +458,7 @@ 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);
|
||||||
|
@ -410,7 +410,13 @@ void EXT_FUNC ResetGlobalState()
|
|||||||
gInitHUD = TRUE;
|
gInitHUD = TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#pragma push_macro("REGAMEDLL_ALLOC_FUNC")
|
||||||
|
#define REGAMEDLL_ALLOC_FUNC Regamedll_AllocEntities(gpGlobals->maxEntities);
|
||||||
|
|
||||||
LINK_ENTITY_TO_CLASS(worldspawn, CWorld);
|
LINK_ENTITY_TO_CLASS(worldspawn, CWorld);
|
||||||
|
LINK_CLASS_TO_WRAP(CWorld, CCSWorld);
|
||||||
|
|
||||||
|
#pragma pop_macro("REGAMEDLL_ALLOC_FUNC")
|
||||||
|
|
||||||
void CWorld::__MAKE_VHOOK(Spawn)()
|
void CWorld::__MAKE_VHOOK(Spawn)()
|
||||||
{
|
{
|
||||||
|
@ -475,7 +475,7 @@ void UTIL_DrawBeamPoints(Vector vecStart, Vector vecEnd, int iLifetime, byte bRe
|
|||||||
MESSAGE_END();
|
MESSAGE_END();
|
||||||
}
|
}
|
||||||
|
|
||||||
void CONSOLE_ECHO(char *pszMsg, ...)
|
void CONSOLE_ECHO(const char *pszMsg, ...)
|
||||||
{
|
{
|
||||||
va_list argptr;
|
va_list argptr;
|
||||||
static char szStr[1024];
|
static char szStr[1024];
|
||||||
@ -487,7 +487,7 @@ void CONSOLE_ECHO(char *pszMsg, ...)
|
|||||||
SERVER_PRINT(szStr);
|
SERVER_PRINT(szStr);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CONSOLE_ECHO_LOGGED(char *pszMsg, ...)
|
void CONSOLE_ECHO_LOGGED(const char *pszMsg, ...)
|
||||||
{
|
{
|
||||||
va_list argptr;
|
va_list argptr;
|
||||||
static char szStr[1024];
|
static char szStr[1024];
|
||||||
|
@ -234,8 +234,8 @@ void UTIL_DrawBeamPoints(Vector vecStart, Vector vecEnd, int iLifetime, byte bRe
|
|||||||
|
|
||||||
// Echos text to the console, and prints it on the client's screen. This is NOT tied to the developer cvar.
|
// Echos text to the console, and prints it on the client's screen. This is NOT tied to the developer cvar.
|
||||||
// If you are adding debugging output in cstrike, use UTIL_DPrintf() (debug.h) instead.
|
// If you are adding debugging output in cstrike, use UTIL_DPrintf() (debug.h) instead.
|
||||||
void CONSOLE_ECHO(char *pszMsg, ...);
|
void CONSOLE_ECHO(const char *pszMsg, ...);
|
||||||
void CONSOLE_ECHO_LOGGED(char *pszMsg, ...);
|
void CONSOLE_ECHO_LOGGED(const char *pszMsg, ...);
|
||||||
|
|
||||||
void BotPrecache();
|
void BotPrecache();
|
||||||
void InitBotTrig();
|
void InitBotTrig();
|
||||||
|
@ -91,6 +91,7 @@
|
|||||||
#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__
|
||||||
|
@ -54,7 +54,7 @@
|
|||||||
#define STEP_SNOW 9
|
#define STEP_SNOW 9
|
||||||
|
|
||||||
#define WJ_HEIGHT 8
|
#define WJ_HEIGHT 8
|
||||||
#define STOP_EPSILON 0.1
|
#define STOP_EPSILON 0.1
|
||||||
#define MAX_CLIMB_SPEED 200
|
#define MAX_CLIMB_SPEED 200
|
||||||
#define PLAYER_DUCKING_MULTIPLIER 0.333
|
#define PLAYER_DUCKING_MULTIPLIER 0.333
|
||||||
#define PM_CHECKSTUCK_MINTIME 0.05 // Don't check again too quickly.
|
#define PM_CHECKSTUCK_MINTIME 0.05 // Don't check again too quickly.
|
||||||
|
@ -25,4 +25,893 @@
|
|||||||
* version.
|
* version.
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
|
class CSave;
|
||||||
|
class Vector;
|
||||||
|
class CRestore;
|
||||||
|
|
||||||
|
class CCSEntity;
|
||||||
|
class CCSPlayer;
|
||||||
|
class CCSMonster;
|
||||||
|
class CCSWeaponBox;
|
||||||
|
class CCSPlayerItem;
|
||||||
|
class CCSPlayerWeapon;
|
||||||
|
class CCSquadMonster;
|
||||||
|
|
||||||
|
class ICSMonster;
|
||||||
|
class ICSquadMonster;
|
||||||
|
|
||||||
|
class ICSEntity {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual void Restart() = 0;
|
||||||
|
virtual void KeyValue(struct KeyValueData_s *pkvd) = 0;
|
||||||
|
virtual int Save(CSave &save) = 0;
|
||||||
|
virtual int Restore(CRestore &restore) = 0;
|
||||||
|
virtual int ObjectCaps() = 0;
|
||||||
|
virtual void Activate() = 0;
|
||||||
|
virtual void SetObjectCollisionBox() = 0;
|
||||||
|
virtual int Classify() = 0;
|
||||||
|
virtual void DeathNotice(struct entvars_s *pevChild) = 0;
|
||||||
|
virtual void TraceAttack(struct entvars_s *pevAttacker, float flDamage, Vector vecDir, struct TraceResult *ptr, int bitsDamageType) = 0;
|
||||||
|
virtual int TakeDamage(struct entvars_s *pevInflictor, struct entvars_s *pevAttacker, float flDamage, int bitsDamageType) = 0;
|
||||||
|
virtual int TakeHealth(float flHealth, int bitsDamageType) = 0;
|
||||||
|
virtual void Killed(struct entvars_s *pevAttacker, int iGib) = 0;
|
||||||
|
virtual int BloodColor() = 0;
|
||||||
|
virtual void TraceBleed(float flDamage, Vector vecDir, struct TraceResult *ptr, int bitsDamageType) = 0;
|
||||||
|
virtual bool IsTriggered(CCSEntity *pActivator) = 0;
|
||||||
|
virtual ICSMonster *MyMonsterPointer() = 0;
|
||||||
|
virtual ICSquadMonster *MySquadMonsterPointer() = 0;
|
||||||
|
virtual int GetToggleState() = 0;
|
||||||
|
virtual void AddPoints(int score, bool bAllowNegativeScore) = 0;
|
||||||
|
virtual void AddPointsToTeam(int score, bool bAllowNegativeScore) = 0;
|
||||||
|
virtual bool AddPlayerItem(CCSPlayerItem *pItem) = 0;
|
||||||
|
virtual bool RemovePlayerItem(CCSPlayerItem *pItem) = 0;
|
||||||
|
virtual int GiveAmmo(int iAmount, char *szName, int iMax) = 0;
|
||||||
|
virtual float GetDelay() = 0;
|
||||||
|
virtual int IsMoving() = 0;
|
||||||
|
virtual void OverrideReset() = 0;
|
||||||
|
virtual int DamageDecal(int bitsDamageType) = 0;
|
||||||
|
virtual void SetToggleState(int state) = 0;
|
||||||
|
virtual void StartSneaking() = 0;
|
||||||
|
virtual void StopSneaking() = 0;
|
||||||
|
virtual bool OnControls(struct entvars_s *onpev) = 0;
|
||||||
|
virtual bool IsSneaking() = 0;
|
||||||
|
virtual bool IsAlive() = 0;
|
||||||
|
virtual bool IsBSPModel() = 0;
|
||||||
|
virtual bool ReflectGauss() = 0;
|
||||||
|
virtual bool HasTarget(string_t targetname) = 0;
|
||||||
|
virtual bool IsInWorld() = 0;
|
||||||
|
virtual bool IsPlayer() = 0;
|
||||||
|
virtual bool IsNetClient() = 0;
|
||||||
|
virtual const char *TeamID() = 0;
|
||||||
|
virtual ICSEntity *GetNextTarget() = 0;
|
||||||
|
virtual void Think() = 0;
|
||||||
|
virtual void Touch(CCSEntity *pOther) = 0;
|
||||||
|
virtual void Use(CCSEntity *pActivator, CCSEntity *pCaller, USE_TYPE useType = USE_OFF, float value = 0.0f) = 0;
|
||||||
|
virtual void Blocked(CCSEntity *pOther) = 0;
|
||||||
|
virtual ICSEntity *Respawn() = 0;
|
||||||
|
virtual void UpdateOwner() = 0;
|
||||||
|
virtual bool FBecomeProne() = 0;
|
||||||
|
virtual Vector Center() = 0;
|
||||||
|
virtual Vector EyePosition() = 0;
|
||||||
|
virtual Vector EarPosition() = 0;
|
||||||
|
virtual Vector BodyTarget(const Vector &posSrc) = 0;
|
||||||
|
virtual int Illumination() = 0;
|
||||||
|
virtual bool FVisible(CCSEntity *pEntity) = 0;
|
||||||
|
virtual bool FVisible(const Vector &vecOrigin) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSDelay: public ICSEntity {
|
||||||
|
public:
|
||||||
|
virtual void KeyValue(struct KeyValueData_s *pkvd) = 0;
|
||||||
|
virtual int Save(CSave &save) = 0;
|
||||||
|
virtual int Restore(CRestore &restore) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSAnimating: public ICSDelay {
|
||||||
|
public:
|
||||||
|
virtual int Save(CSave &save) = 0;
|
||||||
|
virtual int Restore(CRestore &restore) = 0;
|
||||||
|
virtual void HandleAnimEvent(struct MonsterEvent_s *pEvent) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSPlayerItem: public ICSAnimating {
|
||||||
|
public:
|
||||||
|
virtual int Save(CSave &save) = 0;
|
||||||
|
virtual int Restore(CRestore &restore) = 0;
|
||||||
|
virtual void SetObjectCollisionBox() = 0;
|
||||||
|
virtual ICSEntity *Respawn() = 0;
|
||||||
|
virtual int AddToPlayer(CCSPlayer *pPlayer) = 0;
|
||||||
|
virtual int AddDuplicate(CCSPlayerItem *pItem) = 0;
|
||||||
|
virtual int GetItemInfo(struct ItemInfo *p) = 0;
|
||||||
|
virtual bool CanDeploy() = 0;
|
||||||
|
virtual bool CanDrop() = 0;
|
||||||
|
virtual bool Deploy() = 0;
|
||||||
|
virtual bool IsWeapon() = 0;
|
||||||
|
virtual bool CanHolster() = 0;
|
||||||
|
virtual void Holster(int skiplocal = 0) = 0;
|
||||||
|
virtual void UpdateItemInfo() = 0;
|
||||||
|
virtual void ItemPreFrame() = 0;
|
||||||
|
virtual void ItemPostFrame() = 0;
|
||||||
|
virtual void Drop() = 0;
|
||||||
|
virtual void Kill() = 0;
|
||||||
|
virtual void AttachToPlayer(CCSPlayer *pPlayer) = 0;
|
||||||
|
virtual int PrimaryAmmoIndex() = 0;
|
||||||
|
virtual int SecondaryAmmoIndex() = 0;
|
||||||
|
virtual int UpdateClientData(CCSPlayer *pPlayer) = 0;
|
||||||
|
virtual ICSPlayerItem *GetWeaponPtr() = 0;
|
||||||
|
virtual float GetMaxSpeed() = 0;
|
||||||
|
virtual int iItemSlot() = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSPlayerWeapon: public ICSPlayerItem {
|
||||||
|
public:
|
||||||
|
virtual int Save(CSave &save) = 0;
|
||||||
|
virtual int Restore(CRestore &restore) = 0;
|
||||||
|
virtual int AddToPlayer(CCSPlayer *pPlayer) = 0;
|
||||||
|
virtual int AddDuplicate(CCSPlayerItem *pItem) = 0;
|
||||||
|
virtual bool CanDeploy() = 0;
|
||||||
|
virtual bool IsWeapon() = 0;
|
||||||
|
virtual void Holster(int skiplocal = 0) = 0;
|
||||||
|
virtual void UpdateItemInfo() = 0;
|
||||||
|
virtual void ItemPostFrame() = 0;
|
||||||
|
virtual int PrimaryAmmoIndex() = 0;
|
||||||
|
virtual int SecondaryAmmoIndex() = 0;
|
||||||
|
virtual int UpdateClientData(CCSPlayer *pPlayer) = 0;
|
||||||
|
virtual ICSPlayerItem *GetWeaponPtr() = 0;
|
||||||
|
virtual int ExtractAmmo(CCSPlayerWeapon *pWeapon) = 0;
|
||||||
|
virtual int ExtractClipAmmo(CCSPlayerWeapon *pWeapon) = 0;
|
||||||
|
virtual int AddWeapon() = 0;
|
||||||
|
virtual bool PlayEmptySound() = 0;
|
||||||
|
virtual void ResetEmptySound() = 0;
|
||||||
|
virtual void SendWeaponAnim(int iAnim, int skiplocal = 0) = 0;
|
||||||
|
virtual bool IsUseable() = 0;
|
||||||
|
virtual void PrimaryAttack() = 0;
|
||||||
|
virtual void SecondaryAttack() = 0;
|
||||||
|
virtual void Reload() = 0;
|
||||||
|
virtual void WeaponIdle() = 0;
|
||||||
|
virtual void RetireWeapon() = 0;
|
||||||
|
virtual bool ShouldWeaponIdle() = 0;
|
||||||
|
virtual bool UseDecrement() = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSToggle: public ICSAnimating {
|
||||||
|
public:
|
||||||
|
virtual void KeyValue(struct KeyValueData_s *pkvd) = 0;
|
||||||
|
virtual int Save(CSave &save) = 0;
|
||||||
|
virtual int Restore(CRestore &restore) = 0;
|
||||||
|
virtual int GetToggleState() = 0;
|
||||||
|
virtual float GetDelay() = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSMonster: public ICSToggle {
|
||||||
|
public:
|
||||||
|
virtual void KeyValue(struct KeyValueData_s *pkvd) = 0;
|
||||||
|
virtual void TraceAttack(struct entvars_s *pevAttacker, float flDamage, Vector vecDir, struct TraceResult *ptr, int bitsDamageType) = 0;
|
||||||
|
virtual int TakeDamage(struct entvars_s *pevInflictor, struct entvars_s *pevAttacker, float flDamage, int bitsDamageType) = 0;
|
||||||
|
virtual int TakeHealth(float flHealth, int bitsDamageType) = 0;
|
||||||
|
virtual void Killed(struct entvars_s *pevAttacker, int iGib) = 0;
|
||||||
|
virtual int BloodColor() = 0;
|
||||||
|
virtual bool IsAlive() = 0;
|
||||||
|
virtual float ChangeYaw(int speed) = 0;
|
||||||
|
virtual bool HasHumanGibs() = 0;
|
||||||
|
virtual bool HasAlienGibs() = 0;
|
||||||
|
virtual void FadeMonster() = 0;
|
||||||
|
virtual void GibMonster() = 0;
|
||||||
|
virtual enum Activity_s GetDeathActivity() = 0;
|
||||||
|
virtual void BecomeDead() = 0;
|
||||||
|
virtual bool ShouldFadeOnDeath() = 0;
|
||||||
|
virtual int IRelationship(CCSEntity *pTarget) = 0;
|
||||||
|
virtual void PainSound() = 0;
|
||||||
|
virtual void ResetMaxSpeed() = 0;
|
||||||
|
virtual void ReportAIState() = 0;
|
||||||
|
virtual void MonsterInitDead() = 0;
|
||||||
|
virtual void Look(int iDistance) = 0;
|
||||||
|
virtual ICSEntity *BestVisibleEnemy() = 0;
|
||||||
|
virtual bool FInViewCone(CCSEntity *pEntity) = 0;
|
||||||
|
virtual bool FInViewCone(const Vector *pOrigin) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSWeaponBox: public ICSEntity {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual void KeyValue(struct KeyValueData_s *pkvd) = 0;
|
||||||
|
virtual int Save(CSave &save) = 0;
|
||||||
|
virtual int Restore(CRestore &restore) = 0;
|
||||||
|
virtual void SetObjectCollisionBox() = 0;
|
||||||
|
virtual void Touch(CCSEntity *pOther) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSPlayer: public ICSMonster {
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual int Save(CSave &save) = 0;
|
||||||
|
virtual int Restore(CRestore &restore) = 0;
|
||||||
|
virtual int ObjectCaps() = 0;
|
||||||
|
virtual int Classify() = 0;
|
||||||
|
virtual void TraceAttack(struct entvars_s *pevAttacker, float flDamage, Vector vecDir, struct TraceResult *ptr, int bitsDamageType) = 0;
|
||||||
|
virtual int TakeDamage(struct entvars_s *pevInflictor, struct entvars_s *pevAttacker, float flDamage, int bitsDamageType) = 0;
|
||||||
|
virtual int TakeHealth(float flHealth, int bitsDamageType) = 0;
|
||||||
|
virtual void Killed(struct entvars_s *pevAttacker, int iGib) = 0;
|
||||||
|
virtual void AddPoints(int score, bool bAllowNegativeScore) = 0;
|
||||||
|
virtual void AddPointsToTeam(int score, bool bAllowNegativeScore) = 0;
|
||||||
|
virtual bool AddPlayerItem(CCSPlayerItem *pItem) = 0;
|
||||||
|
virtual bool RemovePlayerItem(CCSPlayerItem *pItem) = 0;
|
||||||
|
virtual int GiveAmmo(int iAmount, char *szName, int iMax) = 0;
|
||||||
|
virtual void StartSneaking() = 0;
|
||||||
|
virtual void StopSneaking() = 0;
|
||||||
|
virtual bool IsSneaking() = 0;
|
||||||
|
virtual bool IsAlive() = 0;
|
||||||
|
virtual bool IsPlayer() = 0;
|
||||||
|
virtual bool IsNetClient() = 0;
|
||||||
|
virtual const char *TeamID() = 0;
|
||||||
|
virtual bool FBecomeProne() = 0;
|
||||||
|
virtual Vector BodyTarget(const Vector &posSrc) = 0;
|
||||||
|
virtual int Illumination() = 0;
|
||||||
|
virtual bool ShouldFadeOnDeath() = 0;
|
||||||
|
virtual void ResetMaxSpeed() = 0;
|
||||||
|
virtual void Jump() = 0;
|
||||||
|
virtual void Duck() = 0;
|
||||||
|
virtual void PreThink() = 0;
|
||||||
|
virtual void PostThink() = 0;
|
||||||
|
virtual Vector GetGunPosition() = 0;
|
||||||
|
virtual bool IsBot() = 0;
|
||||||
|
virtual void UpdateClientData() = 0;
|
||||||
|
virtual void ImpulseCommands() = 0;
|
||||||
|
virtual void RoundRespawn() = 0;
|
||||||
|
virtual Vector GetAutoaimVector(float flDelta) = 0;
|
||||||
|
virtual void Blind(float flUntilTime, float flHoldTime, float flFadeTime, int iAlpha) = 0;
|
||||||
|
virtual void OnTouchingWeapon(CCSWeaponBox *pWeapon) = 0;
|
||||||
|
|
||||||
|
virtual bool IsConnected() const = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSWorld: public ICSEntity {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual void KeyValue(struct KeyValueData_s *pkvd) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSGrenade: public ICSMonster {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual int Save(CSave &save) = 0;
|
||||||
|
virtual int Restore(CRestore &restore) = 0;
|
||||||
|
virtual int ObjectCaps() = 0;
|
||||||
|
virtual void Killed(struct entvars_s *pevAttacker, int iGib) = 0;
|
||||||
|
virtual int BloodColor() = 0;
|
||||||
|
virtual void Use(CCSEntity *pActivator, CCSEntity *pCaller, USE_TYPE useType, float value) = 0;
|
||||||
|
virtual void BounceSound() = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSAirtank: public ICSGrenade {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual int Save(CSave &save) = 0;
|
||||||
|
virtual int Restore(CRestore &restore) = 0;
|
||||||
|
virtual void Killed(struct entvars_s *pevAttacker, int iGib) = 0;
|
||||||
|
virtual int BloodColor() = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSPlayerAmmo: public ICSEntity {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual bool AddAmmo(CCSEntity *pOther) = 0;
|
||||||
|
virtual ICSEntity *Respawn() = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICS9MMAmmo: public ICSPlayerAmmo {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual bool AddAmmo(CCSEntity *pOther) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSBuckShotAmmo: public ICSPlayerAmmo {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual bool AddAmmo(CCSEntity *pOther) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICS556NatoAmmo: public ICSPlayerAmmo {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual bool AddAmmo(CCSEntity *pOther) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICS556NatoBoxAmmo: public ICSPlayerAmmo {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual bool AddAmmo(CCSEntity *pOther) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICS762NatoAmmo: public ICSPlayerAmmo {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual bool AddAmmo(CCSEntity *pOther) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICS45ACPAmmo: public ICSPlayerAmmo {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual bool AddAmmo(CCSEntity *pOther) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICS50AEAmmo: public ICSPlayerAmmo {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual bool AddAmmo(CCSEntity *pOther) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICS338MagnumAmmo: public ICSPlayerAmmo {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual bool AddAmmo(CCSEntity *pOther) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICS57MMAmmo: public ICSPlayerAmmo {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual bool AddAmmo(CCSEntity *pOther) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICS357SIGAmmo: public ICSPlayerAmmo {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual bool AddAmmo(CCSEntity *pOther) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSFuncWall: public ICSEntity {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual int ObjectCaps() = 0;
|
||||||
|
virtual void Use(CCSEntity *pActivator, CCSEntity *pCaller, USE_TYPE useType, float value) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSFuncWallToggle: public ICSFuncWall {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Use(CCSEntity *pActivator, CCSEntity *pCaller, USE_TYPE useType, float value) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSFuncConveyor: public ICSFuncWall {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Use(CCSEntity *pActivator, CCSEntity *pCaller, USE_TYPE useType, float value) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSFuncIllusionary: public ICSToggle {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void KeyValue(struct KeyValueData_s *pkvd) = 0;
|
||||||
|
virtual int ObjectCaps() = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSFuncMonsterClip: public ICSFuncWall {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Use(CCSEntity *pActivator, CCSEntity *pCaller, USE_TYPE useType, float value) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSFuncRotating: public ICSEntity {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual void KeyValue(struct KeyValueData_s *pkvd) = 0;
|
||||||
|
virtual int Save(CSave &save) = 0;
|
||||||
|
virtual int Restore(CRestore &restore) = 0;
|
||||||
|
virtual int ObjectCaps() = 0;
|
||||||
|
virtual void Blocked(CCSEntity *pOther) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSPendulum: public ICSEntity {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void KeyValue(struct KeyValueData_s *pkvd) = 0;
|
||||||
|
virtual int Save(CSave &save) = 0;
|
||||||
|
virtual int Restore(CRestore &restore) = 0;
|
||||||
|
virtual int ObjectCaps() = 0;
|
||||||
|
virtual void Touch(CCSEntity *pOther) = 0;
|
||||||
|
virtual void Blocked(CCSEntity *pOther) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSPointEntity: public ICSEntity {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual int ObjectCaps() = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSEnvGlobal: public ICSPointEntity {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void KeyValue(struct KeyValueData_s *pkvd) = 0;
|
||||||
|
virtual int Save(CSave &save) = 0;
|
||||||
|
virtual int Restore(CRestore &restore) = 0;
|
||||||
|
virtual void Use(CCSEntity *pActivator, CCSEntity *pCaller, USE_TYPE useType, float value) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSMultiSource: public ICSPointEntity {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void KeyValue(struct KeyValueData_s *pkvd) = 0;
|
||||||
|
virtual int Save(CSave &save) = 0;
|
||||||
|
virtual int Restore(CRestore &restore) = 0;
|
||||||
|
virtual int ObjectCaps() = 0;
|
||||||
|
virtual bool IsTriggered(CCSEntity *pActivator) = 0;
|
||||||
|
virtual void Use(CCSEntity *pActivator, CCSEntity *pCaller, USE_TYPE useType, float value) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSButton: public ICSToggle {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual void KeyValue(struct KeyValueData_s *pkvd) = 0;
|
||||||
|
virtual int TakeDamage(struct entvars_s *pevInflictor, struct entvars_s *pevAttacker, float flDamage, int bitsDamageType) = 0;
|
||||||
|
virtual int Save(CSave &save) = 0;
|
||||||
|
virtual int Restore(CRestore &restore) = 0;
|
||||||
|
virtual int ObjectCaps() = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSRotButton: public ICSButton {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSMomentaryRotButton: public ICSToggle {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void KeyValue(struct KeyValueData_s *pkvd) = 0;
|
||||||
|
virtual int Save(CSave &save) = 0;
|
||||||
|
virtual int Restore(CRestore &restore) = 0;
|
||||||
|
virtual int ObjectCaps() = 0;
|
||||||
|
virtual void Use(CCSEntity *pActivator, CCSEntity *pCaller, USE_TYPE useType, float value) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSEnvSpark: public ICSEntity {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual void KeyValue(struct KeyValueData_s *pkvd) = 0;
|
||||||
|
virtual int Save(CSave &save) = 0;
|
||||||
|
virtual int Restore(CRestore &restore) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSButtonTarget: public ICSEntity {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual int ObjectCaps() = 0;
|
||||||
|
virtual int TakeDamage(struct entvars_s *pevInflictor, struct entvars_s *pevAttacker, float flDamage, int bitsDamageType) = 0;
|
||||||
|
virtual void Use(CCSEntity *pActivator, CCSEntity *pCaller, USE_TYPE useType, float value) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSDoor: public ICSToggle {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual void Restart() = 0;
|
||||||
|
virtual void KeyValue(struct KeyValueData_s *pkvd) = 0;
|
||||||
|
virtual int Save(CSave &save) = 0;
|
||||||
|
virtual int Restore(CRestore &restore) = 0;
|
||||||
|
virtual int ObjectCaps() = 0;
|
||||||
|
virtual void SetToggleState(int state) = 0;
|
||||||
|
virtual void Use(CCSEntity *pActivator, CCSEntity *pCaller, USE_TYPE useType, float value) = 0;
|
||||||
|
virtual void Blocked(CCSEntity *pOther) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSRotDoor: public ICSDoor {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Restart() = 0;
|
||||||
|
virtual void SetToggleState(int state) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSMomentaryDoor: public ICSToggle {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual void KeyValue(struct KeyValueData_s *pkvd) = 0;
|
||||||
|
virtual int Save(CSave &save) = 0;
|
||||||
|
virtual int Restore(CRestore &restore) = 0;
|
||||||
|
virtual int ObjectCaps() = 0;
|
||||||
|
virtual void Use(CCSEntity *pActivator, CCSEntity *pCaller, USE_TYPE useType, float value) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSGib: public ICSEntity {
|
||||||
|
public:
|
||||||
|
virtual int ObjectCaps() = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSBubbling: public ICSEntity {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual void KeyValue(struct KeyValueData_s *pkvd) = 0;
|
||||||
|
virtual int Save(CSave &save) = 0;
|
||||||
|
virtual int Restore(CRestore &restore) = 0;
|
||||||
|
virtual int ObjectCaps() = 0;
|
||||||
|
virtual void Use(CCSEntity *pActivator, CCSEntity *pCaller, USE_TYPE useType, float value) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSBeam: public ICSEntity {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual int ObjectCaps() = 0;
|
||||||
|
virtual Vector Center() = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSLightning: public ICSBeam {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual void KeyValue(struct KeyValueData_s *pkvd) = 0;
|
||||||
|
virtual int Save(CSave &save) = 0;
|
||||||
|
virtual int Restore(CRestore &restore) = 0;
|
||||||
|
virtual void Activate() = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSLaser: public ICSBeam {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual void KeyValue(struct KeyValueData_s *pkvd) = 0;
|
||||||
|
virtual int Save(CSave &save) = 0;
|
||||||
|
virtual int Restore(CRestore &restore) = 0;
|
||||||
|
virtual void Use(CCSEntity *pActivator, CCSEntity *pCaller, USE_TYPE useType, float value) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSGlow: public ICSPointEntity {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual int Save(CSave &save) = 0;
|
||||||
|
virtual int Restore(CRestore &restore) = 0;
|
||||||
|
virtual void Think() = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSSprite: public ICSPointEntity {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual void Restart() = 0;
|
||||||
|
virtual int Save(CSave &save) = 0;
|
||||||
|
virtual int Restore(CRestore &restore) = 0;
|
||||||
|
virtual int ObjectCaps() = 0;
|
||||||
|
virtual void Use(CCSEntity *pActivator, CCSEntity *pCaller, USE_TYPE useType, float value) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSBombGlow: public ICSSprite {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Think() = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSGibShooter: public ICSDelay {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual void KeyValue(struct KeyValueData_s *pkvd) = 0;
|
||||||
|
virtual int Save(CSave &save) = 0;
|
||||||
|
virtual int Restore(CRestore &restore) = 0;
|
||||||
|
virtual void Use(CCSEntity *pActivator, CCSEntity *pCaller, USE_TYPE useType, float value) = 0;
|
||||||
|
virtual ICSGib *CreateGib() = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSEnvShooter: public ICSGibShooter {
|
||||||
|
public:
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual void KeyValue(struct KeyValueData_s *pkvd) = 0;
|
||||||
|
virtual ICSGib *CreateGib() = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
class ICSTestEffect: public ICSDelay {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual void Use(CCSEntity *pActivator, CCSEntity *pCaller, USE_TYPE useType, float value) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSBlood: public ICSPointEntity {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void KeyValue(struct KeyValueData_s *pkvd) = 0;
|
||||||
|
virtual void Use(CCSEntity *pActivator, CCSEntity *pCaller, USE_TYPE useType, float value) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSShake: public ICSPointEntity {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void KeyValue(struct KeyValueData_s *pkvd) = 0;
|
||||||
|
virtual void Use(CCSEntity *pActivator, CCSEntity *pCaller, USE_TYPE useType, float value) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSFade: public ICSPointEntity {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void KeyValue(struct KeyValueData_s *pkvd) = 0;
|
||||||
|
virtual void Use(CCSEntity *pActivator, CCSEntity *pCaller, USE_TYPE useType, float value) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
class ICSMessage: public ICSPointEntity {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual void KeyValue(struct KeyValueData_s *pkvd) = 0;
|
||||||
|
virtual void Use(CCSEntity *pActivator, CCSEntity *pCaller, USE_TYPE useType, float value) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSEnvFunnel: public ICSDelay {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual void Use(CCSEntity *pActivator, CCSEntity *pCaller, USE_TYPE useType, float value) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSEnvBeverage: public ICSDelay {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual void Use(CCSEntity *pActivator, CCSEntity *pCaller, USE_TYPE useType, float value) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSItemSoda: public ICSEntity {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSShower: public ICSEntity {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual int ObjectCaps() = 0;
|
||||||
|
virtual void Think() = 0;
|
||||||
|
virtual void Touch(CCSEntity *pOther) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSEnvExplosion: public ICSMonster {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void KeyValue(struct KeyValueData_s *pkvd) = 0;
|
||||||
|
virtual int Save(CSave &save) = 0;
|
||||||
|
virtual int Restore(CRestore &restore) = 0;
|
||||||
|
virtual void Use(CCSEntity *pActivator, CCSEntity *pCaller, USE_TYPE useType, float value) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSBreakable: public ICSDelay {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual void Restart() = 0;
|
||||||
|
virtual void KeyValue(struct KeyValueData_s *pkvd) = 0;
|
||||||
|
virtual int Save(CSave &save) = 0;
|
||||||
|
virtual int Restore(CRestore &restore) = 0;
|
||||||
|
virtual int ObjectCaps() = 0;
|
||||||
|
virtual void TraceAttack(struct entvars_s *pevAttacker, float flDamage, Vector vecDir, struct TraceResult *ptr, int bitsDamageType) = 0;
|
||||||
|
virtual int TakeDamage(struct entvars_s *pevInflictor, struct entvars_s *pevAttacker, float flDamage, int bitsDamageType) = 0;
|
||||||
|
virtual int DamageDecal(int bitsDamageType) = 0;
|
||||||
|
virtual void Use(CCSEntity *pActivator, CCSEntity *pCaller, USE_TYPE useType, float value) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSPushable: public ICSBreakable {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual void KeyValue(struct KeyValueData_s *pkvd) = 0;
|
||||||
|
virtual int Save(CSave &save) = 0;
|
||||||
|
virtual int Restore(CRestore &restore) = 0;
|
||||||
|
virtual int ObjectCaps() = 0;
|
||||||
|
virtual int TakeDamage(struct entvars_s *pevInflictor, struct entvars_s *pevAttacker, float flDamage, int bitsDamageType) = 0;
|
||||||
|
virtual void Touch(CCSEntity *pOther) = 0;
|
||||||
|
virtual void Use(CCSEntity *pActivator, CCSEntity *pCaller, USE_TYPE useType, float value) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSFuncTank: public ICSEntity {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual void KeyValue(struct KeyValueData_s *pkvd) = 0;
|
||||||
|
virtual int Save(CSave &save) = 0;
|
||||||
|
virtual int Restore(CRestore &restore) = 0;
|
||||||
|
virtual int ObjectCaps() = 0;
|
||||||
|
virtual bool OnControls(struct entvars_s *pevTest) = 0;
|
||||||
|
virtual void Think() = 0;
|
||||||
|
virtual void Use(CCSEntity *pActivator, CCSEntity *pCaller, USE_TYPE useType, float value) = 0;
|
||||||
|
virtual void Fire(const Vector &barrelEnd, const Vector &forward, struct entvars_s *pevAttacker) = 0;
|
||||||
|
virtual Vector UpdateTargetPosition(CCSEntity *pTarget) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSFuncTankGun: public ICSFuncTank {
|
||||||
|
public:
|
||||||
|
virtual void Fire(const Vector &barrelEnd, const Vector &forward, struct entvars_s *pevAttacker) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSFuncTankLaser: public ICSFuncTank {
|
||||||
|
public:
|
||||||
|
virtual void KeyValue(struct KeyValueData_s *pkvd) = 0;
|
||||||
|
virtual int Save(CSave &save) = 0;
|
||||||
|
virtual int Restore(CRestore &restore) = 0;
|
||||||
|
virtual void Activate() = 0;
|
||||||
|
virtual void Think() = 0;
|
||||||
|
virtual void Fire(const Vector &barrelEnd, const Vector &forward, struct entvars_s *pevAttacker) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSFuncTankRocket: public ICSFuncTank {
|
||||||
|
public:
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual void Fire(const Vector &barrelEnd, const Vector &forward, struct entvars_s *pevAttacker) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSFuncTankMortar: public ICSFuncTank {
|
||||||
|
public:
|
||||||
|
virtual void KeyValue(struct KeyValueData_s *pkvd) = 0;
|
||||||
|
virtual void Fire(const Vector &barrelEnd, const Vector &forward, struct entvars_s *pevAttacker) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSFuncTankControls: public ICSEntity {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual int Save(CSave &save) = 0;
|
||||||
|
virtual int Restore(CRestore &restore) = 0;
|
||||||
|
virtual int ObjectCaps() = 0;
|
||||||
|
virtual void Think() = 0;
|
||||||
|
virtual void Use(CCSEntity *pActivator, CCSEntity *pCaller, USE_TYPE useType, float value) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSRecharge: public ICSToggle {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual void KeyValue(struct KeyValueData_s *pkvd) = 0;
|
||||||
|
virtual int Save(CSave &save) = 0;
|
||||||
|
virtual int Restore(CRestore &restore) = 0;
|
||||||
|
virtual int ObjectCaps() = 0;
|
||||||
|
virtual void Use(CCSEntity *pActivator, CCSEntity *pCaller, USE_TYPE useType, float value) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSCycler: public ICSMonster {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual int Save(CSave &save) = 0;
|
||||||
|
virtual int Restore(CRestore &restore) = 0;
|
||||||
|
virtual int ObjectCaps() = 0;
|
||||||
|
virtual int TakeDamage(struct entvars_s *pevInflictor, struct entvars_s *pevAttacker, float flDamage, int bitsDamageType) = 0;
|
||||||
|
virtual bool IsAlive() = 0;
|
||||||
|
virtual void Think() = 0;
|
||||||
|
virtual void Use(CCSEntity *pActivator, CCSEntity *pCaller, USE_TYPE useType, float value) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSGenericCycler: public ICSCycler {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSCyclerProbe: public ICSCycler {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSCyclerSprite: public ICSEntity {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Restart() = 0;
|
||||||
|
virtual int Save(CSave &save) = 0;
|
||||||
|
virtual int Restore(CRestore &restore) = 0;
|
||||||
|
virtual int ObjectCaps() = 0;
|
||||||
|
virtual int TakeDamage(struct entvars_s *pevInflictor, struct entvars_s *pevAttacker, float flDamage, int bitsDamageType) = 0;
|
||||||
|
virtual void Think() = 0;
|
||||||
|
virtual void Use(CCSEntity *pActivator, CCSEntity *pCaller, USE_TYPE useType, float value) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSWeaponCycler: public ICSPlayerWeapon {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual int GetItemInfo(struct ItemInfo *p) = 0;
|
||||||
|
virtual bool Deploy() = 0;
|
||||||
|
virtual void Holster(int skiplocal = 0) = 0;
|
||||||
|
virtual int iItemSlot() = 0;
|
||||||
|
virtual void PrimaryAttack() = 0;
|
||||||
|
virtual void SecondaryAttack() = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSWreckage: public ICSMonster {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual int Save(CSave &save) = 0;
|
||||||
|
virtual int Restore(CRestore &restore) = 0;
|
||||||
|
virtual void Think() = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSWorldItem: public ICSEntity {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void KeyValue(struct KeyValueData_s *pkvd) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSItem: public ICSEntity {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual ICSEntity *Respawn() = 0;
|
||||||
|
virtual bool MyTouch(CCSPlayer *pPlayer) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSHealthKit: public ICSItem {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual bool MyTouch(CCSPlayer *pPlayer) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSItemSuit: public ICSItem {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual bool MyTouch(CCSPlayer *pPlayer) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSItemBattery: public ICSItem {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual bool MyTouch(CCSPlayer *pPlayer) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSItemAntidote: public ICSItem {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual bool MyTouch(CCSPlayer *pPlayer) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSItemSecurity: public ICSItem {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual bool MyTouch(CCSPlayer *pPlayer) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSItemLongJump: public ICSItem {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual bool MyTouch(CCSPlayer *pPlayer) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSItemKevlar: public ICSItem {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual bool MyTouch(CCSPlayer *pPlayer) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSItemAssaultSuit: public ICSItem {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual bool MyTouch(CCSPlayer *pPlayer) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class ICSItemThighPack: public ICSItem {
|
||||||
|
public:
|
||||||
|
virtual void Spawn() = 0;
|
||||||
|
virtual void Precache() = 0;
|
||||||
|
virtual bool MyTouch(CCSPlayer *pPlayer) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
@ -30,6 +30,7 @@
|
|||||||
#include "interface.h"
|
#include "interface.h"
|
||||||
|
|
||||||
#include "hookchains_impl.h"
|
#include "hookchains_impl.h"
|
||||||
|
|
||||||
#include "regamedll.h"
|
#include "regamedll.h"
|
||||||
#include "regamedll_interfaces.h"
|
#include "regamedll_interfaces.h"
|
||||||
#include "regamedll_interfaces_impl.h"
|
#include "regamedll_interfaces_impl.h"
|
||||||
|
@ -28,3 +28,91 @@
|
|||||||
|
|
||||||
#include "precompiled.h"
|
#include "precompiled.h"
|
||||||
|
|
||||||
|
CCSEntity **g_GameEntities = NULL;
|
||||||
|
bool g_bInitialized = false;
|
||||||
|
|
||||||
|
void Regamedll_AllocEntities(int maxEdicts)
|
||||||
|
{
|
||||||
|
if (g_bInitialized)
|
||||||
|
return;
|
||||||
|
|
||||||
|
g_bInitialized = true;
|
||||||
|
g_GameEntities = (CCSEntity **)Q_malloc(sizeof(CCSEntity *) * maxEdicts);
|
||||||
|
Q_memset(g_GameEntities, 0, sizeof(CCSEntity *) * maxEdicts);
|
||||||
|
|
||||||
|
CONSOLE_ECHO(__FUNCTION__":: alloc entities!\n");
|
||||||
|
|
||||||
|
ADD_SERVER_COMMAND("check", [](){
|
||||||
|
Regamedll_MonitorEntities();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
void Regamedll_FreeEntities(CBaseEntity *pEntity)
|
||||||
|
{
|
||||||
|
if (pEntity == NULL)
|
||||||
|
{
|
||||||
|
for (int i = 0; i < gpGlobals->maxEntities; ++i)
|
||||||
|
{
|
||||||
|
delete g_GameEntities[i];
|
||||||
|
g_GameEntities[i] = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
Q_free(g_GameEntities);
|
||||||
|
g_GameEntities = NULL;
|
||||||
|
g_bInitialized = false;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
int index = pEntity->entindex();
|
||||||
|
if (index < 0 || index > gpGlobals->maxEntities)
|
||||||
|
return;
|
||||||
|
|
||||||
|
delete g_GameEntities[index];
|
||||||
|
g_GameEntities[index] = NULL;
|
||||||
|
|
||||||
|
CONSOLE_ECHO(__FUNCTION__ ":: Free on (#%d. %s)\n", index, STRING(pEntity->edict()->v.classname));
|
||||||
|
}
|
||||||
|
|
||||||
|
void Regamedll_MonitorEntities()
|
||||||
|
{
|
||||||
|
int nCount = 0;
|
||||||
|
for (int i = 0; i < gpGlobals->maxEntities; ++i)
|
||||||
|
{
|
||||||
|
if (g_GameEntities[i] == NULL)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
++nCount;
|
||||||
|
}
|
||||||
|
|
||||||
|
CONSOLE_ECHO(__FUNCTION__":: nCount: (%d) (%d)\n", nCount, gpGlobals->maxEntities);
|
||||||
|
}
|
||||||
|
|
||||||
|
ICSPlayer *CBASE_TO_CSPLAYER(CBaseEntity *pEntity)
|
||||||
|
{
|
||||||
|
if (pEntity == NULL)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
int index = pEntity->entindex();
|
||||||
|
if (index < 1 || index > gpGlobals->maxClients)
|
||||||
|
{
|
||||||
|
return NULL;
|
||||||
|
//regamedll_syserror(__FUNCTION__": Invalid player index %d", index);
|
||||||
|
}
|
||||||
|
|
||||||
|
return reinterpret_cast<ICSPlayer *>(g_GameEntities[index]);
|
||||||
|
}
|
||||||
|
|
||||||
|
ICSEntity *CBASE_TO_CSENTITY(CBaseEntity *pEntity)
|
||||||
|
{
|
||||||
|
if (pEntity == NULL)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
int index = pEntity->entindex();
|
||||||
|
if (index < 0 || index > gpGlobals->maxEntities)
|
||||||
|
{
|
||||||
|
return NULL;
|
||||||
|
//regamedll_syserror(__FUNCTION__": Invalid entity index %d", index);
|
||||||
|
}
|
||||||
|
|
||||||
|
return g_GameEntities[index];
|
||||||
|
}
|
||||||
|
File diff suppressed because it is too large
Load Diff
Loading…
x
Reference in New Issue
Block a user