mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-01-26 11:13:23 -03:00
Removes Boost predicate.hpp dependency
This is a squashed commit that squashes the following commits: This commit removes the `boost/algorithm/string/predicate.hpp` dependenc from the project by replacing the function calls to `boost::algorithm::starts_with` `boost::algorithm::ends_with` and `all` with respectively C++11' `std::basic_string::front`, `std::basic_string::back`, `std::all_of` function calls This commit replaces `boost::algorithm::is_digit` with a locale independent isdigi function, because the use of the standard library's `isdigit` and `std::isdigit functions is discoraged in the developer notes
This commit is contained in:
parent
0a34593ddb
commit
e3245f2e7b
7 changed files with 39 additions and 16 deletions
|
@ -16,10 +16,11 @@
|
||||||
#include <version.h>
|
#include <version.h>
|
||||||
|
|
||||||
#include <boost/algorithm/string/classification.hpp>
|
#include <boost/algorithm/string/classification.hpp>
|
||||||
#include <boost/algorithm/string/predicate.hpp>
|
|
||||||
#include <boost/algorithm/string/replace.hpp>
|
#include <boost/algorithm/string/replace.hpp>
|
||||||
#include <boost/algorithm/string/split.hpp>
|
#include <boost/algorithm/string/split.hpp>
|
||||||
|
|
||||||
|
#include <algorithm>
|
||||||
|
|
||||||
CScript ParseScript(const std::string& s)
|
CScript ParseScript(const std::string& s)
|
||||||
{
|
{
|
||||||
CScript result;
|
CScript result;
|
||||||
|
@ -54,20 +55,20 @@ CScript ParseScript(const std::string& s)
|
||||||
{
|
{
|
||||||
// Empty string, ignore. (boost::split given '' will return one word)
|
// Empty string, ignore. (boost::split given '' will return one word)
|
||||||
}
|
}
|
||||||
else if (all(*w, boost::algorithm::is_digit()) ||
|
else if (std::all_of(w->begin(), w->end(), ::IsDigit) ||
|
||||||
(boost::algorithm::starts_with(*w, "-") && all(std::string(w->begin()+1, w->end()), boost::algorithm::is_digit())))
|
(w->front() == '-' && w->size() > 1 && std::all_of(w->begin()+1, w->end(), ::IsDigit)))
|
||||||
{
|
{
|
||||||
// Number
|
// Number
|
||||||
int64_t n = atoi64(*w);
|
int64_t n = atoi64(*w);
|
||||||
result << n;
|
result << n;
|
||||||
}
|
}
|
||||||
else if (boost::algorithm::starts_with(*w, "0x") && (w->begin()+2 != w->end()) && IsHex(std::string(w->begin()+2, w->end())))
|
else if (w->substr(0,2) == "0x" && w->size() > 2 && IsHex(std::string(w->begin()+2, w->end())))
|
||||||
{
|
{
|
||||||
// Raw hex data, inserted NOT pushed onto stack:
|
// Raw hex data, inserted NOT pushed onto stack:
|
||||||
std::vector<unsigned char> raw = ParseHex(std::string(w->begin()+2, w->end()));
|
std::vector<unsigned char> raw = ParseHex(std::string(w->begin()+2, w->end()));
|
||||||
result.insert(result.end(), raw.begin(), raw.end());
|
result.insert(result.end(), raw.begin(), raw.end());
|
||||||
}
|
}
|
||||||
else if (w->size() >= 2 && boost::algorithm::starts_with(*w, "'") && boost::algorithm::ends_with(*w, "'"))
|
else if (w->size() >= 2 && w->front() == '\'' && w->back() == '\'')
|
||||||
{
|
{
|
||||||
// Single-quoted string, pushed as data. NOTE: this is poor-man's
|
// Single-quoted string, pushed as data. NOTE: this is poor-man's
|
||||||
// parsing, spaces/tabs/newlines in single-quoted strings won't work.
|
// parsing, spaces/tabs/newlines in single-quoted strings won't work.
|
||||||
|
|
|
@ -20,7 +20,6 @@
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include <boost/algorithm/string/case_conv.hpp> // for to_lower()
|
#include <boost/algorithm/string/case_conv.hpp> // for to_lower()
|
||||||
#include <boost/algorithm/string/predicate.hpp> // for startswith() and endswith()
|
|
||||||
|
|
||||||
#if !defined(MSG_NOSIGNAL)
|
#if !defined(MSG_NOSIGNAL)
|
||||||
#define MSG_NOSIGNAL 0
|
#define MSG_NOSIGNAL 0
|
||||||
|
@ -121,8 +120,7 @@ bool LookupHost(const char *pszName, std::vector<CNetAddr>& vIP, unsigned int nM
|
||||||
std::string strHost(pszName);
|
std::string strHost(pszName);
|
||||||
if (strHost.empty())
|
if (strHost.empty())
|
||||||
return false;
|
return false;
|
||||||
if (boost::algorithm::starts_with(strHost, "[") && boost::algorithm::ends_with(strHost, "]"))
|
if (strHost.front() == '[' && strHost.back() == ']') {
|
||||||
{
|
|
||||||
strHost = strHost.substr(1, strHost.size() - 2);
|
strHost = strHost.substr(1, strHost.size() - 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -806,6 +806,21 @@ BOOST_AUTO_TEST_CASE(gettime)
|
||||||
BOOST_CHECK((GetTime() & ~0xFFFFFFFFLL) == 0);
|
BOOST_CHECK((GetTime() & ~0xFFFFFFFFLL) == 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
BOOST_AUTO_TEST_CASE(test_IsDigit)
|
||||||
|
{
|
||||||
|
BOOST_CHECK_EQUAL(IsDigit('0'), true);
|
||||||
|
BOOST_CHECK_EQUAL(IsDigit('1'), true);
|
||||||
|
BOOST_CHECK_EQUAL(IsDigit('8'), true);
|
||||||
|
BOOST_CHECK_EQUAL(IsDigit('9'), true);
|
||||||
|
|
||||||
|
BOOST_CHECK_EQUAL(IsDigit('0' - 1), false);
|
||||||
|
BOOST_CHECK_EQUAL(IsDigit('9' + 1), false);
|
||||||
|
BOOST_CHECK_EQUAL(IsDigit(0), false);
|
||||||
|
BOOST_CHECK_EQUAL(IsDigit(1), false);
|
||||||
|
BOOST_CHECK_EQUAL(IsDigit(8), false);
|
||||||
|
BOOST_CHECK_EQUAL(IsDigit(9), false);
|
||||||
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_CASE(test_ParseInt32)
|
BOOST_AUTO_TEST_CASE(test_ParseInt32)
|
||||||
{
|
{
|
||||||
int32_t n;
|
int32_t n;
|
||||||
|
|
|
@ -473,7 +473,7 @@ bool ParseFixedPoint(const std::string &val, int decimals, int64_t *amount_out)
|
||||||
/* pass single 0 */
|
/* pass single 0 */
|
||||||
++ptr;
|
++ptr;
|
||||||
} else if (val[ptr] >= '1' && val[ptr] <= '9') {
|
} else if (val[ptr] >= '1' && val[ptr] <= '9') {
|
||||||
while (ptr < end && val[ptr] >= '0' && val[ptr] <= '9') {
|
while (ptr < end && IsDigit(val[ptr])) {
|
||||||
if (!ProcessMantissaDigit(val[ptr], mantissa, mantissa_tzeros))
|
if (!ProcessMantissaDigit(val[ptr], mantissa, mantissa_tzeros))
|
||||||
return false; /* overflow */
|
return false; /* overflow */
|
||||||
++ptr;
|
++ptr;
|
||||||
|
@ -483,9 +483,9 @@ bool ParseFixedPoint(const std::string &val, int decimals, int64_t *amount_out)
|
||||||
if (ptr < end && val[ptr] == '.')
|
if (ptr < end && val[ptr] == '.')
|
||||||
{
|
{
|
||||||
++ptr;
|
++ptr;
|
||||||
if (ptr < end && val[ptr] >= '0' && val[ptr] <= '9')
|
if (ptr < end && IsDigit(val[ptr]))
|
||||||
{
|
{
|
||||||
while (ptr < end && val[ptr] >= '0' && val[ptr] <= '9') {
|
while (ptr < end && IsDigit(val[ptr])) {
|
||||||
if (!ProcessMantissaDigit(val[ptr], mantissa, mantissa_tzeros))
|
if (!ProcessMantissaDigit(val[ptr], mantissa, mantissa_tzeros))
|
||||||
return false; /* overflow */
|
return false; /* overflow */
|
||||||
++ptr;
|
++ptr;
|
||||||
|
@ -502,8 +502,8 @@ bool ParseFixedPoint(const std::string &val, int decimals, int64_t *amount_out)
|
||||||
exponent_sign = true;
|
exponent_sign = true;
|
||||||
++ptr;
|
++ptr;
|
||||||
}
|
}
|
||||||
if (ptr < end && val[ptr] >= '0' && val[ptr] <= '9') {
|
if (ptr < end && IsDigit(val[ptr])) {
|
||||||
while (ptr < end && val[ptr] >= '0' && val[ptr] <= '9') {
|
while (ptr < end && IsDigit(val[ptr])) {
|
||||||
if (exponent > (UPPER_BOUND / 10LL))
|
if (exponent > (UPPER_BOUND / 10LL))
|
||||||
return false; /* overflow */
|
return false; /* overflow */
|
||||||
exponent = exponent * 10 + val[ptr] - '0';
|
exponent = exponent * 10 + val[ptr] - '0';
|
||||||
|
|
|
@ -61,6 +61,16 @@ int64_t atoi64(const char* psz);
|
||||||
int64_t atoi64(const std::string& str);
|
int64_t atoi64(const std::string& str);
|
||||||
int atoi(const std::string& str);
|
int atoi(const std::string& str);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 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';
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Convert string to signed 32-bit integer with strict parse error feedback.
|
* Convert string to signed 32-bit integer with strict parse error feedback.
|
||||||
* @returns true if the entire string could be parsed as valid integer,
|
* @returns true if the entire string could be parsed as valid integer,
|
||||||
|
|
|
@ -585,13 +585,13 @@ UniValue importwallet(const JSONRPCRequest& request)
|
||||||
std::string strLabel;
|
std::string strLabel;
|
||||||
bool fLabel = true;
|
bool fLabel = true;
|
||||||
for (unsigned int nStr = 2; nStr < vstr.size(); nStr++) {
|
for (unsigned int nStr = 2; nStr < vstr.size(); nStr++) {
|
||||||
if (boost::algorithm::starts_with(vstr[nStr], "#"))
|
if (vstr[nStr].front() == '#')
|
||||||
break;
|
break;
|
||||||
if (vstr[nStr] == "change=1")
|
if (vstr[nStr] == "change=1")
|
||||||
fLabel = false;
|
fLabel = false;
|
||||||
if (vstr[nStr] == "reserve=1")
|
if (vstr[nStr] == "reserve=1")
|
||||||
fLabel = false;
|
fLabel = false;
|
||||||
if (boost::algorithm::starts_with(vstr[nStr], "label=")) {
|
if (vstr[nStr].substr(0,6) == "label=") {
|
||||||
strLabel = DecodeDumpString(vstr[nStr].substr(6));
|
strLabel = DecodeDumpString(vstr[nStr].substr(6));
|
||||||
fLabel = true;
|
fLabel = true;
|
||||||
}
|
}
|
||||||
|
|
|
@ -49,7 +49,6 @@ EXPECTED_BOOST_INCLUDES=(
|
||||||
boost/algorithm/string.hpp
|
boost/algorithm/string.hpp
|
||||||
boost/algorithm/string/case_conv.hpp
|
boost/algorithm/string/case_conv.hpp
|
||||||
boost/algorithm/string/classification.hpp
|
boost/algorithm/string/classification.hpp
|
||||||
boost/algorithm/string/predicate.hpp
|
|
||||||
boost/algorithm/string/replace.hpp
|
boost/algorithm/string/replace.hpp
|
||||||
boost/algorithm/string/split.hpp
|
boost/algorithm/string/split.hpp
|
||||||
boost/bind.hpp
|
boost/bind.hpp
|
||||||
|
|
Loading…
Add table
Reference in a new issue