vcreate: add `init` command

pull/4033/head
Major Taylor 2020-03-15 06:20:12 -04:00 committed by GitHub
parent d10c1c36a9
commit c546e88577
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 118 additions and 25 deletions

View File

@ -2,6 +2,10 @@
// Use of this source code is governed by an MIT license // Use of this source code is governed by an MIT license
// that can be found in the LICENSE file. // that can be found in the LICENSE file.
// This module follows a similar convention to Rust: `init` makes the
// structure of the program in the _current_ directory, while `create`
// makes the program structure in a _sub_ directory. Besides that, the
// functionality is essentially the same.
module main module main
import ( import (
@ -18,43 +22,103 @@ fn cerror(e string){
eprintln('\nerror: $e') eprintln('\nerror: $e')
} }
fn (c Create)write_vmod() { [inline]
mut vmod := os.create('${c.name}/v.mod') or { fn vmod_content(name, desc string) string {
cerror(err) return [
exit(1)
}
vmod_content := [
'#V Project#\n', '#V Project#\n',
'Module {', 'Module {',
' name: \'${c.name}\',', ' name: \'${name}\',',
' description: \'${c.description}\',', ' description: \'${desc}\',',
' dependencies: []', ' dependencies: []',
'}' '}'
] ].join('\n')
vmod.write(vmod_content.join('\n'))
} }
fn (c Create)write_main() { [inline]
mut main := os.create('${c.name}/${c.name}.v') or { fn main_content() string {
cerror(err) return [
exit(2)
}
main_content := [
'module main\n', 'module main\n',
'fn main() {', 'fn main() {',
' println(\'Hello World !\')', ' println(\'Hello World !\')',
'}' '}'
] ].join('\n')
main.write(main_content.join('\n'))
} }
fn main() { [inline]
fn gen_gitignore(name string) string {
return [
'main',
'$name',
'*.so',
'*.dll'
].join('\n')
}
fn (c &Create)create_vmod() {
mut vmod := os.create('${c.name}/v.mod') or {
cerror(err)
exit(1)
}
vmod.write(vmod_content(c.name, c.description))
vmod.close()
}
fn (c &Create)create_main() {
mut main := os.create('${c.name}/${c.name}.v') or {
cerror(err)
exit(2)
}
main.write(main_content())
main.close()
}
fn (c &Create)init_vmod() {
mut vmod := os.create('v.mod') or {
cerror(err)
exit(1)
}
vmod.write(vmod_content(c.name, c.description))
vmod.close()
}
fn (c &Create)create_git_repo(dir string) {
// Create Git Repo and .gitignore file
if !os.is_dir('${dir}/.git') {
os.exec('git init ${dir}') or {
cerror('Unable to create git repo')
}
if !os.exists('${dir}/.gitignore') {
mut fl := os.create('${dir}/.gitignore') or {
// We don't really need a .gitignore, it's just a nice-to-have
return
}
fl.write(gen_gitignore(c.name))
fl.close()
}
}
}
fn (c &Create)init_main() {
// The file already exists, don't over-write anything.
// Searching in the 'src' directory allows flexibility user module structure
if os.exists('${c.name}.v') || os.exists('src/${c.name}.v') {
return
}
mut main := os.create('${c.name}.v') or {
cerror(err)
exit(2)
}
main.write(main_content())
main.close()
}
fn create() {
mut c := Create{} mut c := Create{}
print('Input your project name: ') print('Input your project name: ')
c.name = os.get_line() c.name = os.get_line()
if (os.is_dir(c.name)) { if os.is_dir(c.name) {
cerror('${c.name} folder already exists') cerror('${c.name} folder already exists')
exit(3) exit(3)
} }
@ -67,7 +131,33 @@ fn main() {
os.mkdir(c.name) or { os.mkdir(c.name) or {
panic(err) panic(err)
} }
c.write_vmod() c.create_vmod()
c.write_main() c.create_main()
println('Complete !') c.create_git_repo(c.name)
}
fn init() {
if os.exists('v.mod') {
cerror('`v init` cannot be run on existing v modules')
exit(3)
}
mut c := Create{}
c.name = os.filename(os.getwd())
c.description = ''
c.init_vmod()
c.init_main()
c.create_git_repo('')
println("Change your module's description in `v.mod`")
}
fn main() {
if 'create' == os.args[1] {
create()
} else if 'init' == os.args[1] {
init()
} else {
cerror('Unknown command: ${os.args[1]}')
exit(1)
}
println('Complete!')
} }

View File

@ -16,7 +16,6 @@ import (
const ( const (
simple_cmd = ['fmt', simple_cmd = ['fmt',
'up', 'self', 'up', 'self',
'create',
'test', 'test-fmt', 'test-compiler', 'test', 'test-fmt', 'test-compiler',
'bin2v', 'bin2v',
'repl', 'repl',
@ -69,6 +68,10 @@ fn main() {
return return
} }
match command { match command {
'create', 'init' {
launch_tool(prefs.verbosity, 'vcreate')
return
}
'translate' { 'translate' {
println('Translating C to V will be available in V 0.3') println('Translating C to V will be available in V 0.3')
return return