aboutsummaryrefslogtreecommitdiffstats
path: root/misc/test/benchmark.sh
blob: fb56d0137401d53308afa9a5aa8ee88cd4456358 (plain) (blame)
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
#!/bin/sh
#
# Usage: ./misc/test/benchmark.sh ./nnn /tmp/testdir1 ./testdir2 ...
#
# Don't forget to build nnn in benchmark mode: make O_BENCH=1

# Use a test dir filled with genfiles.sh to get interesting output
# (or maybe /usr/lib/)

LANG=C

TIME_VAL=${TIME_VAL:-"real"}

SAMPLES=${SAMPLES:-100}

EXE=$1

bench_val () {
    (time "$1" "$2") 2>&1 |\
    awk '$1=="'"$TIME_VAL"'"{match($2, /[0-9]*\.[0-9]*/) ; print substr($2, RSTART, RLENGTH)}'
}

bench_dir () {
    i=$SAMPLES
    printf "$2"
    while [ $((i--)) -gt 0 ] ; do
        printf "\t%s" "$(bench_val "$1" "$2")"
    done
    printf "\n"
}

shift

for dir in "$@" ; do
    bench_dir "$EXE" "$dir"
done