hlsdk-portable/dlls/spectator.cpp

151 lines
3.0 KiB
C++
Raw Normal View History

2016-06-04 13:24:23 +00:00
/***
*
* Copyright (c) 1996-2002, Valve LLC. All rights reserved.
*
* This product contains software technology licensed from Id
* Software, Inc. ("Id Technology"). Id Technology (c) 1996 Id Software, Inc.
* All Rights Reserved.
*
* Use, distribution, and modification of this source code and/or resulting
* object code is restricted to non-commercial enhancements to products from
* Valve LLC. All other use, distribution, or modification is prohibited
* without written permission from Valve LLC.
*
****/
// CBaseSpectator
// YWB: UNDONE
// Spectator functions
//
2016-06-04 13:24:23 +00:00
#include "extdll.h"
#include "util.h"
#include "cbase.h"
#include "monsters.h"
#include "spectator.h"
/*
===========
SpectatorConnect
called when a spectator connects to a server
============
*/
2016-07-31 13:48:50 +00:00
void CBaseSpectator::SpectatorConnect( void )
2016-06-04 13:24:23 +00:00
{
pev->flags = FL_SPECTATOR;
pev->solid = SOLID_NOT;
pev->movetype = MOVETYPE_NOCLIP;
2016-06-04 13:24:23 +00:00
m_pGoalEnt = NULL;
}
/*
===========
SpectatorDisconnect
called when a spectator disconnects from a server
============
*/
2016-07-31 13:48:50 +00:00
void CBaseSpectator::SpectatorDisconnect( void )
2016-06-04 13:24:23 +00:00
{
}
/*
================
SpectatorImpulseCommand
Called by SpectatorThink if the spectator entered an impulse
================
*/
2016-07-31 13:48:50 +00:00
void CBaseSpectator::SpectatorImpulseCommand( void )
2016-06-04 13:24:23 +00:00
{
2016-07-31 13:48:50 +00:00
static edict_t *pGoal = NULL;
edict_t *pPreviousGoal;
edict_t *pCurrentGoal;
BOOL bFound;
2016-07-31 13:48:50 +00:00
switch( pev->impulse )
2016-06-04 13:24:23 +00:00
{
case 1:
// teleport the spectator to the next spawn point
// note that if the spectator is tracking, this doesn't do
// much
pPreviousGoal = pGoal;
pCurrentGoal = pGoal;
// Start at the current goal, skip the world, and stop if we looped
// back around
bFound = FALSE;
2016-07-31 13:48:50 +00:00
while( 1 )
2016-06-04 13:24:23 +00:00
{
2016-07-31 13:48:50 +00:00
pCurrentGoal = FIND_ENTITY_BY_CLASSNAME( pCurrentGoal, "info_player_deathmatch" );
2016-06-04 13:24:23 +00:00
// Looped around, failure
2016-07-31 13:48:50 +00:00
if( pCurrentGoal == pPreviousGoal )
2016-06-04 13:24:23 +00:00
{
2016-07-31 13:48:50 +00:00
ALERT( at_console, "Could not find a spawn spot.\n" );
2016-06-04 13:24:23 +00:00
break;
}
// Found a non-world entity, set success, otherwise, look for the next one.
2016-07-31 13:48:50 +00:00
if( !FNullEnt( pCurrentGoal ) )
2016-06-04 13:24:23 +00:00
{
bFound = TRUE;
break;
}
}
2016-07-31 13:48:50 +00:00
if( !bFound ) // Didn't find a good spot.
2016-06-04 13:24:23 +00:00
break;
2016-06-04 13:24:23 +00:00
pGoal = pCurrentGoal;
UTIL_SetOrigin( pev, pGoal->v.origin );
pev->angles = pGoal->v.angles;
pev->fixangle = FALSE;
break;
default:
2016-07-31 13:48:50 +00:00
ALERT( at_console, "Unknown spectator impulse\n" );
2016-06-04 13:24:23 +00:00
break;
}
pev->impulse = 0;
}
/*
================
SpectatorThink
Called every frame after physics are run
================
*/
2016-07-31 13:48:50 +00:00
void CBaseSpectator::SpectatorThink( void )
2016-06-04 13:24:23 +00:00
{
2016-07-31 13:48:50 +00:00
if( !( pev->flags & FL_SPECTATOR ) )
2016-06-04 13:24:23 +00:00
{
pev->flags = FL_SPECTATOR;
}
2016-07-31 13:48:50 +00:00
pev->solid = SOLID_NOT;
pev->movetype = MOVETYPE_NOCLIP;
2016-06-04 13:24:23 +00:00
2016-07-31 13:48:50 +00:00
if( pev->impulse )
2016-06-04 13:24:23 +00:00
SpectatorImpulseCommand();
}
/*
===========
Spawn
Called when spectator is initialized:
UNDONE: Is this actually being called because spectators are not allocated in normal fashion?
============
*/
void CBaseSpectator::Spawn()
{
pev->flags = FL_SPECTATOR;
pev->solid = SOLID_NOT;
pev->movetype = MOVETYPE_NOCLIP;
2016-06-04 13:24:23 +00:00
m_pGoalEnt = NULL;
}