Open-Transactions  0.93.0-ge03d287
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
StringUtils.hpp
Go to the documentation of this file.
1 /************************************************************
2  *
3  * StringUtils.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_STRINGUTILS_HPP
134 #define OPENTXS_CORE_STRINGUTILS_HPP
135 
136 #include <cinttypes>
137 #include <string>
138 #include <sstream>
139 #include <string.h>
140 
141 namespace opentxs
142 {
143 
144 // from: http://www.cplusplus.com/faq/sequences/strings/split/
145 //
146 struct split
147 {
149 };
150 
151 template <typename Container>
152 static Container& split_byChar(Container& result,
153  const typename Container::value_type& s,
154  const typename Container::value_type& delimiters,
155  split::empties_t empties)
156 {
157  result.clear();
158  int64_t next = -1;
159  do {
160  if (empties == split::no_empties) {
161  next = s.find_first_not_of(delimiters,
162  static_cast<uint32_t>(next) + 1);
163  if (static_cast<size_t>(next) == Container::value_type::npos) {
164  break;
165  }
166  next -= 1;
167  }
168  size_t current = static_cast<size_t>(next + 1);
169  next = s.find_first_of(delimiters, current);
170  result.push_back(
171  s.substr(current, static_cast<uint32_t>(next) - current));
172  } while (static_cast<size_t>(next) != Container::value_type::npos);
173  return result;
174 }
175 
176 // If you've already strlen'd the string,
177 // you can pass the length to str_hsh or str_dup
178 // and save it the trouble.
179 //
180 char* str_dup2(const char* str, uint32_t length);
181 
182 template <typename T>
183 inline std::string to_string(const T& t)
184 {
185  std::stringstream ss;
186  ss << t;
187  return ss.str();
188 }
189 
190 /*
191  * strlcpy and strlcat
192  *
193  * Copyright (c) 1998 Todd C. Miller <[email protected]>
194  *
195  * Permission to use, copy, modify, and distribute this software for any
196  * purpose with or without fee is hereby granted, provided that the above
197  * copyright notice and this permission notice appear in all copies.
198  *
199  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
200  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
201  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
202  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
203  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
204  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
205  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
206  */
207 
208 /*
209  * Copy src to string dst of size siz. At most siz-1 characters
210  * will be copied. Always NUL terminates (unless siz == 0).
211  * Returns strlen(src); if retval >= siz, truncation occurred.
212  */
213 inline size_t strlcpy(char* dst, const char* src, size_t siz)
214 {
215  char* d = dst;
216  const char* s = src;
217  size_t n = siz;
218 
219  /* Copy as many bytes as will fit */
220  if (n != 0) {
221  while (--n != 0) {
222  if ((*d++ = *s++) == '\0') break;
223  }
224  }
225 
226  /* Not enough room in dst, add NUL and traverse rest of src */
227  if (n == 0) {
228  if (siz != 0) *d = '\0'; /* NUL-terminate dst */
229  while (*s++)
230  ;
231  }
232 
233  return (s - src - 1); /* count does not include NUL */
234 }
235 /*
236  * Appends src to string dst of size siz (unlike strncat, siz is the
237  * full size of dst, not space left). At most siz-1 characters
238  * will be copied. Always NUL terminates (unless siz <= strlen(dst)).
239  * Returns strlen(src) + MIN(siz, strlen(initial dst)).
240  * If retval >= siz, truncation occurred.
241  */
242 inline size_t strlcat(char* dst, const char* src, size_t siz)
243 {
244  char* d = dst;
245  const char* s = src;
246  size_t n = siz;
247  size_t dlen;
248 
249  /* Find the end of dst and adjust bytes left but don't go past end */
250  while (n-- != 0 && *d != '\0') d++;
251  dlen = d - dst;
252  n = siz - dlen;
253 
254  if (n == 0) return (dlen + strlen(s));
255  while (*s != '\0') {
256  if (n != 1) {
257  *d++ = *s;
258  n--;
259  }
260  s++;
261  }
262  *d = '\0';
263 
264  return (dlen + (s - src)); /* count does not include NUL */
265 }
266 // (End of the Todd Miller code.)
267 
268 } // namespace opentxs
269 
270 #endif // OPENTXS_CORE_STRINGUTILS_HPP
size_t strlcpy(char *dst, const char *src, size_t siz)
std::string to_string(const T &t)
char * str_dup2(const char *str, uint32_t length)
size_t strlcat(char *dst, const char *src, size_t siz)