2021-11-04 09:56:03 +00:00
|
|
|
// This file is a part of toml++ and is subject to the the terms of the MIT license.
|
|
|
|
// Copyright (c) Mark Gillard <mark.gillard@outlook.com.au>
|
|
|
|
// See https://github.com/marzer/tomlplusplus/blob/master/LICENSE for the full license text.
|
|
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
|
|
|
|
// This example is just a short-n-shiny benchmark.
|
|
|
|
|
|
|
|
#include "examples.h"
|
|
|
|
#include <toml++/toml.h>
|
|
|
|
|
2021-11-04 22:43:42 +00:00
|
|
|
using namespace std::string_view_literals;
|
2021-11-04 09:56:03 +00:00
|
|
|
|
2021-11-04 22:43:42 +00:00
|
|
|
static constexpr size_t iterations = 10000;
|
2021-11-04 09:56:03 +00:00
|
|
|
|
|
|
|
int main(int argc, char** argv)
|
|
|
|
{
|
|
|
|
const auto file_path = std::string(argc > 1 ? std::string_view{ argv[1] } : "benchmark_data.toml"sv);
|
|
|
|
|
|
|
|
// read the file into a string first to remove file I/O from the benchmark
|
|
|
|
std::string file_content;
|
|
|
|
{
|
|
|
|
std::ifstream file(file_path, std::ifstream::in | std::ifstream::binary | std::ifstream::ate);
|
|
|
|
if (!file)
|
|
|
|
{
|
|
|
|
std::cerr << "File '"sv << file_path << "'could not be opened for reading\n"sv;
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
const auto file_size = file.tellg();
|
|
|
|
if (file_size == -1)
|
|
|
|
{
|
|
|
|
std::cerr << "File '"sv << file_path << "' could not be opened for reading\n"sv;
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
file.seekg(0, std::ifstream::beg);
|
|
|
|
|
|
|
|
file_content.resize(static_cast<size_t>(file_size));
|
|
|
|
file.read(file_content.data(), static_cast<std::streamsize>(file_size));
|
|
|
|
if (!file.eof() && !file)
|
|
|
|
{
|
|
|
|
std::cerr << "Failed to read contents of file '"sv << file_path << "'\n"sv;
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// parse once to make sure it isn't garbage
|
|
|
|
{
|
|
|
|
#if TOML_EXCEPTIONS
|
|
|
|
try
|
|
|
|
{
|
2021-11-06 16:59:47 +00:00
|
|
|
const auto result = toml::parse(file_content, file_path);
|
2021-11-04 09:56:03 +00:00
|
|
|
}
|
|
|
|
catch (const toml::parse_error& err)
|
|
|
|
{
|
|
|
|
std::cerr << err << "\n";
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
#else
|
2021-11-06 16:59:47 +00:00
|
|
|
const auto result = toml::parse(file_content, file_path);
|
2021-11-04 09:56:03 +00:00
|
|
|
if (!result)
|
2021-11-15 07:06:03 +00:00
|
|
|
{
|
2021-11-04 09:56:03 +00:00
|
|
|
std::cerr << result.error() << "\n";
|
2021-11-15 07:06:03 +00:00
|
|
|
return 1;
|
|
|
|
}
|
2021-11-04 09:56:03 +00:00
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
// run the benchmark
|
|
|
|
std::cout << "Parsing '"sv << file_path << "' "sv << iterations << " times...\n"sv;
|
2021-11-06 16:59:47 +00:00
|
|
|
|
|
|
|
const auto start = std::chrono::steady_clock::now();
|
2021-11-04 09:56:03 +00:00
|
|
|
for (size_t i = 0; i < iterations; i++)
|
2021-11-11 15:54:40 +00:00
|
|
|
std::ignore = toml::parse(file_content, file_path);
|
2021-11-06 16:59:47 +00:00
|
|
|
const auto cumulative_sec =
|
|
|
|
std::chrono::duration_cast<std::chrono::duration<double>>(std::chrono::steady_clock::now() - start).count();
|
|
|
|
const auto mean_sec = cumulative_sec / static_cast<double>(iterations);
|
2021-11-04 09:56:03 +00:00
|
|
|
std::cout << " total: "sv << cumulative_sec << " s\n"sv
|
|
|
|
<< " mean: "sv << mean_sec << " s\n"sv;
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|