Pyrogenesis trunk
|
A input token. More...
#include <OgreGLSLPreprocessor.h>
Public Types | |
enum | Kind { TK_EOS , TK_ERROR , TK_WHITESPACE , TK_NEWLINE , TK_LINECONT , TK_NUMBER , TK_KEYWORD , TK_PUNCTUATION , TK_DIRECTIVE , TK_STRING , TK_COMMENT , TK_LINECOMMENT , TK_TEXT } |
Public Member Functions | |
Token () | |
Token (Kind iType) | |
Token (Kind iType, const char *iString, size_t iLength) | |
Token (const Token &iOther) | |
~Token () | |
Token & | operator= (const Token &iOther) |
Assignment operator. More... | |
void | Append (const char *iString, size_t iLength) |
Append a string to this token. More... | |
void | Append (const Token &iOther) |
Append a token to this token. More... | |
void | AppendNL (int iCount) |
Append given number of newlines to this token. More... | |
int | CountNL () |
Count number of newlines in this token. More... | |
bool | GetValue (long &oValue) const |
Get the numeric value of the token. More... | |
void | SetValue (long iValue) |
Set the numeric value of the token. More... | |
bool | operator== (const Token &iOther) |
Test two tokens for equality. More... | |
Public Attributes | |
Kind | Type |
Token type. More... | |
size_t | Allocated |
True if string was allocated (and must be freed) More... | |
union { | |
const char * String | |
A pointer somewhere into the input buffer. More... | |
char * Buffer | |
A memory-allocated string. More... | |
}; | |
size_t | Length |
Token length in bytes. More... | |
A input token.
For performance reasons most tokens will point to portions of the input stream, so no unneeded memory allocation is done. However, in some cases we must allocate different memory for token storage, in this case this is signalled by setting the Allocated member to non-zero in which case the destructor will know that it must free memory on object destruction.
Again for performance reasons we use malloc/realloc/free here because C++-style new[] lacks the realloc() counterpart.
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
void Ogre::CPreprocessor::Token::Append | ( | const char * | iString, |
size_t | iLength | ||
) |
Append a string to this token.
void Ogre::CPreprocessor::Token::Append | ( | const Token & | iOther | ) |
Append a token to this token.
void Ogre::CPreprocessor::Token::AppendNL | ( | int | iCount | ) |
Append given number of newlines to this token.
int Ogre::CPreprocessor::Token::CountNL | ( | ) |
Count number of newlines in this token.
bool Ogre::CPreprocessor::Token::GetValue | ( | long & | oValue | ) | const |
Get the numeric value of the token.
|
inline |
Test two tokens for equality.
void Ogre::CPreprocessor::Token::SetValue | ( | long | iValue | ) |
Set the numeric value of the token.
union { ... } Ogre::CPreprocessor::Token::@54 |
|
mutable |
True if string was allocated (and must be freed)
char* Ogre::CPreprocessor::Token::Buffer |
A memory-allocated string.
size_t Ogre::CPreprocessor::Token::Length |
Token length in bytes.
const char* Ogre::CPreprocessor::Token::String |
A pointer somewhere into the input buffer.