Split up util.cpp/h
Split up util.cpp/h into:
- string utilities (hex, base32, base64): no internal dependencies, no dependency on boost (apart from foreach)
- money utilities (parsesmoney, formatmoney)
- time utilities (gettime*, sleep, format date):
- and the rest (logging, argument parsing, config file parsing)
The latter is basically the environment and OS handling,
and is stripped of all utility functions, so we may want to
rename it to something else than util.cpp/h for clarity (Matt suggested
osinterface).
Breaks dependency of sha256.cpp on all the things pulled in by util.
2014-08-21 16:11:09 +02:00
|
|
|
// Copyright (c) 2009-2010 Satoshi Nakamoto
|
2020-04-16 13:14:08 -04:00
|
|
|
// Copyright (c) 2009-2020 The Bitcoin Core developers
|
2014-11-17 11:04:01 +08:00
|
|
|
// Distributed under the MIT software license, see the accompanying
|
Split up util.cpp/h
Split up util.cpp/h into:
- string utilities (hex, base32, base64): no internal dependencies, no dependency on boost (apart from foreach)
- money utilities (parsesmoney, formatmoney)
- time utilities (gettime*, sleep, format date):
- and the rest (logging, argument parsing, config file parsing)
The latter is basically the environment and OS handling,
and is stripped of all utility functions, so we may want to
rename it to something else than util.cpp/h for clarity (Matt suggested
osinterface).
Breaks dependency of sha256.cpp on all the things pulled in by util.
2014-08-21 16:11:09 +02:00
|
|
|
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Utilities for converting data from/to strings.
|
|
|
|
*/
|
2018-10-22 15:51:11 -07:00
|
|
|
#ifndef BITCOIN_UTIL_STRENCODINGS_H
|
|
|
|
#define BITCOIN_UTIL_STRENCODINGS_H
|
Split up util.cpp/h
Split up util.cpp/h into:
- string utilities (hex, base32, base64): no internal dependencies, no dependency on boost (apart from foreach)
- money utilities (parsesmoney, formatmoney)
- time utilities (gettime*, sleep, format date):
- and the rest (logging, argument parsing, config file parsing)
The latter is basically the environment and OS handling,
and is stripped of all utility functions, so we may want to
rename it to something else than util.cpp/h for clarity (Matt suggested
osinterface).
Breaks dependency of sha256.cpp on all the things pulled in by util.
2014-08-21 16:11:09 +02:00
|
|
|
|
2018-09-25 07:00:36 +02:00
|
|
|
#include <attributes.h>
|
|
|
|
|
|
|
|
#include <cstdint>
|
2019-03-10 11:37:05 -06:00
|
|
|
#include <iterator>
|
Split up util.cpp/h
Split up util.cpp/h into:
- string utilities (hex, base32, base64): no internal dependencies, no dependency on boost (apart from foreach)
- money utilities (parsesmoney, formatmoney)
- time utilities (gettime*, sleep, format date):
- and the rest (logging, argument parsing, config file parsing)
The latter is basically the environment and OS handling,
and is stripped of all utility functions, so we may want to
rename it to something else than util.cpp/h for clarity (Matt suggested
osinterface).
Breaks dependency of sha256.cpp on all the things pulled in by util.
2014-08-21 16:11:09 +02:00
|
|
|
#include <string>
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
#define ARRAYLEN(array) (sizeof(array)/sizeof((array)[0]))
|
|
|
|
|
2015-09-09 14:24:56 +02:00
|
|
|
/** Used by SanitizeString() */
|
|
|
|
enum SafeChars
|
|
|
|
{
|
|
|
|
SAFE_CHARS_DEFAULT, //!< The full set of allowed chars
|
2017-01-08 20:41:30 +00:00
|
|
|
SAFE_CHARS_UA_COMMENT, //!< BIP-0014 subset
|
|
|
|
SAFE_CHARS_FILENAME, //!< Chars allowed in filenames
|
2018-11-01 17:03:32 +01:00
|
|
|
SAFE_CHARS_URI, //!< Chars allowed in URIs (RFC 3986)
|
2015-09-09 14:24:56 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Remove unsafe chars. Safe chars chosen to allow simple messages/URLs/email
|
|
|
|
* addresses, but avoid anything even possibly remotely dangerous like & or >
|
|
|
|
* @param[in] str The string to sanitize
|
|
|
|
* @param[in] rule The set of safe chars to choose (default: least restrictive)
|
|
|
|
* @return A new string without unsafe chars
|
|
|
|
*/
|
|
|
|
std::string SanitizeString(const std::string& str, int rule = SAFE_CHARS_DEFAULT);
|
Split up util.cpp/h
Split up util.cpp/h into:
- string utilities (hex, base32, base64): no internal dependencies, no dependency on boost (apart from foreach)
- money utilities (parsesmoney, formatmoney)
- time utilities (gettime*, sleep, format date):
- and the rest (logging, argument parsing, config file parsing)
The latter is basically the environment and OS handling,
and is stripped of all utility functions, so we may want to
rename it to something else than util.cpp/h for clarity (Matt suggested
osinterface).
Breaks dependency of sha256.cpp on all the things pulled in by util.
2014-08-21 16:11:09 +02:00
|
|
|
std::vector<unsigned char> ParseHex(const char* psz);
|
|
|
|
std::vector<unsigned char> ParseHex(const std::string& str);
|
|
|
|
signed char HexDigit(char c);
|
2017-05-07 14:10:19 -04:00
|
|
|
/* Returns true if each character in str is a hex character, and has an even
|
|
|
|
* number of hex digits.*/
|
Split up util.cpp/h
Split up util.cpp/h into:
- string utilities (hex, base32, base64): no internal dependencies, no dependency on boost (apart from foreach)
- money utilities (parsesmoney, formatmoney)
- time utilities (gettime*, sleep, format date):
- and the rest (logging, argument parsing, config file parsing)
The latter is basically the environment and OS handling,
and is stripped of all utility functions, so we may want to
rename it to something else than util.cpp/h for clarity (Matt suggested
osinterface).
Breaks dependency of sha256.cpp on all the things pulled in by util.
2014-08-21 16:11:09 +02:00
|
|
|
bool IsHex(const std::string& str);
|
2017-05-07 14:10:19 -04:00
|
|
|
/**
|
|
|
|
* Return true if the string is a hex number, optionally prefixed with "0x"
|
|
|
|
*/
|
|
|
|
bool IsHexNumber(const std::string& str);
|
2019-01-28 22:44:11 -08:00
|
|
|
std::vector<unsigned char> DecodeBase64(const char* p, bool* pf_invalid = nullptr);
|
|
|
|
std::string DecodeBase64(const std::string& str, bool* pf_invalid = nullptr);
|
Split up util.cpp/h
Split up util.cpp/h into:
- string utilities (hex, base32, base64): no internal dependencies, no dependency on boost (apart from foreach)
- money utilities (parsesmoney, formatmoney)
- time utilities (gettime*, sleep, format date):
- and the rest (logging, argument parsing, config file parsing)
The latter is basically the environment and OS handling,
and is stripped of all utility functions, so we may want to
rename it to something else than util.cpp/h for clarity (Matt suggested
osinterface).
Breaks dependency of sha256.cpp on all the things pulled in by util.
2014-08-21 16:11:09 +02:00
|
|
|
std::string EncodeBase64(const unsigned char* pch, size_t len);
|
|
|
|
std::string EncodeBase64(const std::string& str);
|
2019-01-28 22:44:11 -08:00
|
|
|
std::vector<unsigned char> DecodeBase32(const char* p, bool* pf_invalid = nullptr);
|
|
|
|
std::string DecodeBase32(const std::string& str, bool* pf_invalid = nullptr);
|
Split up util.cpp/h
Split up util.cpp/h into:
- string utilities (hex, base32, base64): no internal dependencies, no dependency on boost (apart from foreach)
- money utilities (parsesmoney, formatmoney)
- time utilities (gettime*, sleep, format date):
- and the rest (logging, argument parsing, config file parsing)
The latter is basically the environment and OS handling,
and is stripped of all utility functions, so we may want to
rename it to something else than util.cpp/h for clarity (Matt suggested
osinterface).
Breaks dependency of sha256.cpp on all the things pulled in by util.
2014-08-21 16:11:09 +02:00
|
|
|
std::string EncodeBase32(const unsigned char* pch, size_t len);
|
|
|
|
std::string EncodeBase32(const std::string& str);
|
|
|
|
|
2020-03-27 09:05:31 -04:00
|
|
|
void SplitHostPort(std::string in, int& portOut, std::string& hostOut);
|
Split up util.cpp/h
Split up util.cpp/h into:
- string utilities (hex, base32, base64): no internal dependencies, no dependency on boost (apart from foreach)
- money utilities (parsesmoney, formatmoney)
- time utilities (gettime*, sleep, format date):
- and the rest (logging, argument parsing, config file parsing)
The latter is basically the environment and OS handling,
and is stripped of all utility functions, so we may want to
rename it to something else than util.cpp/h for clarity (Matt suggested
osinterface).
Breaks dependency of sha256.cpp on all the things pulled in by util.
2014-08-21 16:11:09 +02:00
|
|
|
int64_t atoi64(const char* psz);
|
|
|
|
int64_t atoi64(const std::string& str);
|
|
|
|
int atoi(const std::string& str);
|
|
|
|
|
2018-07-22 21:34:45 +02:00
|
|
|
/**
|
|
|
|
* Tests if the given character is a decimal digit.
|
|
|
|
* @param[in] c character to test
|
|
|
|
* @return true if the argument is a decimal digit; otherwise false.
|
|
|
|
*/
|
|
|
|
constexpr bool IsDigit(char c)
|
|
|
|
{
|
|
|
|
return c >= '0' && c <= '9';
|
|
|
|
}
|
|
|
|
|
2018-10-26 18:54:30 +02:00
|
|
|
/**
|
|
|
|
* Tests if the given character is a whitespace character. The whitespace characters
|
|
|
|
* are: space, form-feed ('\f'), newline ('\n'), carriage return ('\r'), horizontal
|
|
|
|
* tab ('\t'), and vertical tab ('\v').
|
|
|
|
*
|
|
|
|
* This function is locale independent. Under the C locale this function gives the
|
|
|
|
* same result as std::isspace.
|
|
|
|
*
|
|
|
|
* @param[in] c character to test
|
|
|
|
* @return true if the argument is a whitespace character; otherwise false
|
|
|
|
*/
|
|
|
|
constexpr inline bool IsSpace(char c) noexcept {
|
|
|
|
return c == ' ' || c == '\f' || c == '\n' || c == '\r' || c == '\t' || c == '\v';
|
|
|
|
}
|
|
|
|
|
Split up util.cpp/h
Split up util.cpp/h into:
- string utilities (hex, base32, base64): no internal dependencies, no dependency on boost (apart from foreach)
- money utilities (parsesmoney, formatmoney)
- time utilities (gettime*, sleep, format date):
- and the rest (logging, argument parsing, config file parsing)
The latter is basically the environment and OS handling,
and is stripped of all utility functions, so we may want to
rename it to something else than util.cpp/h for clarity (Matt suggested
osinterface).
Breaks dependency of sha256.cpp on all the things pulled in by util.
2014-08-21 16:11:09 +02:00
|
|
|
/**
|
|
|
|
* Convert string to signed 32-bit integer with strict parse error feedback.
|
|
|
|
* @returns true if the entire string could be parsed as valid integer,
|
2014-11-17 11:04:01 +08:00
|
|
|
* false if not the entire string could be parsed or when overflow or underflow occurred.
|
Split up util.cpp/h
Split up util.cpp/h into:
- string utilities (hex, base32, base64): no internal dependencies, no dependency on boost (apart from foreach)
- money utilities (parsesmoney, formatmoney)
- time utilities (gettime*, sleep, format date):
- and the rest (logging, argument parsing, config file parsing)
The latter is basically the environment and OS handling,
and is stripped of all utility functions, so we may want to
rename it to something else than util.cpp/h for clarity (Matt suggested
osinterface).
Breaks dependency of sha256.cpp on all the things pulled in by util.
2014-08-21 16:11:09 +02:00
|
|
|
*/
|
2018-09-25 07:00:36 +02:00
|
|
|
NODISCARD bool ParseInt32(const std::string& str, int32_t *out);
|
Split up util.cpp/h
Split up util.cpp/h into:
- string utilities (hex, base32, base64): no internal dependencies, no dependency on boost (apart from foreach)
- money utilities (parsesmoney, formatmoney)
- time utilities (gettime*, sleep, format date):
- and the rest (logging, argument parsing, config file parsing)
The latter is basically the environment and OS handling,
and is stripped of all utility functions, so we may want to
rename it to something else than util.cpp/h for clarity (Matt suggested
osinterface).
Breaks dependency of sha256.cpp on all the things pulled in by util.
2014-08-21 16:11:09 +02:00
|
|
|
|
2015-06-04 12:03:09 +02:00
|
|
|
/**
|
|
|
|
* Convert string to signed 64-bit integer with strict parse error feedback.
|
|
|
|
* @returns true if the entire string could be parsed as valid integer,
|
|
|
|
* false if not the entire string could be parsed or when overflow or underflow occurred.
|
|
|
|
*/
|
2018-09-25 07:00:36 +02:00
|
|
|
NODISCARD bool ParseInt64(const std::string& str, int64_t *out);
|
2015-06-04 12:03:09 +02:00
|
|
|
|
2016-06-08 10:23:25 +02:00
|
|
|
/**
|
|
|
|
* Convert decimal string to unsigned 32-bit integer with strict parse error feedback.
|
|
|
|
* @returns true if the entire string could be parsed as valid integer,
|
|
|
|
* false if not the entire string could be parsed or when overflow or underflow occurred.
|
|
|
|
*/
|
2018-09-25 07:00:36 +02:00
|
|
|
NODISCARD bool ParseUInt32(const std::string& str, uint32_t *out);
|
2016-06-08 10:23:25 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Convert decimal string to unsigned 64-bit integer with strict parse error feedback.
|
|
|
|
* @returns true if the entire string could be parsed as valid integer,
|
|
|
|
* false if not the entire string could be parsed or when overflow or underflow occurred.
|
|
|
|
*/
|
2018-09-25 07:00:36 +02:00
|
|
|
NODISCARD bool ParseUInt64(const std::string& str, uint64_t *out);
|
2016-06-08 10:23:25 +02:00
|
|
|
|
2015-06-04 12:03:09 +02:00
|
|
|
/**
|
|
|
|
* Convert string to double with strict parse error feedback.
|
|
|
|
* @returns true if the entire string could be parsed as valid double,
|
|
|
|
* false if not the entire string could be parsed or when overflow or underflow occurred.
|
|
|
|
*/
|
2018-09-25 07:00:36 +02:00
|
|
|
NODISCARD bool ParseDouble(const std::string& str, double *out);
|
2015-06-04 12:03:09 +02:00
|
|
|
|
Split up util.cpp/h
Split up util.cpp/h into:
- string utilities (hex, base32, base64): no internal dependencies, no dependency on boost (apart from foreach)
- money utilities (parsesmoney, formatmoney)
- time utilities (gettime*, sleep, format date):
- and the rest (logging, argument parsing, config file parsing)
The latter is basically the environment and OS handling,
and is stripped of all utility functions, so we may want to
rename it to something else than util.cpp/h for clarity (Matt suggested
osinterface).
Breaks dependency of sha256.cpp on all the things pulled in by util.
2014-08-21 16:11:09 +02:00
|
|
|
template<typename T>
|
2019-03-10 11:37:05 -06:00
|
|
|
std::string HexStr(const T itbegin, const T itend)
|
Split up util.cpp/h
Split up util.cpp/h into:
- string utilities (hex, base32, base64): no internal dependencies, no dependency on boost (apart from foreach)
- money utilities (parsesmoney, formatmoney)
- time utilities (gettime*, sleep, format date):
- and the rest (logging, argument parsing, config file parsing)
The latter is basically the environment and OS handling,
and is stripped of all utility functions, so we may want to
rename it to something else than util.cpp/h for clarity (Matt suggested
osinterface).
Breaks dependency of sha256.cpp on all the things pulled in by util.
2014-08-21 16:11:09 +02:00
|
|
|
{
|
|
|
|
std::string rv;
|
|
|
|
static const char hexmap[16] = { '0', '1', '2', '3', '4', '5', '6', '7',
|
|
|
|
'8', '9', 'a', 'b', 'c', 'd', 'e', 'f' };
|
2019-03-10 11:37:05 -06:00
|
|
|
rv.reserve(std::distance(itbegin, itend) * 2);
|
Split up util.cpp/h
Split up util.cpp/h into:
- string utilities (hex, base32, base64): no internal dependencies, no dependency on boost (apart from foreach)
- money utilities (parsesmoney, formatmoney)
- time utilities (gettime*, sleep, format date):
- and the rest (logging, argument parsing, config file parsing)
The latter is basically the environment and OS handling,
and is stripped of all utility functions, so we may want to
rename it to something else than util.cpp/h for clarity (Matt suggested
osinterface).
Breaks dependency of sha256.cpp on all the things pulled in by util.
2014-08-21 16:11:09 +02:00
|
|
|
for(T it = itbegin; it < itend; ++it)
|
|
|
|
{
|
|
|
|
unsigned char val = (unsigned char)(*it);
|
|
|
|
rv.push_back(hexmap[val>>4]);
|
|
|
|
rv.push_back(hexmap[val&15]);
|
|
|
|
}
|
|
|
|
return rv;
|
|
|
|
}
|
|
|
|
|
|
|
|
template<typename T>
|
2019-03-10 11:37:05 -06:00
|
|
|
inline std::string HexStr(const T& vch)
|
Split up util.cpp/h
Split up util.cpp/h into:
- string utilities (hex, base32, base64): no internal dependencies, no dependency on boost (apart from foreach)
- money utilities (parsesmoney, formatmoney)
- time utilities (gettime*, sleep, format date):
- and the rest (logging, argument parsing, config file parsing)
The latter is basically the environment and OS handling,
and is stripped of all utility functions, so we may want to
rename it to something else than util.cpp/h for clarity (Matt suggested
osinterface).
Breaks dependency of sha256.cpp on all the things pulled in by util.
2014-08-21 16:11:09 +02:00
|
|
|
{
|
2019-03-10 11:37:05 -06:00
|
|
|
return HexStr(vch.begin(), vch.end());
|
Split up util.cpp/h
Split up util.cpp/h into:
- string utilities (hex, base32, base64): no internal dependencies, no dependency on boost (apart from foreach)
- money utilities (parsesmoney, formatmoney)
- time utilities (gettime*, sleep, format date):
- and the rest (logging, argument parsing, config file parsing)
The latter is basically the environment and OS handling,
and is stripped of all utility functions, so we may want to
rename it to something else than util.cpp/h for clarity (Matt suggested
osinterface).
Breaks dependency of sha256.cpp on all the things pulled in by util.
2014-08-21 16:11:09 +02:00
|
|
|
}
|
|
|
|
|
2015-05-31 15:36:44 +02:00
|
|
|
/**
|
2014-11-17 11:04:01 +08:00
|
|
|
* Format a paragraph of text to a fixed width, adding spaces for
|
Split up util.cpp/h
Split up util.cpp/h into:
- string utilities (hex, base32, base64): no internal dependencies, no dependency on boost (apart from foreach)
- money utilities (parsesmoney, formatmoney)
- time utilities (gettime*, sleep, format date):
- and the rest (logging, argument parsing, config file parsing)
The latter is basically the environment and OS handling,
and is stripped of all utility functions, so we may want to
rename it to something else than util.cpp/h for clarity (Matt suggested
osinterface).
Breaks dependency of sha256.cpp on all the things pulled in by util.
2014-08-21 16:11:09 +02:00
|
|
|
* indentation to any added line.
|
|
|
|
*/
|
2015-05-31 15:36:44 +02:00
|
|
|
std::string FormatParagraph(const std::string& in, size_t width = 79, size_t indent = 0);
|
Split up util.cpp/h
Split up util.cpp/h into:
- string utilities (hex, base32, base64): no internal dependencies, no dependency on boost (apart from foreach)
- money utilities (parsesmoney, formatmoney)
- time utilities (gettime*, sleep, format date):
- and the rest (logging, argument parsing, config file parsing)
The latter is basically the environment and OS handling,
and is stripped of all utility functions, so we may want to
rename it to something else than util.cpp/h for clarity (Matt suggested
osinterface).
Breaks dependency of sha256.cpp on all the things pulled in by util.
2014-08-21 16:11:09 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Timing-attack-resistant comparison.
|
|
|
|
* Takes time proportional to length
|
|
|
|
* of first argument.
|
|
|
|
*/
|
|
|
|
template <typename T>
|
|
|
|
bool TimingResistantEqual(const T& a, const T& b)
|
|
|
|
{
|
|
|
|
if (b.size() == 0) return a.size() == 0;
|
|
|
|
size_t accumulator = a.size() ^ b.size();
|
|
|
|
for (size_t i = 0; i < a.size(); i++)
|
|
|
|
accumulator |= a[i] ^ b[i%b.size()];
|
|
|
|
return accumulator == 0;
|
|
|
|
}
|
|
|
|
|
2015-07-06 10:49:24 +02:00
|
|
|
/** Parse number as fixed point according to JSON number syntax.
|
|
|
|
* See http://json.org/number.gif
|
|
|
|
* @returns true on success, false on error.
|
|
|
|
* @note The result must be in the range (-10^18,10^18), otherwise an overflow error will trigger.
|
|
|
|
*/
|
2018-09-25 07:00:36 +02:00
|
|
|
NODISCARD bool ParseFixedPoint(const std::string &val, int decimals, int64_t *amount_out);
|
2015-07-06 10:49:24 +02:00
|
|
|
|
2017-08-25 19:55:52 -07:00
|
|
|
/** Convert from one power-of-2 number base to another. */
|
|
|
|
template<int frombits, int tobits, bool pad, typename O, typename I>
|
2017-11-22 17:04:48 -08:00
|
|
|
bool ConvertBits(const O& outfn, I it, I end) {
|
2017-08-25 19:55:52 -07:00
|
|
|
size_t acc = 0;
|
|
|
|
size_t bits = 0;
|
|
|
|
constexpr size_t maxv = (1 << tobits) - 1;
|
|
|
|
constexpr size_t max_acc = (1 << (frombits + tobits - 1)) - 1;
|
|
|
|
while (it != end) {
|
|
|
|
acc = ((acc << frombits) | *it) & max_acc;
|
|
|
|
bits += frombits;
|
|
|
|
while (bits >= tobits) {
|
|
|
|
bits -= tobits;
|
2017-11-22 17:04:48 -08:00
|
|
|
outfn((acc >> bits) & maxv);
|
2017-08-25 19:55:52 -07:00
|
|
|
}
|
|
|
|
++it;
|
|
|
|
}
|
|
|
|
if (pad) {
|
2017-11-22 17:04:48 -08:00
|
|
|
if (bits) outfn((acc << (tobits - bits)) & maxv);
|
2017-08-25 19:55:52 -07:00
|
|
|
} else if (bits >= frombits || ((acc << (tobits - bits)) & maxv)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2018-08-28 18:42:27 +02:00
|
|
|
/**
|
|
|
|
* Converts the given character to its lowercase equivalent.
|
|
|
|
* This function is locale independent. It only converts uppercase
|
|
|
|
* characters in the standard 7-bit ASCII range.
|
2019-08-07 13:42:54 +09:00
|
|
|
* This is a feature, not a limitation.
|
|
|
|
*
|
2018-08-28 18:42:27 +02:00
|
|
|
* @param[in] c the character to convert to lowercase.
|
|
|
|
* @return the lowercase equivalent of c; or the argument
|
|
|
|
* if no conversion is possible.
|
|
|
|
*/
|
2019-01-10 01:46:32 +01:00
|
|
|
constexpr char ToLower(char c)
|
2018-08-28 18:42:27 +02:00
|
|
|
{
|
|
|
|
return (c >= 'A' && c <= 'Z' ? (c - 'A') + 'a' : c);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2019-08-07 13:42:54 +09:00
|
|
|
* Returns the lowercase equivalent of the given string.
|
2018-08-28 18:42:27 +02:00
|
|
|
* This function is locale independent. It only converts uppercase
|
|
|
|
* characters in the standard 7-bit ASCII range.
|
2019-08-07 13:42:54 +09:00
|
|
|
* This is a feature, not a limitation.
|
|
|
|
*
|
|
|
|
* @param[in] str the string to convert to lowercase.
|
|
|
|
* @returns lowercased equivalent of str
|
2018-08-28 18:42:27 +02:00
|
|
|
*/
|
2019-08-07 13:42:54 +09:00
|
|
|
std::string ToLower(const std::string& str);
|
2018-08-28 18:42:27 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Converts the given character to its uppercase equivalent.
|
|
|
|
* This function is locale independent. It only converts lowercase
|
|
|
|
* characters in the standard 7-bit ASCII range.
|
2019-08-07 13:42:54 +09:00
|
|
|
* This is a feature, not a limitation.
|
|
|
|
*
|
2018-08-28 18:42:27 +02:00
|
|
|
* @param[in] c the character to convert to uppercase.
|
|
|
|
* @return the uppercase equivalent of c; or the argument
|
|
|
|
* if no conversion is possible.
|
|
|
|
*/
|
2019-01-10 01:46:32 +01:00
|
|
|
constexpr char ToUpper(char c)
|
2018-08-28 18:42:27 +02:00
|
|
|
{
|
|
|
|
return (c >= 'a' && c <= 'z' ? (c - 'a') + 'A' : c);
|
|
|
|
}
|
|
|
|
|
2019-08-07 13:42:54 +09:00
|
|
|
/**
|
|
|
|
* Returns the uppercase equivalent of the given string.
|
|
|
|
* This function is locale independent. It only converts lowercase
|
|
|
|
* characters in the standard 7-bit ASCII range.
|
|
|
|
* This is a feature, not a limitation.
|
|
|
|
*
|
|
|
|
* @param[in] str the string to convert to uppercase.
|
|
|
|
* @returns UPPERCASED EQUIVALENT OF str
|
|
|
|
*/
|
|
|
|
std::string ToUpper(const std::string& str);
|
|
|
|
|
2018-08-28 18:42:27 +02:00
|
|
|
/**
|
|
|
|
* Capitalizes the first character of the given string.
|
2019-08-07 13:42:54 +09:00
|
|
|
* This function is locale independent. It only converts lowercase
|
|
|
|
* characters in the standard 7-bit ASCII range.
|
|
|
|
* This is a feature, not a limitation.
|
|
|
|
*
|
2018-08-28 18:42:27 +02:00
|
|
|
* @param[in] str the string to capitalize.
|
2019-08-07 13:42:54 +09:00
|
|
|
* @returns string with the first letter capitalized.
|
2018-08-28 18:42:27 +02:00
|
|
|
*/
|
|
|
|
std::string Capitalize(std::string str);
|
|
|
|
|
2018-10-22 15:51:11 -07:00
|
|
|
#endif // BITCOIN_UTIL_STRENCODINGS_H
|