1
0
mirror of https://github.com/vlang/v.git synced 2023-08-10 21:13:21 +03:00
v/cmd/tools/vbuild-tools.v

77 lines
2.5 KiB
V
Raw Normal View History

2019-12-01 12:50:13 +03:00
module main
2020-04-26 09:32:05 +03:00
import os
import testing
import v.util
2019-12-01 12:50:13 +03:00
// Note: tools like vdoc are compiled in their own subfolder
// => cmd/tools/vdoc/vdoc.exe
// Usually, they have several top level .v files in the subfolder,
// that cannot be compiled separately, but instead, the whole folder,
// should be compiled (v folder).
// To implement that, these folders are initially skipped, then added
// as a whole *after the testing.prepare_test_session call*.
const tools_in_subfolders = ['vdoc', 'vvet', 'vast', 'vwhere']
// non_packaged_tools are tools that should not be packaged with
// prebuild versions of V, to keep the size smaller.
// They are mainly usefull for the V project itself, not to end users.
const non_packaged_tools = ['gen1m', 'gen_vc', 'fast', 'wyhash']
2020-12-01 18:43:34 +03:00
2019-12-01 12:50:13 +03:00
fn main() {
util.ensure_modules_for_all_tools_are_installed('-v' in os.args)
2020-12-20 20:01:02 +03:00
args_string := os.args[1..].join(' ')
2020-12-01 18:43:34 +03:00
vexe := os.getenv('VEXE')
vroot := os.dir(vexe)
os.chdir(vroot)?
folder := os.join_path('cmd', 'tools')
tfolder := os.join_path(vroot, 'cmd', 'tools')
2020-12-01 18:43:34 +03:00
main_label := 'Building $folder ...'
finish_label := 'building $folder'
//
mut skips := []string{}
for stool in tools_in_subfolders {
skips << os.join_path(tfolder, stool).replace('\\', '/')
}
buildopts := args_string.all_before('build-tools')
mut session := testing.prepare_test_session(buildopts, folder, skips, main_label)
2020-12-01 18:43:34 +03:00
session.rm_binaries = false
for stool in tools_in_subfolders {
session.add(os.join_path(tfolder, stool))
}
// eprintln('> session.files: $session.files')
// eprintln('> session.skip_files: $session.skip_files')
2020-12-01 18:43:34 +03:00
session.test()
eprintln(session.benchmark.total_message(finish_label))
if session.failed_cmds.len > 0 {
2019-12-01 12:50:13 +03:00
exit(1)
}
2020-12-01 18:43:34 +03:00
//
mut executables := os.ls(session.vtmp_dir)?
2020-12-01 18:43:34 +03:00
executables.sort()
for texe in executables {
tname := texe.replace(os.file_ext(texe), '')
if tname in non_packaged_tools {
continue
}
//
tpath := os.join_path(session.vtmp_dir, texe)
if texe.ends_with('_builder') || texe.ends_with('_builder.exe') {
os.mv_by_cp(tpath, os.join_path(tfolder, 'builders', texe)) or { panic(err) }
continue
}
if tname in tools_in_subfolders {
os.mv_by_cp(tpath, os.join_path(tfolder, tname, texe)) or { panic(err) }
continue
}
target_path := os.join_path(tfolder, texe)
os.mv_by_cp(tpath, target_path) or {
emsg := err.msg()
if !emsg.contains('vbuild-tools') && !emsg.contains('vtest-all') {
eprintln('error while moving $tpath to $target_path: $emsg')
}
continue
}
2020-12-01 18:43:34 +03:00
}
2019-12-01 12:50:13 +03:00
}