Fix branches. (#1619)
This commit is contained in:
parent
a4803d50c5
commit
03f7396d50
|
@ -55,7 +55,9 @@ SIMDJSON_POP_DISABLE_WARNINGS
|
||||||
#include "kostya/nlohmann_json_sax.h"
|
#include "kostya/nlohmann_json_sax.h"
|
||||||
|
|
||||||
#include "distinct_user_id/simdjson_dom.h"
|
#include "distinct_user_id/simdjson_dom.h"
|
||||||
|
#include "distinct_user_id/simdjson_dom_json_pointer.h"
|
||||||
#include "distinct_user_id/simdjson_ondemand.h"
|
#include "distinct_user_id/simdjson_ondemand.h"
|
||||||
|
#include "distinct_user_id/simdjson_ondemand_json_pointer.h"
|
||||||
#include "distinct_user_id/yyjson.h"
|
#include "distinct_user_id/yyjson.h"
|
||||||
#include "distinct_user_id/sajson.h"
|
#include "distinct_user_id/sajson.h"
|
||||||
#include "distinct_user_id/rapidjson.h"
|
#include "distinct_user_id/rapidjson.h"
|
||||||
|
|
|
@ -0,0 +1,36 @@
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#if SIMDJSON_EXCEPTIONS
|
||||||
|
|
||||||
|
#include "distinct_user_id.h"
|
||||||
|
|
||||||
|
namespace distinct_user_id {
|
||||||
|
|
||||||
|
using namespace simdjson;
|
||||||
|
|
||||||
|
struct simdjson_dom_json_pointer {
|
||||||
|
dom::parser parser{};
|
||||||
|
|
||||||
|
bool run(simdjson::padded_string &json, std::vector<uint64_t> &result) {
|
||||||
|
// Walk the document, parsing as we go
|
||||||
|
auto doc = parser.parse(json);
|
||||||
|
for (dom::object tweet : doc["statuses"]) {
|
||||||
|
// We believe that all statuses have a matching
|
||||||
|
// user, and we are willing to throw when they do not.
|
||||||
|
result.push_back(tweet.at_pointer("/user/id"));
|
||||||
|
// Not all tweets have a "retweeted_status", but when they do
|
||||||
|
// we want to go and find the user within.
|
||||||
|
auto retweet_id = tweet.at_pointer("/retweeted_status/user/id");
|
||||||
|
if (retweet_id.error() != NO_SUCH_FIELD) {
|
||||||
|
result.push_back(retweet_id);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
BENCHMARK_TEMPLATE(distinct_user_id, simdjson_dom_json_pointer)->UseManualTime();
|
||||||
|
|
||||||
|
} // namespace distinct_user_id
|
||||||
|
|
||||||
|
#endif // SIMDJSON_EXCEPTIONS
|
|
@ -0,0 +1,37 @@
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#if SIMDJSON_EXCEPTIONS
|
||||||
|
|
||||||
|
#include "distinct_user_id.h"
|
||||||
|
|
||||||
|
namespace distinct_user_id {
|
||||||
|
|
||||||
|
using namespace simdjson;
|
||||||
|
|
||||||
|
struct simdjson_ondemand_json_pointer {
|
||||||
|
ondemand::parser parser{};
|
||||||
|
|
||||||
|
bool run(simdjson::padded_string &json, std::vector<uint64_t> &result) {
|
||||||
|
// Walk the document, parsing as we go
|
||||||
|
auto doc = parser.iterate(json);
|
||||||
|
for (ondemand::object tweet : doc.find_field("statuses")) {
|
||||||
|
// We believe that all statuses have a matching
|
||||||
|
// user, and we are willing to throw when they do not.
|
||||||
|
result.push_back(tweet.at_pointer("/user/id"));
|
||||||
|
// Not all tweets have a "retweeted_status", but when they do
|
||||||
|
// we want to go and find the user within.
|
||||||
|
auto retweet_id = tweet.at_pointer("/retweeted_status/user/id");
|
||||||
|
if (retweet_id.error() != NO_SUCH_FIELD) {
|
||||||
|
result.push_back(retweet_id);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
BENCHMARK_TEMPLATE(distinct_user_id, simdjson_ondemand_json_pointer)->UseManualTime();
|
||||||
|
|
||||||
|
} // namespace distinct_user_id
|
||||||
|
|
||||||
|
#endif // SIMDJSON_EXCEPTIONS
|
Loading…
Reference in New Issue