2012-06-14 09:06:06 -04:00
|
|
|
|
|
|
|
// StringUtils.h
|
|
|
|
|
|
|
|
// Interfaces to various string helper functions
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#ifndef STRINGUTILS_H_INCLUDED
|
|
|
|
#define STRINGUTILS_H_INCLUDED
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
typedef std::string AString;
|
|
|
|
typedef std::vector<AString> AStringVector;
|
|
|
|
typedef std::list<AString> AStringList;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2014-01-16 02:34:10 -05:00
|
|
|
/** Add the formated string to the existing data in the string */
|
|
|
|
extern AString & AppendVPrintf(AString & str, const char * format, va_list args);
|
2012-06-14 09:06:06 -04:00
|
|
|
|
|
|
|
/// Output the formatted text into the string
|
|
|
|
extern AString & Printf (AString & str, const char * format, ...);
|
|
|
|
|
2012-11-15 05:58:46 -05:00
|
|
|
/// Output the formatted text into string, return string by value
|
|
|
|
extern AString Printf(const char * format, ...);
|
|
|
|
|
2012-06-14 09:06:06 -04:00
|
|
|
/// Add the formatted string to the existing data in the string
|
|
|
|
extern AString & AppendPrintf (AString & str, const char * format, ...);
|
|
|
|
|
2013-05-01 13:02:09 -04:00
|
|
|
/// Split the string at any of the listed delimiters, return as a stringvector
|
2012-06-14 09:06:06 -04:00
|
|
|
extern AStringVector StringSplit(const AString & str, const AString & delim);
|
|
|
|
|
2013-05-01 13:02:09 -04:00
|
|
|
/// Split the string at any of the listed delimiters and trim each value, return as a stringvector
|
2013-03-14 05:52:57 -04:00
|
|
|
extern AStringVector StringSplitAndTrim(const AString & str, const AString & delim);
|
|
|
|
|
2012-06-14 09:06:06 -04:00
|
|
|
/// Trime whitespace at both ends of the string
|
2013-07-07 10:42:07 -04:00
|
|
|
extern AString TrimString(const AString & str); // tolua_export
|
2012-06-14 09:06:06 -04:00
|
|
|
|
|
|
|
/// In-place string conversion to uppercase; returns the same string
|
|
|
|
extern AString & StrToUpper(AString & s);
|
|
|
|
|
2013-09-30 13:59:40 -04:00
|
|
|
/// In-place string conversion to lowercase; returns the same string
|
|
|
|
extern AString & StrToLower(AString & s);
|
|
|
|
|
2012-06-14 09:06:06 -04:00
|
|
|
/// Case-insensitive string comparison; returns 0 if the strings are the same
|
2013-07-07 10:42:07 -04:00
|
|
|
extern int NoCaseCompare(const AString & s1, const AString & s2); // tolua_export
|
2012-06-14 09:06:06 -04:00
|
|
|
|
2012-08-22 19:05:12 -04:00
|
|
|
/// Case-insensitive string comparison that returns a rating of equal-ness between [0 - s1.length()]
|
|
|
|
extern unsigned int RateCompareString(const AString & s1, const AString & s2 );
|
|
|
|
|
2012-06-14 09:06:06 -04:00
|
|
|
/// Replaces *each* occurence of iNeedle in iHayStack with iReplaceWith
|
2013-07-07 10:42:07 -04:00
|
|
|
extern void ReplaceString(AString & iHayStack, const AString & iNeedle, const AString & iReplaceWith); // tolua_export
|
2012-06-14 09:06:06 -04:00
|
|
|
|
2012-08-17 06:18:07 -04:00
|
|
|
/// Converts a stream of BE shorts into UTF-8 string; returns a ref to a_UTF8
|
|
|
|
extern AString & RawBEToUTF8(short * a_RawData, int a_NumShorts, AString & a_UTF8);
|
|
|
|
|
2012-08-28 17:59:49 -04:00
|
|
|
/// Converts a UTF-8 string into a UTF-16 BE string, packing that back into AString; return a ref to a_UTF16
|
|
|
|
extern AString & UTF8ToRawBEUTF16(const char * a_UTF8, size_t a_UTF8Length, AString & a_UTF16);
|
|
|
|
|
2012-09-02 05:04:11 -04:00
|
|
|
/// Creates a nicely formatted HEX dump of the given memory block. Max a_BytesPerLine is 120
|
|
|
|
extern AString & CreateHexDump(AString & a_Out, const void * a_Data, int a_Size, int a_BytesPerLine);
|
2012-06-14 09:06:06 -04:00
|
|
|
|
2013-07-07 10:13:43 -04:00
|
|
|
/// Returns a copy of a_Message with all quotes and backslashes escaped by a backslash
|
2013-07-07 10:42:07 -04:00
|
|
|
extern AString EscapeString(const AString & a_Message); // tolua_export
|
|
|
|
|
|
|
|
/// Removes all control codes used by MC for colors and styles
|
|
|
|
extern AString StripColorCodes(const AString & a_Message); // tolua_export
|
2013-07-07 10:13:43 -04:00
|
|
|
|
2013-09-28 13:28:19 -04:00
|
|
|
/// URL-Decodes the given string, replacing all "%HH" into the correct characters. Invalid % sequences are left intact
|
|
|
|
extern AString URLDecode(const AString & a_String); // Cannot export to Lua automatically - would generated an extra return value
|
|
|
|
|
|
|
|
/// Replaces all occurrences of char a_From inside a_String with char a_To.
|
|
|
|
extern AString ReplaceAllCharOccurrences(const AString & a_String, char a_From, char a_To); // Needn't export to Lua, since Lua doesn't have chars anyway
|
|
|
|
|
2013-10-04 14:28:30 -04:00
|
|
|
/// Decodes a Base64-encoded string into the raw data
|
|
|
|
extern AString Base64Decode(const AString & a_Base64String);
|
|
|
|
|
2014-01-07 06:36:36 -05:00
|
|
|
/// Encodes a string into Base64
|
|
|
|
extern AString Base64Encode(const AString & a_Input);
|
|
|
|
|
2014-01-02 11:33:18 -05:00
|
|
|
/// Reads two bytes from the specified memory location and interprets them as BigEndian short
|
|
|
|
extern short GetBEShort(const char * a_Mem);
|
|
|
|
|
|
|
|
/// Reads four bytes from the specified memory location and interprets them as BigEndian int
|
|
|
|
extern int GetBEInt(const char * a_Mem);
|
|
|
|
|
|
|
|
/// Writes four bytes to the specified memory location so that they interpret as BigEndian int
|
|
|
|
extern void SetBEInt(char * a_Mem, Int32 a_Value);
|
|
|
|
|
2012-06-14 09:06:06 -04:00
|
|
|
// If you have any other string helper functions, declare them here
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#endif // STRINGUTILS_H_INCLUDED
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|