v/cmd/v/v.v

176 lines
4.3 KiB
V
Raw Normal View History

2020-02-09 10:08:04 +01:00
// Copyright (c) 2019-2020 Alexander Medvednikov. All rights reserved.
// Use of this source code is governed by an MIT license
// that can be found in the LICENSE file.
module main
import (
2020-03-06 18:53:29 +01:00
internal.compile
internal.flag
2020-02-16 12:50:25 +01:00
internal.help
2020-02-09 10:08:04 +01:00
os
2020-02-19 16:12:39 +01:00
v.table
v.doc
v.pref
v.util
2020-02-09 10:08:04 +01:00
)
const (
2020-02-10 14:42:57 +01:00
simple_cmd = ['fmt',
2020-02-28 13:02:56 +01:00
'up', 'self',
2020-02-10 14:42:57 +01:00
'test', 'test-fmt', 'test-compiler',
'bin2v',
'repl',
2020-02-24 18:01:35 +01:00
'build-tools', 'build-examples', 'build-vbinaries',
'setup-freetype']
2020-02-09 10:08:04 +01:00
)
fn main() {
2020-03-06 18:53:29 +01:00
prefs := flag.MainCmdPreferences{}
2020-03-20 17:20:53 +01:00
values := flag.parse_main_cmd(os.args, parse_flags, prefs) or {
2020-03-13 09:45:40 +01:00
println('V Error: An error has occurred while parsing flags: ')
2020-03-06 18:53:29 +01:00
println(err)
exit(1)
2020-02-09 10:08:04 +01:00
}
2020-03-06 18:53:29 +01:00
if prefs.verbosity.is_higher_or_equal(.level_two) {
println(util.full_v_version())
2020-02-09 10:08:04 +01:00
}
2020-03-06 18:53:29 +01:00
if prefs.verbosity.is_higher_or_equal(.level_three) {
println('Parsed preferences: ')
//println(prefs) // QTODO
2020-03-06 18:53:29 +01:00
println('Remaining: $values')
2020-02-09 10:08:04 +01:00
}
2020-03-06 18:53:29 +01:00
// Do a quick check for `v -v`. Too much error has been made this way.
if prefs.verbosity == .level_one && values.len == 0 {
println("`v -v` now runs V with verbose mode set to level one which doesn't do anything.")
println('Did you mean `v -version` instead?')
exit(1)
}
// Start calling the correct functions/external tools
// Note for future contributors: Please add new subcommands in the `match` block below.
if prefs.action == .version {
disallow_unknown_flags(prefs)
print_version_and_exit()
}
if values.len == 0 && prefs.action == .help {
2020-03-13 20:52:49 +01:00
invoke_help_and_exit(values)
2020-03-06 18:53:29 +01:00
}
if values.len == 0 || values[0] == '-' || values[0] == 'repl' {
// Check for REPL.
if values.len == 0 {
println('Running REPL as no arguments are provided.')
println('For usage information, quit V REPL using `exit` and use `v help`.')
}
launch_tool(prefs.verbosity, 'vrepl')
2020-02-19 16:12:39 +01:00
}
2020-03-06 18:53:29 +01:00
command := values[0]
2020-02-09 10:08:04 +01:00
if command in simple_cmd {
2020-02-10 14:42:57 +01:00
// External tools
2020-03-06 18:53:29 +01:00
launch_tool(prefs.verbosity, 'v' + command)
2020-02-09 10:08:04 +01:00
return
}
match command {
2020-03-15 11:20:12 +01:00
'create', 'init' {
launch_tool(prefs.verbosity, 'vcreate')
return
}
2020-02-09 10:08:04 +01:00
'translate' {
2020-02-19 16:12:39 +01:00
println('Translating C to V will be available in V 0.3')
2020-03-06 18:53:29 +01:00
return
2020-02-09 10:08:04 +01:00
}
'search', 'install', 'update', 'remove' {
2020-03-06 18:53:29 +01:00
launch_tool(prefs.verbosity, 'vpm')
return
2020-02-09 10:08:04 +01:00
}
'get' {
2020-03-06 18:53:29 +01:00
println('V Error: Use `v install` to install modules from vpm.vlang.io')
exit(1)
2020-02-09 10:08:04 +01:00
}
'symlink' {
2020-03-06 18:53:29 +01:00
disallow_unknown_flags(prefs)
2020-02-09 10:08:04 +01:00
create_symlink()
2020-03-06 18:53:29 +01:00
return
2020-02-09 10:08:04 +01:00
}
2020-03-06 18:53:29 +01:00
'doc' {
disallow_unknown_flags(prefs)
if values.len == 1 {
println('V Error: Expected argument: Module name to output documentations for')
exit(1)
}
table := table.new_table()
println(doc.doc(values[1], table))
return
}
'help' {
disallow_unknown_flags(prefs)
2020-03-13 20:52:49 +01:00
invoke_help_and_exit(values)
2020-03-06 18:53:29 +01:00
return
}
'version' {
disallow_unknown_flags(prefs)
print_version_and_exit()
return
2020-02-09 10:08:04 +01:00
}
2020-03-06 18:53:29 +01:00
else {}
}
if command == 'run' || command == 'build' || command.ends_with('.v') || os.exists(command) {
arg := join_flags_and_argument()
compile.compile(command, arg)
return
}
eprintln('v $command: unknown command\nRun "v help" for usage.')
exit(1)
}
fn print_version_and_exit() {
println(util.full_v_version())
2020-03-06 18:53:29 +01:00
exit(0)
}
2020-03-13 20:52:49 +01:00
fn invoke_help_and_exit(remaining []string) {
match remaining.len {
0, 1 {
help.print_and_exit('default')
}
2 {
help.print_and_exit(remaining[1])
}
else {}
}
println('V Error: Expected only one help topic to be provided.')
println('For usage information, use `v help`.')
exit(1)
}
2020-03-06 18:53:29 +01:00
[inline]
fn disallow_unknown_flags(prefs flag.MainCmdPreferences) {
if prefs.unknown_flag == '' {
return
2020-02-09 10:08:04 +01:00
}
2020-03-06 18:53:29 +01:00
println('V Error: Unexpected flag found: $prefs.unknown_flag')
exit(1)
2020-02-09 10:08:04 +01:00
}
fn create_symlink() {
$if windows {
return
}
vexe := pref.vexe_path()
mut link_path := '/usr/local/bin/v'
mut ret := os.exec('ln -sf $vexe $link_path') or { panic(err) }
if ret.exit_code == 0 {
println('Symlink "$link_path" has been created')
}
else if os.system('uname -o | grep -q \'[A/a]ndroid\'') == 0 {
println('Failed to create symlink "$link_path". Trying again with Termux path for Android.')
link_path = '/data/data/com.termux/files/usr/bin/v'
ret = os.exec('ln -sf $vexe $link_path') or { panic(err) }
if ret.exit_code == 0 {
println('Symlink "$link_path" has been created')
} else {
println('Failed to create symlink "$link_path". Try again with sudo.')
}
} else {
println('Failed to create symlink "$link_path". Try again with sudo.')
}
}