tools: fix parsing of new -show-timings output format in fast.vlang.io

pull/9570/head
Delyan Angelov 2021-04-02 20:23:32 +03:00
parent 53cbdbc2de
commit d7331f981b
No known key found for this signature in database
GPG Key ID: 66886C0F12D595ED
1 changed files with 21 additions and 5 deletions
cmd/tools/fast

View File

@ -116,12 +116,28 @@ fn measure(cmd string, description string) int {
fn measure_steps(vdir string) (int, int, int) { fn measure_steps(vdir string) (int, int, int) {
resp := os.execute_or_panic('$vdir/vprod -o v.c -show-timings $vdir/cmd/v') resp := os.execute_or_panic('$vdir/vprod -o v.c -show-timings $vdir/cmd/v')
mut parse, mut check, mut cgen := 0, 0, 0
lines := resp.output.split_into_lines() lines := resp.output.split_into_lines()
if lines.len != 3 { if lines.len == 3 {
return 0, 0, 0 parse = lines[0].before('.').int()
check = lines[1].before('.').int()
cgen = lines[2].before('.').int()
} else {
ms_lines := lines.map(it.split(' ms '))
for line in ms_lines {
if line.len == 2 {
// if line[1] == 'SCAN' { scan = line[0].int() }
if line[1] == 'PARSE' {
parse = line[0].int()
}
if line[1] == 'CHECK' {
check = line[0].int()
}
if line[1] == 'C GEN' {
cgen = line[0].int()
}
}
}
} }
parse := lines[0].before('.').int()
check := lines[1].before('.').int()
cgen := lines[2].before('.').int()
return parse, check, cgen return parse, check, cgen
} }