v: add support for `$if freestanding {`, without using it (part 1) (#9656)
parent
f0a67a4813
commit
903dd49212
|
@ -3700,8 +3700,8 @@ Full list of builtin options:
|
||||||
| --- | --- | --- | --- |
|
| --- | --- | --- | --- |
|
||||||
| `windows`, `linux`, `macos` | `gcc`, `tinyc` | `amd64`, `aarch64` | `debug`, `prod`, `test` |
|
| `windows`, `linux`, `macos` | `gcc`, `tinyc` | `amd64`, `aarch64` | `debug`, `prod`, `test` |
|
||||||
| `mac`, `darwin`, `ios`, | `clang`, `mingw` | `x64`, `x32` | `js`, `glibc`, `prealloc` |
|
| `mac`, `darwin`, `ios`, | `clang`, `mingw` | `x64`, `x32` | `js`, `glibc`, `prealloc` |
|
||||||
| `android`,`mach`, `dragonfly` | `msvc` | `little_endian` | `no_bounds_checking` |
|
| `android`,`mach`, `dragonfly` | `msvc` | `little_endian` | `no_bounds_checking`, `freestanding` |
|
||||||
| `gnu`, `hpux`, `haiku`, `qnx` | `cplusplus` | `big_endian` | |
|
| `gnu`, `hpux`, `haiku`, `qnx` | `cplusplus` | `big_endian` |
|
||||||
| `solaris`, `linux_or_macos` | | | |
|
| `solaris`, `linux_or_macos` | | | |
|
||||||
|
|
||||||
#### $embed_file
|
#### $embed_file
|
||||||
|
|
|
@ -198,15 +198,15 @@ pub fn (v Builder) get_builtin_files() []string {
|
||||||
for location in v.pref.lookup_path {
|
for location in v.pref.lookup_path {
|
||||||
if os.exists(os.join_path(location, 'builtin')) {
|
if os.exists(os.join_path(location, 'builtin')) {
|
||||||
mut builtin_files := []string{}
|
mut builtin_files := []string{}
|
||||||
if v.pref.is_bare {
|
if v.pref.backend == .js {
|
||||||
builtin_files << v.v_files_from_dir(os.join_path(location, 'builtin',
|
|
||||||
'bare'))
|
|
||||||
} else if v.pref.backend == .js {
|
|
||||||
builtin_files << v.v_files_from_dir(os.join_path(location, 'builtin',
|
builtin_files << v.v_files_from_dir(os.join_path(location, 'builtin',
|
||||||
'js'))
|
'js'))
|
||||||
} else {
|
} else {
|
||||||
builtin_files << v.v_files_from_dir(os.join_path(location, 'builtin'))
|
builtin_files << v.v_files_from_dir(os.join_path(location, 'builtin'))
|
||||||
}
|
}
|
||||||
|
if v.pref.is_bare {
|
||||||
|
builtin_files << v.v_files_from_dir(v.pref.bare_builtin_dir)
|
||||||
|
}
|
||||||
if v.pref.backend == .c {
|
if v.pref.backend == .c {
|
||||||
// TODO JavaScript backend doesn't handle os for now
|
// TODO JavaScript backend doesn't handle os for now
|
||||||
if v.pref.is_vsh && os.exists(os.join_path(location, 'os')) {
|
if v.pref.is_vsh && os.exists(os.join_path(location, 'os')) {
|
||||||
|
|
|
@ -25,8 +25,7 @@ const (
|
||||||
valid_comp_if_compilers = ['gcc', 'tinyc', 'clang', 'mingw', 'msvc', 'cplusplus']
|
valid_comp_if_compilers = ['gcc', 'tinyc', 'clang', 'mingw', 'msvc', 'cplusplus']
|
||||||
valid_comp_if_platforms = ['amd64', 'aarch64', 'x64', 'x32', 'little_endian', 'big_endian']
|
valid_comp_if_platforms = ['amd64', 'aarch64', 'x64', 'x32', 'little_endian', 'big_endian']
|
||||||
valid_comp_if_other = ['js', 'debug', 'prod', 'test', 'glibc', 'prealloc',
|
valid_comp_if_other = ['js', 'debug', 'prod', 'test', 'glibc', 'prealloc',
|
||||||
'no_bounds_checking',
|
'no_bounds_checking', 'freestanding']
|
||||||
]
|
|
||||||
array_builtin_methods = ['filter', 'clone', 'repeat', 'reverse', 'map', 'slice', 'sort',
|
array_builtin_methods = ['filter', 'clone', 'repeat', 'reverse', 'map', 'slice', 'sort',
|
||||||
'contains', 'index', 'wait', 'any', 'all', 'first', 'last', 'pop']
|
'contains', 'index', 'wait', 'any', 'all', 'first', 'last', 'pop']
|
||||||
)
|
)
|
||||||
|
@ -5582,6 +5581,7 @@ fn (mut c Checker) comp_if_branch(cond ast.Expr, pos token.Position) bool {
|
||||||
'glibc' { return false } // TODO
|
'glibc' { return false } // TODO
|
||||||
'prealloc' { return !c.pref.prealloc }
|
'prealloc' { return !c.pref.prealloc }
|
||||||
'no_bounds_checking' { return cond.name !in c.pref.compile_defines_all }
|
'no_bounds_checking' { return cond.name !in c.pref.compile_defines_all }
|
||||||
|
'freestanding' { return !c.pref.is_bare }
|
||||||
else { return false }
|
else { return false }
|
||||||
}
|
}
|
||||||
} else if cond.name !in c.pref.compile_defines_all {
|
} else if cond.name !in c.pref.compile_defines_all {
|
||||||
|
|
|
@ -575,6 +575,9 @@ fn (mut g Gen) comp_if_to_ifdef(name string, is_comptime_optional bool) ?string
|
||||||
'no_bounds_checking' {
|
'no_bounds_checking' {
|
||||||
return 'CUSTOM_DEFINE_no_bounds_checking'
|
return 'CUSTOM_DEFINE_no_bounds_checking'
|
||||||
}
|
}
|
||||||
|
'freestanding' {
|
||||||
|
return '_VFREESTANDING'
|
||||||
|
}
|
||||||
// architectures:
|
// architectures:
|
||||||
'amd64' {
|
'amd64' {
|
||||||
return '__V_amd64'
|
return '__V_amd64'
|
||||||
|
|
|
@ -130,6 +130,9 @@ pub fn (mut p Preferences) fill_with_defaults() {
|
||||||
// eprintln('-usecache and -shared flags are not compatible')
|
// eprintln('-usecache and -shared flags are not compatible')
|
||||||
p.use_cache = false
|
p.use_cache = false
|
||||||
}
|
}
|
||||||
|
if p.bare_builtin_dir == '' {
|
||||||
|
p.bare_builtin_dir = os.join_path(p.vroot, 'vlib', 'builtin', 'linux_bare')
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn (mut p Preferences) find_cc_if_cross_compiling() {
|
fn (mut p Preferences) find_cc_if_cross_compiling() {
|
||||||
|
|
|
@ -130,6 +130,7 @@ pub mut:
|
||||||
no_preludes bool // Prevents V from generating preludes in resulting .c files
|
no_preludes bool // Prevents V from generating preludes in resulting .c files
|
||||||
custom_prelude string // Contents of custom V prelude that will be prepended before code in resulting .c files
|
custom_prelude string // Contents of custom V prelude that will be prepended before code in resulting .c files
|
||||||
lookup_path []string
|
lookup_path []string
|
||||||
|
bare_builtin_dir string // Path to implementation of malloc, memset, etc. Only used if is_bare is true
|
||||||
output_cross_c bool
|
output_cross_c bool
|
||||||
prealloc bool
|
prealloc bool
|
||||||
vroot string
|
vroot string
|
||||||
|
@ -464,6 +465,12 @@ pub fn parse_args(known_external_commands []string, args []string) (&Preferences
|
||||||
res.lookup_path = path.replace('|', os.path_delimiter).split(os.path_delimiter)
|
res.lookup_path = path.replace('|', os.path_delimiter).split(os.path_delimiter)
|
||||||
i++
|
i++
|
||||||
}
|
}
|
||||||
|
'-bare-builtin-dir' {
|
||||||
|
bare_builtin_dir := cmdline.option(current_args, arg, '')
|
||||||
|
res.build_options << '$arg "$bare_builtin_dir"'
|
||||||
|
res.bare_builtin_dir = bare_builtin_dir
|
||||||
|
i++
|
||||||
|
}
|
||||||
'-custom-prelude' {
|
'-custom-prelude' {
|
||||||
path := cmdline.option(current_args, '-custom-prelude', '')
|
path := cmdline.option(current_args, '-custom-prelude', '')
|
||||||
res.build_options << '$arg $path'
|
res.build_options << '$arg $path'
|
||||||
|
|
|
@ -8,6 +8,9 @@ pub fn (prefs &Preferences) should_compile_filtered_files(dir string, files_ []s
|
||||||
files.sort()
|
files.sort()
|
||||||
mut all_v_files := []string{}
|
mut all_v_files := []string{}
|
||||||
for file in files {
|
for file in files {
|
||||||
|
if prefs.is_bare && os.join_path(dir, file).ends_with('/vlib/builtin/builtin_nix.c.v') {
|
||||||
|
continue
|
||||||
|
}
|
||||||
if !file.ends_with('.v') && !file.ends_with('.vh') {
|
if !file.ends_with('.v') && !file.ends_with('.vh') {
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
@ -123,6 +126,9 @@ pub fn (prefs &Preferences) should_compile_c(file string) bool {
|
||||||
if prefs.os == .all {
|
if prefs.os == .all {
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
|
if !prefs.is_bare && file.ends_with('.freestanding.v') {
|
||||||
|
return false
|
||||||
|
}
|
||||||
if (file.ends_with('_windows.c.v') || file.ends_with('_windows.v')) && prefs.os != .windows {
|
if (file.ends_with('_windows.c.v') || file.ends_with('_windows.v')) && prefs.os != .windows {
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue