v test-fmt: reuse v.util.should_recompile_tool/2, extracted from v.util.launch_tool/3

pull/6665/head
Delyan Angelov 2020-10-21 12:54:03 +03:00
parent dab66593fc
commit 02db94c4bc
2 changed files with 48 additions and 40 deletions

View File

@ -2,6 +2,7 @@ module main
import os import os
import testing import testing
import v.util
// os.v - // embeded comments, mib := [1/* CTL_KERN */, 14/* KERN_PROC */, 12/* KERN_PROC_PATHNAME */, -1] => comment the rest of the line // os.v - // embeded comments, mib := [1/* CTL_KERN */, 14/* KERN_PROC */, 12/* KERN_PROC_PATHNAME */, -1] => comment the rest of the line
const ( const (
@ -60,11 +61,14 @@ fn prepare_vfmt_when_needed() {
vexe := os.getenv('VEXE') vexe := os.getenv('VEXE')
vroot := os.dir(vexe) vroot := os.dir(vexe)
vfmtv := os.join_path(vroot, 'cmd', 'tools', 'vfmt.v') vfmtv := os.join_path(vroot, 'cmd', 'tools', 'vfmt.v')
if os.file_last_mod_unix(vexe) <= os.file_last_mod_unix(vfmtv) { if util.should_recompile_tool(vexe, vfmtv) {
recompile_result := os.system('$vexe ' + os.join_path(vroot, 'cmd', 'tools', 'vfmt.v')) recompile_file(vexe, vfmtv)
}
}
fn recompile_file(vexe string, file string) {
if recompile_result != 0 { if recompile_result != 0 {
eprintln('could not recompile cmd/tools/vfmt.v') eprintln('could not recompile $file')
exit(2) exit(2)
} }
} }
}

View File

@ -126,8 +126,9 @@ pub fn launch_tool(is_verbose bool, tool_name string, args []string) {
vroot := os.dir(vexe) vroot := os.dir(vexe)
set_vroot_folder(vroot) set_vroot_folder(vroot)
tool_args := args_quote_paths_with_spaces(args) tool_args := args_quote_paths_with_spaces(args)
tool_exe := path_of_executable(os.real_path('$vroot/cmd/tools/$tool_name')) tool_basename := os.real_path(os.join_path(vroot, 'cmd', 'tools', tool_name))
tool_source := os.real_path('$vroot/cmd/tools/${tool_name}.v') tool_exe := path_of_executable(tool_basename)
tool_source := tool_basename + '.v'
tool_command := '"$tool_exe" $tool_args' tool_command := '"$tool_exe" $tool_args'
if is_verbose { if is_verbose {
println('launch_tool vexe : $vroot') println('launch_tool vexe : $vroot')
@ -135,6 +136,40 @@ pub fn launch_tool(is_verbose bool, tool_name string, args []string) {
println('launch_tool tool_args : $tool_args') println('launch_tool tool_args : $tool_args')
println('launch_tool tool_command: $tool_command') println('launch_tool tool_command: $tool_command')
} }
should_compile := should_recompile_tool(vexe, tool_source)
if is_verbose {
println('launch_tool should_compile: $should_compile')
}
if should_compile {
emodules := external_module_dependencies_for_tool[tool_name]
for emodule in emodules {
check_module_is_installed(emodule, is_verbose) or {
panic(err)
}
}
mut compilation_command := '"$vexe" '
compilation_command += '"$tool_source"'
if is_verbose {
println('Compiling $tool_name with: "$compilation_command"')
}
tool_compilation := os.exec(compilation_command) or {
panic(err)
}
if tool_compilation.exit_code != 0 {
eprintln('cannot compile `$tool_source`: \n$tool_compilation.output')
exit(1)
}
}
if is_verbose {
println('launch_tool running tool command: $tool_command ...')
}
exit(os.system(tool_command))
}
pub fn should_recompile_tool(vexe string, tool_source string) bool {
sfolder := os.base(tool_source)
tool_name := os.file_name(tool_source).replace('.v', '')
tool_exe := os.join_path(sfolder, path_of_executable(tool_name))
// TODO Caching should be done on the `vlib/v` level. // TODO Caching should be done on the `vlib/v` level.
mut should_compile := false mut should_compile := false
if !os.exists(tool_exe) { if !os.exists(tool_exe) {
@ -158,37 +193,6 @@ pub fn launch_tool(is_verbose bool, tool_name string, args []string) {
should_compile = true should_compile = true
} }
} }
if is_verbose {
println('launch_tool should_compile: $should_compile')
}
if should_compile {
emodules := external_module_dependencies_for_tool[tool_name]
for emodule in emodules {
check_module_is_installed(emodule, is_verbose) or {
panic(err)
}
}
mut compilation_command := '"$vexe" '
compilation_command += '"$tool_source"'
if is_verbose {
println('Compiling $tool_name with: "$compilation_command"')
}
tool_compilation := os.exec(compilation_command) or {
panic(err)
}
if tool_compilation.exit_code != 0 {
mut err := 'Permission denied'
if !tool_compilation.output.contains(err) {
err = '\n$tool_compilation.output'
}
eprintln('cannot compile `$tool_source`: $err')
exit(1)
}
}
if is_verbose {
println('launch_tool running tool command: $tool_command ...')
}
exit(os.system(tool_command))
} }
pub fn quote_path_with_spaces(s string) string { pub fn quote_path_with_spaces(s string) string {