44 lines
1.4 KiB
C
44 lines
1.4 KiB
C
|
//===== Copyright <20> 1996-2005, Valve Corporation, All rights reserved. ======//
|
|||
|
//
|
|||
|
// Purpose: Shared code for parsing / searching for characters in a string
|
|||
|
// using lookup tables
|
|||
|
//
|
|||
|
// $Workfile: $
|
|||
|
// $Date: $
|
|||
|
// $NoKeywords: $
|
|||
|
//===========================================================================//
|
|||
|
|
|||
|
#ifndef CHARACTERSET_H
|
|||
|
#define CHARACTERSET_H
|
|||
|
|
|||
|
#ifdef _WIN32
|
|||
|
#pragma once
|
|||
|
#endif
|
|||
|
|
|||
|
|
|||
|
struct characterset_t
|
|||
|
{
|
|||
|
char set[256];
|
|||
|
};
|
|||
|
|
|||
|
|
|||
|
// This is essentially a strpbrk() using a precalculated lookup table
|
|||
|
//-----------------------------------------------------------------------------
|
|||
|
// Purpose: builds a simple lookup table of a group of important characters
|
|||
|
// Input : *pSetBuffer - pointer to the buffer for the group
|
|||
|
// *pSetString - list of characters to flag
|
|||
|
//-----------------------------------------------------------------------------
|
|||
|
extern void CharacterSetBuild( characterset_t *pSetBuffer, const char *pSetString );
|
|||
|
|
|||
|
|
|||
|
//-----------------------------------------------------------------------------
|
|||
|
// Purpose:
|
|||
|
// Input : *pSetBuffer - pre-build group buffer
|
|||
|
// character - character to lookup
|
|||
|
// Output : int - 1 if the character was in the set
|
|||
|
//-----------------------------------------------------------------------------
|
|||
|
#define IN_CHARACTERSET( SetBuffer, character ) ((SetBuffer).set[(unsigned char)(character)])
|
|||
|
|
|||
|
|
|||
|
#endif // CHARACTERSET_H
|