From 39ed87570bdb2f86969d4be821c94b722dc71179 Mon Sep 17 00:00:00 2001 From: Joe Ludwig Date: Wed, 26 Jun 2013 15:22:04 -0700 Subject: First version of the SOurce SDK 2013 --- mp/src/public/stringregistry.cpp | 145 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 145 insertions(+) create mode 100644 mp/src/public/stringregistry.cpp (limited to 'mp/src/public/stringregistry.cpp') diff --git a/mp/src/public/stringregistry.cpp b/mp/src/public/stringregistry.cpp new file mode 100644 index 00000000..beaf3767 --- /dev/null +++ b/mp/src/public/stringregistry.cpp @@ -0,0 +1,145 @@ +//========= Copyright Valve Corporation, All rights reserved. ============// +// +// Purpose: A registry of strings and associated ints +// +// $Workfile: $ +// $Date: $ +// +//----------------------------------------------------------------------------- +// $Log: $ +// +// $NoKeywords: $ +//=============================================================================// + + +#include +#include +#include "stringregistry.h" +#include "utldict.h" + +// memdbgon must be the last include file in a .cpp file!!! +#include "tier0/memdbgon.h" + +#if !defined(_STATIC_LINKED) || defined(CLIENT_DLL) + +//----------------------------------------------------------------------------- +// Purpose: This class wraps the containers that do the actual work +//----------------------------------------------------------------------------- +struct StringTable_t : public CUtlDict +{ +}; + + + +//----------------------------------------------------------------------------- +// Purpose: Add null terminated string to the string registry +// Input : +// Output : +//----------------------------------------------------------------------------- +unsigned short CStringRegistry::AddString(const char *stringText, int stringID) +{ + return m_pStringList->Insert( stringText, stringID ); +} + +//----------------------------------------------------------------------------- +// Purpose: Given string text get the string ID +// Input : Text of string to find +// Output : Return string id or -1 if no such string exists +//----------------------------------------------------------------------------- +int CStringRegistry::GetStringID( const char *stringText ) +{ + unsigned short index = m_pStringList->Find( stringText ); + if ( m_pStringList->IsValidIndex( index ) ) + { + return (*m_pStringList)[index]; + } + + return -1; +} + +//----------------------------------------------------------------------------- +// Purpose: Given a string ID return the string text +// Input : ID of string to find +// Output : Return string text of NULL of no such ID exists +//----------------------------------------------------------------------------- +char const *CStringRegistry::GetStringText( int stringID ) +{ + for( unsigned short index = m_pStringList->First() ; index != m_pStringList->InvalidIndex(); index = m_pStringList->Next( index ) ) + { + if ( (*m_pStringList)[index] == stringID ) + { + return m_pStringList->GetElementName( index ); + } + } + + return NULL; +} + + +//----------------------------------------------------------------------------- +// Purpose: Given a key return the string text +//----------------------------------------------------------------------------- +char const *CStringRegistry::GetStringForKey( unsigned short key ) +{ + if ( !m_pStringList->IsValidIndex( key ) ) + return NULL; + + return m_pStringList->GetElementName( key ); +} + +//----------------------------------------------------------------------------- +// Purpose: Given a key return the string text +//----------------------------------------------------------------------------- +int CStringRegistry::GetIDForKey( unsigned short key ) +{ + if ( !m_pStringList->IsValidIndex( key ) ) + return 0; + + return (*m_pStringList)[key]; +} + +//----------------------------------------------------------------------------- +// Purpose: Clear all strings from the string registry +//----------------------------------------------------------------------------- +void CStringRegistry::ClearStrings(void) +{ + m_pStringList->RemoveAll(); +} + +//----------------------------------------------------------------------------- +// Purpose: Destructor - delete the list of strings and maps +// Input : +// Output : +//----------------------------------------------------------------------------- +CStringRegistry::~CStringRegistry(void) +{ + delete m_pStringList; +} + +//----------------------------------------------------------------------------- +// Purpose: Constructor +// Input : +// Output : +//----------------------------------------------------------------------------- +CStringRegistry::CStringRegistry(void) +{ + m_pStringList = new StringTable_t; +} + + +unsigned short CStringRegistry::First() const +{ + return m_pStringList->First(); +} + +unsigned short CStringRegistry::Next( unsigned short key ) const +{ + return m_pStringList->Next( key ); +} + +unsigned short CStringRegistry::InvalidIndex() const +{ + return m_pStringList->InvalidIndex(); +} + +#endif // _STATIC_LINKED && CLIENT_DLL -- cgit v1.2.3