icinga2/lib/base/qstring.cpp

352 lines
7.5 KiB
C++
Raw Normal View History

2012-09-17 13:35:55 +02:00
/******************************************************************************
* Icinga 2 *
2014-01-09 00:32:11 +01:00
* Copyright (C) 2012-present Icinga Development Team (http://www.icinga.org) *
2012-09-17 13:35:55 +02:00
* *
* This program is free software; you can redistribute it and/or *
* modify it under the terms of the GNU General Public License *
* as published by the Free Software Foundation; either version 2 *
* of the License, or (at your option) any later version. *
* *
* This program is distributed in the hope that it will be useful, *
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
* GNU General Public License for more details. *
* *
* 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 St, Fifth Floor, Boston, MA 02110-1301, USA. *
******************************************************************************/
2013-03-16 21:18:53 +01:00
#include "base/qstring.h"
#include "base/value.h"
2013-03-15 18:21:29 +01:00
#include <boost/algorithm/string/trim.hpp>
#include <boost/algorithm/string/join.hpp>
#include <boost/algorithm/string/compare.hpp>
2013-12-17 12:19:29 +01:00
#include <boost/algorithm/string/predicate.hpp>
#include <boost/algorithm/string/classification.hpp>
using namespace icinga;
const size_t String::NPos = std::string::npos;
String::String(void)
2012-08-03 13:19:55 +02:00
: m_Data()
{ }
String::String(const char *data)
: m_Data(data)
{ }
String::String(const std::string& data)
: m_Data(data)
{ }
2013-03-10 03:09:01 +01:00
String::String(size_t n, char c)
: m_Data(n, c)
{ }
String::String(const String& other)
: m_Data(other.m_Data)
{ }
String& String::operator=(const String& rhs)
{
m_Data = rhs.m_Data;
return *this;
}
String& String::operator=(const std::string& rhs)
{
m_Data = rhs;
return *this;
}
String& String::operator=(const char *rhs)
{
m_Data = rhs;
return *this;
}
const char& String::operator[](size_t pos) const
{
return m_Data[pos];
}
char& String::operator[](size_t pos)
{
return m_Data[pos];
}
String& String::operator+=(const String& rhs)
{
m_Data += rhs.m_Data;
return *this;
}
String& String::operator+=(const char *rhs)
{
m_Data += rhs;
return *this;
}
String& String::operator+=(const Value& rhs)
{
m_Data += static_cast<String>(rhs);
return *this;
}
2013-03-22 10:58:47 +01:00
String& String::operator+=(char rhs)
{
m_Data += rhs;
return *this;
}
bool String::IsEmpty(void) const
{
return m_Data.empty();
}
bool String::operator<(const String& rhs) const
{
return m_Data < rhs.m_Data;
}
String::operator const std::string&(void) const
{
return m_Data;
}
const char *String::CStr(void) const
{
return m_Data.c_str();
}
void String::Clear(void)
{
2013-09-02 12:02:43 +02:00
m_Data.clear();
}
size_t String::GetLength(void) const
{
return m_Data.size();
}
2013-11-05 18:52:13 +01:00
std::string& String::GetData(void)
{
return m_Data;
}
size_t String::Find(const String& str, size_t pos) const
{
return m_Data.find(str, pos);
}
size_t String::RFind(const String& str, size_t pos) const
{
return m_Data.rfind(str, pos);
}
size_t String::FindFirstOf(const char *s, size_t pos) const
{
return m_Data.find_first_of(s, pos);
}
2013-03-22 10:58:47 +01:00
size_t String::FindFirstOf(char ch, size_t pos) const
{
return m_Data.find_first_of(ch, pos);
}
size_t String::FindFirstNotOf(const char *s, size_t pos) const
{
return m_Data.find_first_not_of(s, pos);
}
size_t String::FindFirstNotOf(char ch, size_t pos) const
{
return m_Data.find_first_not_of(ch, pos);
}
2013-01-21 13:21:10 +01:00
String String::SubStr(size_t first, size_t len) const
{
2013-01-21 13:21:10 +01:00
return m_Data.substr(first, len);
}
void String::Replace(size_t first, size_t second, const String& str)
{
m_Data.replace(first, second, str);
}
void String::Trim(void)
{
boost::algorithm::trim(m_Data);
}
2013-12-17 12:19:29 +01:00
bool String::Contains(const String& str) const
{
return (m_Data.find(str) != std::string::npos);
2013-12-17 12:19:29 +01:00
}
void String::swap(String& str)
{
m_Data.swap(str.m_Data);
}
String::Iterator String::erase(String::Iterator first, String::Iterator last)
{
return m_Data.erase(first, last);
}
String::Iterator String::Begin(void)
{
return m_Data.begin();
}
String::ConstIterator String::Begin(void) const
{
return m_Data.begin();
}
String::Iterator String::End(void)
{
return m_Data.end();
}
String::ConstIterator String::End(void) const
{
return m_Data.end();
}
2013-03-16 21:18:53 +01:00
std::ostream& icinga::operator<<(std::ostream& stream, const String& str)
{
stream << static_cast<std::string>(str);
return stream;
}
2013-03-16 21:18:53 +01:00
std::istream& icinga::operator>>(std::istream& stream, String& str)
{
std::string tstr;
stream >> tstr;
str = tstr;
return stream;
}
String icinga::operator+(const String& lhs, const String& rhs)
{
return static_cast<std::string>(lhs) + static_cast<std::string>(rhs);
}
String icinga::operator+(const String& lhs, const char *rhs)
{
return static_cast<std::string>(lhs) + rhs;
}
String icinga::operator+(const char *lhs, const String& rhs)
{
return lhs + static_cast<std::string>(rhs);
}
bool icinga::operator==(const String& lhs, const String& rhs)
{
return static_cast<std::string>(lhs) == static_cast<std::string>(rhs);
}
bool icinga::operator==(const String& lhs, const char *rhs)
{
return static_cast<std::string>(lhs) == rhs;
}
bool icinga::operator==(const char *lhs, const String& rhs)
{
return lhs == static_cast<std::string>(rhs);
}
2013-03-10 15:11:32 +01:00
bool icinga::operator<(const String& lhs, const char *rhs)
2012-08-03 13:19:55 +02:00
{
2013-03-10 15:11:32 +01:00
return static_cast<std::string>(lhs) < rhs;
2012-08-03 13:19:55 +02:00
}
2013-03-10 15:11:32 +01:00
bool icinga::operator<(const char *lhs, const String& rhs)
2012-08-03 13:19:55 +02:00
{
2013-03-10 15:11:32 +01:00
return lhs < static_cast<std::string>(rhs);
2012-08-03 13:19:55 +02:00
}
2013-03-10 15:11:32 +01:00
bool icinga::operator>(const String& lhs, const String& rhs)
2012-08-03 13:19:55 +02:00
{
2013-03-10 15:11:32 +01:00
return static_cast<std::string>(lhs) > static_cast<std::string>(rhs);
2012-08-03 13:19:55 +02:00
}
2013-03-10 15:11:32 +01:00
bool icinga::operator>(const String& lhs, const char *rhs)
{
2013-03-10 15:11:32 +01:00
return static_cast<std::string>(lhs) > rhs;
}
2013-03-10 15:11:32 +01:00
bool icinga::operator>(const char *lhs, const String& rhs)
{
2013-03-10 15:11:32 +01:00
return lhs > static_cast<std::string>(rhs);
}
2013-03-10 15:11:32 +01:00
bool icinga::operator<=(const String& lhs, const String& rhs)
{
2013-03-10 15:11:32 +01:00
return static_cast<std::string>(lhs) <= static_cast<std::string>(rhs);
}
2013-03-10 15:11:32 +01:00
bool icinga::operator<=(const String& lhs, const char *rhs)
{
2013-03-10 15:11:32 +01:00
return static_cast<std::string>(lhs) <= rhs;
}
bool icinga::operator<=(const char *lhs, const String& rhs)
{
return lhs <= static_cast<std::string>(rhs);
}
bool icinga::operator>=(const String& lhs, const String& rhs)
{
return static_cast<std::string>(lhs) >= static_cast<std::string>(rhs);
}
bool icinga::operator>=(const String& lhs, const char *rhs)
{
return static_cast<std::string>(lhs) >= rhs;
}
bool icinga::operator>=(const char *lhs, const String& rhs)
{
return lhs >= static_cast<std::string>(rhs);
}
bool icinga::operator!=(const String& lhs, const String& rhs)
{
return static_cast<std::string>(lhs) != static_cast<std::string>(rhs);
}
bool icinga::operator!=(const String& lhs, const char *rhs)
{
return static_cast<std::string>(lhs) != rhs;
}
bool icinga::operator!=(const char *lhs, const String& rhs)
{
return lhs != static_cast<std::string>(rhs);
}
String::Iterator icinga::range_begin(String& x)
{
return x.Begin();
}
String::ConstIterator icinga::range_begin(const String& x)
{
return x.Begin();
}
String::Iterator icinga::range_end(String& x)
{
return x.End();
}
String::ConstIterator icinga::range_end(const String& x)
{
return x.End();
}