File: libcxx-benchmark-json

package info (click to toggle)
llvm-toolchain-20 1%3A20.1.6-1~exp1
  • links: PTS, VCS
  • area: main
  • in suites: experimental
  • size: 2,111,304 kB
  • sloc: cpp: 7,438,677; ansic: 1,393,822; asm: 1,012,926; python: 241,650; f90: 86,635; objc: 75,479; lisp: 42,144; pascal: 17,286; sh: 10,027; ml: 5,082; perl: 4,730; awk: 3,523; makefile: 3,349; javascript: 2,251; xml: 892; fortran: 672
file content (57 lines) | stat: -rwxr-xr-x 1,767 bytes parent folder | download | duplicates (11)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
#!/usr/bin/env bash

set -e

PROGNAME="$(basename "${0}")"
MONOREPO_ROOT="$(realpath $(dirname "${PROGNAME}"))"
function usage() {
cat <<EOF
Usage:
${PROGNAME} [-h|--help] <build-directory> benchmarks...

Print the path to the JSON files containing benchmark results for the given benchmarks.

This requires those benchmarks to have already been run, i.e. this only resolves the path
to the benchmark .json file within the build directory.

<build-directory>  The path to the build directory.
benchmarks...      Paths of the benchmarks to extract the results for. Those paths are relative to '<monorepo-root>'.

Example
=======
$ cmake -S runtimes -B build/ -DLLVM_ENABLE_RUNTIMES="libcxx;libcxxabi"
$ libcxx-lit build/ -sv libcxx/test/benchmarks/algorithms/for_each.bench.cpp
$ less \$(${PROGNAME} build/ libcxx/test/benchmarks/algorithms/for_each.bench.cpp)
EOF
}

if [[ "${1}" == "-h" || "${1}" == "--help" ]]; then
    usage
    exit 0
fi

if [[ $# -lt 1 ]]; then
    usage
    exit 1
fi

build_dir="${1}"
shift

for benchmark in ${@}; do
    # Normalize the paths by turning all benchmarks paths into absolute ones and then making them
    # relative to the root of the monorepo.
    benchmark="$(realpath ${benchmark})"
    relative=$(python -c "import os; import sys; print(os.path.relpath(sys.argv[1], sys.argv[2]))" "${benchmark}" "${MONOREPO_ROOT}")

    # Extract components of the benchmark path
    directory="$(dirname ${relative})"
    file="$(basename ${relative})"

    # Reconstruct the (slightly weird) path to the benchmark json file. This should be kept in sync
    # whenever the test suite changes.
    json="${build_dir}/${directory}/Output/${file}.dir/benchmark-result.json"
    if [[ -f "${json}" ]]; then
        echo "${json}"
    fi
done