2003-04-26 18:12:47 +00:00
|
|
|
// StringUtil.hh for fluxbox
|
2006-02-16 06:53:05 +00:00
|
|
|
// Copyright (c) 2001 - 2006 Henrik Kinnunen (fluxgen at fluxbox dot org)
|
2003-04-26 18:12:47 +00:00
|
|
|
//
|
|
|
|
// Permission is hereby granted, free of charge, to any person obtaining a
|
|
|
|
// copy of this software and associated documentation files (the "Software"),
|
|
|
|
// to deal in the Software without restriction, including without limitation
|
|
|
|
// the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
|
|
|
// and/or sell copies of the Software, and to permit persons to whom the
|
|
|
|
// Software is furnished to do so, subject to the following conditions:
|
|
|
|
//
|
|
|
|
// The above copyright notice and this permission notice shall be included in
|
|
|
|
// all copies or substantial portions of the Software.
|
|
|
|
//
|
|
|
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
|
|
|
// THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
|
|
|
// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
|
|
|
// DEALINGS IN THE SOFTWARE.
|
|
|
|
|
|
|
|
#ifndef FBTK_STRINGUTIL_HH
|
|
|
|
#define FBTK_STRINGUTIL_HH
|
|
|
|
|
|
|
|
#include <string>
|
|
|
|
|
2007-12-28 09:19:33 +00:00
|
|
|
#include "stringstream.hh"
|
|
|
|
|
2003-04-26 18:12:47 +00:00
|
|
|
namespace FbTk {
|
|
|
|
|
|
|
|
namespace StringUtil {
|
|
|
|
|
2009-10-01 19:16:46 +00:00
|
|
|
/// \@{
|
|
|
|
/// @param in - input string, might be 0xab or 0123
|
|
|
|
/// @param out - result if extraction was ok
|
|
|
|
/// @return 1 - ok, result stored in 'out'
|
|
|
|
int extractNumber(const std::string& in, unsigned int& out);
|
|
|
|
int extractNumber(const std::string& in, int& out);
|
|
|
|
/// \@}
|
|
|
|
|
2009-10-01 06:57:31 +00:00
|
|
|
/// creates a number to a string
|
|
|
|
std::string number2String(int num);
|
2004-09-10 16:04:16 +00:00
|
|
|
|
2003-04-26 18:12:47 +00:00
|
|
|
/// Similar to `strstr' but this function ignores the case of both strings
|
|
|
|
const char *strcasestr(const char *str, const char *ptn);
|
|
|
|
|
|
|
|
/// expands ~ to value of ${HOME} enviroment variable
|
|
|
|
std::string expandFilename(const std::string &filename);
|
2004-05-02 20:42:56 +00:00
|
|
|
|
2003-08-22 19:37:07 +00:00
|
|
|
/// @return extension of filename (ex: filename.txt will return txt)
|
|
|
|
std::string findExtension(const std::string &filename);
|
2003-04-26 18:12:47 +00:00
|
|
|
|
2010-08-24 15:30:24 +00:00
|
|
|
/// is the char after a 'trigger' part of an alphabet?
|
|
|
|
/// @param in - string to analyze
|
|
|
|
/// @param trigger - check for char after trigger
|
|
|
|
/// @param alphabet - contains chars to search for
|
|
|
|
/// @param len_alphabet - length of alphabet
|
|
|
|
/// @param found - position of found char in alphabet (optional)
|
|
|
|
/// @return position of trigger if found
|
|
|
|
/// @return std::string::npos if nothing found
|
|
|
|
std::string::size_type findCharFromAlphabetAfterTrigger(const std::string& in,
|
|
|
|
char trigger,
|
|
|
|
const char alphabet[], size_t len_alphabet, size_t* found);
|
|
|
|
|
2005-10-20 14:48:53 +00:00
|
|
|
/// @return copy of original with find_string replaced with "replace"
|
|
|
|
std::string replaceString(const std::string &original,
|
|
|
|
const char *find_string,
|
|
|
|
const char *replace);
|
2005-10-21 19:23:57 +00:00
|
|
|
|
2003-04-26 18:12:47 +00:00
|
|
|
/// returns string between character first and last
|
2004-09-10 16:04:16 +00:00
|
|
|
int getStringBetween(std::string& out, const char *instr,
|
2003-04-26 18:12:47 +00:00
|
|
|
char first, char last,
|
2003-06-12 15:14:03 +00:00
|
|
|
const char *ok_chars=" \t\n", bool allow_nesting = false);
|
2003-04-26 18:12:47 +00:00
|
|
|
|
2003-08-22 19:37:07 +00:00
|
|
|
/// @return lower case letters of conv
|
2003-07-01 01:49:13 +00:00
|
|
|
std::string toLower(const std::string &conv);
|
2003-08-22 19:37:07 +00:00
|
|
|
/// @return upper case letters of conv
|
|
|
|
std::string toUpper(const std::string &conv);
|
2003-08-22 22:11:19 +00:00
|
|
|
#ifdef basename
|
|
|
|
#undef basename
|
|
|
|
#endif // basename
|
|
|
|
std::string basename(const std::string &basename);
|
2003-04-26 18:12:47 +00:00
|
|
|
|
2003-09-29 14:01:48 +00:00
|
|
|
|
|
|
|
/// removes the first whitespace characters of the string
|
|
|
|
std::string::size_type removeFirstWhitespace(std::string &str);
|
2003-10-25 22:06:53 +00:00
|
|
|
std::string::size_type removeTrailingWhitespace(std::string &str);
|
2003-09-29 14:01:48 +00:00
|
|
|
|
2007-12-14 20:05:14 +00:00
|
|
|
/// splits input at first non-leading whitespace and returns both parts
|
2007-12-13 05:48:00 +00:00
|
|
|
void getFirstWord(const std::string &in, std::string &first, std::string &rest);
|
|
|
|
|
2007-12-28 09:19:33 +00:00
|
|
|
template <typename T>
|
|
|
|
void fromString(const char *in, T &out) {
|
|
|
|
FbTk_istringstream iss(in);
|
|
|
|
iss >> out;
|
|
|
|
}
|
|
|
|
|
2007-12-20 20:23:56 +00:00
|
|
|
template <typename Container>
|
|
|
|
static void stringTokensBetween(Container &container, const std::string &in,
|
|
|
|
std::string &rest, char first, char last,
|
|
|
|
const char *ok_chars = " \t\n", bool allow_nesting = true) {
|
|
|
|
|
|
|
|
std::string token;
|
|
|
|
int err = 0, pos = 0;
|
|
|
|
|
|
|
|
while (true) {
|
|
|
|
err = getStringBetween(token, in.c_str() + pos, first, last, ok_chars,
|
|
|
|
allow_nesting);
|
2009-04-06 21:25:01 +00:00
|
|
|
if (err <= 0)
|
2007-12-20 20:23:56 +00:00
|
|
|
break;
|
|
|
|
container.push_back(token);
|
|
|
|
pos += err;
|
|
|
|
}
|
|
|
|
|
|
|
|
rest = in.c_str() + pos;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2003-04-26 18:12:47 +00:00
|
|
|
/// Breaks a string into tokens
|
|
|
|
template <typename Container>
|
|
|
|
static void
|
|
|
|
stringtok (Container &container, std::string const &in,
|
|
|
|
const char * const delimiters = " \t\n") {
|
|
|
|
|
|
|
|
const std::string::size_type len = in.length();
|
|
|
|
std::string::size_type i = 0;
|
|
|
|
|
|
|
|
while ( i < len ) {
|
|
|
|
// eat leading whitespace
|
|
|
|
i = in.find_first_not_of(delimiters, i);
|
|
|
|
if (i == std::string::npos)
|
|
|
|
return; // nothing left but white space
|
|
|
|
|
|
|
|
// find the end of the token
|
|
|
|
std::string::size_type j = in.find_first_of(delimiters, i);
|
|
|
|
|
|
|
|
// push token
|
|
|
|
if (j == std::string::npos) {
|
|
|
|
container.push_back(in.substr(i));
|
|
|
|
return;
|
|
|
|
} else
|
|
|
|
container.push_back(in.substr(i, j-i));
|
|
|
|
|
|
|
|
// set up for next loop
|
|
|
|
i = j + 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2003-12-16 17:06:52 +00:00
|
|
|
} // end namespace StringUtil
|
2003-04-26 18:12:47 +00:00
|
|
|
|
2003-12-16 17:06:52 +00:00
|
|
|
} // end namespace FbTk
|
2003-04-26 18:12:47 +00:00
|
|
|
|
|
|
|
|
|
|
|
#endif // FBTK_STRINGUTIL_HH
|