Bitcoin ABC 0.32.12
P2P Digital Currency
strencodings.h
Go to the documentation of this file.
1// Copyright (c) 2009-2010 Satoshi Nakamoto
2// Copyright (c) 2009-2016 The Bitcoin Core developers
3// Distributed under the MIT software license, see the accompanying
4// file COPYING or http://www.opensource.org/licenses/mit-license.php.
5
9#ifndef BITCOIN_UTIL_STRENCODINGS_H
10#define BITCOIN_UTIL_STRENCODINGS_H
11
12#include <crypto/hex_base.h> // IWYU pragma: export
13#include <span.h>
14#include <util/string.h>
15
16#include <charconv>
17#include <cstdint>
18#include <iterator>
19#include <optional>
20#include <string>
21#include <vector>
22
33};
34
43std::string SanitizeString(std::string_view str, int rule = SAFE_CHARS_DEFAULT);
48template <typename Byte = std::byte>
49std::optional<std::vector<Byte>> TryParseHex(std::string_view str);
52template <typename Byte = uint8_t>
53std::vector<Byte> ParseHex(std::string_view hex_str) {
54 return TryParseHex<Byte>(hex_str).value_or(std::vector<Byte>{});
55}
60bool IsHex(std::string_view str);
64bool IsHexNumber(std::string_view str);
65std::optional<std::vector<uint8_t>> DecodeBase64(std::string_view str);
66std::string EncodeBase64(Span<const uint8_t> input);
67inline std::string EncodeBase64(Span<const std::byte> input) {
68 return EncodeBase64(MakeUCharSpan(input));
69}
70inline std::string EncodeBase64(std::string_view str) {
71 return EncodeBase64(MakeUCharSpan(str));
72}
73std::optional<std::vector<uint8_t>> DecodeBase32(std::string_view str);
74
80std::string EncodeBase32(Span<const uint8_t> input, bool pad = true);
81
87std::string EncodeBase32(std::string_view str, bool pad = true);
88
99bool SplitHostPort(std::string_view in, uint16_t &portOut,
100 std::string &hostOut);
101
102// LocaleIndependentAtoi is provided for backwards compatibility reasons.
103//
104// New code should use ToIntegral or the ParseInt* functions which provide parse
105// error feedback.
106//
107// The goal of LocaleIndependentAtoi is to replicate the exact defined behaviour
108// of atoi and atoi64 as they behave under the "C" locale.
109template <typename T> T LocaleIndependentAtoi(const std::string &str) {
110 static_assert(std::is_integral<T>::value);
111 T result;
112 // Emulate atoi(...) handling of white space and leading +/-.
113 std::string s = util::TrimString(str);
114 if (!s.empty() && s[0] == '+') {
115 if (s.length() >= 2 && s[1] == '-') {
116 return 0;
117 }
118 s = s.substr(1);
119 }
120 auto [_, error_condition] =
121 std::from_chars(s.data(), s.data() + s.size(), result);
122 if (error_condition != std::errc{}) {
123 return 0;
124 }
125 return result;
126}
127
133constexpr bool IsDigit(char c) {
134 return c >= '0' && c <= '9';
135}
136
149constexpr inline bool IsSpace(char c) noexcept {
150 return c == ' ' || c == '\f' || c == '\n' || c == '\r' || c == '\t' ||
151 c == '\v';
152}
153
162template <typename T> std::optional<T> ToIntegral(std::string_view str) {
163 static_assert(std::is_integral<T>::value);
164 T result;
165 const auto [first_nonmatching, error_condition] =
166 std::from_chars(str.data(), str.data() + str.size(), result);
167 if (first_nonmatching != str.data() + str.size() ||
168 error_condition != std::errc{}) {
169 return std::nullopt;
170 }
171 return result;
172}
173
179[[nodiscard]] bool ParseInt32(std::string_view str, int32_t *out);
180
186[[nodiscard]] bool ParseInt64(std::string_view str, int64_t *out);
187
195[[nodiscard]] bool ParseUInt8(std::string_view str, uint8_t *out);
196
204[[nodiscard]] bool ParseUInt16(std::string_view str, uint16_t *out);
205
212[[nodiscard]] bool ParseUInt32(std::string_view str, uint32_t *out);
213
220[[nodiscard]] bool ParseUInt64(std::string_view str, uint64_t *out);
221
226std::string FormatParagraph(std::string_view in, size_t width = 79,
227 size_t indent = 0);
228
233template <typename T> bool TimingResistantEqual(const T &a, const T &b) {
234 if (b.size() == 0) {
235 return a.size() == 0;
236 }
237 size_t accumulator = a.size() ^ b.size();
238 for (size_t i = 0; i < a.size(); i++) {
239 accumulator |= size_t(a[i] ^ b[i % b.size()]);
240 }
241 return accumulator == 0;
242}
243
251[[nodiscard]] bool ParseFixedPoint(std::string_view, int decimals,
252 int64_t *amount_out);
253
254namespace {
259struct IntIdentity {
260 [[maybe_unused]] int operator()(int x) const { return x; }
261};
262
263} // namespace
264
271template <int frombits, int tobits, bool pad, typename O, typename It,
272 typename I = IntIdentity>
273bool ConvertBits(O outfn, It it, It end, I infn = {}) {
274 size_t acc = 0;
275 size_t bits = 0;
276 constexpr size_t maxv = (1 << tobits) - 1;
277 constexpr size_t max_acc = (1 << (frombits + tobits - 1)) - 1;
278 while (it != end) {
279 int v = infn(*it);
280 if (v < 0) {
281 return false;
282 }
283 acc = ((acc << frombits) | v) & max_acc;
284 bits += frombits;
285 while (bits >= tobits) {
286 bits -= tobits;
287 outfn((acc >> bits) & maxv);
288 }
289 ++it;
290 }
291
292 if (pad) {
293 if (bits) {
294 outfn((acc << (tobits - bits)) & maxv);
295 }
296 } else if (bits >= frombits || ((acc << (tobits - bits)) & maxv)) {
297 return false;
298 }
299
300 return true;
301}
302
313constexpr char ToLower(char c) {
314 return (c >= 'A' && c <= 'Z' ? (c - 'A') + 'a' : c);
315}
316
326std::string ToLower(std::string_view str);
327
338constexpr char ToUpper(char c) {
339 return (c >= 'a' && c <= 'z' ? (c - 'a') + 'A' : c);
340}
341
351std::string ToUpper(std::string_view str);
352
362std::string Capitalize(std::string str);
363
364#endif // BITCOIN_UTIL_STRENCODINGS_H
std::string TrimString(std::string_view str, std::string_view pattern=" \f\n\r\t\v")
Definition: string.h:80
constexpr auto MakeUCharSpan(V &&v) -> decltype(UCharSpanCast(Span{std::forward< V >(v)}))
Like the Span constructor, but for (const) uint8_t member types only.
Definition: span.h:350
std::string Capitalize(std::string str)
Capitalizes the first character of the given string.
bool IsHexNumber(std::string_view str)
Return true if the string is a hex number, optionally prefixed with "0x".
bool ParseInt32(std::string_view str, int32_t *out)
Convert string to signed 32-bit integer with strict parse error feedback.
std::string EncodeBase64(Span< const uint8_t > input)
std::string EncodeBase32(Span< const uint8_t > input, bool pad=true)
Base32 encode.
bool ParseUInt16(std::string_view str, uint16_t *out)
Convert decimal string to unsigned 16-bit integer with strict parse error feedback.
constexpr char ToLower(char c)
Converts the given character to its lowercase equivalent.
Definition: strencodings.h:313
constexpr bool IsDigit(char c)
Tests if the given character is a decimal digit.
Definition: strencodings.h:133
constexpr char ToUpper(char c)
Converts the given character to its uppercase equivalent.
Definition: strencodings.h:338
T LocaleIndependentAtoi(const std::string &str)
Definition: strencodings.h:109
bool ParseInt64(std::string_view str, int64_t *out)
Convert string to signed 64-bit integer with strict parse error feedback.
bool TimingResistantEqual(const T &a, const T &b)
Timing-attack-resistant comparison.
Definition: strencodings.h:233
bool ParseUInt8(std::string_view str, uint8_t *out)
Convert decimal string to unsigned 8-bit integer with strict parse error feedback.
std::vector< Byte > ParseHex(std::string_view hex_str)
Like TryParseHex, but returns an empty vector on invalid input.
Definition: strencodings.h:53
bool ParseFixedPoint(std::string_view, int decimals, int64_t *amount_out)
Parse number as fixed point according to JSON number syntax.
bool ParseUInt64(std::string_view str, uint64_t *out)
Convert decimal string to unsigned 64-bit integer with strict parse error feedback.
constexpr bool IsSpace(char c) noexcept
Tests if the given character is a whitespace character.
Definition: strencodings.h:149
bool IsHex(std::string_view str)
Returns true if each character in str is a hex character, and has an even number of hex digits.
std::optional< T > ToIntegral(std::string_view str)
Convert string to integral type T.
Definition: strencodings.h:162
std::optional< std::vector< uint8_t > > DecodeBase64(std::string_view str)
bool SplitHostPort(std::string_view in, uint16_t &portOut, std::string &hostOut)
Splits socket address string into host string and port value.
bool ParseUInt32(std::string_view str, uint32_t *out)
Convert decimal string to unsigned 32-bit integer with strict parse error feedback.
bool ConvertBits(O outfn, It it, It end, I infn={})
Convert from one power-of-2 number base to another.
Definition: strencodings.h:273
std::string FormatParagraph(std::string_view in, size_t width=79, size_t indent=0)
Format a paragraph of text to a fixed width, adding spaces for indentation to any added line.
std::string SanitizeString(std::string_view str, int rule=SAFE_CHARS_DEFAULT)
Remove unsafe chars.
std::optional< std::vector< Byte > > TryParseHex(std::string_view str)
Parse the hex string into bytes (uint8_t or std::byte).
SafeChars
Utilities for converting data from/to strings.
Definition: strencodings.h:24
@ SAFE_CHARS_DEFAULT
The full set of allowed chars.
Definition: strencodings.h:26
@ SAFE_CHARS_UA_COMMENT
BIP-0014 subset.
Definition: strencodings.h:28
@ SAFE_CHARS_URI
Chars allowed in URIs (RFC 3986)
Definition: strencodings.h:32
@ SAFE_CHARS_FILENAME
Chars allowed in filenames.
Definition: strencodings.h:30
std::optional< std::vector< uint8_t > > DecodeBase32(std::string_view str)
bilingual_str _(const char *psz)
Translation function.
Definition: translation.h:68