tools: support cmd/tools/.disable_autorecompilation in `v up` and `v self` too

pull/8179/head
Delyan Angelov 2021-01-18 09:33:33 +02:00
parent 2f82466d30
commit 17266ecb07
No known key found for this signature in database
GPG Key ID: 66886C0F12D595ED
4 changed files with 49 additions and 4 deletions

View File

@ -3,10 +3,12 @@ module main
import os import os
import os.cmdline import os.cmdline
import v.pref import v.pref
import v.util.recompilation
fn main() { fn main() {
vexe := pref.vexe_path() vexe := pref.vexe_path()
vroot := os.dir(vexe) vroot := os.dir(vexe)
recompilation.must_be_enabled(vroot, 'Please install V from source, to use `v self` .')
os.chdir(vroot) os.chdir(vroot)
os.setenv('VCOLORS', 'always', true) os.setenv('VCOLORS', 'always', true)
self_idx := os.args.index('self') self_idx := os.args.index('self')

View File

@ -3,6 +3,7 @@ module main
import os import os
import v.pref import v.pref
import v.util import v.util
import v.util.recompilation
struct App { struct App {
is_verbose bool is_verbose bool
@ -12,15 +13,17 @@ struct App {
fn new_app() App { fn new_app() App {
vexe := os.real_path(pref.vexe_path()) vexe := os.real_path(pref.vexe_path())
vroot := os.dir(vexe)
return App{ return App{
is_verbose: '-v' in os.args is_verbose: '-v' in os.args
vexe: vexe vexe: vexe
vroot: os.dir(vexe) vroot: vroot
} }
} }
fn main() { fn main() {
app := new_app() app := new_app()
recompilation.must_be_enabled(app.vroot, 'Please install V from source, to use `v up` .')
os.chdir(app.vroot) os.chdir(app.vroot)
println('Updating V...') println('Updating V...')
app.update_from_master() app.update_from_master()

View File

@ -0,0 +1,26 @@
module recompilation
import os
// disabling_file returns the path to a file, which if present, will disable the automatic recompilation
// that V attempts, when it detects that itself is newer than a tool .v source file.
// That file is intended to be made by `touch cmd/tools/.disable_autorecompilation` by package managers,
// so that tools like `v up` and `v self` will not work anymore, instead they will direct users to install
// V from source.
pub fn disabling_file(vroot string) string {
tools_folder := os.join_path(vroot, 'cmd', 'tools')
res := os.join_path(tools_folder, '.disable_autorecompilation')
return res
}
// must_be_enabled is intended to be used by tools like `v self` and `v up`, to abort them
// early, when they detect that the V installation is part of a distro package, that has disabled autorecompilation.
pub fn must_be_enabled(vroot string, error_message string) {
file := disabling_file(vroot)
is_recompilation_disabled := os.exists(file)
if is_recompilation_disabled {
eprintln('Recompilation is disabled, since there is a "$file" file present.')
eprintln(error_message)
exit(1)
}
}

View File

@ -7,6 +7,7 @@ import os
import time import time
import v.pref import v.pref
import v.vmod import v.vmod
import v.util.recompilation
pub const ( pub const (
v_version = '0.2.1' v_version = '0.2.1'
@ -119,13 +120,23 @@ pub fn resolve_vroot(str string, dir string) ?string {
return str.replace('@VROOT', os.real_path(vmod_path)) return str.replace('@VROOT', os.real_path(vmod_path))
} }
// launch_tool - starts a V tool in a separate process, passing it the `args`.
// All V tools are located in the cmd/tools folder, in files or folders prefixed by
// the letter `v`, followed by the tool name, i.e. `cmd/tools/vdoc/` or `cmd/tools/vpm.v`.
// The folder variant is suitable for larger and more complex tools, like `v doc`, because
// it provides you the ability to split their source in separate .v files, organized by topic,
// as well as have resources like static css/text/js files, that the tools can use.
// launch_tool uses a timestamp based detection mechanism, so that after `v self`, each tool
// will be recompiled too, before it is used, which guarantees that it would be up to date with
// V itself. That mechanism can be disabled by package managers by creating/touching a small
// `cmd/tools/.disable_autorecompilation` file, OR by changing the timestamps of all executables
// in cmd/tools to be < 1024 seconds (in unix time).
pub fn launch_tool(is_verbose bool, tool_name string, args []string) { pub fn launch_tool(is_verbose bool, tool_name string, args []string) {
vexe := pref.vexe_path() vexe := pref.vexe_path()
vroot := os.dir(vexe) vroot := os.dir(vexe)
set_vroot_folder(vroot) set_vroot_folder(vroot)
tool_args := args_quote_paths(args) tool_args := args_quote_paths(args)
tools_folder := os.join_path(vroot, 'cmd', 'tools') tools_folder := os.join_path(vroot, 'cmd', 'tools')
is_recompilation_disabled := os.exists(os.join_path(tools_folder, '.disable_autorecompilation'))
tool_basename := os.real_path(os.join_path(tools_folder, tool_name)) tool_basename := os.real_path(os.join_path(tools_folder, tool_name))
mut tool_exe := '' mut tool_exe := ''
mut tool_source := '' mut tool_source := ''
@ -144,11 +155,14 @@ pub fn launch_tool(is_verbose bool, tool_name string, args []string) {
println('launch_tool tool_source : $tool_source') println('launch_tool tool_source : $tool_source')
println('launch_tool tool_command: $tool_command') println('launch_tool tool_command: $tool_command')
} }
should_compile := should_recompile_tool(vexe, tool_source, tool_name, tool_exe) disabling_file := recompilation.disabling_file(vroot)
is_recompilation_disabled := os.exists(disabling_file)
should_compile := !is_recompilation_disabled &&
should_recompile_tool(vexe, tool_source, tool_name, tool_exe)
if is_verbose { if is_verbose {
println('launch_tool should_compile: $should_compile') println('launch_tool should_compile: $should_compile')
} }
if should_compile && !is_recompilation_disabled { if should_compile {
emodules := external_module_dependencies_for_tool[tool_name] emodules := external_module_dependencies_for_tool[tool_name]
for emodule in emodules { for emodule in emodules {
check_module_is_installed(emodule, is_verbose) or { panic(err) } check_module_is_installed(emodule, is_verbose) or { panic(err) }