2021-05-31 22:15:50 +08:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#ifdef SIMDJSON_COMPETITION_NLOHMANN_JSON
|
|
|
|
|
|
|
|
#include "kostya.h"
|
|
|
|
|
|
|
|
namespace kostya {
|
|
|
|
|
|
|
|
using json = nlohmann::json;
|
|
|
|
|
|
|
|
struct nlohmann_json_sax {
|
|
|
|
static constexpr diff_flags DiffFlags = diff_flags::NONE;
|
|
|
|
|
|
|
|
struct Handler : json::json_sax_t
|
|
|
|
{
|
|
|
|
size_t k{0};
|
|
|
|
double buffer[3];
|
2021-06-04 04:40:39 +08:00
|
|
|
std::vector<point>& result;
|
2021-05-31 22:15:50 +08:00
|
|
|
|
2021-06-04 04:40:39 +08:00
|
|
|
Handler(std::vector<point>& r) : result(r) { }
|
2021-05-31 22:15:50 +08:00
|
|
|
|
|
|
|
bool key(string_t& val) override {
|
|
|
|
switch(val[0]) {
|
|
|
|
case 'x':
|
|
|
|
k = 0;
|
|
|
|
break;
|
|
|
|
case 'y':
|
|
|
|
k = 1;
|
|
|
|
break;
|
|
|
|
case 'z':
|
|
|
|
k = 2;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
2021-06-04 04:40:39 +08:00
|
|
|
bool number_float(number_float_t val, const string_t& s) override {
|
2021-05-31 22:15:50 +08:00
|
|
|
buffer[k] = val;
|
2021-06-04 04:40:39 +08:00
|
|
|
if (k == 2) {
|
|
|
|
result.emplace_back(json_benchmark::point{buffer[0],buffer[1],buffer[2]});
|
2021-05-31 22:15:50 +08:00
|
|
|
k = 0;
|
|
|
|
}
|
|
|
|
return true;
|
2021-06-04 04:40:39 +08:00
|
|
|
}
|
|
|
|
bool number_unsigned(number_unsigned_t val) override { // Need this event because coordinate value can be equal to 1
|
2021-05-31 22:15:50 +08:00
|
|
|
buffer[k] = val;
|
2021-06-04 04:40:39 +08:00
|
|
|
if (k == 2) {
|
|
|
|
result.emplace_back(json_benchmark::point{buffer[0],buffer[1],buffer[2]});
|
2021-05-31 22:15:50 +08:00
|
|
|
k = 0;
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
// Irrelevant events
|
|
|
|
bool null() override { return true; }
|
|
|
|
bool boolean(bool val) override { return true; }
|
|
|
|
bool number_integer(number_integer_t val) override { return true; }
|
|
|
|
bool string(string_t& val) override { return true; }
|
|
|
|
bool start_object(std::size_t elements) override { return true; }
|
|
|
|
bool end_object() override { return true; }
|
|
|
|
bool start_array(std::size_t elements) override { return true; }
|
|
|
|
bool end_array() override { return true; }
|
|
|
|
bool binary(json::binary_t& val) override { return true; }
|
|
|
|
bool parse_error(std::size_t position, const std::string& last_token, const json::exception& ex) override { return false; }
|
|
|
|
}; // Handler
|
|
|
|
|
|
|
|
bool run(simdjson::padded_string &json, std::vector<point> &result) {
|
|
|
|
Handler handler(result);
|
|
|
|
json::sax_parse(json.data(), &handler);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}; // nlohmann_json_sax
|
|
|
|
BENCHMARK_TEMPLATE(kostya, nlohmann_json_sax)->UseManualTime();
|
|
|
|
} // namespace kostya
|
|
|
|
|
|
|
|
#endif // SIMDJSON_COMPETITION_NLOHMANN_JSON
|