1
This commit is contained in:
commit
3bf9df6b27
15370 changed files with 5489726 additions and 0 deletions
public
240
public/UnicodeFileHelpers.cpp
Normal file
240
public/UnicodeFileHelpers.cpp
Normal file
|
@ -0,0 +1,240 @@
|
|||
//========= 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('\"');
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue