v/cmd/tools/vself.v

53 lines
1.5 KiB
V
Raw Normal View History

2020-02-28 13:02:56 +01:00
module main
2020-04-26 08:32:05 +02:00
import os
import os.cmdline
2020-04-26 08:32:05 +02:00
import v.pref
import v.util.recompilation
2020-02-28 13:02:56 +01:00
fn main() {
vexe := pref.vexe_path()
2020-03-07 22:26:26 +01:00
vroot := os.dir(vexe)
recompilation.must_be_enabled(vroot, 'Please install V from source, to use `v self` .')
2020-02-28 13:02:56 +01:00
os.chdir(vroot)
os.setenv('VCOLORS', 'always', true)
2020-04-24 12:36:27 +02:00
self_idx := os.args.index('self')
args := os.args[1..self_idx]
jargs := args.join(' ')
obinary := cmdline.option(args, '-o', '')
sargs := if obinary != '' { jargs } else { '$jargs -o v2' }
cmd := '$vexe $sargs cmd/v'
options := if args.len > 0 { '($sargs)' } else { '' }
2020-04-24 12:36:27 +02:00
println('V self compiling ${options}...')
compile(vroot, cmd)
if obinary != '' {
// When -o was given, there is no need to backup/rename the original.
// The user just wants an independent copy of v, and so we are done.
return
}
backup_old_version_and_rename_newer() or { panic(err) }
println('V built successfully!')
}
fn compile(vroot string, cmd string) {
result := os.exec(cmd) or { panic(err) }
if result.exit_code != 0 {
eprintln('cannot compile to `$vroot`: \n$result.output')
exit(1)
}
if result.output.len > 0 {
2020-07-14 17:45:44 +02:00
println(result.output.trim_space())
}
}
fn backup_old_version_and_rename_newer() ? {
v_file := if os.user_os() == 'windows' { 'v.exe' } else { 'v' }
v2_file := if os.user_os() == 'windows' { 'v2.exe' } else { 'v2' }
bak_file := if os.user_os() == 'windows' { 'v_old.exe' } else { 'v_old' }
if os.exists(bak_file) {
os.rm(bak_file) ?
2020-02-28 13:02:56 +01:00
}
os.mv(v_file, bak_file) ?
os.mv(v2_file, v_file) ?
2020-02-28 13:02:56 +01:00
}