You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
240 lines
4.8 KiB
240 lines
4.8 KiB
//========= Copyright Valve Corporation, All rights reserved. ============// |
|
// |
|
// Purpose: |
|
// |
|
//=============================================================================// |
|
|
|
#include <stdlib.h> |
|
#include <ctype.h> |
|
#include "utlbuffer.h" |
|
|
|
// memdbgon must be the last include file in a .cpp file!!! |
|
#include "tier0/memdbgon.h" |
|
|
|
//----------------------------------------------------------------------------- |
|
// Purpose: Advances until non-whitespace hit |
|
//----------------------------------------------------------------------------- |
|
ucs2 *AdvanceOverWhitespace(ucs2 *Start) |
|
{ |
|
while (*Start != 0 && iswspace(*Start)) |
|
{ |
|
Start++; |
|
} |
|
|
|
return Start; |
|
} |
|
|
|
//----------------------------------------------------------------------------- |
|
// Purpose: |
|
//----------------------------------------------------------------------------- |
|
ucs2 *ReadUnicodeToken(ucs2 *start, ucs2 *token, int tokenBufferSize, bool "ed) |
|
{ |
|
// skip over any whitespace |
|
start = AdvanceOverWhitespace(start); |
|
quoted = false; |
|
*token = 0; |
|
|
|
if (!*start) |
|
{ |
|
return start; |
|
} |
|
|
|
// check to see if it's a quoted string |
|
if (*start == '\"') |
|
{ |
|
quoted = true; |
|
// copy out the string until we hit an end quote |
|
start++; |
|
int count = 0; |
|
while (*start && *start != '\"' && count < tokenBufferSize-1) |
|
{ |
|
// check for special characters |
|
if (*start == '\\' && *(start+1) == 'n') |
|
{ |
|
start++; |
|
*token = '\n'; |
|
} |
|
else if (*start == '\\' && *(start+1) == '\"') |
|
{ |
|
start++; |
|
*token = '\"'; |
|
} |
|
else |
|
{ |
|
*token = *start; |
|
} |
|
|
|
start++; |
|
token++; |
|
count++; |
|
} |
|
|
|
if (*start == '\"') |
|
{ |
|
start++; |
|
} |
|
} |
|
else |
|
{ |
|
// copy out the string until we hit a whitespace |
|
int count = 0; |
|
while (*start && !iswspace(*start) && count < tokenBufferSize-1) |
|
{ |
|
// no checking for special characters if it's not a quoted string |
|
*token = *start; |
|
|
|
start++; |
|
token++; |
|
count++; |
|
} |
|
} |
|
|
|
*token = 0; |
|
return start; |
|
} |
|
|
|
//----------------------------------------------------------------------------- |
|
// Purpose: Same as above but no translation of \n |
|
//----------------------------------------------------------------------------- |
|
ucs2 *ReadUnicodeTokenNoSpecial(ucs2 *start, ucs2 *token, int tokenBufferSize, bool "ed) |
|
{ |
|
// skip over any whitespace |
|
start = AdvanceOverWhitespace(start); |
|
quoted = false; |
|
*token = 0; |
|
|
|
if (!*start) |
|
{ |
|
return start; |
|
} |
|
|
|
// check to see if it's a quoted string |
|
if (*start == '\"') |
|
{ |
|
quoted = true; |
|
// copy out the string until we hit an end quote |
|
start++; |
|
int count = 0; |
|
while (*start && *start != '\"' && count < tokenBufferSize-1) |
|
{ |
|
// check for special characters |
|
/* |
|
if (*start == '\\' && *(start+1) == 'n') |
|
{ |
|
start++; |
|
*token = '\n'; |
|
} |
|
else |
|
*/ |
|
if (*start == '\\' && *(start+1) == '\"') |
|
{ |
|
start++; |
|
*token = '\"'; |
|
} |
|
else |
|
{ |
|
*token = *start; |
|
} |
|
|
|
start++; |
|
token++; |
|
count++; |
|
} |
|
|
|
if (*start == '\"') |
|
{ |
|
start++; |
|
} |
|
} |
|
else |
|
{ |
|
// copy out the string until we hit a whitespace |
|
int count = 0; |
|
while (*start && !iswspace(*start) && count < tokenBufferSize-1) |
|
{ |
|
// no checking for special characters if it's not a quoted string |
|
*token = *start; |
|
|
|
start++; |
|
token++; |
|
count++; |
|
} |
|
} |
|
|
|
*token = 0; |
|
return start; |
|
} |
|
|
|
//----------------------------------------------------------------------------- |
|
// Purpose: Returns the first character after the next EOL characters |
|
//----------------------------------------------------------------------------- |
|
ucs2 *ReadToEndOfLine(ucs2 *start) |
|
{ |
|
if (!*start) |
|
return start; |
|
|
|
while (*start) |
|
{ |
|
if (*start == 0x0D || *start== 0x0A) |
|
break; |
|
start++; |
|
} |
|
|
|
while (*start == 0x0D || *start== 0x0A) |
|
start++; |
|
|
|
return start; |
|
} |
|
|
|
//----------------------------------------------------------------------------- |
|
// Purpose: file writing |
|
//----------------------------------------------------------------------------- |
|
void WriteUnicodeString(CUtlBuffer &buf, const wchar_t *string, bool addQuotes) |
|
{ |
|
if (addQuotes) |
|
{ |
|
buf.PutUnsignedShort('\"'); |
|
} |
|
|
|
for (const wchar_t *ws = string; *ws != 0; ws++) |
|
{ |
|
// handle special characters |
|
if (addQuotes && *ws == '\"') |
|
{ |
|
buf.PutUnsignedShort('\\'); |
|
} |
|
// write the character |
|
buf.PutUnsignedShort(*ws); |
|
} |
|
|
|
if (addQuotes) |
|
{ |
|
buf.PutUnsignedShort('\"'); |
|
} |
|
} |
|
|
|
//----------------------------------------------------------------------------- |
|
// Purpose: file writing |
|
//----------------------------------------------------------------------------- |
|
void WriteAsciiStringAsUnicode(CUtlBuffer &buf, const char *string, bool addQuotes) |
|
{ |
|
if (addQuotes) |
|
{ |
|
buf.PutUnsignedShort('\"'); |
|
} |
|
|
|
for (const char *sz = string; *sz != 0; sz++) |
|
{ |
|
// handle special characters |
|
if (addQuotes && *sz == '\"') |
|
{ |
|
buf.PutUnsignedShort('\\'); |
|
} |
|
buf.PutUnsignedShort(*sz); |
|
} |
|
|
|
if (addQuotes) |
|
{ |
|
buf.PutUnsignedShort('\"'); |
|
} |
|
}
|
|
|