mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-01-25 10:43:19 -03:00
Update univalue subtree
This commit is contained in:
commit
faad55a9a2
6 changed files with 27 additions and 104 deletions
|
@ -12,8 +12,6 @@
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include "univalue.h"
|
#include "univalue.h"
|
||||||
|
|
||||||
using namespace std;
|
|
||||||
|
|
||||||
static bool initEscapes;
|
static bool initEscapes;
|
||||||
static std::string escapes[256];
|
static std::string escapes[256];
|
||||||
|
|
||||||
|
|
|
@ -15,7 +15,6 @@
|
||||||
#include <cassert>
|
#include <cassert>
|
||||||
|
|
||||||
#include <sstream> // .get_int64()
|
#include <sstream> // .get_int64()
|
||||||
#include <utility> // std::pair
|
|
||||||
|
|
||||||
class UniValue {
|
class UniValue {
|
||||||
public:
|
public:
|
||||||
|
@ -177,76 +176,9 @@ public:
|
||||||
const UniValue& get_array() const;
|
const UniValue& get_array() const;
|
||||||
|
|
||||||
enum VType type() const { return getType(); }
|
enum VType type() const { return getType(); }
|
||||||
bool push_back(std::pair<std::string,UniValue> pear) {
|
|
||||||
return pushKV(pear.first, pear.second);
|
|
||||||
}
|
|
||||||
friend const UniValue& find_value( const UniValue& obj, const std::string& name);
|
friend const UniValue& find_value( const UniValue& obj, const std::string& name);
|
||||||
};
|
};
|
||||||
|
|
||||||
//
|
|
||||||
// The following were added for compatibility with json_spirit.
|
|
||||||
// Most duplicate other methods, and should be removed.
|
|
||||||
//
|
|
||||||
static inline std::pair<std::string,UniValue> Pair(const char *cKey, const char *cVal)
|
|
||||||
{
|
|
||||||
std::string key(cKey);
|
|
||||||
UniValue uVal(cVal);
|
|
||||||
return std::make_pair(key, uVal);
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline std::pair<std::string,UniValue> Pair(const char *cKey, std::string strVal)
|
|
||||||
{
|
|
||||||
std::string key(cKey);
|
|
||||||
UniValue uVal(strVal);
|
|
||||||
return std::make_pair(key, uVal);
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline std::pair<std::string,UniValue> Pair(const char *cKey, uint64_t u64Val)
|
|
||||||
{
|
|
||||||
std::string key(cKey);
|
|
||||||
UniValue uVal(u64Val);
|
|
||||||
return std::make_pair(key, uVal);
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline std::pair<std::string,UniValue> Pair(const char *cKey, int64_t i64Val)
|
|
||||||
{
|
|
||||||
std::string key(cKey);
|
|
||||||
UniValue uVal(i64Val);
|
|
||||||
return std::make_pair(key, uVal);
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline std::pair<std::string,UniValue> Pair(const char *cKey, bool iVal)
|
|
||||||
{
|
|
||||||
std::string key(cKey);
|
|
||||||
UniValue uVal(iVal);
|
|
||||||
return std::make_pair(key, uVal);
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline std::pair<std::string,UniValue> Pair(const char *cKey, int iVal)
|
|
||||||
{
|
|
||||||
std::string key(cKey);
|
|
||||||
UniValue uVal(iVal);
|
|
||||||
return std::make_pair(key, uVal);
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline std::pair<std::string,UniValue> Pair(const char *cKey, double dVal)
|
|
||||||
{
|
|
||||||
std::string key(cKey);
|
|
||||||
UniValue uVal(dVal);
|
|
||||||
return std::make_pair(key, uVal);
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline std::pair<std::string,UniValue> Pair(const char *cKey, const UniValue& uVal)
|
|
||||||
{
|
|
||||||
std::string key(cKey);
|
|
||||||
return std::make_pair(key, uVal);
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline std::pair<std::string,UniValue> Pair(std::string key, const UniValue& uVal)
|
|
||||||
{
|
|
||||||
return std::make_pair(key, uVal);
|
|
||||||
}
|
|
||||||
|
|
||||||
enum jtokentype {
|
enum jtokentype {
|
||||||
JTOK_ERR = -1,
|
JTOK_ERR = -1,
|
||||||
JTOK_NONE = 0, // eof
|
JTOK_NONE = 0, // eof
|
||||||
|
|
|
@ -10,8 +10,6 @@
|
||||||
|
|
||||||
#include "univalue.h"
|
#include "univalue.h"
|
||||||
|
|
||||||
using namespace std;
|
|
||||||
|
|
||||||
const UniValue NullUniValue;
|
const UniValue NullUniValue;
|
||||||
|
|
||||||
void UniValue::clear()
|
void UniValue::clear()
|
||||||
|
@ -37,15 +35,15 @@ bool UniValue::setBool(bool val_)
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool validNumStr(const string& s)
|
static bool validNumStr(const std::string& s)
|
||||||
{
|
{
|
||||||
string tokenVal;
|
std::string tokenVal;
|
||||||
unsigned int consumed;
|
unsigned int consumed;
|
||||||
enum jtokentype tt = getJsonToken(tokenVal, consumed, s.data(), s.data() + s.size());
|
enum jtokentype tt = getJsonToken(tokenVal, consumed, s.data(), s.data() + s.size());
|
||||||
return (tt == JTOK_NUMBER);
|
return (tt == JTOK_NUMBER);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool UniValue::setNumStr(const string& val_)
|
bool UniValue::setNumStr(const std::string& val_)
|
||||||
{
|
{
|
||||||
if (!validNumStr(val_))
|
if (!validNumStr(val_))
|
||||||
return false;
|
return false;
|
||||||
|
@ -58,7 +56,7 @@ bool UniValue::setNumStr(const string& val_)
|
||||||
|
|
||||||
bool UniValue::setInt(uint64_t val_)
|
bool UniValue::setInt(uint64_t val_)
|
||||||
{
|
{
|
||||||
ostringstream oss;
|
std::ostringstream oss;
|
||||||
|
|
||||||
oss << val_;
|
oss << val_;
|
||||||
|
|
||||||
|
@ -67,7 +65,7 @@ bool UniValue::setInt(uint64_t val_)
|
||||||
|
|
||||||
bool UniValue::setInt(int64_t val_)
|
bool UniValue::setInt(int64_t val_)
|
||||||
{
|
{
|
||||||
ostringstream oss;
|
std::ostringstream oss;
|
||||||
|
|
||||||
oss << val_;
|
oss << val_;
|
||||||
|
|
||||||
|
@ -76,7 +74,7 @@ bool UniValue::setInt(int64_t val_)
|
||||||
|
|
||||||
bool UniValue::setFloat(double val_)
|
bool UniValue::setFloat(double val_)
|
||||||
{
|
{
|
||||||
ostringstream oss;
|
std::ostringstream oss;
|
||||||
|
|
||||||
oss << std::setprecision(16) << val_;
|
oss << std::setprecision(16) << val_;
|
||||||
|
|
||||||
|
@ -85,7 +83,7 @@ bool UniValue::setFloat(double val_)
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool UniValue::setStr(const string& val_)
|
bool UniValue::setStr(const std::string& val_)
|
||||||
{
|
{
|
||||||
clear();
|
clear();
|
||||||
typ = VSTR;
|
typ = VSTR;
|
||||||
|
|
|
@ -8,8 +8,6 @@
|
||||||
#include "univalue.h"
|
#include "univalue.h"
|
||||||
#include "univalue_utffilter.h"
|
#include "univalue_utffilter.h"
|
||||||
|
|
||||||
using namespace std;
|
|
||||||
|
|
||||||
static bool json_isdigit(int ch)
|
static bool json_isdigit(int ch)
|
||||||
{
|
{
|
||||||
return ((ch >= '0') && (ch <= '9'));
|
return ((ch >= '0') && (ch <= '9'));
|
||||||
|
@ -42,7 +40,7 @@ static const char *hatoui(const char *first, const char *last,
|
||||||
return first;
|
return first;
|
||||||
}
|
}
|
||||||
|
|
||||||
enum jtokentype getJsonToken(string& tokenVal, unsigned int& consumed,
|
enum jtokentype getJsonToken(std::string& tokenVal, unsigned int& consumed,
|
||||||
const char *raw, const char *end)
|
const char *raw, const char *end)
|
||||||
{
|
{
|
||||||
tokenVal.clear();
|
tokenVal.clear();
|
||||||
|
@ -114,7 +112,7 @@ enum jtokentype getJsonToken(string& tokenVal, unsigned int& consumed,
|
||||||
case '8':
|
case '8':
|
||||||
case '9': {
|
case '9': {
|
||||||
// part 1: int
|
// part 1: int
|
||||||
string numStr;
|
std::string numStr;
|
||||||
|
|
||||||
const char *first = raw;
|
const char *first = raw;
|
||||||
|
|
||||||
|
@ -174,7 +172,7 @@ enum jtokentype getJsonToken(string& tokenVal, unsigned int& consumed,
|
||||||
case '"': {
|
case '"': {
|
||||||
raw++; // skip "
|
raw++; // skip "
|
||||||
|
|
||||||
string valStr;
|
std::string valStr;
|
||||||
JSONUTF8StringFilter writer(valStr);
|
JSONUTF8StringFilter writer(valStr);
|
||||||
|
|
||||||
while (true) {
|
while (true) {
|
||||||
|
@ -255,9 +253,9 @@ bool UniValue::read(const char *raw, size_t size)
|
||||||
clear();
|
clear();
|
||||||
|
|
||||||
uint32_t expectMask = 0;
|
uint32_t expectMask = 0;
|
||||||
vector<UniValue*> stack;
|
std::vector<UniValue*> stack;
|
||||||
|
|
||||||
string tokenVal;
|
std::string tokenVal;
|
||||||
unsigned int consumed;
|
unsigned int consumed;
|
||||||
enum jtokentype tok = JTOK_NONE;
|
enum jtokentype tok = JTOK_NONE;
|
||||||
enum jtokentype last_tok = JTOK_NONE;
|
enum jtokentype last_tok = JTOK_NONE;
|
||||||
|
|
|
@ -8,11 +8,9 @@
|
||||||
#include "univalue.h"
|
#include "univalue.h"
|
||||||
#include "univalue_escapes.h"
|
#include "univalue_escapes.h"
|
||||||
|
|
||||||
using namespace std;
|
static std::string json_escape(const std::string& inS)
|
||||||
|
|
||||||
static string json_escape(const string& inS)
|
|
||||||
{
|
{
|
||||||
string outS;
|
std::string outS;
|
||||||
outS.reserve(inS.size() * 2);
|
outS.reserve(inS.size() * 2);
|
||||||
|
|
||||||
for (unsigned int i = 0; i < inS.size(); i++) {
|
for (unsigned int i = 0; i < inS.size(); i++) {
|
||||||
|
@ -28,10 +26,10 @@ static string json_escape(const string& inS)
|
||||||
return outS;
|
return outS;
|
||||||
}
|
}
|
||||||
|
|
||||||
string UniValue::write(unsigned int prettyIndent,
|
std::string UniValue::write(unsigned int prettyIndent,
|
||||||
unsigned int indentLevel) const
|
unsigned int indentLevel) const
|
||||||
{
|
{
|
||||||
string s;
|
std::string s;
|
||||||
s.reserve(1024);
|
s.reserve(1024);
|
||||||
|
|
||||||
unsigned int modIndent = indentLevel;
|
unsigned int modIndent = indentLevel;
|
||||||
|
@ -62,12 +60,12 @@ string UniValue::write(unsigned int prettyIndent,
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void indentStr(unsigned int prettyIndent, unsigned int indentLevel, string& s)
|
static void indentStr(unsigned int prettyIndent, unsigned int indentLevel, std::string& s)
|
||||||
{
|
{
|
||||||
s.append(prettyIndent * indentLevel, ' ');
|
s.append(prettyIndent * indentLevel, ' ');
|
||||||
}
|
}
|
||||||
|
|
||||||
void UniValue::writeArray(unsigned int prettyIndent, unsigned int indentLevel, string& s) const
|
void UniValue::writeArray(unsigned int prettyIndent, unsigned int indentLevel, std::string& s) const
|
||||||
{
|
{
|
||||||
s += "[";
|
s += "[";
|
||||||
if (prettyIndent)
|
if (prettyIndent)
|
||||||
|
@ -89,7 +87,7 @@ void UniValue::writeArray(unsigned int prettyIndent, unsigned int indentLevel, s
|
||||||
s += "]";
|
s += "]";
|
||||||
}
|
}
|
||||||
|
|
||||||
void UniValue::writeObject(unsigned int prettyIndent, unsigned int indentLevel, string& s) const
|
void UniValue::writeObject(unsigned int prettyIndent, unsigned int indentLevel, std::string& s) const
|
||||||
{
|
{
|
||||||
s += "{";
|
s += "{";
|
||||||
if (prettyIndent)
|
if (prettyIndent)
|
||||||
|
|
|
@ -17,8 +17,7 @@
|
||||||
#define ARRAY_SIZE(arr) (sizeof(arr) / sizeof((arr)[0]))
|
#define ARRAY_SIZE(arr) (sizeof(arr) / sizeof((arr)[0]))
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
using namespace std;
|
std::string srcdir(JSON_TEST_SRC);
|
||||||
string srcdir(JSON_TEST_SRC);
|
|
||||||
static bool test_failed = false;
|
static bool test_failed = false;
|
||||||
|
|
||||||
#define d_assert(expr) { if (!(expr)) { test_failed = true; fprintf(stderr, "%s failed\n", filename.c_str()); } }
|
#define d_assert(expr) { if (!(expr)) { test_failed = true; fprintf(stderr, "%s failed\n", filename.c_str()); } }
|
||||||
|
@ -30,9 +29,9 @@ static std::string rtrim(std::string s)
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void runtest(string filename, const string& jdata)
|
static void runtest(std::string filename, const std::string& jdata)
|
||||||
{
|
{
|
||||||
string prefix = filename.substr(0, 4);
|
std::string prefix = filename.substr(0, 4);
|
||||||
|
|
||||||
bool wantPass = (prefix == "pass") || (prefix == "roun");
|
bool wantPass = (prefix == "pass") || (prefix == "roun");
|
||||||
bool wantFail = (prefix == "fail");
|
bool wantFail = (prefix == "fail");
|
||||||
|
@ -56,19 +55,19 @@ static void runtest(string filename, const string& jdata)
|
||||||
|
|
||||||
static void runtest_file(const char *filename_)
|
static void runtest_file(const char *filename_)
|
||||||
{
|
{
|
||||||
string basename(filename_);
|
std::string basename(filename_);
|
||||||
string filename = srcdir + "/" + basename;
|
std::string filename = srcdir + "/" + basename;
|
||||||
FILE *f = fopen(filename.c_str(), "r");
|
FILE *f = fopen(filename.c_str(), "r");
|
||||||
assert(f != NULL);
|
assert(f != NULL);
|
||||||
|
|
||||||
string jdata;
|
std::string jdata;
|
||||||
|
|
||||||
char buf[4096];
|
char buf[4096];
|
||||||
while (!feof(f)) {
|
while (!feof(f)) {
|
||||||
int bread = fread(buf, 1, sizeof(buf), f);
|
int bread = fread(buf, 1, sizeof(buf), f);
|
||||||
assert(!ferror(f));
|
assert(!ferror(f));
|
||||||
|
|
||||||
string s(buf, bread);
|
std::string s(buf, bread);
|
||||||
jdata += s;
|
jdata += s;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue