mirror of
https://github.com/pocoproject/poco.git
synced 2025-04-02 17:50:53 +02:00
[SF 2479446] Extend StringTokenizer interface
This commit is contained in:
parent
66dc4abff0
commit
736cb1fcee
@ -61,7 +61,8 @@ public:
|
|||||||
TOK_TRIM = 2 /// remove leading and trailing whitespace from tokens
|
TOK_TRIM = 2 /// remove leading and trailing whitespace from tokens
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef std::vector<std::string>::const_iterator Iterator;
|
typedef std::vector<std::string> TokenVec;
|
||||||
|
typedef TokenVec::const_iterator Iterator;
|
||||||
|
|
||||||
StringTokenizer(const std::string& str, const std::string& separators, int options = 0);
|
StringTokenizer(const std::string& str, const std::string& separators, int options = 0);
|
||||||
/// Splits the given string into tokens. The tokens are expected to be
|
/// Splits the given string into tokens. The tokens are expected to be
|
||||||
@ -81,22 +82,37 @@ public:
|
|||||||
Iterator end() const;
|
Iterator end() const;
|
||||||
|
|
||||||
const std::string& operator [] (std::size_t index) const;
|
const std::string& operator [] (std::size_t index) const;
|
||||||
/// Returns the index'th token.
|
/// Returns const reference the index'th token.
|
||||||
/// Throws a RangeException if the index is out of range.
|
/// Throws a RangeException if the index is out of range.
|
||||||
|
|
||||||
std::size_t find(const std::string& key, std::size_t pos = 0) const;
|
std::string& operator [] (std::size_t index);
|
||||||
/// Returns the index of the first occurence of the key token
|
/// Returns reference to the index'th token.
|
||||||
|
/// Throws a RangeException if the index is out of range.
|
||||||
|
|
||||||
|
bool has(const std::string& token) const;
|
||||||
|
/// Returns true if token exists, false otherwise.
|
||||||
|
|
||||||
|
std::size_t find(const std::string& token, std::size_t pos = 0) const;
|
||||||
|
/// Returns the index of the first occurence of the token
|
||||||
/// starting at position pos.
|
/// starting at position pos.
|
||||||
/// Throws a NotFoundException if the key is not found.
|
/// Throws a NotFoundException if the token is not found.
|
||||||
|
|
||||||
|
std::size_t replace(const std::string& oldToken, const std::string& newToken, std::size_t pos = 0);
|
||||||
|
/// Starting at position pos, replaces all subsequent tokens having value
|
||||||
|
/// equal to oldToken with newToken.
|
||||||
|
/// Returns the number of modified tokens.
|
||||||
|
|
||||||
std::size_t count() const;
|
std::size_t count() const;
|
||||||
/// Returns the number of tokens.
|
/// Returns the total number of tokens.
|
||||||
|
|
||||||
|
std::size_t count(const std::string& token) const;
|
||||||
|
/// Returns the number of tokens equal to the specified token.
|
||||||
|
|
||||||
private:
|
private:
|
||||||
StringTokenizer(const StringTokenizer&);
|
StringTokenizer(const StringTokenizer&);
|
||||||
StringTokenizer& operator = (const StringTokenizer&);
|
StringTokenizer& operator = (const StringTokenizer&);
|
||||||
|
|
||||||
std::vector<std::string> _tokens;
|
TokenVec _tokens;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@ -117,6 +133,13 @@ inline StringTokenizer::Iterator StringTokenizer::end() const
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
inline std::string& StringTokenizer::operator [] (std::size_t index)
|
||||||
|
{
|
||||||
|
if (index >= _tokens.size()) throw RangeException();
|
||||||
|
return _tokens[index];
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
inline const std::string& StringTokenizer::operator [] (std::size_t index) const
|
inline const std::string& StringTokenizer::operator [] (std::size_t index) const
|
||||||
{
|
{
|
||||||
if (index >= _tokens.size()) throw RangeException();
|
if (index >= _tokens.size()) throw RangeException();
|
||||||
|
@ -83,14 +83,55 @@ StringTokenizer::~StringTokenizer()
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
std::size_t StringTokenizer::find(const std::string& key, std::size_t pos) const
|
bool StringTokenizer::has(const std::string& token) const
|
||||||
|
{
|
||||||
|
Iterator it = begin();
|
||||||
|
Iterator stop = end();
|
||||||
|
for (; it != stop; ++it)
|
||||||
|
if (*it == token) return true;
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
std::size_t StringTokenizer::find(const std::string& token, std::size_t pos) const
|
||||||
{
|
{
|
||||||
Iterator it = begin();
|
Iterator it = begin();
|
||||||
Iterator stop = end();
|
Iterator stop = end();
|
||||||
for (it += pos; it != stop; ++it)
|
for (it += pos; it != stop; ++it)
|
||||||
if (*it == key) return it - begin();
|
if (*it == token) return it - begin();
|
||||||
|
|
||||||
throw NotFoundException(key);
|
throw NotFoundException(token);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
std::size_t StringTokenizer::replace(const std::string& oldToken, const std::string& newToken, std::size_t pos)
|
||||||
|
{
|
||||||
|
std::size_t count = 0;
|
||||||
|
TokenVec::iterator it = _tokens.begin();
|
||||||
|
TokenVec::iterator stop = _tokens.end();
|
||||||
|
for (it += pos; it != stop; ++it)
|
||||||
|
{
|
||||||
|
if (*it == oldToken)
|
||||||
|
{
|
||||||
|
*it = newToken;
|
||||||
|
++count;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return count;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
std::size_t StringTokenizer::count(const std::string& token) const
|
||||||
|
{
|
||||||
|
std::size_t cnt = 0;
|
||||||
|
Iterator it = begin();
|
||||||
|
Iterator stop = end();
|
||||||
|
for (; it != stop; ++it)
|
||||||
|
if (*it == token) ++cnt;
|
||||||
|
|
||||||
|
return cnt;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -346,7 +346,17 @@ void StringTokenizerTest::testStringTokenizer()
|
|||||||
void StringTokenizerTest::testFind()
|
void StringTokenizerTest::testFind()
|
||||||
{
|
{
|
||||||
StringTokenizer st("0,1,2,3,3,2,1,0", ",", StringTokenizer::TOK_TRIM | StringTokenizer::TOK_IGNORE_EMPTY);
|
StringTokenizer st("0,1,2,3,3,2,1,0", ",", StringTokenizer::TOK_TRIM | StringTokenizer::TOK_IGNORE_EMPTY);
|
||||||
|
|
||||||
assert (st.count() == 8);
|
assert (st.count() == 8);
|
||||||
|
assert (2 == st.count("0"));
|
||||||
|
assert (2 == st.count("1"));
|
||||||
|
assert (2 == st.count("2"));
|
||||||
|
assert (2 == st.count("3"));
|
||||||
|
assert (0 == st.count("4"));
|
||||||
|
assert (0 == st.count("5"));
|
||||||
|
assert (0 == st.count("6"));
|
||||||
|
assert (0 == st.count("7"));
|
||||||
|
|
||||||
assert (st[0] == "0");
|
assert (st[0] == "0");
|
||||||
assert (st[1] == "1");
|
assert (st[1] == "1");
|
||||||
assert (st[2] == "2");
|
assert (st[2] == "2");
|
||||||
@ -355,6 +365,16 @@ void StringTokenizerTest::testFind()
|
|||||||
assert (st[5] == "2");
|
assert (st[5] == "2");
|
||||||
assert (st[6] == "1");
|
assert (st[6] == "1");
|
||||||
assert (st[7] == "0");
|
assert (st[7] == "0");
|
||||||
|
|
||||||
|
assert (st.has("0"));
|
||||||
|
assert (st.has("1"));
|
||||||
|
assert (st.has("2"));
|
||||||
|
assert (st.has("3"));
|
||||||
|
assert (!st.has("4"));
|
||||||
|
assert (!st.has("5"));
|
||||||
|
assert (!st.has("6"));
|
||||||
|
assert (!st.has("7"));
|
||||||
|
|
||||||
assert (st.find("0") == 0);
|
assert (st.find("0") == 0);
|
||||||
assert (st.find("1") == 1);
|
assert (st.find("1") == 1);
|
||||||
assert (st.find("2") == 2);
|
assert (st.find("2") == 2);
|
||||||
@ -378,6 +398,21 @@ void StringTokenizerTest::testFind()
|
|||||||
fail ("must fail");
|
fail ("must fail");
|
||||||
}
|
}
|
||||||
catch (RangeException&) { }
|
catch (RangeException&) { }
|
||||||
|
|
||||||
|
st[0] = "1";
|
||||||
|
st[7] = "1";
|
||||||
|
assert (st[0] == "1");
|
||||||
|
assert (st[7] == "1");
|
||||||
|
assert (0 == st.count("0"));
|
||||||
|
assert (4 == st.count("1"));
|
||||||
|
|
||||||
|
st.replace("2", "5");
|
||||||
|
assert (0 == st.count("2"));
|
||||||
|
assert (2 == st.count("5"));
|
||||||
|
|
||||||
|
st.replace("3", "6", 4);
|
||||||
|
assert (1 == st.count("3"));
|
||||||
|
assert (1 == st.count("6"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user