123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244 |
- /*
- * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License, version 2.0, as
- * published by the Free Software Foundation.
- *
- * This program is also distributed with certain software (including
- * but not limited to OpenSSL) that is licensed under separate terms,
- * as designated in a particular file or component or in included license
- * documentation. The authors of MySQL hereby grant you an
- * additional permission to link the program and your derivative works
- * with the separately licensed software that they have included with
- * MySQL.
- *
- * Without limiting anything contained in the foregoing, this file,
- * which is part of MySQL Connector/C++, is also subject to the
- * Universal FOSS Exception, version 1.0, a copy of which can be found at
- * http://oss.oracle.com/licenses/universal-foss-exception.
- *
- * 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, version 2.0, 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
- */
- #ifndef _SQL_STRING_H_
- #define _SQL_STRING_H_
- #include <string>
- #include <algorithm>
- #include "build_config.h"
- #include <iostream>
- namespace sql
- {
- class CPPCONN_PUBLIC_FUNC SQLString
- {
- std::string realStr;
- public:
- #ifdef _WIN32
- //TODO something less dirty-hackish.
- static const size_t npos = static_cast<std::string::size_type>(-1);
- #else
- static const size_t npos = std::string::npos;
- #endif
- ~SQLString() {}
- SQLString() {}
- SQLString(const SQLString & other) : realStr(other.realStr) {}
- SQLString(const std::string & other) : realStr(other) {}
- SQLString(const char other[]) : realStr(other) {}
- SQLString(const char * s, size_t n) : realStr(s, n) {}
- // Needed for stuff like SQLString str= "char * string constant"
- const SQLString & operator=(const char * s)
- {
- realStr = s;
- return *this;
- }
- const SQLString & operator=(const std::string & rhs)
- {
- realStr = rhs;
- return *this;
- }
- const SQLString & operator=(const SQLString & rhs)
- {
- realStr = rhs.realStr;
- return *this;
- }
- // Conversion to st::string. Comes in play for stuff like std::string str= SQLString_var;
- operator const std::string &() const
- {
- return realStr;
- }
- /** For access std::string methods. Not sure we need it. Makes it look like some smart ptr.
- possibly operator* - will look even more like smart ptr */
- std::string * operator ->()
- {
- return & realStr;
- }
- int compare(const SQLString& str) const
- {
- return realStr.compare(str.realStr);
- }
- int compare(const char * s) const
- {
- return realStr.compare(s);
- }
- int compare(size_t pos1, size_t n1, const char * s) const
- {
- return realStr.compare(pos1, n1, s);
- }
- int caseCompare(const SQLString &s) const
- {
- std::string tmp(realStr), str(s);
- std::transform(tmp.begin(), tmp.end(), tmp.begin(), ::tolower);
- std::transform(str.begin(), str.end(), str.begin(), ::tolower);
- return tmp.compare(str);
- }
- int caseCompare(const char * s) const
- {
- std::string tmp(realStr), str(s);
- std::transform(str.begin(), str.end(), str.begin(), ::tolower);
- std::transform(tmp.begin(), tmp.end(), tmp.begin(), ::tolower);
- return tmp.compare(str);
- }
- int caseCompare(size_t pos1, size_t n1, const char * s) const
- {
- std::string tmp(realStr.c_str() + pos1, n1), str(s);
- std::transform(str.begin(), str.end(), str.begin(), ::tolower);
- std::transform(tmp.begin(), tmp.end(), tmp.begin(), ::tolower);
- return tmp.compare(str);
- }
- const std::string & asStdString() const
- {
- return realStr;
- }
- const char * c_str() const
- {
- return realStr.c_str();
- }
- size_t length() const
- {
- return realStr.length();
- }
- SQLString & append(const std::string & str)
- {
- realStr.append(str);
- return *this;
- }
- SQLString & append(const char * s)
- {
- realStr.append(s);
- return *this;
- }
- const char& operator[](size_t pos) const
- {
- return realStr[pos];
- }
- size_t find(char c, size_t pos = 0) const
- {
- return realStr.find(c, pos);
- }
- size_t find(const SQLString & s, size_t pos = 0) const
- {
- return realStr.find(s.realStr, pos);
- }
- SQLString substr(size_t pos = 0, size_t n = npos) const
- {
- return realStr.substr(pos, n);
- }
- const SQLString& replace(size_t pos1, size_t n1, const SQLString & s)
- {
- realStr.replace(pos1, n1, s.realStr);
- return *this;
- }
- size_t find_first_of(char c, size_t pos = 0) const
- {
- return realStr.find_first_of(c, pos);
- }
- size_t find_last_of(char c, size_t pos = npos) const
- {
- return realStr.find_last_of(c, pos);
- }
- const SQLString & operator+=(const SQLString & op2)
- {
- realStr += op2.realStr;
- return *this;
- }
- };
- /*
- Operators that can and have to be not a member.
- */
- inline const SQLString operator+(const SQLString & op1, const SQLString & op2)
- {
- return sql::SQLString(op1.asStdString() + op2.asStdString());
- }
- inline bool operator ==(const SQLString & op1, const SQLString & op2)
- {
- return (op1.asStdString() == op2.asStdString());
- }
- inline bool operator !=(const SQLString & op1, const SQLString & op2)
- {
- return (op1.asStdString() != op2.asStdString());
- }
- inline bool operator <(const SQLString & op1, const SQLString & op2)
- {
- return op1.asStdString() < op2.asStdString();
- }
- }// namespace sql
- namespace std
- {
- // operator << for SQLString output
- inline ostream & operator << (ostream & os, const sql::SQLString & str )
- {
- return os << str.asStdString();
- }
- }
- #endif
|