css_enhanced_waf/game/server/tf2/trigger_fall.cpp
FluorescentCIAAfricanAmerican 3bf9df6b27 1
2020-04-22 12:56:21 -04:00

72 lines
1.9 KiB
C++

//========= Copyright Valve Corporation, All rights reserved. ============//
//
// Purpose: Used at the bottom of maps where objects should fall away to infinity
//
// $NoKeywords: $
//=============================================================================//
#include "cbase.h"
#include "triggers.h"
//-----------------------------------------------------------------------------
// Purpose: Used at the bottom of maps where objects should fall away to infinity
//-----------------------------------------------------------------------------
class CTriggerFall : public CBaseTrigger
{
DECLARE_CLASS( CTriggerFall, CBaseTrigger );
public:
void Spawn( void );
void FallTouch( CBaseEntity *pOther );
DECLARE_DATADESC();
// Outputs
COutputEvent m_OnFallingObject;
};
BEGIN_DATADESC( CTriggerFall )
// Function Pointers
DEFINE_FUNCTION( FallTouch ),
// Outputs
DEFINE_OUTPUT( m_OnFallingObject, "OnFallingObject" ),
END_DATADESC()
LINK_ENTITY_TO_CLASS( trigger_fall, CTriggerFall );
//-----------------------------------------------------------------------------
// Purpose: Called when spawning, after keyvalues have been handled.
//-----------------------------------------------------------------------------
void CTriggerFall::Spawn( void )
{
BaseClass::Spawn();
InitTrigger();
SetTouch( FallTouch );
}
//-----------------------------------------------------------------------------
// Purpose: Make the object fall away
// Input : pOther - The entity that is touching us.
//-----------------------------------------------------------------------------
void CTriggerFall::FallTouch( CBaseEntity *pOther )
{
// If it's a player, just kill him for now
if ( pOther->IsPlayer() )
{
if ( pOther->IsAlive() == false )
return;
pOther->TakeDamage( CTakeDamageInfo( this, this, 200, DMG_FALL ) );
}
else
{
// Just remove the entity
UTIL_Remove( pOther );
}
// Fire our output
m_OnFallingObject.FireOutput( pOther, this );
}