libcruft-util/string.cpp

117 lines
3.0 KiB
C++
Raw Normal View History

2011-08-12 00:25:59 +10:00
/*
2015-04-13 18:05:28 +10:00
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
2011-08-12 00:25:59 +10:00
*
2015-04-13 18:05:28 +10:00
* http://www.apache.org/licenses/LICENSE-2.0
2011-08-12 00:25:59 +10:00
*
2015-04-13 18:05:28 +10:00
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
2011-08-12 00:25:59 +10:00
*
2016-03-17 18:13:19 +11:00
* Copyright 2011-2016 Danny Robson <danny@nerdcruft.net>
2011-08-12 00:25:59 +10:00
*/
#include "./string.hpp"
2011-08-12 00:25:59 +10:00
#include <cstring>
2013-08-05 16:41:20 +10:00
2016-03-17 18:13:19 +11:00
using util::tokeniser;
///////////////////////////////////////////////////////////////////////////////
2011-08-12 00:25:59 +10:00
// TODO: Horribly inefficient, but God help you if you're relying on this
// being efficient in the first place.
bool
strbegins (const char *restrict str,
const char *restrict prefix) {
return 0 == strncmp (prefix, str, strlen (prefix));
}
2016-03-17 18:13:19 +11:00
///////////////////////////////////////////////////////////////////////////////
tokeniser::tokeniser (const string_type &_value,
value_type _separator):
m_value (_value),
m_separator (_separator)
{ }
//-----------------------------------------------------------------------------
tokeniser::iterator
tokeniser::cbegin (void) const
{
return iterator (
{m_value.cbegin (), m_value.cend ()},
m_separator
);
}
//-----------------------------------------------------------------------------
tokeniser::iterator
tokeniser::cend (void) const
{
return iterator (
{m_value.cend (), m_value.cend ()},
m_separator
);
}
///////////////////////////////////////////////////////////////////////////////
tokeniser::iterator::iterator (range_type _range, value_type _separator):
m_separator (_separator),
m_range (_range.cbegin (),
std::find (_range.cbegin (),
_range.cend (),
_separator)),
m_end (_range.cend ())
{ }
//-----------------------------------------------------------------------------
tokeniser::iterator
tokeniser::iterator::operator++ (int)
{
iterator res(*this);
++*this;
return res;
}
//-----------------------------------------------------------------------------
tokeniser::iterator&
tokeniser::iterator::operator++ (void)
{
auto newend = m_range.cend ();
if (newend != m_end) {
CHECK_EQ (*m_range.cend (), m_separator);
newend++;
}
m_range = {
newend,
std::find (newend, m_end, m_separator)
};
return *this;
}
//-----------------------------------------------------------------------------
tokeniser::iterator::range_type
tokeniser::iterator::operator* (void) const
{
return m_range;
}
//-----------------------------------------------------------------------------
bool
tokeniser::iterator::operator== (const iterator &rhs) const
{
return m_range == rhs.m_range && m_separator == rhs.m_separator;
}