hotreload: fix compilation of .so file on macos

pull/4077/head
Delyan Angelov 2020-03-19 15:50:37 +02:00 committed by GitHub
parent dd96421a9f
commit 0fbb056ac7
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
6 changed files with 57 additions and 44 deletions

View File

@ -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 {

View File

@ -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'])

View File

@ -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] {

View File

@ -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

View File

@ -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.

View File

@ -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);
}
')
}