591 lines
15 KiB
C++
Raw Normal View History

2015-06-30 15:46:07 +06:00
#include "precompiled.h"
/*
* Globals initialization
*/
#ifndef HOOK_GAMEDLL
2015-09-17 02:19:21 +06:00
// Global Savedata for Delay
2015-06-30 15:46:07 +06:00
TYPEDESCRIPTION CBaseDelay::m_SaveData[] =
{
DEFINE_FIELD(CBaseDelay, m_flDelay, FIELD_FLOAT),
DEFINE_FIELD(CBaseDelay, m_iszKillTarget, FIELD_STRING),
};
2015-09-17 02:19:21 +06:00
// Global Savedata for Toggle
2015-06-30 15:46:07 +06:00
TYPEDESCRIPTION CBaseToggle::m_SaveData[] =
{
DEFINE_FIELD(CBaseToggle, m_toggle_state, FIELD_INTEGER),
DEFINE_FIELD(CBaseToggle, m_flActivateFinished, FIELD_TIME),
DEFINE_FIELD(CBaseToggle, m_flMoveDistance, FIELD_FLOAT),
DEFINE_FIELD(CBaseToggle, m_flWait, FIELD_FLOAT),
DEFINE_FIELD(CBaseToggle, m_flLip, FIELD_FLOAT),
DEFINE_FIELD(CBaseToggle, m_flTWidth, FIELD_FLOAT),
DEFINE_FIELD(CBaseToggle, m_flTLength, FIELD_FLOAT),
DEFINE_FIELD(CBaseToggle, m_vecPosition1, FIELD_POSITION_VECTOR),
DEFINE_FIELD(CBaseToggle, m_vecPosition2, FIELD_POSITION_VECTOR),
2015-09-17 02:19:21 +06:00
DEFINE_FIELD(CBaseToggle, m_vecAngle1, FIELD_VECTOR), // UNDONE: Position could go through transition, but also angle?
DEFINE_FIELD(CBaseToggle, m_vecAngle2, FIELD_VECTOR), // UNDONE: Position could go through transition, but also angle?
2015-06-30 15:46:07 +06:00
DEFINE_FIELD(CBaseToggle, m_cTriggersLeft, FIELD_INTEGER),
DEFINE_FIELD(CBaseToggle, m_flHeight, FIELD_FLOAT),
DEFINE_FIELD(CBaseToggle, m_hActivator, FIELD_EHANDLE),
DEFINE_FIELD(CBaseToggle, m_pfnCallWhenMoveDone, FIELD_FUNCTION),
DEFINE_FIELD(CBaseToggle, m_vecFinalDest, FIELD_POSITION_VECTOR),
DEFINE_FIELD(CBaseToggle, m_vecFinalAngle, FIELD_VECTOR),
DEFINE_FIELD(CBaseToggle, m_sMaster, FIELD_STRING),
2015-09-17 02:19:21 +06:00
DEFINE_FIELD(CBaseToggle, m_bitsDamageInflict, FIELD_INTEGER), // damage type inflicted
2015-06-30 15:46:07 +06:00
};
#else // HOOK_GAMEDLL
2015-12-09 04:39:54 +06:00
TYPEDESCRIPTION IMPL_CLASS(CBaseDelay, m_SaveData)[2];
TYPEDESCRIPTION IMPL_CLASS(CBaseToggle, m_SaveData)[19];
2015-06-30 15:46:07 +06:00
#endif // HOOK_GAMEDLL
2015-09-17 02:19:21 +06:00
// Landmark class
2015-06-30 15:46:07 +06:00
/* <1832bc> ../cstrike/dlls/subs.cpp:38 */
2015-09-17 02:19:21 +06:00
void CPointEntity::__MAKE_VHOOK(Spawn)(void)
2015-06-30 15:46:07 +06:00
{
2015-09-17 02:19:21 +06:00
pev->solid = SOLID_NOT;
2015-06-30 15:46:07 +06:00
}
2015-09-17 02:19:21 +06:00
// Null Entity, remove on startup
2015-06-30 15:46:07 +06:00
/* <183417> ../cstrike/dlls/subs.cpp:53 */
2015-09-17 02:19:21 +06:00
void CNullEntity::__MAKE_VHOOK(Spawn)(void)
2015-06-30 15:46:07 +06:00
{
2015-09-17 02:19:21 +06:00
REMOVE_ENTITY(ENT(pev));
2015-06-30 15:46:07 +06:00
}
/* <1838f5> ../cstrike/dlls/subs.cpp:57 */
LINK_ENTITY_TO_CLASS(info_null, CNullEntity);
2015-09-17 02:19:21 +06:00
// These are the new entry points to entities.
2015-06-30 15:46:07 +06:00
/* <1839f1> ../cstrike/dlls/subs.cpp:69 */
LINK_ENTITY_TO_CLASS(info_player_deathmatch, CBaseDMStart);
/* <183aed> ../cstrike/dlls/subs.cpp:70 */
LINK_ENTITY_TO_CLASS(info_player_start, CPointEntity);
/* <183bb7> ../cstrike/dlls/subs.cpp:71 */
LINK_ENTITY_TO_CLASS(info_vip_start, CBaseDMStart);
/* <183c81> ../cstrike/dlls/subs.cpp:72 */
LINK_ENTITY_TO_CLASS(info_landmark, CPointEntity);
/* <183d4b> ../cstrike/dlls/subs.cpp:75 */
LINK_ENTITY_TO_CLASS(info_hostage_rescue, CPointEntity);
/* <183e15> ../cstrike/dlls/subs.cpp:77 */
LINK_ENTITY_TO_CLASS(info_bomb_target, CPointEntity);
/* <183647> ../cstrike/dlls/subs.cpp:79 */
2015-09-17 02:19:21 +06:00
void CBaseDMStart::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
2015-06-30 15:46:07 +06:00
{
2015-09-17 02:19:21 +06:00
if (FStrEq(pkvd->szKeyName, "master"))
{
pev->netname = ALLOC_STRING(pkvd->szValue);
pkvd->fHandled = TRUE;
}
else
CPointEntity::KeyValue(pkvd);
2015-06-30 15:46:07 +06:00
}
/* <18331c> ../cstrike/dlls/subs.cpp:90 */
2015-09-17 02:19:21 +06:00
BOOL CBaseDMStart::__MAKE_VHOOK(IsTriggered)(CBaseEntity *pEntity)
2015-06-30 15:46:07 +06:00
{
2015-09-17 02:19:21 +06:00
BOOL master = UTIL_IsMasterTriggered(pev->netname, pEntity);
return master;
2015-06-30 15:46:07 +06:00
}
2015-09-17 02:19:21 +06:00
// This updates global tables that need to know about entities being removed
2015-06-30 15:46:07 +06:00
/* <183f03> ../cstrike/dlls/subs.cpp:98 */
void CBaseEntity::UpdateOnRemove(void)
{
2015-09-17 02:19:21 +06:00
int i;
2015-08-20 16:35:01 +06:00
if (pev->flags & FL_GRAPHED)
2015-06-30 15:46:07 +06:00
{
2015-09-17 02:19:21 +06:00
// this entity was a LinkEnt in the world node graph, so we must remove it from
// the graph since we are removing it from the world.
for (i = 0; i < WorldGraph.m_cLinks; i++)
2015-06-30 15:46:07 +06:00
{
if (WorldGraph.m_pLinkPool[i].m_pLinkEnt == pev)
2015-09-17 02:19:21 +06:00
{
// if this link has a link ent which is the same ent that is removing itself, remove it!
2015-06-30 15:46:07 +06:00
WorldGraph.m_pLinkPool[i].m_pLinkEnt = NULL;
2015-09-17 02:19:21 +06:00
}
2015-06-30 15:46:07 +06:00
}
}
2015-08-20 16:35:01 +06:00
2015-06-30 15:46:07 +06:00
if (pev->globalname)
2015-08-20 16:35:01 +06:00
{
2015-06-30 15:46:07 +06:00
gGlobalState.EntitySetState(pev->globalname, GLOBAL_DEAD);
2015-08-20 16:35:01 +06:00
}
2015-06-30 15:46:07 +06:00
}
2015-09-17 02:19:21 +06:00
// Convenient way to delay removing oneself
2015-06-30 15:46:07 +06:00
/* <183f38> ../cstrike/dlls/subs.cpp:120 */
void CBaseEntity::SUB_Remove(void)
{
UpdateOnRemove();
if (pev->health > 0)
{
2015-09-17 02:19:21 +06:00
// this situation can screw up monsters who can't tell their entity pointers are invalid.
2015-06-30 15:46:07 +06:00
pev->health = 0;
ALERT(at_aiconsole, "SUB_Remove called on entity with health > 0\n");
}
2015-08-20 16:35:01 +06:00
2015-06-30 15:46:07 +06:00
REMOVE_ENTITY(ENT(pev));
}
2015-09-17 02:19:21 +06:00
// Convenient way to explicitly do nothing (passed to functions that require a method)
2015-06-30 15:46:07 +06:00
/* <183f8a> ../cstrike/dlls/subs.cpp:135 */
void CBaseEntity::SUB_DoNothing(void)
{
;
}
/* <183523> ../cstrike/dlls/subs.cpp:147 */
IMPLEMENT_SAVERESTORE(CBaseDelay, CBaseEntity);
/* <18356f> ../cstrike/dlls/subs.cpp:149 */
2015-08-20 16:35:01 +06:00
void CBaseDelay::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
2015-06-30 15:46:07 +06:00
{
if (FStrEq(pkvd->szKeyName, "delay"))
{
2015-08-20 16:35:01 +06:00
m_flDelay = Q_atof(pkvd->szValue);
2015-06-30 15:46:07 +06:00
pkvd->fHandled = TRUE;
}
else if (FStrEq(pkvd->szKeyName, "killtarget"))
{
m_iszKillTarget = ALLOC_STRING(pkvd->szValue);
pkvd->fHandled = TRUE;
}
else
CBaseEntity::KeyValue(pkvd);
}
2015-09-17 02:19:21 +06:00
// If self.delay is set, a DelayedUse entity will be created that will actually
// do the SUB_UseTargets after that many seconds have passed.
// Removes all entities with a targetname that match self.killtarget,
// and removes them, so some events can remove other triggers.
// Search for (string)targetname in all entities that
// match (string)self.target and call their .use function (if they have one)
2015-06-30 15:46:07 +06:00
/* <1840d5> ../cstrike/dlls/subs.cpp:183 */
void CBaseEntity::SUB_UseTargets(CBaseEntity *pActivator, USE_TYPE useType, float value)
{
2015-09-17 02:19:21 +06:00
// fire targets
2015-06-30 15:46:07 +06:00
if (!FStringNull(pev->target))
2015-09-17 02:19:21 +06:00
{
2015-06-30 15:46:07 +06:00
FireTargets(STRING(pev->target), pActivator, this, useType, value);
2015-09-17 02:19:21 +06:00
}
2015-06-30 15:46:07 +06:00
}
/* <183fb0> ../cstrike/dlls/subs.cpp:195 */
void FireTargets(const char *targetName, CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value)
{
edict_t *pentTarget = NULL;
if (!targetName)
return;
ALERT(at_aiconsole, "Firing: (%s)\n", targetName);
2015-09-17 02:19:21 +06:00
while (true)
2015-06-30 15:46:07 +06:00
{
pentTarget = FIND_ENTITY_BY_TARGETNAME(pentTarget, targetName);
if (FNullEnt(pentTarget))
break;
CBaseEntity *pTarget = CBaseEntity::Instance(pentTarget);
2015-09-17 02:19:21 +06:00
// Don't use dying ents
2015-06-30 15:46:07 +06:00
if (pTarget && !(pTarget->pev->flags & FL_KILLME))
{
ALERT(at_aiconsole, "Found: %s, firing (%s)\n", STRING(pTarget->pev->classname), targetName);
pTarget->Use(pActivator, pCaller, useType, value);
}
}
}
/* <1843f8> ../cstrike/dlls/subs.cpp:249 */
LINK_ENTITY_TO_CLASS(DelayedUse, CBaseDelay);
/* <1844c2> ../cstrike/dlls/subs.cpp:252 */
void CBaseDelay::SUB_UseTargets(CBaseEntity *pActivator, USE_TYPE useType, float value)
{
2015-09-17 02:19:21 +06:00
// exit immediatly if we don't have a target or kill target
if (FStringNull(pev->target) && !m_iszKillTarget)
2015-06-30 15:46:07 +06:00
return;
2015-09-17 02:19:21 +06:00
// check for a delay
if (m_flDelay != 0)
2015-06-30 15:46:07 +06:00
{
2015-09-17 02:19:21 +06:00
// create a temp object to fire at a later time
2015-06-30 15:46:07 +06:00
CBaseDelay *pTemp = GetClassPtr((CBaseDelay *)NULL);
if (pTemp->pev->classname)
2015-09-17 02:19:21 +06:00
{
2015-06-30 15:46:07 +06:00
RemoveEntityHashValue(pTemp->pev, STRING(pTemp->pev->classname), CLASSNAME);
2015-09-17 02:19:21 +06:00
}
2015-06-30 15:46:07 +06:00
MAKE_STRING_CLASS("DelayedUse", pTemp->pev);
2015-06-30 15:46:07 +06:00
AddEntityHashValue(pTemp->pev, STRING(pTemp->pev->classname), CLASSNAME);
pTemp->pev->nextthink = gpGlobals->time + m_flDelay;
pTemp->SetThink(&CBaseDelay::DelayThink);
2015-09-17 02:19:21 +06:00
// Save the useType
2015-06-30 15:46:07 +06:00
pTemp->pev->button = (int)useType;
pTemp->m_iszKillTarget = m_iszKillTarget;
2015-09-17 02:19:21 +06:00
// prevent "recursion"
pTemp->m_flDelay = 0;
2015-06-30 15:46:07 +06:00
pTemp->pev->target = pev->target;
2015-09-17 02:19:21 +06:00
// HACKHACK
// This wasn't in the release build of Half-Life. We should have moved m_hActivator into this class
// but changing member variable hierarchy would break save/restore without some ugly code.
// This code is not as ugly as that code
// If a player activates, then save it
2015-06-30 15:46:07 +06:00
if (pActivator && pActivator->IsPlayer())
2015-09-17 02:19:21 +06:00
{
2015-06-30 15:46:07 +06:00
pTemp->pev->owner = pActivator->edict();
2015-09-17 02:19:21 +06:00
}
2015-06-30 15:46:07 +06:00
else
2015-09-17 02:19:21 +06:00
{
2015-06-30 15:46:07 +06:00
pTemp->pev->owner = NULL;
2015-09-17 02:19:21 +06:00
}
return;
}
// kill the killtargets
if (m_iszKillTarget)
{
edict_t *pentKillTarget = NULL;
ALERT(at_aiconsole, "KillTarget: %s\n", STRING(m_iszKillTarget));
pentKillTarget = FIND_ENTITY_BY_TARGETNAME(NULL, STRING(m_iszKillTarget));
while (!FNullEnt(pentKillTarget))
{
UTIL_Remove(CBaseEntity::Instance(pentKillTarget));
ALERT(at_aiconsole, "killing %s\n", STRING(pentKillTarget->v.classname));
pentKillTarget = FIND_ENTITY_BY_TARGETNAME(pentKillTarget, STRING(m_iszKillTarget));
}
}
// fire targets
if (!FStringNull(pev->target))
{
FireTargets(STRING(pev->target), pActivator, this, useType, value);
2015-06-30 15:46:07 +06:00
}
}
2015-09-17 02:19:21 +06:00
// QuakeEd only writes a single float for angles (bad idea), so up and down are
// just constant angles.
2015-06-30 15:46:07 +06:00
/* <1846d9> ../cstrike/dlls/subs.cpp:335 */
void SetMovedir(entvars_t *pev)
{
if (pev->angles == Vector(0, -1, 0))
2015-09-17 02:19:21 +06:00
{
2015-06-30 15:46:07 +06:00
pev->movedir = Vector(0, 0, 1);
2015-09-17 02:19:21 +06:00
}
2015-06-30 15:46:07 +06:00
else if (pev->angles == Vector(0, -2, 0))
2015-09-17 02:19:21 +06:00
{
2015-06-30 15:46:07 +06:00
pev->movedir = Vector(0, 0, -1);
2015-09-17 02:19:21 +06:00
}
2015-06-30 15:46:07 +06:00
else
{
UTIL_MakeVectors(pev->angles);
pev->movedir = gpGlobals->v_forward;
}
2015-09-17 02:19:21 +06:00
2015-06-30 15:46:07 +06:00
pev->angles = g_vecZero;
}
/* <184158> ../cstrike/dlls/subs.cpp:357 */
void CBaseDelay::DelayThink(void)
{
CBaseEntity *pActivator = NULL;
2015-09-17 02:19:21 +06:00
// A player activated this on delay
if (pev->owner != NULL)
{
2015-06-30 15:46:07 +06:00
pActivator = CBaseEntity::Instance(pev->owner);
2015-09-17 02:19:21 +06:00
}
2015-06-30 15:46:07 +06:00
2015-09-17 02:19:21 +06:00
// The use type is cached (and stashed) in pev->button
SUB_UseTargets(pActivator, (USE_TYPE)pev->button, 0);
2015-06-30 15:46:07 +06:00
REMOVE_ENTITY(ENT(pev));
}
/* <1834d6> ../cstrike/dlls/subs.cpp:394 */
IMPLEMENT_SAVERESTORE(CBaseToggle, CBaseAnimating);
/* <1836dc> ../cstrike/dlls/subs.cpp:397 */
2015-08-20 16:35:01 +06:00
void CBaseToggle::__MAKE_VHOOK(KeyValue)(KeyValueData *pkvd)
2015-06-30 15:46:07 +06:00
{
if (FStrEq(pkvd->szKeyName, "lip"))
{
2015-08-20 16:35:01 +06:00
m_flLip = Q_atof(pkvd->szValue);
2015-06-30 15:46:07 +06:00
pkvd->fHandled = TRUE;
}
else if (FStrEq(pkvd->szKeyName, "wait"))
{
2015-08-20 16:35:01 +06:00
m_flWait = Q_atof(pkvd->szValue);
2015-06-30 15:46:07 +06:00
pkvd->fHandled = TRUE;
}
else if (FStrEq(pkvd->szKeyName, "master"))
{
m_sMaster = ALLOC_STRING(pkvd->szValue);
pkvd->fHandled = TRUE;
}
else if (FStrEq(pkvd->szKeyName, "distance"))
{
2015-08-20 16:35:01 +06:00
m_flMoveDistance = Q_atof(pkvd->szValue);
2015-06-30 15:46:07 +06:00
pkvd->fHandled = TRUE;
}
else
CBaseDelay::KeyValue(pkvd);
}
2015-09-17 02:19:21 +06:00
// calculate pev->velocity and pev->nextthink to reach vecDest from
// pev->origin traveling at flSpeed
2015-06-30 15:46:07 +06:00
/* <18474d> ../cstrike/dlls/subs.cpp:431 */
2015-09-17 02:19:21 +06:00
void CBaseToggle::LinearMove(Vector vecDest, float flSpeed)
{
assert(("LinearMove: no speed is defined!", flSpeed != 0));
//assert(("LinearMove: no post-move function defined", m_pfnCallWhenMoveDone != NULL));
m_vecFinalDest = vecDest;
// Already there?
if (vecDest == pev->origin)
{
LinearMoveDone();
return;
}
// set destdelta to the vector needed to move
Vector vecDestDelta = vecDest - pev->origin;
// divide vector length by speed to get time to reach dest
float_precision flTravelTime = vecDestDelta.Length() / flSpeed;
// set nextthink to trigger a call to LinearMoveDone when dest is reached
pev->nextthink = pev->ltime + flTravelTime;
SetThink(&CBaseToggle::LinearMoveDone);
// scale the destdelta vector by the time spent traveling to get velocity
pev->velocity = vecDestDelta * (float)(1 / flTravelTime);
2015-06-30 15:46:07 +06:00
}
2015-09-17 02:19:21 +06:00
// After moving, set origin to exact final destination, call "move done" function
2015-06-30 15:46:07 +06:00
/* <18337e> ../cstrike/dlls/subs.cpp:465 */
2015-09-17 02:19:21 +06:00
void CBaseToggle::LinearMoveDone(void)
2015-06-30 15:46:07 +06:00
{
2015-09-17 02:19:21 +06:00
UTIL_SetOrigin(pev, m_vecFinalDest);
pev->velocity = g_vecZero;
pev->nextthink = -1;
if (m_pfnCallWhenMoveDone)
{
(this->*m_pfnCallWhenMoveDone)();
}
2015-06-30 15:46:07 +06:00
}
/* <184855> ../cstrike/dlls/subs.cpp:474 */
2015-09-17 02:19:21 +06:00
NOXREF BOOL CBaseToggle::IsLockedByMaster(void)
2015-06-30 15:46:07 +06:00
{
2015-09-17 02:19:21 +06:00
if (!FStringNull(m_sMaster) && !UTIL_IsMasterTriggered(m_sMaster, m_hActivator))
return TRUE;
else
return FALSE;
2015-06-30 15:46:07 +06:00
}
2015-09-17 02:19:21 +06:00
// calculate pev->velocity and pev->nextthink to reach vecDest from
// pev->origin traveling at flSpeed
// Just like LinearMove, but rotational.
2015-06-30 15:46:07 +06:00
/* <18487c> ../cstrike/dlls/subs.cpp:491 */
2015-09-17 02:19:21 +06:00
void CBaseToggle::AngularMove(Vector vecDestAngle, float flSpeed)
{
assert(("AngularMove: no speed is defined!", flSpeed != 0));
//assert(("AngularMove: no post-move function defined", m_pfnCallWhenMoveDone != NULL));
m_vecFinalAngle = vecDestAngle;
// Already there?
if (vecDestAngle == pev->angles)
{
AngularMoveDone();
return;
}
// set destdelta to the vector needed to move
Vector vecDestDelta = vecDestAngle - pev->angles;
// divide by speed to get time to reach dest
float_precision flTravelTime = vecDestDelta.Length() / flSpeed;
// set nextthink to trigger a call to AngularMoveDone when dest is reached
pev->nextthink = pev->ltime + flTravelTime;
SetThink(&CBaseToggle::AngularMoveDone);
// scale the destdelta vector by the time spent traveling to get velocity
pev->avelocity = vecDestDelta / flTravelTime;
2015-06-30 15:46:07 +06:00
}
2015-09-17 02:19:21 +06:00
// After rotating, set angle to exact final angle, call "move done" function
2015-06-30 15:46:07 +06:00
/* <1832fb> ../cstrike/dlls/subs.cpp:525 */
2015-09-17 02:19:21 +06:00
void CBaseToggle::AngularMoveDone(void)
2015-06-30 15:46:07 +06:00
{
2015-09-17 02:19:21 +06:00
pev->angles = m_vecFinalAngle;
pev->avelocity = g_vecZero;
pev->nextthink = -1;
if (m_pfnCallWhenMoveDone)
{
(this->*m_pfnCallWhenMoveDone)();
}
2015-06-30 15:46:07 +06:00
}
/* <184984> ../cstrike/dlls/subs.cpp:535 */
2015-09-17 02:19:21 +06:00
float CBaseToggle::AxisValue(int flags, const Vector &angles)
2015-06-30 15:46:07 +06:00
{
2015-09-17 02:19:21 +06:00
if (flags & SF_DOOR_ROTATE_Z)
return angles.z;
if (flags & SF_DOOR_ROTATE_X)
return angles.x;
return angles.y;
2015-06-30 15:46:07 +06:00
}
/* <1849bd> ../cstrike/dlls/subs.cpp:546 */
2015-09-17 02:19:21 +06:00
void CBaseToggle::AxisDir(entvars_t *pev)
2015-06-30 15:46:07 +06:00
{
2015-09-17 02:19:21 +06:00
if (pev->spawnflags & SF_DOOR_ROTATE_Z)
{
// around z-axis
pev->movedir = Vector(0, 0, 1);
}
else if (pev->spawnflags & SF_DOOR_ROTATE_X)
{
// around x-axis
pev->movedir = Vector(1, 0, 0);
}
else
{
// around y-axis
pev->movedir = Vector(0, 1, 0);
}
2015-06-30 15:46:07 +06:00
}
/* <1849e3> ../cstrike/dlls/subs.cpp:557 */
2015-09-17 02:19:21 +06:00
float CBaseToggle::AxisDelta(int flags, const Vector &angle1, const Vector &angle2)
2015-06-30 15:46:07 +06:00
{
2015-09-17 02:19:21 +06:00
if (flags & SF_DOOR_ROTATE_Z)
return angle1.z - angle2.z;
if (flags & SF_DOOR_ROTATE_X)
return angle1.x - angle2.x;
return angle1.y - angle2.y;
2015-06-30 15:46:07 +06:00
}
2015-09-17 02:19:21 +06:00
// returns TRUE if the passed entity is visible to caller, even if not infront ()
2015-06-30 15:46:07 +06:00
/* <184a30> ../cstrike/dlls/subs.cpp:577 */
2015-09-17 02:19:21 +06:00
NOXREF BOOL FEntIsVisible(entvars_t *pev, entvars_t *pevTarget)
{
Vector vecSpot1 = pev->origin + pev->view_ofs;
Vector vecSpot2 = pevTarget->origin + pevTarget->view_ofs;
TraceResult tr;
UTIL_TraceLine(vecSpot1, vecSpot2, ignore_monsters, ENT(pev), &tr);
if (tr.fInOpen && tr.fInWater)
{
// sight line crossed contents
return FALSE;
}
if (tr.flFraction == 1.0f)
{
return TRUE;
}
return FALSE;
2015-06-30 15:46:07 +06:00
}
#ifdef HOOK_GAMEDLL
void CNullEntity::Spawn(void)
{
Spawn_();
}
void CPointEntity::Spawn(void)
{
Spawn_();
}
void CBaseDelay::KeyValue(KeyValueData *pkvd)
{
KeyValue_(pkvd);
}
int CBaseDelay::Save(CSave &save)
{
return Save_(save);
}
int CBaseDelay::Restore(CRestore &restore)
{
return Restore_(restore);
}
void CBaseToggle::KeyValue(KeyValueData *pkvd)
{
KeyValue_(pkvd);
}
int CBaseToggle::Save(CSave &save)
{
return Save_(save);
}
int CBaseToggle::Restore(CRestore &restore)
{
return Restore_(restore);
}
void CBaseDMStart::KeyValue(KeyValueData *pkvd)
{
KeyValue_(pkvd);
}
BOOL CBaseDMStart::IsTriggered(CBaseEntity *pEntity)
{
return IsTriggered_(pEntity);
}
#endif // HOOK_GAMEDLL