Combine prime and parse
This commit is contained in:
12
src/test.cpp
12
src/test.cpp
@@ -542,18 +542,15 @@ TEST_CASE("parser2") {
|
||||
Parser2 parser(&c, &state);
|
||||
int i = 0;
|
||||
for (; i < copy.length() - 1; ++i) {
|
||||
parser.prime(copy.data() + i, 1);
|
||||
REQUIRE(parser.parse() == Parser2::S_AGAIN);
|
||||
REQUIRE(parser.parse(copy.data() + i, 1) == Parser2::S_AGAIN);
|
||||
}
|
||||
parser.prime(copy.data() + i, 1);
|
||||
CHECK(parser.parse() == Parser2::S_OK);
|
||||
CHECK(parser.parse(copy.data() + i, 1) == Parser2::S_OK);
|
||||
puts("");
|
||||
}
|
||||
{
|
||||
std::string copy = "{\"x\": [], \"y\": {}}";
|
||||
Parser2 parser(&c, &state);
|
||||
parser.prime(copy.data(), copy.length());
|
||||
CHECK(parser.parse() == Parser2::S_OK);
|
||||
CHECK(parser.parse(copy.data(), copy.length()) == Parser2::S_OK);
|
||||
puts("");
|
||||
}
|
||||
}
|
||||
@@ -578,8 +575,7 @@ TEST_CASE("bench2") {
|
||||
bench.run("parser2", [&]() {
|
||||
auto copy = json;
|
||||
Parser2 parser(&c, nullptr);
|
||||
parser.prime(copy.data(), copy.length());
|
||||
bench.doNotOptimizeAway(parser.parse());
|
||||
bench.doNotOptimizeAway(parser.parse(copy.data(), copy.length()));
|
||||
});
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user