mirror of
https://github.com/llvm/llvm-project.git
synced 2025-04-15 22:16:30 +00:00
64 lines
2.1 KiB
C++
64 lines
2.1 KiB
C++
//===- FormatVariadicBM.cpp - formatv() benchmark ---------- --------------===//
|
|
//
|
|
// 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 "benchmark/benchmark.h"
|
|
#include "llvm/Support/FormatVariadic.h"
|
|
#include <algorithm>
|
|
#include <string>
|
|
#include <vector>
|
|
|
|
using namespace llvm;
|
|
using namespace std;
|
|
|
|
// Generate a list of format strings that have `NumReplacements` replacements
|
|
// by permuting the replacements and some literal text.
|
|
static vector<string> getFormatStrings(int NumReplacements) {
|
|
vector<string> Components;
|
|
for (int I = 0; I < NumReplacements; I++)
|
|
Components.push_back("{" + to_string(I) + "}");
|
|
// Intersperse these with some other literal text (_).
|
|
const string_view Literal = "____";
|
|
for (char C : Literal)
|
|
Components.push_back(string(1, C));
|
|
|
|
vector<string> Formats;
|
|
do {
|
|
string Concat;
|
|
for (const string &C : Components)
|
|
Concat += C;
|
|
Formats.emplace_back(Concat);
|
|
} while (next_permutation(Components.begin(), Components.end()));
|
|
return Formats;
|
|
}
|
|
|
|
// Generate the set of formats to exercise outside the benchmark code.
|
|
static const vector<vector<string>> Formats = {
|
|
getFormatStrings(1), getFormatStrings(2), getFormatStrings(3),
|
|
getFormatStrings(4), getFormatStrings(5),
|
|
};
|
|
|
|
// Benchmark formatv() for a variety of format strings and 1-5 replacements.
|
|
static void BM_FormatVariadic(benchmark::State &state) {
|
|
for (auto _ : state) {
|
|
for (const string &Fmt : Formats[0])
|
|
formatv(Fmt.c_str(), 1).str();
|
|
for (const string &Fmt : Formats[1])
|
|
formatv(Fmt.c_str(), 1, 2).str();
|
|
for (const string &Fmt : Formats[2])
|
|
formatv(Fmt.c_str(), 1, 2, 3).str();
|
|
for (const string &Fmt : Formats[3])
|
|
formatv(Fmt.c_str(), 1, 2, 3, 4).str();
|
|
for (const string &Fmt : Formats[4])
|
|
formatv(Fmt.c_str(), 1, 2, 3, 4, 5).str();
|
|
}
|
|
}
|
|
|
|
BENCHMARK(BM_FormatVariadic);
|
|
|
|
BENCHMARK_MAIN();
|