tools/fast: add "V lines" and "V lines/s"
parent
d236d6a473
commit
e949d4b26c
|
@ -38,6 +38,7 @@ 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')
|
||||||
|
// exec('v -o $vdir/vprod $vdir/cmd/v') // for faster debugging
|
||||||
diff1 := measure('$vdir/vprod -cc clang -o v.c -show-timings $vdir/cmd/v', 'v.c')
|
diff1 := measure('$vdir/vprod -cc clang -o v.c -show-timings $vdir/cmd/v', 'v.c')
|
||||||
mut tcc_path := 'tcc'
|
mut tcc_path := 'tcc'
|
||||||
$if freebsd {
|
$if freebsd {
|
||||||
|
@ -48,7 +49,7 @@ fn main() {
|
||||||
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
|
vc_size := os.file_size('v.c') / 1000
|
||||||
// scan/parse/check/cgen
|
// scan/parse/check/cgen
|
||||||
scan, parse, check, cgen := measure_steps(vdir)
|
scan, parse, check, cgen, vlines := 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())
|
||||||
|
@ -69,6 +70,8 @@ fn main() {
|
||||||
<td>${check}ms</td>
|
<td>${check}ms</td>
|
||||||
<td>${cgen}ms</td>
|
<td>${cgen}ms</td>
|
||||||
<td>${scan}ms</td>
|
<td>${scan}ms</td>
|
||||||
|
<td>$vlines</td>
|
||||||
|
<td>${int(f64(vlines) / f64(diff1) * 1000.0)} lines/s</td>
|
||||||
</tr>\n' +
|
</tr>\n' +
|
||||||
table.trim_space()
|
table.trim_space()
|
||||||
out.writeln(table) ?
|
out.writeln(table) ?
|
||||||
|
@ -116,9 +119,10 @@ fn measure(cmd string, description string) int {
|
||||||
return int(sum / 3)
|
return int(sum / 3)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn measure_steps(vdir string) (int, int, int, int) {
|
fn measure_steps(vdir string) (int, int, 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 -stats $vdir/cmd/v')
|
||||||
mut scan, mut parse, mut check, mut cgen := 0, 0, 0, 0
|
|
||||||
|
mut scan, mut parse, mut check, mut cgen, mut vlines := 0, 0, 0, 0, 0
|
||||||
lines := resp.output.split_into_lines()
|
lines := resp.output.split_into_lines()
|
||||||
if lines.len == 3 {
|
if lines.len == 3 {
|
||||||
parse = lines[0].before('.').int()
|
parse = lines[0].before('.').int()
|
||||||
|
@ -140,8 +144,16 @@ fn measure_steps(vdir string) (int, int, int, int) {
|
||||||
if line[1] == 'C GEN' {
|
if line[1] == 'C GEN' {
|
||||||
cgen = line[0].int()
|
cgen = line[0].int()
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
// Fetch number of V lines
|
||||||
|
if line[0].contains('V') && line[0].contains('source') && line[0].contains('size') {
|
||||||
|
start := line[0].index(':') or { 0 }
|
||||||
|
end := line[0].index('lines,') or { 0 }
|
||||||
|
s := line[0][start + 1..end]
|
||||||
|
vlines = s.trim_space().int()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return scan, parse, check, cgen
|
}
|
||||||
|
return scan, parse, check, cgen, vlines
|
||||||
}
|
}
|
||||||
|
|
|
@ -60,4 +60,6 @@ Source code: <a target=blank href='https://github.com/vlang/v/blob/master/cmd/to
|
||||||
<td style='width:55px'>check</td>
|
<td style='width:55px'>check</td>
|
||||||
<td style='width:55px'>cgen</td>
|
<td style='width:55px'>cgen</td>
|
||||||
<td style='width:55px'>scan</td>
|
<td style='width:55px'>scan</td>
|
||||||
|
<td style='width:55px'>V lines</td>
|
||||||
|
<td style='width:55px'>V lines/s</td>
|
||||||
</tr>
|
</tr>
|
||||||
|
|
|
@ -551,8 +551,8 @@ pub struct File {
|
||||||
pub:
|
pub:
|
||||||
path string // absolute path of the source file - '/projects/v/file.v'
|
path string // absolute path of the source file - '/projects/v/file.v'
|
||||||
path_base string // file name - 'file.v' (useful for tracing)
|
path_base string // file name - 'file.v' (useful for tracing)
|
||||||
lines int // number of source code lines in the file (including newlines and comments)
|
nr_lines int // number of source code lines in the file (including newlines and comments)
|
||||||
bytes int // number of processed source code bytes
|
nr_bytes int // number of processed source code bytes
|
||||||
mod Module // the module of the source file (from `module xyz` at the top)
|
mod Module // the module of the source file (from `module xyz` at the top)
|
||||||
global_scope &Scope
|
global_scope &Scope
|
||||||
is_test bool // true for _test.v files
|
is_test bool // true for _test.v files
|
||||||
|
|
|
@ -49,8 +49,8 @@ pub fn compile(command string, pref &pref.Preferences) {
|
||||||
scompilation_time_ms := util.bold('${f64(compilation_time_micros) / 1000.0:6.3f}')
|
scompilation_time_ms := util.bold('${f64(compilation_time_micros) / 1000.0:6.3f}')
|
||||||
mut all_v_source_lines, mut all_v_source_bytes := 0, 0
|
mut all_v_source_lines, mut all_v_source_bytes := 0, 0
|
||||||
for mut pf in b.parsed_files {
|
for mut pf in b.parsed_files {
|
||||||
all_v_source_lines += pf.lines
|
all_v_source_lines += pf.nr_lines
|
||||||
all_v_source_bytes += pf.bytes
|
all_v_source_bytes += pf.nr_bytes
|
||||||
}
|
}
|
||||||
mut sall_v_source_lines := all_v_source_lines.str()
|
mut sall_v_source_lines := all_v_source_lines.str()
|
||||||
mut sall_v_source_bytes := all_v_source_bytes.str()
|
mut sall_v_source_bytes := all_v_source_bytes.str()
|
||||||
|
|
|
@ -1959,6 +1959,7 @@ fn (mut c Checker) array_builtin_method_call(mut call_expr ast.CallExpr, left_ty
|
||||||
} else if method_name == 'sort' {
|
} else if method_name == 'sort' {
|
||||||
call_expr.return_type = ast.void_type
|
call_expr.return_type = ast.void_type
|
||||||
} else if method_name == 'contains' {
|
} else if method_name == 'contains' {
|
||||||
|
// c.warn('use `value in arr` instead of `arr.contains(value)`', call_expr.pos)
|
||||||
call_expr.return_type = ast.bool_type
|
call_expr.return_type = ast.bool_type
|
||||||
} else if method_name == 'index' {
|
} else if method_name == 'index' {
|
||||||
call_expr.return_type = ast.int_type
|
call_expr.return_type = ast.int_type
|
||||||
|
|
|
@ -283,8 +283,8 @@ pub fn (mut p Parser) parse() ast.File {
|
||||||
path: p.file_name
|
path: p.file_name
|
||||||
path_base: p.file_base
|
path_base: p.file_base
|
||||||
is_test: p.inside_test_file
|
is_test: p.inside_test_file
|
||||||
lines: p.scanner.line_nr
|
nr_lines: p.scanner.line_nr
|
||||||
bytes: p.scanner.text.len
|
nr_bytes: p.scanner.text.len
|
||||||
mod: module_decl
|
mod: module_decl
|
||||||
imports: p.ast_imports
|
imports: p.ast_imports
|
||||||
imported_symbols: p.imported_symbols
|
imported_symbols: p.imported_symbols
|
||||||
|
|
Loading…
Reference in New Issue