cgen: get usecache working with clang (fix duplicate symbols)
parent
245b70cabc
commit
6fc654821f
|
@ -188,13 +188,10 @@ jobs:
|
||||||
echo $VFLAGS
|
echo $VFLAGS
|
||||||
./v cmd/tools/test_if_v_test_system_works.v
|
./v cmd/tools/test_if_v_test_system_works.v
|
||||||
./cmd/tools/test_if_v_test_system_works
|
./cmd/tools/test_if_v_test_system_works
|
||||||
|
|
||||||
- name: Self tests
|
- name: Self tests
|
||||||
run: VJOBS=1 ./v test-self
|
run: VJOBS=1 ./v test-self
|
||||||
|
|
||||||
- name: Build examples
|
- name: Build examples
|
||||||
run: ./v build-examples
|
run: ./v build-examples
|
||||||
|
|
||||||
- name: Build examples with -autofree
|
- name: Build examples with -autofree
|
||||||
run: |
|
run: |
|
||||||
./v -autofree -o tetris examples/tetris/tetris.v
|
./v -autofree -o tetris examples/tetris/tetris.v
|
||||||
|
@ -202,14 +199,12 @@ jobs:
|
||||||
- name: v doctor
|
- name: v doctor
|
||||||
run: |
|
run: |
|
||||||
./v doctor
|
./v doctor
|
||||||
|
|
||||||
- name: Test ved
|
- name: Test ved
|
||||||
run: |
|
run: |
|
||||||
git clone --depth 1 https://github.com/vlang/ved
|
git clone --depth 1 https://github.com/vlang/ved
|
||||||
cd ved && ../v -o ved .
|
cd ved && ../v -o ved .
|
||||||
../v -autofree .
|
../v -autofree .
|
||||||
cd ..
|
cd ..
|
||||||
|
|
||||||
# - name: Test c2v
|
# - name: Test c2v
|
||||||
# run: |
|
# run: |
|
||||||
# git clone --depth 1 https://github.com/vlang/c2v
|
# git clone --depth 1 https://github.com/vlang/c2v
|
||||||
|
@ -218,7 +213,6 @@ jobs:
|
||||||
# ../v run tests/run_tests.vsh
|
# ../v run tests/run_tests.vsh
|
||||||
# ../v -experimental -w c2v_test.v
|
# ../v -experimental -w c2v_test.v
|
||||||
# cd ..
|
# cd ..
|
||||||
|
|
||||||
- name: Build V UI examples
|
- name: Build V UI examples
|
||||||
run: |
|
run: |
|
||||||
git clone --depth 1 https://github.com/vlang/ui
|
git clone --depth 1 https://github.com/vlang/ui
|
||||||
|
@ -227,6 +221,14 @@ jobs:
|
||||||
ln -s $(pwd) ~/.vmodules/ui
|
ln -s $(pwd) ~/.vmodules/ui
|
||||||
../v examples/rectangles.v
|
../v examples/rectangles.v
|
||||||
## ../v run examples/build_examples.vsh
|
## ../v run examples/build_examples.vsh
|
||||||
|
- name: V self compilation with -usecache
|
||||||
|
run: |
|
||||||
|
unset VFLAGS
|
||||||
|
./v -usecache examples/hello_world.v && examples/hello_world
|
||||||
|
./v -o v2 -usecache cmd/v
|
||||||
|
./v2 -o v3 -usecache cmd/v
|
||||||
|
./v3 version
|
||||||
|
./v3 -o tetris -usecache examples/tetris/tetris.v
|
||||||
|
|
||||||
ubuntu:
|
ubuntu:
|
||||||
runs-on: ubuntu-20.04
|
runs-on: ubuntu-20.04
|
||||||
|
@ -517,31 +519,23 @@ jobs:
|
||||||
- name: v doctor
|
- name: v doctor
|
||||||
run: |
|
run: |
|
||||||
./v doctor
|
./v doctor
|
||||||
|
|
||||||
- name: Verify `v test` works
|
- name: Verify `v test` works
|
||||||
run: |
|
run: |
|
||||||
.\v.exe cmd/tools/test_if_v_test_system_works.v
|
.\v.exe cmd/tools/test_if_v_test_system_works.v
|
||||||
.\cmd\tools\test_if_v_test_system_works.exe
|
.\cmd\tools\test_if_v_test_system_works.exe
|
||||||
|
|
||||||
- name: Verify `v vlib/v/gen/c/coutput_test.v` works
|
- name: Verify `v vlib/v/gen/c/coutput_test.v` works
|
||||||
run: |
|
run: |
|
||||||
.\v.exe vlib/v/gen/c/coutput_test.v
|
.\v.exe vlib/v/gen/c/coutput_test.v
|
||||||
|
|
||||||
- name: Make sure running TCC64 instead of TCC32
|
- name: Make sure running TCC64 instead of TCC32
|
||||||
run: ./v test .github\workflows\make_sure_ci_run_with_64bit_compiler_test.v
|
run: ./v test .github\workflows\make_sure_ci_run_with_64bit_compiler_test.v
|
||||||
|
|
||||||
- name: Test ./v doc -v clipboard *BEFORE building tools*
|
- name: Test ./v doc -v clipboard *BEFORE building tools*
|
||||||
run: ./v doc -v clipboard
|
run: ./v doc -v clipboard
|
||||||
|
|
||||||
- name: Test v build-tools
|
- name: Test v build-tools
|
||||||
run: ./v -W build-tools
|
run: ./v -W build-tools
|
||||||
|
|
||||||
- name: Test ./v doc clipboard
|
- name: Test ./v doc clipboard
|
||||||
run: ./v doc clipboard
|
run: ./v doc clipboard
|
||||||
|
|
||||||
- name: Self tests
|
- name: Self tests
|
||||||
run: ./v test-self
|
run: ./v test-self
|
||||||
|
|
||||||
- name: Test v->js
|
- name: Test v->js
|
||||||
run: ./v -o hi.js examples/hello_v_js.v && node hi.js
|
run: ./v -o hi.js examples/hello_v_js.v && node hi.js
|
||||||
- name: Test v binaries
|
- name: Test v binaries
|
||||||
|
|
|
@ -720,6 +720,12 @@ pub fn (mut g Gen) init() {
|
||||||
if g.pref.prealloc {
|
if g.pref.prealloc {
|
||||||
g.comptime_definitions.writeln('#define _VPREALLOC (1)')
|
g.comptime_definitions.writeln('#define _VPREALLOC (1)')
|
||||||
}
|
}
|
||||||
|
if g.pref.use_cache {
|
||||||
|
g.comptime_definitions.writeln('#define _VUSECACHE (1)')
|
||||||
|
}
|
||||||
|
if g.pref.build_mode == .build_module {
|
||||||
|
g.comptime_definitions.writeln('#define _VBUILDMODULE (1)')
|
||||||
|
}
|
||||||
if g.pref.is_livemain || g.pref.is_liveshared {
|
if g.pref.is_livemain || g.pref.is_liveshared {
|
||||||
g.generate_hotcode_reloading_declarations()
|
g.generate_hotcode_reloading_declarations()
|
||||||
}
|
}
|
||||||
|
@ -812,7 +818,7 @@ pub fn (mut g Gen) write_typeof_functions() {
|
||||||
}
|
}
|
||||||
g.writeln('}')
|
g.writeln('}')
|
||||||
g.writeln('')
|
g.writeln('')
|
||||||
g.writeln('int v_typeof_sumtype_idx_${sym.cname}(int sidx) { /* $sym.name */ ')
|
g.writeln('static int v_typeof_sumtype_idx_${sym.cname}(int sidx) { /* $sym.name */ ')
|
||||||
if g.pref.build_mode == .build_module {
|
if g.pref.build_mode == .build_module {
|
||||||
g.writeln('\t\tif( sidx == _v_type_idx_${sym.cname}() ) return ${int(ityp)};')
|
g.writeln('\t\tif( sidx == _v_type_idx_${sym.cname}() ) return ${int(ityp)};')
|
||||||
for v in sum_info.variants {
|
for v in sum_info.variants {
|
||||||
|
@ -4295,7 +4301,17 @@ fn (mut g Gen) const_decl_init_later(mod string, name string, expr ast.Expr, typ
|
||||||
}
|
}
|
||||||
|
|
||||||
fn (mut g Gen) global_decl(node ast.GlobalDecl) {
|
fn (mut g Gen) global_decl(node ast.GlobalDecl) {
|
||||||
mod := if g.pref.build_mode == .build_module && g.is_builtin_mod { 'static ' } else { '' }
|
// was static used here to to make code optimizable? it was removed when
|
||||||
|
// 'extern' was used to fix the duplicate symbols with usecache && clang
|
||||||
|
// visibility_kw := if g.pref.build_mode == .build_module && g.is_builtin_mod { 'static ' }
|
||||||
|
visibility_kw := if
|
||||||
|
(g.pref.use_cache || (g.pref.build_mode == .build_module && g.module_built != node.mod))
|
||||||
|
&& !util.should_bundle_module(node.mod) {
|
||||||
|
'extern '
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
''
|
||||||
|
}
|
||||||
mut attributes := ''
|
mut attributes := ''
|
||||||
if node.attrs.contains('weak') {
|
if node.attrs.contains('weak') {
|
||||||
attributes += 'VWEAK '
|
attributes += 'VWEAK '
|
||||||
|
@ -4310,20 +4326,20 @@ fn (mut g Gen) global_decl(node ast.GlobalDecl) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
styp := g.typ(field.typ)
|
styp := g.typ(field.typ)
|
||||||
|
should_init := (!g.pref.use_cache && g.pref.build_mode != .build_module)
|
||||||
|
|| (g.pref.build_mode == .build_module && g.module_built == node.mod)
|
||||||
|
g.definitions.write_string('$visibility_kw$styp $attributes $field.name')
|
||||||
if field.has_expr {
|
if field.has_expr {
|
||||||
g.definitions.write_string('$mod$styp $attributes $field.name')
|
if field.expr.is_literal() && should_init {
|
||||||
if field.expr.is_literal() {
|
g.definitions.write_string(' = ${g.expr_string(field.expr)}; // global')
|
||||||
g.definitions.writeln(' = ${g.expr_string(field.expr)}; // global')
|
|
||||||
} else {
|
} else {
|
||||||
g.definitions.writeln(';')
|
|
||||||
g.global_init.writeln('\t$field.name = ${g.expr_string(field.expr)}; // global')
|
g.global_init.writeln('\t$field.name = ${g.expr_string(field.expr)}; // global')
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
default_initializer := g.type_default(field.typ)
|
default_initializer := g.type_default(field.typ)
|
||||||
if default_initializer == '{0}' {
|
if default_initializer == '{0}' && should_init {
|
||||||
g.definitions.writeln('$mod$styp $attributes $field.name = {0}; // global')
|
g.definitions.writeln(' = {0}; // global')
|
||||||
} else {
|
} else {
|
||||||
g.definitions.writeln('$mod$styp $attributes $field.name; // global')
|
|
||||||
if field.name !in ['as_cast_type_indexes', 'g_memory_block', 'global_allocator'] {
|
if field.name !in ['as_cast_type_indexes', 'g_memory_block', 'global_allocator'] {
|
||||||
g.global_init.writeln('\t$field.name = *($styp*)&(($styp[]){${g.type_default(field.typ)}}[0]); // global')
|
g.global_init.writeln('\t$field.name = *($styp*)&(($styp[]){${g.type_default(field.typ)}}[0]); // global')
|
||||||
}
|
}
|
||||||
|
|
|
@ -362,7 +362,11 @@ const c_common_macros = '
|
||||||
#else
|
#else
|
||||||
#define VV_EXPORTED_SYMBOL extern __attribute__((visibility("default")))
|
#define VV_EXPORTED_SYMBOL extern __attribute__((visibility("default")))
|
||||||
#endif
|
#endif
|
||||||
|
#if defined(__clang__) && (defined(_VUSECACHE) || defined(_VBUILDMODULE))
|
||||||
|
#define VV_LOCAL_SYMBOL static
|
||||||
|
#else
|
||||||
#define VV_LOCAL_SYMBOL __attribute__ ((visibility ("hidden")))
|
#define VV_LOCAL_SYMBOL __attribute__ ((visibility ("hidden")))
|
||||||
|
#endif
|
||||||
#else
|
#else
|
||||||
#define VV_EXPORTED_SYMBOL extern
|
#define VV_EXPORTED_SYMBOL extern
|
||||||
#define VV_LOCAL_SYMBOL static
|
#define VV_LOCAL_SYMBOL static
|
||||||
|
@ -478,33 +482,6 @@ typedef int (*qsort_callback_func)(const void*, const void*);
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
#if defined(_WIN32) || defined(__CYGWIN__)
|
|
||||||
#define VV_EXPORTED_SYMBOL extern __declspec(dllexport)
|
|
||||||
#define VV_LOCAL_SYMBOL static
|
|
||||||
#else
|
|
||||||
// 4 < gcc < 5 is used by some older Ubuntu LTS and Centos versions,
|
|
||||||
// and does not support __has_attribute(visibility) ...
|
|
||||||
#ifndef __has_attribute
|
|
||||||
#define __has_attribute(x) 0 // Compatibility with non-clang compilers.
|
|
||||||
#endif
|
|
||||||
#if (defined(__GNUC__) && (__GNUC__ >= 4)) || (defined(__clang__) && __has_attribute(visibility))
|
|
||||||
#ifdef ARM
|
|
||||||
#define VV_EXPORTED_SYMBOL extern __attribute__((externally_visible,visibility("default")))
|
|
||||||
#else
|
|
||||||
#define VV_EXPORTED_SYMBOL extern __attribute__((visibility("default")))
|
|
||||||
#endif
|
|
||||||
#define VV_LOCAL_SYMBOL __attribute__ ((visibility ("hidden")))
|
|
||||||
#else
|
|
||||||
#define VV_EXPORTED_SYMBOL extern
|
|
||||||
#define VV_LOCAL_SYMBOL static
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(__TINYC__) && defined(__has_include)
|
|
||||||
// tcc does not support has_include properly yet, turn it off completely
|
|
||||||
#undef __has_include
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef _WIN32
|
#ifndef _WIN32
|
||||||
#if defined __has_include
|
#if defined __has_include
|
||||||
#if __has_include (<execinfo.h>)
|
#if __has_include (<execinfo.h>)
|
||||||
|
|
|
@ -61,7 +61,10 @@ fn (mut g Gen) fn_decl(node ast.FnDecl) {
|
||||||
// TODO true for not just "builtin"
|
// TODO true for not just "builtin"
|
||||||
// TODO: clean this up
|
// TODO: clean this up
|
||||||
mod := if g.is_builtin_mod { 'builtin' } else { node.name.all_before_last('.') }
|
mod := if g.is_builtin_mod { 'builtin' } else { node.name.all_before_last('.') }
|
||||||
if (mod != g.module_built && node.mod != g.module_built.after('/')) || should_bundle_module {
|
// for now dont skip generic functions as they are being marked as static
|
||||||
|
// when -usecache is enabled, until a better solution is implemented.
|
||||||
|
if ((mod != g.module_built && node.mod != g.module_built.after('/'))
|
||||||
|
|| should_bundle_module) && node.generic_names.len == 0 {
|
||||||
// Skip functions that don't have to be generated for this module.
|
// Skip functions that don't have to be generated for this module.
|
||||||
// println('skip bm $node.name mod=$node.mod module_built=$g.module_built')
|
// println('skip bm $node.name mod=$node.mod module_built=$g.module_built')
|
||||||
skip = true
|
skip = true
|
||||||
|
@ -269,7 +272,16 @@ fn (mut g Gen) gen_fn_decl(node &ast.FnDecl, skip bool) {
|
||||||
g.definitions.write_string('VV_LOCAL_SYMBOL ')
|
g.definitions.write_string('VV_LOCAL_SYMBOL ')
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
fn_header := '$type_name $fn_attrs${name}('
|
// as a temp solution generic functions are marked static
|
||||||
|
// when -usecache is enabled to fix duplicate symbols with clang
|
||||||
|
// TODO: implement a better sulution
|
||||||
|
visibility_kw := if g.cur_concrete_types.len > 0
|
||||||
|
&& (g.pref.build_mode == .build_module || g.pref.use_cache) {
|
||||||
|
'static '
|
||||||
|
} else {
|
||||||
|
''
|
||||||
|
}
|
||||||
|
fn_header := '$visibility_kw$type_name $fn_attrs${name}('
|
||||||
g.definitions.write_string(fn_header)
|
g.definitions.write_string(fn_header)
|
||||||
g.write(fn_header)
|
g.write(fn_header)
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue