File: yyjson.h

package info (click to toggle)
simdjson 4.2.4-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 27,936 kB
  • sloc: cpp: 171,612; ansic: 19,122; sh: 1,126; python: 842; makefile: 47; ruby: 25; javascript: 13
file content (125 lines) | stat: -rw-r--r-- 3,467 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
#pragma once
#ifdef SIMDJSON_COMPETITION_YYJSON

#include "json2msgpack.h"

namespace json2msgpack {

struct yyjson2msgpack {
  inline std::string_view to_msgpack(yyjson_doc *doc, uint8_t *buf);

private:
  inline void write_double(const double d) noexcept;
  inline void write_byte(const uint8_t b) noexcept;
  inline void write_uint32(const uint32_t w) noexcept;
  inline void write_string(const char *s, size_t length) noexcept;
  inline void recursive_processor(yyjson_val *obj);

  uint8_t *buff{};
};

std::string_view yyjson2msgpack::to_msgpack(yyjson_doc *doc, uint8_t *buf) {
  buff = buf;
  yyjson_val *root = yyjson_doc_get_root(doc);
  recursive_processor(root);
  return std::string_view(reinterpret_cast<char *>(buf), size_t(buff - buf));
}

void yyjson2msgpack::write_string(const char *c, size_t len) noexcept {
  write_byte(0xdb);
  write_uint32(uint32_t(len));
  ::memcpy(buff, c, len);
  buff += len;
}

void yyjson2msgpack::write_double(const double d) noexcept {
  *buff++ = 0xcb;
  ::memcpy(buff, &d, sizeof(d));
  buff += sizeof(d);
}

void yyjson2msgpack::write_byte(const uint8_t b) noexcept {
  *buff = b;
  buff++;
}

void yyjson2msgpack::write_uint32(const uint32_t w) noexcept {
  ::memcpy(buff, &w, sizeof(w));
  buff += sizeof(w);
}

void yyjson2msgpack::recursive_processor(yyjson_val *obj) {
  size_t idx, max;
  yyjson_val *val;
  yyjson_val *key;
  switch (yyjson_get_type(obj)) {
  case YYJSON_TYPE_STR:
    write_string(yyjson_get_str(obj), yyjson_get_len(obj));
    break;
  case YYJSON_TYPE_ARR:
    write_byte(0xdf);
    write_uint32(uint32_t(yyjson_arr_size(obj)));
    yyjson_arr_foreach(obj, idx, max, val) { recursive_processor(val); }
   break;
  case YYJSON_TYPE_OBJ:
    write_byte(0xdd);
    write_uint32(uint32_t(yyjson_obj_size(obj)));
    yyjson_obj_foreach(obj, idx, max, key, val) {
      write_string(yyjson_get_str(key), yyjson_get_len(key));
      recursive_processor(val);
    }
    break;
  case YYJSON_TYPE_BOOL:
    write_byte(0xc2 + yyjson_get_bool(obj));
    break;
  case YYJSON_TYPE_NULL:
    write_byte(0xc0);
    break;
  case YYJSON_TYPE_NUM:
    switch (yyjson_get_subtype(obj)) {
    case YYJSON_SUBTYPE_UINT:
      write_double(double(yyjson_get_uint(obj)));
      break;
    case YYJSON_SUBTYPE_SINT:
      write_double(double(yyjson_get_sint(obj)));
      break;
    case YYJSON_SUBTYPE_REAL:
      write_double(yyjson_get_real(obj));
      break;
    default:
      SIMDJSON_UNREACHABLE();
    }
    break;
  default:
    SIMDJSON_UNREACHABLE();
  }
}

struct yyjson : yyjson2msgpack {
  bool run(simdjson::padded_string &json, char *buffer,
           std::string_view &result) {
    yyjson_doc *doc = yyjson_read(json.data(), json.size(), 0);
    result = to_msgpack(doc, reinterpret_cast<uint8_t*>(buffer));
    yyjson_doc_free(doc);
    return true;
  }
};

BENCHMARK_TEMPLATE(json2msgpack, yyjson)->UseManualTime();

#if SIMDJSON_COMPETITION_ONDEMAND_INSITU
struct yyjson_insitu : yyjson2msgpack {
  bool run(simdjson::padded_string &json, char *buffer,
           std::string_view &result) {
    yyjson_doc *doc =
        yyjson_read_opts(json.data(), json.size(), YYJSON_READ_INSITU, 0, 0);
    result = to_msgpack(doc, reinterpret_cast<uint8_t*>(buffer));
    yyjson_doc_free(doc);
    return true;
  }
};
BENCHMARK_TEMPLATE(json2msgpack, yyjson_insitu)->UseManualTime();
#endif // SIMDJSON_COMPETITION_ONDEMAND_INSITU
} // namespace json2msgpack

#endif // SIMDJSON_COMPETITION_YYJSON