xref: /netbsd-src/external/apache2/llvm/dist/libcxx/utils/google-benchmark/test/cxx03_test.cc (revision 4d6fc14bc9b0c5bf3e30be318c143ee82cadd108)
1*4d6fc14bSjoerg #undef NDEBUG
2*4d6fc14bSjoerg #include <cassert>
3*4d6fc14bSjoerg #include <cstddef>
4*4d6fc14bSjoerg 
5*4d6fc14bSjoerg #include "benchmark/benchmark.h"
6*4d6fc14bSjoerg 
7*4d6fc14bSjoerg #if __cplusplus >= 201103L
8*4d6fc14bSjoerg #error C++11 or greater detected. Should be C++03.
9*4d6fc14bSjoerg #endif
10*4d6fc14bSjoerg 
11*4d6fc14bSjoerg #ifdef BENCHMARK_HAS_CXX11
12*4d6fc14bSjoerg #error C++11 or greater detected by the library. BENCHMARK_HAS_CXX11 is defined.
13*4d6fc14bSjoerg #endif
14*4d6fc14bSjoerg 
BM_empty(benchmark::State & state)15*4d6fc14bSjoerg void BM_empty(benchmark::State& state) {
16*4d6fc14bSjoerg   while (state.KeepRunning()) {
17*4d6fc14bSjoerg     volatile std::size_t x = state.iterations();
18*4d6fc14bSjoerg     ((void)x);
19*4d6fc14bSjoerg   }
20*4d6fc14bSjoerg }
21*4d6fc14bSjoerg BENCHMARK(BM_empty);
22*4d6fc14bSjoerg 
23*4d6fc14bSjoerg // The new C++11 interface for args/ranges requires initializer list support.
24*4d6fc14bSjoerg // Therefore we provide the old interface to support C++03.
BM_old_arg_range_interface(benchmark::State & state)25*4d6fc14bSjoerg void BM_old_arg_range_interface(benchmark::State& state) {
26*4d6fc14bSjoerg   assert((state.range(0) == 1 && state.range(1) == 2) ||
27*4d6fc14bSjoerg          (state.range(0) == 5 && state.range(1) == 6));
28*4d6fc14bSjoerg   while (state.KeepRunning()) {
29*4d6fc14bSjoerg   }
30*4d6fc14bSjoerg }
31*4d6fc14bSjoerg BENCHMARK(BM_old_arg_range_interface)->ArgPair(1, 2)->RangePair(5, 5, 6, 6);
32*4d6fc14bSjoerg 
33*4d6fc14bSjoerg template <class T, class U>
BM_template2(benchmark::State & state)34*4d6fc14bSjoerg void BM_template2(benchmark::State& state) {
35*4d6fc14bSjoerg   BM_empty(state);
36*4d6fc14bSjoerg }
37*4d6fc14bSjoerg BENCHMARK_TEMPLATE2(BM_template2, int, long);
38*4d6fc14bSjoerg 
39*4d6fc14bSjoerg template <class T>
BM_template1(benchmark::State & state)40*4d6fc14bSjoerg void BM_template1(benchmark::State& state) {
41*4d6fc14bSjoerg   BM_empty(state);
42*4d6fc14bSjoerg }
43*4d6fc14bSjoerg BENCHMARK_TEMPLATE(BM_template1, long);
44*4d6fc14bSjoerg BENCHMARK_TEMPLATE1(BM_template1, int);
45*4d6fc14bSjoerg 
46*4d6fc14bSjoerg template <class T>
47*4d6fc14bSjoerg struct BM_Fixture : public ::benchmark::Fixture {
48*4d6fc14bSjoerg };
49*4d6fc14bSjoerg 
BENCHMARK_TEMPLATE_F(BM_Fixture,BM_template1,long)50*4d6fc14bSjoerg BENCHMARK_TEMPLATE_F(BM_Fixture, BM_template1, long)(benchmark::State& state) {
51*4d6fc14bSjoerg   BM_empty(state);
52*4d6fc14bSjoerg }
BENCHMARK_TEMPLATE1_F(BM_Fixture,BM_template2,int)53*4d6fc14bSjoerg BENCHMARK_TEMPLATE1_F(BM_Fixture, BM_template2, int)(benchmark::State& state) {
54*4d6fc14bSjoerg   BM_empty(state);
55*4d6fc14bSjoerg }
56*4d6fc14bSjoerg 
BM_counters(benchmark::State & state)57*4d6fc14bSjoerg void BM_counters(benchmark::State& state) {
58*4d6fc14bSjoerg     BM_empty(state);
59*4d6fc14bSjoerg     state.counters["Foo"] = 2;
60*4d6fc14bSjoerg }
61*4d6fc14bSjoerg BENCHMARK(BM_counters);
62*4d6fc14bSjoerg 
63*4d6fc14bSjoerg BENCHMARK_MAIN();
64