Open-Transactions  0.93.0-ge03d287
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
OTString.hpp
Go to the documentation of this file.
1 /************************************************************
2  *
3  * OTString.hpp
4  *
5  */
6 
7 /************************************************************
8  -----BEGIN PGP SIGNED MESSAGE-----
9  Hash: SHA1
10 
11  * OPEN TRANSACTIONS
12  *
13  * Financial Cryptography and Digital Cash
14  * Library, Protocol, API, Server, CLI, GUI
15  *
16  * -- Anonymous Numbered Accounts.
17  * -- Untraceable Digital Cash.
18  * -- Triple-Signed Receipts.
19  * -- Cheques, Vouchers, Transfers, Inboxes.
20  * -- Basket Currencies, Markets, Payment Plans.
21  * -- Signed, XML, Ricardian-style Contracts.
22  * -- Scripted smart contracts.
23  *
24  * Copyright (C) 2010-2013 by "Fellow Traveler" (A pseudonym)
25  *
26  * EMAIL:
28  *
29  * BITCOIN: 1NtTPVVjDsUfDWybS4BwvHpG2pdS9RnYyQ
30  *
31  * KEY FINGERPRINT (PGP Key in license file):
32  * 9DD5 90EB 9292 4B48 0484 7910 0308 00ED F951 BB8E
33  *
34  * OFFICIAL PROJECT WIKI(s):
35  * https://github.com/FellowTraveler/Moneychanger
36  * https://github.com/FellowTraveler/Open-Transactions/wiki
37  *
38  * WEBSITE:
39  * http://www.OpenTransactions.org/
40  *
41  * Components and licensing:
42  * -- Moneychanger..A Java client GUI.....LICENSE:.....GPLv3
43  * -- otlib.........A class library.......LICENSE:...LAGPLv3
44  * -- otapi.........A client API..........LICENSE:...LAGPLv3
45  * -- opentxs/ot....Command-line client...LICENSE:...LAGPLv3
46  * -- otserver......Server Application....LICENSE:....AGPLv3
47  * Github.com/FellowTraveler/Open-Transactions/wiki/Components
48  *
49  * All of the above OT components were designed and written by
50  * Fellow Traveler, with the exception of Moneychanger, which
51  * was contracted out to Vicky C ([email protected]).
52  * The open-source community has since actively contributed.
53  *
54  * -----------------------------------------------------
55  *
56  * LICENSE:
57  * This program is free software: you can redistribute it
58  * and/or modify it under the terms of the GNU Affero
59  * General Public License as published by the Free Software
60  * Foundation, either version 3 of the License, or (at your
61  * option) any later version.
62  *
63  * ADDITIONAL PERMISSION under the GNU Affero GPL version 3
64  * section 7: (This paragraph applies only to the LAGPLv3
65  * components listed above.) If you modify this Program, or
66  * any covered work, by linking or combining it with other
67  * code, such other code is not for that reason alone subject
68  * to any of the requirements of the GNU Affero GPL version 3.
69  * (==> This means if you are only using the OT API, then you
70  * don't have to open-source your code--only your changes to
71  * Open-Transactions itself must be open source. Similar to
72  * LGPLv3, except it applies to software-as-a-service, not
73  * just to distributing binaries.)
74  *
75  * Extra WAIVER for OpenSSL, Lucre, and all other libraries
76  * used by Open Transactions: This program is released under
77  * the AGPL with the additional exemption that compiling,
78  * linking, and/or using OpenSSL is allowed. The same is true
79  * for any other open source libraries included in this
80  * project: complete waiver from the AGPL is hereby granted to
81  * compile, link, and/or use them with Open-Transactions,
82  * according to their own terms, as long as the rest of the
83  * Open-Transactions terms remain respected, with regard to
84  * the Open-Transactions code itself.
85  *
86  * Lucre License:
87  * This code is also "dual-license", meaning that Ben Lau-
88  * rie's license must also be included and respected, since
89  * the code for Lucre is also included with Open Transactions.
90  * See Open-Transactions/src/otlib/lucre/LUCRE_LICENSE.txt
91  * The Laurie requirements are light, but if there is any
92  * problem with his license, simply remove the Lucre code.
93  * Although there are no other blind token algorithms in Open
94  * Transactions (yet. credlib is coming), the other functions
95  * will continue to operate.
96  * See Lucre on Github: https://github.com/benlaurie/lucre
97  * -----------------------------------------------------
98  * You should have received a copy of the GNU Affero General
99  * Public License along with this program. If not, see:
100  * http://www.gnu.org/licenses/
101  *
102  * If you would like to use this software outside of the free
103  * software license, please contact FellowTraveler.
104  * (Unfortunately many will run anonymously and untraceably,
105  * so who could really stop them?)
106  *
107  * DISCLAIMER:
108  * This program is distributed in the hope that it will be
109  * useful, but WITHOUT ANY WARRANTY; without even the implied
110  * warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
111  * PURPOSE. See the GNU Affero General Public License for
112  * more details.
113 
114  -----BEGIN PGP SIGNATURE-----
115  Version: GnuPG v1.4.9 (Darwin)
116 
117  iQIcBAEBAgAGBQJRSsfJAAoJEAMIAO35UbuOQT8P/RJbka8etf7wbxdHQNAY+2cC
118  vDf8J3X8VI+pwMqv6wgTVy17venMZJa4I4ikXD/MRyWV1XbTG0mBXk/7AZk7Rexk
119  KTvL/U1kWiez6+8XXLye+k2JNM6v7eej8xMrqEcO0ZArh/DsLoIn1y8p8qjBI7+m
120  aE7lhstDiD0z8mwRRLKFLN2IH5rAFaZZUvj5ERJaoYUKdn4c+RcQVei2YOl4T0FU
121  LWND3YLoH8naqJXkaOKEN4UfJINCwxhe5Ke9wyfLWLUO7NamRkWD2T7CJ0xocnD1
122  sjAzlVGNgaFDRflfIF4QhBx1Ddl6wwhJfw+d08bjqblSq8aXDkmFA7HeunSFKkdn
123  oIEOEgyj+veuOMRJC5pnBJ9vV+7qRdDKQWaCKotynt4sWJDGQ9kWGWm74SsNaduN
124  TPMyr9kNmGsfR69Q2Zq/FLcLX/j8ESxU+HYUB4vaARw2xEOu2xwDDv6jt0j3Vqsg
125  x7rWv4S/Eh18FDNDkVRChiNoOIilLYLL6c38uMf1pnItBuxP3uhgY6COm59kVaRh
126  nyGTYCDYD2TK+fI9o89F1297uDCwEJ62U0Q7iTDp5QuXCoxkPfv8/kX6lS6T3y9G
127  M9mqIoLbIQ1EDntFv7/t6fUTS2+46uCrdZWbQ5RjYXdrzjij02nDmJAm2BngnZvd
128  kamH0Y/n11lCvo1oQxM+
129  =uSzz
130  -----END PGP SIGNATURE-----
131  **************************************************************/
132 
133 #ifndef OPENTXS_CORE_OTSTRING_HPP
134 #define OPENTXS_CORE_OTSTRING_HPP
135 
136 #ifdef _WIN32
137 #include "util/win32_utf8conv.hpp" // support for changing between std::string and std::wstring
138 #endif
139 
140 #include <iostream>
141 #include <list>
142 #include <map>
143 #include <sstream>
144 #include <cstdarg>
145 #include <cstring>
146 
147 #define MAX_STRING_LENGTH 0x800000 // this is about 8 megs.
148 
149 namespace opentxs
150 {
151 
152 class OTASCIIArmor;
153 class OTContract;
154 class OTIdentifier;
155 class OTPseudonym;
156 class OTSignature;
157 
158 class OTString
159 {
160 public:
161  typedef std::list<std::string> List;
162  typedef std::map<std::string, std::string> Map;
163 
164 public:
165  EXPORT friend std::ostream& operator<<(std::ostream& os,
166  const OTString& obj);
167 
168  EXPORT OTString();
169  EXPORT OTString(const OTString& value);
170  EXPORT OTString(const OTASCIIArmor& value);
171  OTString(const OTSignature& value);
172  EXPORT OTString(const OTContract& value);
173  EXPORT OTString(const OTIdentifier& value);
174  OTString(OTPseudonym& value);
175  EXPORT OTString(const char* value);
176  OTString(const char* value, size_t size);
177  EXPORT OTString(const std::string& value);
178  EXPORT virtual ~OTString();
179 
180  EXPORT virtual void Release();
181 
182  void Initialize();
183 
184  EXPORT OTString& operator=(OTString rhs);
185 
186  static bool vformat(const char* fmt, std::va_list* pvl, std::string& s);
187 
188  void swap(OTString& rhs);
189  bool operator>(const OTString& rhs) const;
190  bool operator<(const OTString& rhs) const;
191  bool operator<=(const OTString& rhs) const;
192  bool operator>=(const OTString& rhs) const;
193  EXPORT bool operator==(const OTString& rhs) const;
194 
195  EXPORT static std::string& trim(std::string& str);
196  EXPORT static std::string replace_chars(const std::string& str,
197  const std::string& charsFrom,
198  const char& charTo);
199 #ifdef _WIN32
200  EXPORT static std::wstring s2ws(const std::string& s);
201  EXPORT static std::string ws2s(const std::wstring& s);
202 #endif
203 
204 public:
205  EXPORT static bool safe_strcpy(
206  char* dest, const char* src,
207  // max size of destination must be passed here.
208  size_t destSize,
209  // if true, sets the source buffer to zero after copying is done.
210  bool zeroSource = false);
211  static size_t safe_strlen(const char* s, size_t max);
212 
213  EXPORT static int64_t StringToLong(const std::string& number);
214 
215  EXPORT int64_t ToLong() const;
216 
217  EXPORT static uint64_t StringToUlong(const std::string& number);
218 
219  EXPORT uint64_t ToUlong() const;
220 
221  EXPORT bool At(uint32_t index, char& c) const;
222  EXPORT bool Exists() const;
223  EXPORT bool DecodeIfArmored(bool escapedIsAllowed = true);
224  EXPORT uint32_t GetLength() const;
225  EXPORT bool Compare(const char* compare) const;
226  EXPORT bool Compare(const OTString& compare) const;
227 
228  EXPORT bool Contains(const char* compare) const;
229  bool Contains(const OTString& compare) const;
230 
231  EXPORT const char* Get() const;
232  // new_string MUST be at least nEnforcedMaxLength in size if
233  // nEnforcedMaxLength is passed in at all.
234  //
235  // That's because this function forces the null terminator at
236  // that length, minus 1. For example, if the max is set to 10, then
237  // the valid range is 0..9. Therefore 9 (10 minus 1) is where the
238  // nullptr terminator goes.
239  //
240  EXPORT void Set(const char* data, uint32_t enforcedMaxLength = 0);
241  EXPORT void Set(const OTString& data);
242  // For a straight-across, exact-size copy of bytes.
243  // Source not expected to be null-terminated.
244  EXPORT bool MemSet(const char* mem, uint32_t size);
245  EXPORT void Concatenate(const char* arg, ...);
246  void Concatenate(const OTString& data);
247  void Truncate(uint32_t index);
248  EXPORT void Format(const char* fmt, ...);
249  void ConvertToLowerCase() const;
250  void ConvertToUpperCase() const;
251  EXPORT bool TokenizeIntoKeyValuePairs(Map& map) const;
252  EXPORT void OTfgets(std::istream& ofs);
253  // true == there are more lines to read.
254  // false == this is the last line. Like EOF.
255  bool sgets(char* buffer, uint32_t size);
256 
257  char sgetc();
258  void sungetc();
259  void reset();
260 
261  void WriteToFile(std::ostream& ofs) const;
262  void Release_String();
263  EXPORT void zeroMemory() const;
264 
265 private:
266  // You better have called Initialize() or Release() before you dare call
267  // this.
268  void LowLevelSetStr(const OTString& buffer);
269 
270  // Only call this right after calling Initialize() or Release().
271  // Also, this function ASSUMES the new_string pointer is good.
272  void LowLevelSet(const char* data, uint32_t enforcedMaxLength);
273 
274 protected:
275  uint32_t length_;
276  uint32_t position_;
277  char* data_;
278 };
279 
280 // bool operator >(const OTString& s1, const OTString& s2);
281 // bool operator <(const OTString& s1, const OTString& s2);
282 // bool operator >=(const OTString& s1, const OTString& s2);
283 // bool operator <=(const OTString& s1, const OTString& s2);
284 
285 } // namespace opentxs
286 
287 #endif // OPENTXS_CORE_OTSTRING_HPP
void Truncate(uint32_t index)
Definition: OTString.cpp:1193
EXPORT OTString & operator=(OTString rhs)
Definition: OTString.cpp:1011
std::map< std::string, std::string > Map
Definition: OTString.hpp:162
uint32_t length_
Definition: OTString.hpp:275
static EXPORT int64_t StringToLong(const std::string &number)
Definition: OTString.cpp:677
static EXPORT uint64_t StringToUlong(const std::string &number)
Definition: OTString.cpp:662
static EXPORT bool safe_strcpy(char *dest, const char *src, size_t destSize, bool zeroSource=false)
Definition: OTString.cpp:353
void ConvertToUpperCase() const
Definition: OTString.cpp:1182
EXPORT int64_t ToLong() const
Definition: OTString.cpp:702
EXPORT OTString()
Definition: OTString.cpp:786
EXPORT void OTfgets(std::istream &ofs)
Definition: OTString.cpp:1159
EXPORT uint32_t GetLength() const
Definition: OTString.cpp:1040
EXPORT void Concatenate(const char *arg,...)
Definition: OTString.cpp:1334
bool operator<(const OTString &rhs) const
Definition: OTString.cpp:477
EXPORT bool DecodeIfArmored(bool escapedIsAllowed=true)
Definition: OTString.cpp:1212
EXPORT bool Exists() const
Definition: OTString.cpp:1035
EXPORT void Format(const char *fmt,...)
Definition: OTString.cpp:1319
EXPORT bool Compare(const char *compare) const
Definition: OTString.cpp:1102
static size_t safe_strlen(const char *s, size_t max)
Definition: OTString.cpp:388
EXPORT void Set(const char *data, uint32_t enforcedMaxLength=0)
Definition: OTString.cpp:1055
uint32_t position_
Definition: OTString.hpp:276
EXPORT bool TokenizeIntoKeyValuePairs(Map &map) const
Definition: OTString.cpp:550
void Release_String()
Definition: OTString.cpp:751
bool sgets(char *buffer, uint32_t size)
Definition: OTString.cpp:1380
bool operator>=(const OTString &rhs) const
Definition: OTString.cpp:505
EXPORT friend std::ostream & operator<<(std::ostream &os, const OTString &obj)
Definition: OTString.cpp:150
std::list< std::string > List
Definition: OTString.hpp:161
EXPORT bool At(uint32_t index, char &c) const
Definition: OTString.cpp:1025
EXPORT const char * Get() const
Definition: OTString.cpp:1045
EXPORT bool operator==(const OTString &rhs) const
Definition: OTString.cpp:1077
EXPORT void zeroMemory() const
Definition: OTString.cpp:744
bool operator<=(const OTString &rhs) const
Definition: OTString.cpp:491
EXPORT uint64_t ToUlong() const
Definition: OTString.cpp:695
EXPORT bool Contains(const char *compare) const
Definition: OTString.cpp:1137
static EXPORT std::string & trim(std::string &str)
Definition: OTString.cpp:398
bool operator>(const OTString &rhs) const
Definition: OTString.cpp:463
virtual EXPORT ~OTString()
Definition: OTString.cpp:774
EXPORT bool MemSet(const char *mem, uint32_t size)
Definition: OTString.cpp:967
static bool vformat(const char *fmt, std::va_list *pvl, std::string &s)
Definition: OTString.cpp:191
virtual EXPORT void Release()
Definition: OTString.cpp:765
void WriteToFile(std::ostream &ofs) const
Definition: OTString.cpp:1364
static EXPORT std::string replace_chars(const std::string &str, const std::string &charsFrom, const char &charTo)
Definition: OTString.cpp:420
void swap(OTString &rhs)
Definition: OTString.cpp:1018
void ConvertToLowerCase() const
Definition: OTString.cpp:1171