cc: experimental -fast option for tcc/codegen in the future

pull/2607/head
Alexander Medvednikov 2019-11-01 00:37:24 +03:00
parent 987f5fd2a1
commit 91df08f56d
3 changed files with 32 additions and 26 deletions

View File

@ -64,28 +64,32 @@ fn (v mut V) cc() {
// TCC on Linux by default, unless -cc was provided // TCC on Linux by default, unless -cc was provided
// TODO if -cc = cc, TCC is still used, default compiler should be // TODO if -cc = cc, TCC is still used, default compiler should be
// used instead. // used instead.
$if linux { if v.pref.fast {
$if !android { $if linux {
vdir := os.dir(vexe) $if !android {
tcc_3rd := '$vdir/thirdparty/tcc/bin/tcc' vdir := os.dir(vexe)
//println('tcc third "$tcc_3rd"') tcc_3rd := '$vdir/thirdparty/tcc/bin/tcc'
tcc_path := '/var/tmp/tcc/bin/tcc' //println('tcc third "$tcc_3rd"')
if os.file_exists(tcc_3rd) && !os.file_exists(tcc_path) { tcc_path := '/var/tmp/tcc/bin/tcc'
//println('moving tcc') if os.file_exists(tcc_3rd) && !os.file_exists(tcc_path) {
// if there's tcc in thirdparty/, that means this is //println('moving tcc')
// a prebuilt V_linux.zip. // if there's tcc in thirdparty/, that means this is
// Until the libtcc1.a bug is fixed, we neeed to move // a prebuilt V_linux.zip.
// it to /var/tmp/ // Until the libtcc1.a bug is fixed, we neeed to move
os.system('mv $vdir/thirdparty/tcc /var/tmp/') // it to /var/tmp/
os.system('mv $vdir/thirdparty/tcc /var/tmp/')
}
if v.pref.ccompiler == 'cc' && os.file_exists(tcc_path) {
// TODO tcc bug, needs an empty libtcc1.a fila
//os.mkdir('/var/tmp/tcc/lib/tcc/')
//os.create('/var/tmp/tcc/lib/tcc/libtcc1.a')
v.pref.ccompiler = tcc_path
}
} }
if v.pref.ccompiler == 'cc' && os.file_exists(tcc_path) { } $else {
// TODO tcc bug, needs an empty libtcc1.a fila verror('-fast is only supported on Linux right now')
//os.mkdir('/var/tmp/tcc/lib/tcc/')
//os.create('/var/tmp/tcc/lib/tcc/libtcc1.a')
v.pref.ccompiler = tcc_path
} }
} }
}
//linux_host := os.user_os() == 'linux' //linux_host := os.user_os() == 'linux'
v.log('cc() isprod=$v.pref.is_prod outname=$v.out_name') v.log('cc() isprod=$v.pref.is_prod outname=$v.out_name')
mut a := [v.pref.cflags, '-std=gnu11', '-w'] // arguments for the C compiler mut a := [v.pref.cflags, '-std=gnu11', '-w'] // arguments for the C compiler

View File

@ -114,6 +114,7 @@ pub mut:
// work on the builtin module itself. // work on the builtin module itself.
//generating_vh bool //generating_vh bool
comptime_define string // -D vfmt for `if $vfmt {` comptime_define string // -D vfmt for `if $vfmt {`
fast bool // use tcc/x64 codegen
} }
// Should be called by main at the end of the compilation process, to cleanup // Should be called by main at the end of the compilation process, to cleanup
@ -930,6 +931,7 @@ pub fn new_v(args[]string) &V {
is_run: 'run' in args is_run: 'run' in args
autofree: '-autofree' in args autofree: '-autofree' in args
compress: '-compress' in args compress: '-compress' in args
fast: '-fast' in args
is_repl: is_repl is_repl: is_repl
build_mode: build_mode build_mode: build_mode
cflags: cflags cflags: cflags