198 lines
5.0 KiB
C++
198 lines
5.0 KiB
C++
/**
|
|
@file stringutils.h
|
|
|
|
@maintainer Morgan McGuire, http://graphics.cs.williams.edu
|
|
|
|
@author 2000-09-09
|
|
@edited 2010-03-05
|
|
*/
|
|
|
|
#ifndef G3D_stringutils_h
|
|
#define G3D_stringutils_h
|
|
|
|
#include "G3D/platform.h"
|
|
#include "G3D/Array.h"
|
|
#include <cstring>
|
|
|
|
namespace G3D {
|
|
|
|
extern const char* NEWLINE;
|
|
|
|
/** Separates a comma-separated line, properly escaping commas within
|
|
double quotes (") and super quotes ("""). This matches Microsoft Excel's
|
|
CSV output.
|
|
|
|
\param stripQuotes If true, strips leading and trailing " and """
|
|
|
|
\sa G3D::stringSplit, G3D::TextInput, G3D::readWholeFile
|
|
*/
|
|
void parseCommaSeparated(const std::string s, Array<std::string>& array, bool stripQuotes = true);
|
|
|
|
/** Finds the index of the first '\\' or '/' character, starting at index \a start.
|
|
\sa G3D::findLastSlash, G3D::isSlash
|
|
*/
|
|
inline size_t findSlash(const std::string& f, size_t start = 0) {
|
|
size_t i = f.find('/', start);
|
|
size_t j = f.find('\\', start);
|
|
if ((i != std::string::npos) && (i < j)) {
|
|
return i;
|
|
} else {
|
|
return j;
|
|
}
|
|
}
|
|
|
|
/** \brief Returns the larger string index, ignoring std::string::npos. */
|
|
inline size_t maxNotNPOS(size_t i, size_t j) {
|
|
if (i == std::string::npos) {
|
|
return j;
|
|
} else if (j == std::string::npos) {
|
|
return i;
|
|
} else {
|
|
return max(i, j);
|
|
}
|
|
}
|
|
|
|
/** Finds the index of the first '\\' or '/' character, starting at index \a start (if \a start is -1, starts at the end of the string).
|
|
\sa G3D::findSlash, G3D::isSlash
|
|
*/
|
|
inline size_t findLastSlash(const std::string& f, size_t start = std::string::npos) {
|
|
if (start == std::string::npos) {
|
|
start = f.length() - 1;
|
|
}
|
|
|
|
size_t i = f.rfind('/', start);
|
|
size_t j = f.rfind('\\', start);
|
|
return maxNotNPOS(i, j);
|
|
}
|
|
|
|
|
|
/** Returns a string which is \a s, with all instances of \a pattern replaced */
|
|
std::string replace(const std::string& s, const std::string& pattern, const std::string& replacement);
|
|
|
|
/** Returns true if \a s is a valid C++ identifier */
|
|
bool isValidIdentifier(const std::string& s);
|
|
|
|
/**
|
|
\brief Returns true if the test string begins with the pattern string.
|
|
*/
|
|
bool beginsWith
|
|
(const std::string& test,
|
|
const std::string& pattern);
|
|
|
|
/**
|
|
\brief Returns true if the test string ends with the pattern string.
|
|
*/
|
|
bool endsWith
|
|
(const std::string& test,
|
|
const std::string& pattern);
|
|
|
|
/**
|
|
\brief Produces a new string that is the input string
|
|
wrapped at a certain number of columns (where
|
|
the line is broken at the latest space before the
|
|
column limit.) Platform specific NEWLINEs
|
|
are inserted to wrap.
|
|
|
|
\sa G3D::GFont::wordWrapCut, G3D::TextOutput::Settings::WordWrapMode
|
|
*/
|
|
std::string wordWrap
|
|
(const std::string& input,
|
|
int numCols);
|
|
|
|
/**
|
|
A comparison function for passing to Array::sort.
|
|
*/
|
|
int stringCompare(
|
|
const std::string& s1,
|
|
const std::string& s2);
|
|
|
|
int stringPtrCompare(
|
|
const std::string* s1,
|
|
const std::string* s2);
|
|
|
|
/**
|
|
Returns a new string that is an uppercase version of x.
|
|
*/
|
|
std::string toUpper(
|
|
const std::string& x);
|
|
|
|
std::string toLower(
|
|
const std::string& x);
|
|
|
|
/**
|
|
Splits x at each occurance of splitChar.
|
|
*/
|
|
G3D::Array<std::string> stringSplit(
|
|
const std::string& x,
|
|
char splitChar);
|
|
|
|
/**
|
|
joinChar is not inserted at the beginning or end, just in between
|
|
elements.
|
|
*/
|
|
std::string stringJoin(
|
|
const G3D::Array<std::string>& a,
|
|
char joinChar);
|
|
|
|
std::string stringJoin(
|
|
const G3D::Array<std::string>& a,
|
|
const std::string& joinStr);
|
|
|
|
/**
|
|
Strips whitespace from both ends of the string.
|
|
*/
|
|
std::string trimWhitespace(
|
|
const std::string& s);
|
|
|
|
/** These standard C functions are renamed for clarity/naming
|
|
conventions and to return bool, not int.
|
|
*/
|
|
inline bool isWhiteSpace(const unsigned char c) {
|
|
return isspace(c) != 0;
|
|
}
|
|
|
|
/** These standard C functions are renamed for clarity/naming
|
|
conventions and to return bool, not int.
|
|
*/
|
|
inline bool isNewline(const unsigned char c) {
|
|
return (c == '\n') || (c == '\r');
|
|
}
|
|
|
|
/** These standard C functions are renamed for clarity/naming
|
|
conventions and to return bool, not int.
|
|
*/
|
|
inline bool isDigit(const unsigned char c) {
|
|
return isdigit(c) != 0;
|
|
}
|
|
|
|
/** These standard C functions are renamed for clarity/naming
|
|
conventions and to return bool, not int.
|
|
*/
|
|
inline bool isLetter(const unsigned char c) {
|
|
return isalpha(c) != 0;
|
|
}
|
|
|
|
inline bool isSlash(const unsigned char c) {
|
|
return (c == '\\') || (c == '/');
|
|
}
|
|
|
|
inline bool isQuote(const unsigned char c) {
|
|
return (c == '\'') || (c == '\"');
|
|
}
|
|
|
|
/** Number of new lines in the given string */
|
|
inline int countNewlines(const std::string& s) {
|
|
int c = 0;
|
|
for (int i = 0; i < (int)s.size(); ++i) {
|
|
if (s[i] == '\n') {
|
|
++c;
|
|
}
|
|
}
|
|
return c;
|
|
}
|
|
|
|
}; // namespace
|
|
|
|
#endif
|
|
|