//========= Copyright © 1996-2005, Valve Corporation, All rights reserved. ============// // // Purpose: // // $Workfile: $ // $NoKeywords: $ //=============================================================================// #include #include "gameui_util.h" #include "strtools.h" #include "engineinterface.h" // memdbgon must be the last include file in a .cpp file!!! #include "tier0/memdbgon.h" using namespace vgui; static int g_nGameUIActiveSplitscreenPlayerSlot = 0; int GetGameUIActiveSplitScreenPlayerSlot() { return g_nGameUIActiveSplitscreenPlayerSlot; } void SetGameUIActiveSplitScreenPlayerSlot( int nSlot ) { if ( g_nGameUIActiveSplitscreenPlayerSlot != nSlot ) { g_nGameUIActiveSplitscreenPlayerSlot = nSlot; } } //----------------------------------------------------------------------------- // Purpose: Scans player names //Passes the player name to be checked in a KeyValues pointer //with the keyname "name" // - replaces '&' with '&&' so they will draw in the scoreboard // - replaces '#' at the start of the name with '*' //----------------------------------------------------------------------------- void GameUI_MakeSafeName( const char *oldName, char *newName, int newNameBufSize ) { if ( !oldName ) { newName[0] = 0; return; } int newpos = 0; for( const char *p=oldName; *p != 0 && newpos < newNameBufSize-1; p++ ) { //check for a '#' char at the beginning /* if( p == oldName && *p == '#' ) { newName[newpos] = '*'; newpos++; } else */ if( *p == '%' ) { // remove % chars newName[newpos] = '*'; newpos++; } else if( *p == '&' ) { //insert another & after this one if ( newpos+2 < newNameBufSize ) { newName[newpos] = '&'; newName[newpos+1] = '&'; newpos+=2; } } else { newName[newpos] = *p; newpos++; } } newName[newpos] = 0; } //----------------------------------------------------------------------------- // Purpose: Performs a var args printf into a static return buffer // Input : *format - // ... - // Output : char //----------------------------------------------------------------------------- // Unused :: char *VarArgs( PRINTF_FORMAT_STRING const char *format, ... ); //----------------------------------------------------------------------------- // This version is simply used to make reading convars simpler. // Writing convars isn't allowed in this mode //----------------------------------------------------------------------------- class CEmptyGameUIConVar : public ConVar { public: CEmptyGameUIConVar() : ConVar( "", "0" ) {} // Used for optimal read access virtual void SetValue( const char *pValue ) {} virtual void SetValue( float flValue ) {} virtual void SetValue( int nValue ) {} virtual const char *GetName( void ) const { return ""; } virtual bool IsFlagSet( int nFlags ) const { return false; } }; static CEmptyGameUIConVar s_EmptyConVar; // Helper for splitscreen ConVars CGameUIConVarRef::CGameUIConVarRef( const char *pName ) { Init( pName, false ); } CGameUIConVarRef::CGameUIConVarRef( const char *pName, bool bIgnoreMissing ) { Init( pName, bIgnoreMissing ); } void CGameUIConVarRef::Init( const char *pName, bool bIgnoreMissing ) { for ( int i = 0; i < MAX_SPLITSCREEN_CLIENTS; ++i ) { cv_t &info = m_Info[ i ]; char pchName[ 256 ]; if ( i != 0 ) { Q_snprintf( pchName, sizeof( pchName ), "%s%d", pName, i + 1 ); } else { Q_strncpy( pchName, pName, sizeof( pchName ) ); } info.m_pConVar = g_pCVar ? g_pCVar->FindVar( pchName ) : &s_EmptyConVar; if ( !info.m_pConVar ) { info.m_pConVar = &s_EmptyConVar; if ( i > 0 ) { // Point at slot zero instead, in case we got in here with a non FCVAR_SS var... info.m_pConVar = m_Info[ 0 ].m_pConVar; } } info.m_pConVarState = static_cast< ConVar * >( info.m_pConVar ); } if ( !IsValid() ) { static bool bFirst = true; if ( g_pCVar || bFirst ) { if ( !bIgnoreMissing ) { Warning( "CGameUIConVarRef %s doesn't point to an existing ConVar\n", pName ); } bFirst = false; } } } CGameUIConVarRef::CGameUIConVarRef( IConVar *pConVar ) { cv_t &info = m_Info[ 0 ]; info.m_pConVar = pConVar ? pConVar : &s_EmptyConVar; info.m_pConVarState = static_cast< ConVar * >( info.m_pConVar ); for ( int i = 1; i < MAX_SPLITSCREEN_CLIENTS; ++i ) { info = m_Info[ i ]; char pchName[ 256 ]; Q_snprintf( pchName, sizeof( pchName ), "%s%d", pConVar->GetName(), i + 1 ); info.m_pConVar = g_pCVar ? g_pCVar->FindVar( pchName ) : &s_EmptyConVar; if ( !info.m_pConVar ) { info.m_pConVar = &s_EmptyConVar; if ( i > 0 ) { // Point at slot zero instead, in case we got in here with a non FCVAR_SS var... info.m_pConVar = m_Info[ 0 ].m_pConVar; } } info.m_pConVarState = static_cast< ConVar * >( info.m_pConVar ); } } bool CGameUIConVarRef::IsValid() const { return m_Info[ 0 ].m_pConVar != &s_EmptyConVar; } //----------------------------------------------------------------------------- CGameUiSetActiveSplitScreenPlayerGuard::CGameUiSetActiveSplitScreenPlayerGuard( int slot ) { m_nSaveSlot = engine->GetActiveSplitScreenPlayerSlot(); engine->SetActiveSplitScreenPlayerSlot( slot ); } CGameUiSetActiveSplitScreenPlayerGuard::~CGameUiSetActiveSplitScreenPlayerGuard() { engine->SetActiveSplitScreenPlayerSlot( m_nSaveSlot ); }