X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=simgear%2Fmisc%2Fstrutils.hxx;h=c9aa525c4b4f8389e2983bb84517478cb6a44533;hb=b703102d9b3981d18ccdec9cc3a936408824a202;hp=40c5f7fced9b0720c8e4c93cb9caa67e088933b8;hpb=d498199e8ae54cda37b20965ef5b69bdde464977;p=simgear.git diff --git a/simgear/misc/strutils.hxx b/simgear/misc/strutils.hxx index 40c5f7fc..c9aa525c 100644 --- a/simgear/misc/strutils.hxx +++ b/simgear/misc/strutils.hxx @@ -1,8 +1,11 @@ -// String utilities. -// -// Written by Bernie Bright, 1998 +/** + * \file strutils.hxx + * String utilities. + */ + +// Written by Bernie Bright, started 1998 // -// Copyright (C) 1998 Bernie Bright - bbright@c031.aone.net.au +// Copyright (C) 1998 Bernie Bright - bbright@bigpond.net.au // // This library is free software; you can redistribute it and/or // modify it under the terms of the GNU Library General Public @@ -14,53 +17,146 @@ // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Library General Public License for more details. // -// You should have received a copy of the GNU Library General Public -// License along with this library; if not, write to the -// Free Software Foundation, Inc., 59 Temple Place - Suite 330, -// Boston, MA 02111-1307, USA. +// You should have received a copy of the GNU General Public License +// along with this program; if not, write to the Free Software +// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // // $Id$ + #ifndef STRUTILS_H #define STRUTILS_H #include -#include STL_STRING +#include +#include +#include + +typedef std::vector < std::string > string_list; + +namespace simgear { + namespace strutils { + +// /** +// * atof() wrapper for "string" type +// */ +// inline double +// atof( const string& str ) +// { +// return ::atof( str.c_str() ); +// } + +// /** +// * atoi() wrapper for "string" type +// */ +// inline int +// atoi( const string& str ) +// { +// return ::atoi( str.c_str() ); +// } + + /** + * Strip leading and/or trailing whitespace from s. + * @param s String to strip. + * @return The stripped string. + */ + std::string lstrip( const std::string& s ); + std::string rstrip( const std::string& s ); + std::string strip( const std::string& s ); -#ifdef SG_HAVE_STD_INCLUDES -# include -#else -# include -#endif + /** + * Right-padding of a string to a given length + * @param s String to pad + * @param length The total length of the resulting string + * @param c The character to pad with + * @return The padded string + */ + std::string rpad( const std::string & s, size_t length, char c ); -FG_USING_STD(string); + /** + * Left-padding of a string to a given length + * @param s String to pad + * @param length The total length of the resulting string + * @param c The character to pad with + * @return The padded string + */ + std::string lpad( const std::string & s, size_t length, char c ); -// Default characters to remove. -extern const string whitespace; + /** + * Split a string into a words using 'sep' as the delimiter string. + * Produces a result similar to the perl and python functions of the + * same name. + * + * @param s The string to split into words, + * @param sep Word delimiters. If not specified then any whitespace is a separator, + * @param maxsplit If given, splits at no more than maxsplit places, + * resulting in at most maxsplit+1 words. + * @return Array of words. + */ + string_list + split( const std::string& s, + const char* sep = 0, + int maxsplit = 0 ); -// Returns a string with trailing characters removed. -string trimleft( const string& s, const string& trimmings = whitespace ); + /** + * create a single string by joining the elements of a list with + * another string. + */ + std::string join(const string_list& l, const std::string& joinWith = ""); -// Returns a string with leading characters removed. -string trimright( const string& s, const string& trimmings = whitespace ); + /** + * Test if a string starts with a string + * + * @param s The string to be tested + * @param substr The string to test + * @return True, if s starts with substr, False otherwise + */ + bool starts_with( const std::string & s, const std::string & substr ); -// Returns a string with leading and trailing characters removed. -string trim( const string& s, const string& trimmings = whitespace ); + /** + * Test if a string ends with a string + * + * @param s The string to be tested + * @param substr The string to test + * @return True, if s ends with substr, False otherwise + */ + bool ends_with( const std::string & s, const std::string & substr ); + + /** + * Strip all leading/trailing whitespace, and transform all interal + * whitespace into a single ' ' character - i.e newlines/carriage returns/ + * tabs/multiple spaces will be condensed. + */ + std::string simplify(const std::string& s); + + /** + * convert a string representing a decimal number, to an int + */ + int to_int(const std::string& s, int base = 10); + + /** + * Like strcmp(), but for dotted versions strings NN.NN.NN + * any number of terms are support. + * @return 0 if versions match, -ve number if v1 is lower, +ve if v1 + * is greater + */ + int compare_versions(const std::string& v1, const std::string& v2); -//----------------------------------------------------------------------------- + /** + * Convert a string to upper case. + * @return upper case string + */ + std::string uppercase(const std::string &s); -inline double -atof( const string& str ) -{ - return ::atof( str.c_str() ); -} + /** + * convert a string in the local Windows 8-bit encoding to UTF-8 + * (no-op on other platforms) + */ + std::string convertWindowsLocal8BitToUtf8(const std::string& a); -inline int -atoi( const string& str ) -{ - return ::atoi( str.c_str() ); -} + } // end namespace strutils +} // end namespace simgear #endif // STRUTILS_H