tools/fast: measure v.c size and parse/check/cgen steps
parent
32cd2846f5
commit
a81ee0e94e
|
@ -56,6 +56,10 @@ fn main() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
println(last_commits)
|
println(last_commits)
|
||||||
|
if commits.len == 0 {
|
||||||
|
// Just benchmark the last commit if the tool hasn't been run for too long.
|
||||||
|
// commits = [commit_hash]
|
||||||
|
}
|
||||||
println('Commits to benchmark:')
|
println('Commits to benchmark:')
|
||||||
println(commits)
|
println(commits)
|
||||||
for i, commit in commits {
|
for i, commit in commits {
|
||||||
|
@ -66,10 +70,13 @@ fn main() {
|
||||||
exec('git checkout $commit')
|
exec('git checkout $commit')
|
||||||
println(' Building vprod...')
|
println(' Building vprod...')
|
||||||
exec('v -o $vdir/vprod -prod $vdir/cmd/v')
|
exec('v -o $vdir/vprod -prod $vdir/cmd/v')
|
||||||
diff1 := measure('$vdir/vprod -cc clang -o v.c $vdir/cmd/v', 'v.c')
|
diff1 := measure('$vdir/vprod -cc clang -o v.c -show-timings $vdir/cmd/v', 'v.c')
|
||||||
diff2 := measure('$vdir/vprod -cc clang -o v2 $vdir/cmd/v', 'v2')
|
diff2 := measure('$vdir/vprod -cc clang -o v2 $vdir/cmd/v', 'v2')
|
||||||
diff3 := measure('$vdir/vprod -x64 $vdir/cmd/tools/1mil.v', 'x64 1mil')
|
diff3 := measure('$vdir/vprod -x64 $vdir/cmd/tools/1mil.v', 'x64 1mil')
|
||||||
diff4 := measure('$vdir/vprod -cc clang $vdir/examples/hello_world.v', 'hello.v')
|
diff4 := measure('$vdir/vprod -cc clang $vdir/examples/hello_world.v', 'hello.v')
|
||||||
|
vc_size := os.file_size('v.c') / 1000
|
||||||
|
// parse/check/cgen
|
||||||
|
parse, check, cgen := measure_steps(vdir)
|
||||||
// println('Building V took ${diff}ms')
|
// println('Building V took ${diff}ms')
|
||||||
commit_date := exec('git log -n1 --pretty="format:%at" $commit')
|
commit_date := exec('git log -n1 --pretty="format:%at" $commit')
|
||||||
date := time.unix(commit_date.int())
|
date := time.unix(commit_date.int())
|
||||||
|
@ -84,6 +91,10 @@ fn main() {
|
||||||
<td>${diff2}ms</td>
|
<td>${diff2}ms</td>
|
||||||
<td>${diff3}ms</td>
|
<td>${diff3}ms</td>
|
||||||
<td>${diff4}ms</td>
|
<td>${diff4}ms</td>
|
||||||
|
<td>$vc_size KB</td>
|
||||||
|
<td>${parse}ms</td>
|
||||||
|
<td>${check}ms</td>
|
||||||
|
<td>${cgen}ms</td>
|
||||||
</tr>\n' +
|
</tr>\n' +
|
||||||
table.trim_space()
|
table.trim_space()
|
||||||
out.writeln(table) ?
|
out.writeln(table) ?
|
||||||
|
@ -130,3 +141,17 @@ fn measure(cmd string, description string) int {
|
||||||
}
|
}
|
||||||
return int(sum / 3)
|
return int(sum / 3)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn measure_steps(vdir string) (int, int, int) {
|
||||||
|
resp := os.exec('$vdir/vprod -o v.c -show-timings $vdir/cmd/v') or { panic(err) }
|
||||||
|
println('=======')
|
||||||
|
println(resp.output)
|
||||||
|
lines := resp.output.split_into_lines()
|
||||||
|
if lines.len != 3 {
|
||||||
|
return 0, 0, 0
|
||||||
|
}
|
||||||
|
parse := lines[0].before('.').int()
|
||||||
|
check := lines[1].before('.').int()
|
||||||
|
cgen := lines[2].before('.').int()
|
||||||
|
return parse, check, cgen
|
||||||
|
}
|
||||||
|
|
|
@ -52,4 +52,8 @@ Source code: <a target=blank href='https://github.com/vlang/v/blob/master/cmd/to
|
||||||
<td style='width:120px'>v -o v</td>
|
<td style='width:120px'>v -o v</td>
|
||||||
<td style='width:130px'>v -x64 1mil.v</td>
|
<td style='width:130px'>v -x64 1mil.v</td>
|
||||||
<td style='width:120px'>v hello.v</td>
|
<td style='width:120px'>v hello.v</td>
|
||||||
|
<td style='width:120px'>v.c size</td>
|
||||||
|
<td style='width:120px'>parse</td>
|
||||||
|
<td style='width:120px'>check</td>
|
||||||
|
<td style='width:120px'>cgen</td>
|
||||||
</tr>
|
</tr>
|
||||||
|
|
|
@ -1403,9 +1403,20 @@ pub fn (s &string) free() {
|
||||||
s.is_lit = -98761234
|
s.is_lit = -98761234
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// before returns the contents before `dot` in the string.
|
||||||
|
// Example: assert '23:34:45.234'.all_before('.') == '23:34:45'
|
||||||
|
pub fn (s string) before(dot string) string {
|
||||||
|
pos := s.index_(dot)
|
||||||
|
if pos == -1 {
|
||||||
|
return s
|
||||||
|
}
|
||||||
|
return s[..pos]
|
||||||
|
}
|
||||||
|
|
||||||
// all_before returns the contents before `dot` in the string.
|
// all_before returns the contents before `dot` in the string.
|
||||||
// Example: assert '23:34:45.234'.all_before('.') == '23:34:45'
|
// Example: assert '23:34:45.234'.all_before('.') == '23:34:45'
|
||||||
pub fn (s string) all_before(dot string) string {
|
pub fn (s string) all_before(dot string) string {
|
||||||
|
// TODO remove dup method
|
||||||
pos := s.index_(dot)
|
pos := s.index_(dot)
|
||||||
if pos == -1 {
|
if pos == -1 {
|
||||||
return s
|
return s
|
||||||
|
|
Loading…
Reference in New Issue