From c5492e3c65e40cdcab9771b692f9ad437c65aa04 Mon Sep 17 00:00:00 2001 From: Nikolas Klauser Date: Sun, 22 Dec 2024 20:43:46 +0100 Subject: [PATCH] [libc++] Add a benchmark for std::num_get --- .../test/benchmarks/locale/num_get.bench.cpp | 44 +++++++++++++++++++ 1 file changed, 44 insertions(+) create mode 100644 libcxx/test/benchmarks/locale/num_get.bench.cpp diff --git a/libcxx/test/benchmarks/locale/num_get.bench.cpp b/libcxx/test/benchmarks/locale/num_get.bench.cpp new file mode 100644 index 000000000000..3588d120d00c --- /dev/null +++ b/libcxx/test/benchmarks/locale/num_get.bench.cpp @@ -0,0 +1,44 @@ + +//===----------------------------------------------------------------------===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// + +#include +#include + +#include + +struct num_get : std::num_get {}; + +template +void BM_num_get(benchmark::State& state) { + auto val = std::string("123"); + std::ios ios(nullptr); + num_get np; + + for (auto _ : state) { + benchmark::DoNotOptimize(val); + T out; + std::ios_base::iostate err = ios.goodbit; + benchmark::DoNotOptimize(np.get(val.begin(), val.end(), ios, err, out)); + benchmark::DoNotOptimize(out); + } +} + +BENCHMARK(BM_num_get); +BENCHMARK(BM_num_get); +BENCHMARK(BM_num_get); +BENCHMARK(BM_num_get); +BENCHMARK(BM_num_get); +BENCHMARK(BM_num_get); +BENCHMARK(BM_num_get); +BENCHMARK(BM_num_get); +BENCHMARK(BM_num_get); +BENCHMARK(BM_num_get); +BENCHMARK(BM_num_get); + +BENCHMARK_MAIN();