|
@@ -45,7 +45,7 @@ const char *JSON::tk_name[TK_MAX] = {
|
|
|
"EOF",
|
|
|
};
|
|
|
|
|
|
-static String _make_indent(const String &p_indent, int p_size) {
|
|
|
+String JSON::_make_indent(const String &p_indent, int p_size) {
|
|
|
String indent_text = "";
|
|
|
if (!p_indent.is_empty()) {
|
|
|
for (int i = 0; i < p_size; i++) {
|
|
@@ -55,7 +55,7 @@ static String _make_indent(const String &p_indent, int p_size) {
|
|
|
return indent_text;
|
|
|
}
|
|
|
|
|
|
-String JSON::_print_var(const Variant &p_var, const String &p_indent, int p_cur_indent, bool p_sort_keys, Set<const void *> &p_markers, bool p_full_precision) {
|
|
|
+String JSON::_stringify(const Variant &p_var, const String &p_indent, int p_cur_indent, bool p_sort_keys, Set<const void *> &p_markers, bool p_full_precision) {
|
|
|
String colon = ":";
|
|
|
String end_statement = "";
|
|
|
|
|
@@ -100,7 +100,7 @@ String JSON::_print_var(const Variant &p_var, const String &p_indent, int p_cur_
|
|
|
s += ",";
|
|
|
s += end_statement;
|
|
|
}
|
|
|
- s += _make_indent(p_indent, p_cur_indent + 1) + _print_var(a[i], p_indent, p_cur_indent + 1, p_sort_keys, p_markers);
|
|
|
+ s += _make_indent(p_indent, p_cur_indent + 1) + _stringify(a[i], p_indent, p_cur_indent + 1, p_sort_keys, p_markers);
|
|
|
}
|
|
|
s += end_statement + _make_indent(p_indent, p_cur_indent) + "]";
|
|
|
p_markers.erase(a.id());
|
|
@@ -126,9 +126,9 @@ String JSON::_print_var(const Variant &p_var, const String &p_indent, int p_cur_
|
|
|
s += ",";
|
|
|
s += end_statement;
|
|
|
}
|
|
|
- s += _make_indent(p_indent, p_cur_indent + 1) + _print_var(String(E->get()), p_indent, p_cur_indent + 1, p_sort_keys, p_markers);
|
|
|
+ s += _make_indent(p_indent, p_cur_indent + 1) + _stringify(String(E->get()), p_indent, p_cur_indent + 1, p_sort_keys, p_markers);
|
|
|
s += colon;
|
|
|
- s += _print_var(d[E->get()], p_indent, p_cur_indent + 1, p_sort_keys, p_markers);
|
|
|
+ s += _stringify(d[E->get()], p_indent, p_cur_indent + 1, p_sort_keys, p_markers);
|
|
|
}
|
|
|
|
|
|
s += end_statement + _make_indent(p_indent, p_cur_indent) + "}";
|
|
@@ -140,11 +140,6 @@ String JSON::_print_var(const Variant &p_var, const String &p_indent, int p_cur_
|
|
|
}
|
|
|
}
|
|
|
|
|
|
-String JSON::print(const Variant &p_var, const String &p_indent, bool p_sort_keys, bool p_full_precision) {
|
|
|
- Set<const void *> markers;
|
|
|
- return _print_var(p_var, p_indent, 0, p_sort_keys, markers, p_full_precision);
|
|
|
-}
|
|
|
-
|
|
|
Error JSON::_get_token(const char32_t *p_str, int &index, int p_len, Token &r_token, int &line, String &r_err_str) {
|
|
|
while (p_len > 0) {
|
|
|
switch (p_str[index]) {
|
|
@@ -499,7 +494,7 @@ Error JSON::_parse_object(Dictionary &object, const char32_t *p_str, int &index,
|
|
|
return ERR_PARSE_ERROR;
|
|
|
}
|
|
|
|
|
|
-Error JSON::parse(const String &p_json, Variant &r_ret, String &r_err_str, int &r_err_line) {
|
|
|
+Error JSON::_parse_string(const String &p_json, Variant &r_ret, String &r_err_str, int &r_err_line) {
|
|
|
const char32_t *str = p_json.ptr();
|
|
|
int idx = 0;
|
|
|
int len = p_json.length();
|
|
@@ -530,34 +525,24 @@ Error JSON::parse(const String &p_json, Variant &r_ret, String &r_err_str, int &
|
|
|
return err;
|
|
|
}
|
|
|
|
|
|
-Error JSONParser::parse_string(const String &p_json_string) {
|
|
|
- return JSON::parse(p_json_string, data, err_text, err_line);
|
|
|
-}
|
|
|
-String JSONParser::get_error_text() const {
|
|
|
- return err_text;
|
|
|
-}
|
|
|
-int JSONParser::get_error_line() const {
|
|
|
- return err_line;
|
|
|
-}
|
|
|
-Variant JSONParser::get_data() const {
|
|
|
- return data;
|
|
|
+String JSON::stringify(const Variant &p_var, const String &p_indent, bool p_sort_keys, bool p_full_precision) {
|
|
|
+ Set<const void *> markers;
|
|
|
+ return _stringify(p_var, p_indent, 0, p_sort_keys, markers, p_full_precision);
|
|
|
}
|
|
|
|
|
|
-Error JSONParser::decode_data(const Variant &p_data, const String &p_indent, bool p_sort_keys) {
|
|
|
- string = JSON::print(p_data, p_indent, p_sort_keys);
|
|
|
- data = p_data;
|
|
|
- return OK;
|
|
|
+Error JSON::parse(const String &p_json_string) {
|
|
|
+ Error err = _parse_string(p_json_string, data, err_str, err_line);
|
|
|
+ if (err == Error::OK) {
|
|
|
+ err_line = 0;
|
|
|
+ }
|
|
|
+ return err;
|
|
|
}
|
|
|
|
|
|
-String JSONParser::get_string() const {
|
|
|
- return string;
|
|
|
-}
|
|
|
+void JSON::_bind_methods() {
|
|
|
+ ClassDB::bind_method(D_METHOD("stringify", "data", "indent", "sort_keys", "full_precision"), &JSON::stringify, DEFVAL(""), DEFVAL(true), DEFVAL(false));
|
|
|
+ ClassDB::bind_method(D_METHOD("parse", "json_string"), &JSON::parse);
|
|
|
|
|
|
-void JSONParser::_bind_methods() {
|
|
|
- ClassDB::bind_method(D_METHOD("parse_string", "json_string"), &JSONParser::parse_string);
|
|
|
- ClassDB::bind_method(D_METHOD("get_error_text"), &JSONParser::get_error_text);
|
|
|
- ClassDB::bind_method(D_METHOD("get_error_line"), &JSONParser::get_error_line);
|
|
|
- ClassDB::bind_method(D_METHOD("get_data"), &JSONParser::get_data);
|
|
|
- ClassDB::bind_method(D_METHOD("decode_data", "data", "indent", "sort_keys"), &JSONParser::decode_data, DEFVAL(""), DEFVAL(true));
|
|
|
- ClassDB::bind_method(D_METHOD("get_string"), &JSONParser::get_string);
|
|
|
+ ClassDB::bind_method(D_METHOD("get_data"), &JSON::get_data);
|
|
|
+ ClassDB::bind_method(D_METHOD("get_error_line"), &JSON::get_error_line);
|
|
|
+ ClassDB::bind_method(D_METHOD("get_error_message"), &JSON::get_error_message);
|
|
|
}
|