compiler: allow passing options to v run

pull/1766/head
Delyan Angelov 2019-08-27 21:08:54 +03:00 committed by Alexander Medvednikov
parent 96747187b4
commit 2d87fea074
4 changed files with 22 additions and 14 deletions

View File

@ -39,14 +39,15 @@ script:
- | - |
if [[ "${TRAVIS_OS_NAME}" == "windows" ]]; then if [[ "${TRAVIS_OS_NAME}" == "windows" ]]; then
git clone --depth=1 https://github.com/ubawurinna/freetype-windows-binaries thirdparty/freetype/ git clone --depth=1 https://github.com/ubawurinna/freetype-windows-binaries thirdparty/freetype/
##echo "Just running ./make.bat to produce v.exe" echo "Just running ./make.bat to produce v.exe"
##./make.bat ./make.bat
ls -la v.exe
echo "Running v test v..."
./v.exe test v
##echo "Running only the repl tests directly" ##echo "Running only the repl tests directly"
##./v.exe ./compiler/tests/repl/repl_test.v ##./v.exe ./compiler/tests/repl/repl_test.v
echo "Testing msvc bootstrapping" echo "Testing msvc bootstrapping"
./make_msvc.bat ./make_msvc.bat
echo "Running v test v..."
v.exe test v
fi fi
- | - |
if [[ "${TRAVIS_OS_NAME}" != "windows" ]]; then if [[ "${TRAVIS_OS_NAME}" != "windows" ]]; then

View File

@ -616,7 +616,11 @@ fn (v mut V) add_v_files_to_compile() {
} }
fn get_arg(joined_args, arg, def string) string { fn get_arg(joined_args, arg, def string) string {
key := '-$arg ' return get_all_after(joined_args, '-$arg', def)
}
fn get_all_after(joined_args, arg, def string) string {
key := '$arg '
mut pos := joined_args.index(key) mut pos := joined_args.index(key)
if pos == -1 { if pos == -1 {
return def return def
@ -648,17 +652,18 @@ fn (v &V) log(s string) {
} }
fn new_v(args[]string) *V { fn new_v(args[]string) *V {
mut dir := args.last()
if args.contains('run') {
dir = args[2]
}
// println('new compiler "$dir"')
if args.len < 2 {
dir = ''
}
joined_args := args.join(' ') joined_args := args.join(' ')
target_os := get_arg(joined_args, 'os', '') target_os := get_arg(joined_args, 'os', '')
mut out_name := get_arg(joined_args, 'o', 'a.out') mut out_name := get_arg(joined_args, 'o', 'a.out')
mut dir := args.last()
if args.contains('run') {
dir = get_all_after(joined_args, 'run', '')
}
if args.len < 2 {
dir = ''
}
// println('new compiler "$dir"')
// build mode // build mode
mut build_mode := BuildMode.default_mode mut build_mode := BuildMode.default_mode
mut mod := '' mut mod := ''

View File

@ -1,4 +1,5 @@
rd /s /q vc rd /s /q vc
git version
git clone --depth 1 --quiet https://github.com/vlang/vc git clone --depth 1 --quiet https://github.com/vlang/vc
gcc -std=gnu11 -DUNICODE -D_UNICODE -w -o v2.exe vc/v_win.c gcc -std=gnu11 -DUNICODE -D_UNICODE -w -o v2.exe vc/v_win.c
v2.exe -o v.exe compiler v2.exe -o v.exe compiler

View File

@ -28,11 +28,12 @@ if %ERRORLEVEL% GEQ 1 (
echo rebuild from source echo rebuild from source
v2.exe -os msvc -o v.exe compiler v2.exe -os msvc -o v.exe compiler
if %ERRORLEVEL% GEQ 1 ( if %ERRORLEVEL% GEQ 1 (
goto :compileerror goto :compileerror
) )
dir v_win.c v2.exe v.exe
del .v_win.c.obj del .v_win.c.obj
del v_win.c del v_win.c
del v2.exe del v2.exe