5 #ifndef BITCOIN_UTIL_STRING_H 6 #define BITCOIN_UTIL_STRING_H 18 [[nodiscard]]
inline std::string
TrimString(
const std::string& str,
const std::string& pattern =
" \f\n\r\t\v")
20 std::string::size_type front = str.find_first_not_of(pattern);
21 if (front == std::string::npos) {
24 std::string::size_type end = str.find_last_not_of(pattern);
25 return str.substr(front, end - front + 1);
31 return str.substr(
prefix.size());
43 template <
typename T,
typename BaseType,
typename UnaryOp>
44 auto Join(
const std::vector<T>& list,
const BaseType& separator, UnaryOp unary_op)
45 -> decltype(unary_op(list.at(0)))
47 decltype(unary_op(list.at(0))) ret;
48 for (
size_t i = 0; i < list.size(); ++i) {
49 if (i > 0) ret += separator;
50 ret += unary_op(list.at(i));
56 T
Join(
const std::vector<T>& list,
const T& separator)
58 return Join(list, separator, [](
const T& i) {
return i; });
62 inline std::string
Join(
const std::vector<std::string>& list,
const std::string& separator)
64 return Join<std::string>(list, separator);
72 return str.size() == strlen(str.c_str());
81 std::ostringstream oss;
82 oss.imbue(std::locale::classic());
90 template <
typename T1,
size_t PREFIX_LEN>
92 const std::array<uint8_t, PREFIX_LEN>&
prefix)
94 return obj.size() >= PREFIX_LEN &&
95 std::equal(std::begin(
prefix), std::end(
prefix), std::begin(obj));
98 #endif // BITCOIN_UTIL_STRENCODINGS_H auto Join(const std::vector< T > &list, const BaseType &separator, UnaryOp unary_op) -> decltype(unary_op(list.at(0)))
Join a list of items.
std::string RemovePrefix(const std::string &str, const std::string &prefix)
std::string TrimString(const std::string &str, const std::string &pattern=" \\\)
std::string ToString(const T &t)
Locale-independent version of std::to_string.
bool HasPrefix(const T1 &obj, const std::array< uint8_t, PREFIX_LEN > &prefix)
Check whether a container begins with the given prefix.
bool ValidAsCString(const std::string &str) noexcept
Check if a string does not contain any embedded NUL (\0) characters.