hotreload: fix compilation of .so file on macos
parent
dd96421a9f
commit
0fbb056ac7
cmd/v
internal
10
cmd/v/flag.v
10
cmd/v/flag.v
|
@ -9,8 +9,9 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
|
list_of_flags_that_allow_duplicates = ['cc','d','define','cf','cflags']
|
||||||
//list_of_flags contains a list of flags where an argument is expected past it.
|
//list_of_flags contains a list of flags where an argument is expected past it.
|
||||||
list_of_flags = [
|
list_of_flags_with_param = [
|
||||||
'o', 'output', 'd', 'define', 'b', 'backend', 'cc', 'os', 'target-os', 'arch',
|
'o', 'output', 'd', 'define', 'b', 'backend', 'cc', 'os', 'target-os', 'arch',
|
||||||
'csource', 'cf', 'cflags', 'path'
|
'csource', 'cf', 'cflags', 'path'
|
||||||
]
|
]
|
||||||
|
@ -85,8 +86,11 @@ fn parse_flags(flag string, f mut flag.Instance, prefs mut flag.MainCmdPreferenc
|
||||||
exit(1)
|
exit(1)
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
prefs.unknown_flag = '-$flag'
|
if flag in list_of_flags_that_allow_duplicates {
|
||||||
if !(flag in list_of_flags) {
|
f.allow_duplicate()
|
||||||
|
}
|
||||||
|
prefs.unknown_flag = '-$flag'
|
||||||
|
if !(flag in list_of_flags_with_param) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
f.string() or {
|
f.string() or {
|
||||||
|
|
|
@ -12,7 +12,6 @@ import (
|
||||||
v.pref
|
v.pref
|
||||||
)
|
)
|
||||||
|
|
||||||
[inline]
|
|
||||||
fn parse_c_options(flag string, f mut flag.Instance, prefs mut pref.Preferences) {
|
fn parse_c_options(flag string, f mut flag.Instance, prefs mut pref.Preferences) {
|
||||||
match flag {
|
match flag {
|
||||||
'cc', 'compiler' {
|
'cc', 'compiler' {
|
||||||
|
@ -23,6 +22,8 @@ fn parse_c_options(flag string, f mut flag.Instance, prefs mut pref.Preferences)
|
||||||
exit(1)
|
exit(1)
|
||||||
}
|
}
|
||||||
prefs.ccompiler = tmp
|
prefs.ccompiler = tmp
|
||||||
|
// needed to enable CI compiling of -live examples.
|
||||||
|
f.allow_duplicate()
|
||||||
}
|
}
|
||||||
'cg', 'cdebug' {
|
'cg', 'cdebug' {
|
||||||
f.is_equivalent_to(['cg', 'cdebug', 'g', 'debug'])
|
f.is_equivalent_to(['cg', 'cdebug', 'g', 'debug'])
|
||||||
|
|
|
@ -32,6 +32,8 @@ fn parse_arguments(args []string) (pref.Preferences, []string) {
|
||||||
mut remaining := flag.parse_pref(args, parse_options, &p) or {
|
mut remaining := flag.parse_pref(args, parse_options, &p) or {
|
||||||
println('V error: Error while parsing flags.')
|
println('V error: Error while parsing flags.')
|
||||||
println(err)
|
println(err)
|
||||||
|
println('Args:')
|
||||||
|
println(args)
|
||||||
exit(1)
|
exit(1)
|
||||||
}
|
}
|
||||||
match remaining[0] {
|
match remaining[0] {
|
||||||
|
|
|
@ -16,8 +16,7 @@ pub fn parse_pref(args []string, callback fn(string, &Instance, &pref.Preference
|
||||||
args: args
|
args: args
|
||||||
current_pos: 0
|
current_pos: 0
|
||||||
}
|
}
|
||||||
casted_callback := *(&void_cb(&callback))
|
tmp := p.parse_impl(args, voidptr(obj), void_cb(callback)) or {
|
||||||
tmp := p.parse_impl(args, voidptr(obj), casted_callback) or {
|
|
||||||
return error(err)
|
return error(err)
|
||||||
}
|
}
|
||||||
return tmp
|
return tmp
|
||||||
|
@ -41,8 +40,7 @@ pub fn parse_main_cmd(args []string, callback fn(string, &Instance, &MainCmdPref
|
||||||
args: args
|
args: args
|
||||||
current_pos: 0
|
current_pos: 0
|
||||||
}
|
}
|
||||||
casted_callback := *(&void_cb(&callback))
|
tmp := p.parse_impl(args, voidptr(obj), void_cb(callback)) or {
|
||||||
tmp := p.parse_impl(args, voidptr(obj), casted_callback) or {
|
|
||||||
return error(err)
|
return error(err)
|
||||||
}
|
}
|
||||||
return tmp
|
return tmp
|
||||||
|
|
|
@ -98,12 +98,15 @@ fn (v &V) generate_hot_reload_code() {
|
||||||
println(cmd_compile_shared_library)
|
println(cmd_compile_shared_library)
|
||||||
}
|
}
|
||||||
ticks := time.ticks()
|
ticks := time.ticks()
|
||||||
os.system(cmd_compile_shared_library)
|
so_compilation_result := os.system(cmd_compile_shared_library)
|
||||||
if v.pref.verbosity.is_higher_or_equal(.level_two) {
|
if v.pref.verbosity.is_higher_or_equal(.level_two) {
|
||||||
diff := time.ticks() - ticks
|
diff := time.ticks() - ticks
|
||||||
println('compiling shared library took $diff ms')
|
println('compiling shared library took $diff ms')
|
||||||
println('=========\n')
|
println('=========\n')
|
||||||
}
|
}
|
||||||
|
if so_compilation_result != 0 {
|
||||||
|
exit(1)
|
||||||
|
}
|
||||||
cgen.genln('
|
cgen.genln('
|
||||||
|
|
||||||
void lfnmutex_print(char *s){
|
void lfnmutex_print(char *s){
|
||||||
|
@ -199,7 +202,6 @@ void reload_so() {
|
||||||
pthread_mutex_lock(&live_fn_mutex);
|
pthread_mutex_lock(&live_fn_mutex);
|
||||||
lfnmutex_print("reload_so locked");
|
lfnmutex_print("reload_so locked");
|
||||||
|
|
||||||
live_lib = 0; // hack: force skipping dlclose/1, the code may be still used...
|
|
||||||
load_so(new_so_name);
|
load_so(new_so_name);
|
||||||
#ifndef _WIN32
|
#ifndef _WIN32
|
||||||
unlink(new_so_name); // removing the .so file from the filesystem after dlopen-ing it is safe, since it will still be mapped in memory.
|
unlink(new_so_name); // removing the .so file from the filesystem after dlopen-ing it is safe, since it will still be mapped in memory.
|
||||||
|
|
|
@ -422,41 +422,10 @@ $consts_init_body
|
||||||
builtin__init();
|
builtin__init();
|
||||||
$call_mod_init
|
$call_mod_init
|
||||||
}')
|
}')
|
||||||
// _STR function can't be defined in vlib
|
|
||||||
v.cgen.genln('
|
|
||||||
string _STR(const char *fmt, ...) {
|
|
||||||
va_list argptr;
|
|
||||||
va_start(argptr, fmt);
|
|
||||||
size_t len = vsnprintf(0, 0, fmt, argptr) + 1;
|
|
||||||
va_end(argptr);
|
|
||||||
byte* buf = malloc(len);
|
|
||||||
va_start(argptr, fmt);
|
|
||||||
vsprintf((char *)buf, fmt, argptr);
|
|
||||||
va_end(argptr);
|
|
||||||
#ifdef DEBUG_ALLOC
|
|
||||||
puts("_STR:");
|
|
||||||
puts(buf);
|
|
||||||
#endif
|
|
||||||
return tos2(buf);
|
|
||||||
}
|
|
||||||
|
|
||||||
string _STR_TMP(const char *fmt, ...) {
|
|
||||||
va_list argptr;
|
|
||||||
va_start(argptr, fmt);
|
|
||||||
//size_t len = vsnprintf(0, 0, fmt, argptr) + 1;
|
|
||||||
va_end(argptr);
|
|
||||||
va_start(argptr, fmt);
|
|
||||||
vsprintf((char *)g_str_buf, fmt, argptr);
|
|
||||||
va_end(argptr);
|
|
||||||
#ifdef DEBUG_ALLOC
|
|
||||||
//puts("_STR_TMP:");
|
|
||||||
//puts(g_str_buf);
|
|
||||||
#endif
|
|
||||||
return tos2(g_str_buf);
|
|
||||||
}
|
|
||||||
|
|
||||||
')
|
|
||||||
}
|
}
|
||||||
|
if !v.pref.is_bare {
|
||||||
|
v.generate_str_definitions()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -936,3 +905,40 @@ pub fn set_vroot_folder(vroot_path string) {
|
||||||
vname := if os.user_os() == 'windows' { 'v.exe' } else { 'v' }
|
vname := if os.user_os() == 'windows' { 'v.exe' } else { 'v' }
|
||||||
os.setenv('VEXE', os.realpath([vroot_path, vname].join(os.path_separator)), true)
|
os.setenv('VEXE', os.realpath([vroot_path, vname].join(os.path_separator)), true)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn (v mut V) generate_str_definitions() {
|
||||||
|
// _STR function can't be defined in vlib
|
||||||
|
v.cgen.genln('
|
||||||
|
string _STR(const char *fmt, ...) {
|
||||||
|
va_list argptr;
|
||||||
|
va_start(argptr, fmt);
|
||||||
|
size_t len = vsnprintf(0, 0, fmt, argptr) + 1;
|
||||||
|
va_end(argptr);
|
||||||
|
byte* buf = malloc(len);
|
||||||
|
va_start(argptr, fmt);
|
||||||
|
vsprintf((char *)buf, fmt, argptr);
|
||||||
|
va_end(argptr);
|
||||||
|
#ifdef DEBUG_ALLOC
|
||||||
|
puts("_STR:");
|
||||||
|
puts(buf);
|
||||||
|
#endif
|
||||||
|
return tos2(buf);
|
||||||
|
}
|
||||||
|
|
||||||
|
string _STR_TMP(const char *fmt, ...) {
|
||||||
|
va_list argptr;
|
||||||
|
va_start(argptr, fmt);
|
||||||
|
//size_t len = vsnprintf(0, 0, fmt, argptr) + 1;
|
||||||
|
va_end(argptr);
|
||||||
|
va_start(argptr, fmt);
|
||||||
|
vsprintf((char *)g_str_buf, fmt, argptr);
|
||||||
|
va_end(argptr);
|
||||||
|
#ifdef DEBUG_ALLOC
|
||||||
|
//puts("_STR_TMP:");
|
||||||
|
//puts(g_str_buf);
|
||||||
|
#endif
|
||||||
|
return tos2(g_str_buf);
|
||||||
|
}
|
||||||
|
|
||||||
|
')
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue