![]() |
BSHA3
0.17.99
P2P Blockchain, based on Bitcoin
|
#include <stdint.h>
#include <string>
#include <vector>
Go to the source code of this file.
Macros | |
#define | BEGIN(a) ((char*)&(a)) |
Utilities for converting data from/to strings. More... | |
#define | END(a) ((char*)&((&(a))[1])) |
#define | UBEGIN(a) ((unsigned char*)&(a)) |
#define | UEND(a) ((unsigned char*)&((&(a))[1])) |
#define | ARRAYLEN(array) (sizeof(array)/sizeof((array)[0])) |
Enumerations | |
enum | SafeChars { SAFE_CHARS_DEFAULT, SAFE_CHARS_UA_COMMENT, SAFE_CHARS_FILENAME } |
Used by SanitizeString() More... | |
Functions | |
std::string | SanitizeString (const std::string &str, int rule=SAFE_CHARS_DEFAULT) |
Remove unsafe chars. More... | |
std::vector< unsigned char > | ParseHex (const char *psz) |
std::vector< unsigned char > | ParseHex (const std::string &str) |
signed char | HexDigit (char c) |
bool | IsHex (const std::string &str) |
bool | IsHexNumber (const std::string &str) |
Return true if the string is a hex number, optionally prefixed with "0x". More... | |
std::vector< unsigned char > | DecodeBase64 (const char *p, bool *pfInvalid=nullptr) |
std::string | DecodeBase64 (const std::string &str) |
std::string | EncodeBase64 (const unsigned char *pch, size_t len) |
std::string | EncodeBase64 (const std::string &str) |
std::vector< unsigned char > | DecodeBase32 (const char *p, bool *pfInvalid=nullptr) |
std::string | DecodeBase32 (const std::string &str) |
std::string | EncodeBase32 (const unsigned char *pch, size_t len) |
std::string | EncodeBase32 (const std::string &str) |
void | SplitHostPort (std::string in, int &portOut, std::string &hostOut) |
std::string | i64tostr (int64_t n) |
std::string | itostr (int n) |
int64_t | atoi64 (const char *psz) |
int64_t | atoi64 (const std::string &str) |
int | atoi (const std::string &str) |
constexpr bool | IsDigit (char c) |
Tests if the given character is a decimal digit. More... | |
constexpr bool | IsSpace (char c) noexcept |
Tests if the given character is a whitespace character. More... | |
bool | ParseInt32 (const std::string &str, int32_t *out) |
Convert string to signed 32-bit integer with strict parse error feedback. More... | |
bool | ParseInt64 (const std::string &str, int64_t *out) |
Convert string to signed 64-bit integer with strict parse error feedback. More... | |
bool | ParseUInt32 (const std::string &str, uint32_t *out) |
Convert decimal string to unsigned 32-bit integer with strict parse error feedback. More... | |
bool | ParseUInt64 (const std::string &str, uint64_t *out) |
Convert decimal string to unsigned 64-bit integer with strict parse error feedback. More... | |
bool | ParseDouble (const std::string &str, double *out) |
Convert string to double with strict parse error feedback. More... | |
template<typename T > | |
std::string | HexStr (const T itbegin, const T itend, bool fSpaces=false) |
template<typename T > | |
std::string | HexStr (const T &vch, bool fSpaces=false) |
std::string | FormatParagraph (const std::string &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. More... | |
template<typename T > | |
bool | TimingResistantEqual (const T &a, const T &b) |
Timing-attack-resistant comparison. More... | |
bool | ParseFixedPoint (const std::string &val, int decimals, int64_t *amount_out) |
Parse number as fixed point according to JSON number syntax. More... | |
template<int frombits, int tobits, bool pad, typename O , typename I > | |
bool | ConvertBits (const O &outfn, I it, I end) |
Convert from one power-of-2 number base to another. More... | |
bool | ParseHDKeypath (const std::string &keypath_str, std::vector< uint32_t > &keypath) |
Parse an HD keypaths like "m/7/0'/2000". More... | |
constexpr unsigned char | ToLower (unsigned char c) |
Converts the given character to its lowercase equivalent. More... | |
void | Downcase (std::string &str) |
Converts the given string to its lowercase equivalent. More... | |
constexpr unsigned char | ToUpper (unsigned char c) |
Converts the given character to its uppercase equivalent. More... | |
std::string | Capitalize (std::string str) |
Capitalizes the first character of the given string. More... | |
#define ARRAYLEN | ( | array | ) | (sizeof(array)/sizeof((array)[0])) |
Definition at line 20 of file utilstrencodings.h.
#define BEGIN | ( | a | ) | ((char*)&(a)) |
Utilities for converting data from/to strings.
Definition at line 16 of file utilstrencodings.h.
#define END | ( | a | ) | ((char*)&((&(a))[1])) |
Definition at line 17 of file utilstrencodings.h.
#define UBEGIN | ( | a | ) | ((unsigned char*)&(a)) |
Definition at line 18 of file utilstrencodings.h.
#define UEND | ( | a | ) | ((unsigned char*)&((&(a))[1])) |
Definition at line 19 of file utilstrencodings.h.
enum SafeChars |
Used by SanitizeString()
Enumerator | |
---|---|
SAFE_CHARS_DEFAULT | The full set of allowed chars. |
SAFE_CHARS_UA_COMMENT | BIP-0014 subset. |
SAFE_CHARS_FILENAME | Chars allowed in filenames. |
Definition at line 23 of file utilstrencodings.h.
int atoi | ( | const std::string & | str | ) |
Definition at line 424 of file utilstrencodings.cpp.
int64_t atoi64 | ( | const char * | psz | ) |
int64_t atoi64 | ( | const std::string & | str | ) |
Definition at line 415 of file utilstrencodings.cpp.
std::string Capitalize | ( | std::string | str | ) |
Capitalizes the first character of the given string.
This function is locale independent. It only capitalizes the first character of the argument if it has an uppercase equivalent in the standard 7-bit ASCII range.
[in] | str | the string to capitalize. |
Definition at line 594 of file utilstrencodings.cpp.
bool ConvertBits | ( | const O & | outfn, |
I | it, | ||
I | end | ||
) |
Convert from one power-of-2 number base to another.
Definition at line 179 of file utilstrencodings.h.
std::vector<unsigned char> DecodeBase32 | ( | const char * | p, |
bool * | pfInvalid = nullptr |
||
) |
Definition at line 212 of file utilstrencodings.cpp.
std::string DecodeBase32 | ( | const std::string & | str | ) |
std::vector<unsigned char> DecodeBase64 | ( | const char * | p, |
bool * | pfInvalid = nullptr |
||
) |
Definition at line 143 of file utilstrencodings.cpp.
std::string DecodeBase64 | ( | const std::string & | str | ) |
void Downcase | ( | std::string & | str | ) |
Converts the given string to its lowercase equivalent.
This function is locale independent. It only converts uppercase characters in the standard 7-bit ASCII range.
[in,out] | str | the string to convert to lowercase. |
Definition at line 589 of file utilstrencodings.cpp.
std::string EncodeBase32 | ( | const unsigned char * | pch, |
size_t | len | ||
) |
std::string EncodeBase32 | ( | const std::string & | str | ) |
std::string EncodeBase64 | ( | const unsigned char * | pch, |
size_t | len | ||
) |
std::string EncodeBase64 | ( | const std::string & | str | ) |
std::string FormatParagraph | ( | const std::string & | 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.
Definition at line 355 of file utilstrencodings.cpp.
signed char HexDigit | ( | char | c | ) |
std::string HexStr | ( | const T | itbegin, |
const T | itend, | ||
bool | fSpaces = false |
||
) |
|
inline |
std::string i64tostr | ( | int64_t | n | ) |
Definition at line 396 of file utilstrencodings.cpp.
constexpr bool IsDigit | ( | char | c | ) |
Tests if the given character is a decimal digit.
[in] | c | character to test |
Definition at line 69 of file utilstrencodings.h.
bool IsHex | ( | const std::string & | str | ) |
Definition at line 59 of file utilstrencodings.cpp.
bool IsHexNumber | ( | const std::string & | str | ) |
Return true if the string is a hex number, optionally prefixed with "0x".
Definition at line 69 of file utilstrencodings.cpp.
|
inlinenoexcept |
Tests if the given character is a whitespace character.
The whitespace characters are: space, form-feed (''), newline ('
'), carriage return (''), horizontal tab (''), and vertical tab ('').
This function is locale independent. Under the C locale this function gives the same result as std::isspace.
[in] | c | character to test |
Definition at line 85 of file utilstrencodings.h.
std::string itostr | ( | int | n | ) |
Definition at line 401 of file utilstrencodings.cpp.
bool ParseDouble | ( | const std::string & | str, |
double * | out | ||
) |
Convert string to double with strict parse error feedback.
Definition at line 341 of file utilstrencodings.cpp.
bool ParseFixedPoint | ( | const std::string & | val, |
int | decimals, | ||
int64_t * | amount_out | ||
) |
Parse number as fixed point according to JSON number syntax.
See http://json.org/number.gif
Definition at line 456 of file utilstrencodings.cpp.
bool ParseHDKeypath | ( | const std::string & | keypath_str, |
std::vector< uint32_t > & | keypath | ||
) |
Parse an HD keypaths like "m/7/0'/2000".
Definition at line 548 of file utilstrencodings.cpp.
std::vector<unsigned char> ParseHex | ( | const char * | psz | ) |
Definition at line 82 of file utilstrencodings.cpp.
std::vector<unsigned char> ParseHex | ( | const std::string & | str | ) |
bool ParseInt32 | ( | const std::string & | str, |
int32_t * | out | ||
) |
Convert string to signed 32-bit integer with strict parse error feedback.
Definition at line 276 of file utilstrencodings.cpp.
bool ParseInt64 | ( | const std::string & | str, |
int64_t * | out | ||
) |
Convert string to signed 64-bit integer with strict parse error feedback.
Definition at line 292 of file utilstrencodings.cpp.
bool ParseUInt32 | ( | const std::string & | str, |
uint32_t * | out | ||
) |
Convert decimal string to unsigned 32-bit integer with strict parse error feedback.
Definition at line 307 of file utilstrencodings.cpp.
bool ParseUInt64 | ( | const std::string & | str, |
uint64_t * | out | ||
) |
Convert decimal string to unsigned 64-bit integer with strict parse error feedback.
Definition at line 324 of file utilstrencodings.cpp.
std::string SanitizeString | ( | const std::string & | str, |
int | rule = SAFE_CHARS_DEFAULT |
||
) |
Remove unsafe chars.
Safe chars chosen to allow simple messages/URLs/email addresses, but avoid anything even possibly remotely dangerous like & or >
[in] | str | The string to sanitize |
[in] | rule | The set of safe chars to choose (default: least restrictive) |
Definition at line 25 of file utilstrencodings.cpp.
void SplitHostPort | ( | std::string | in, |
int & | portOut, | ||
std::string & | hostOut | ||
) |
Definition at line 108 of file utilstrencodings.cpp.
bool TimingResistantEqual | ( | const T & | a, |
const T & | b | ||
) |
Timing-attack-resistant comparison.
Takes time proportional to length of first argument.
Definition at line 161 of file utilstrencodings.h.
constexpr unsigned char ToLower | ( | unsigned char | c | ) |
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.
[in] | c | the character to convert to lowercase. |
Definition at line 212 of file utilstrencodings.h.
constexpr unsigned char ToUpper | ( | unsigned char | c | ) |
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.
[in] | c | the character to convert to uppercase. |
Definition at line 233 of file utilstrencodings.h.