[meson] Reenable make check-symbols compatible with gcov
This commit is contained in:
parent
68855e4a6d
commit
15083c24ee
|
@ -8,7 +8,7 @@ test -z "$builddir" && builddir=.
|
||||||
test -z "$libs" && libs=.libs
|
test -z "$libs" && libs=.libs
|
||||||
stat=0
|
stat=0
|
||||||
|
|
||||||
IGNORED_SYMBOLS='_fini\|_init\|_fdata\|_ftext\|_fbss\|__bss_start\|__bss_start__\|__bss_end__\|_edata\|_end\|_bss_end__\|__end__\|__gcov_.*\|llvm_.*'
|
IGNORED_SYMBOLS='_fini\|_init\|_fdata\|_ftext\|_fbss\|__bss_start\|__bss_start__\|__bss_end__\|_edata\|_end\|_bss_end__\|__end__\|__gcov_.*\|llvm_.*\|flush_fn_list\|writeout_fn_list'
|
||||||
|
|
||||||
if which nm 2>/dev/null >/dev/null; then
|
if which nm 2>/dev/null >/dev/null; then
|
||||||
:
|
:
|
||||||
|
|
|
@ -346,6 +346,7 @@ harfbuzz_def = custom_target('harfbuzz.def',
|
||||||
command: harfbuzz_def_command_args,
|
command: harfbuzz_def_command_args,
|
||||||
input: hb_headers,
|
input: hb_headers,
|
||||||
output: 'harfbuzz.def')
|
output: 'harfbuzz.def')
|
||||||
|
defs_list = [harfbuzz_def]
|
||||||
|
|
||||||
version = '0.' + '0'.join(meson.project_version().split('.')) + '.0'
|
version = '0.' + '0'.join(meson.project_version().split('.')) + '.0'
|
||||||
|
|
||||||
|
@ -380,6 +381,7 @@ harfbuzz_subset_def = custom_target('harfbuzz-subset.def',
|
||||||
command: [gen_def, '@OUTPUT@', '@INPUT@'],
|
command: [gen_def, '@OUTPUT@', '@INPUT@'],
|
||||||
input: hb_subset_headers,
|
input: hb_subset_headers,
|
||||||
output: 'harfbuzz-subset.def')
|
output: 'harfbuzz-subset.def')
|
||||||
|
defs_list += [harfbuzz_subset_def]
|
||||||
|
|
||||||
libharfbuzz_subset = library('harfbuzz-subset', hb_subset_sources,
|
libharfbuzz_subset = library('harfbuzz-subset', hb_subset_sources,
|
||||||
include_directories: incconfig,
|
include_directories: incconfig,
|
||||||
|
@ -418,7 +420,7 @@ if get_option('tests').enabled()
|
||||||
)
|
)
|
||||||
endforeach
|
endforeach
|
||||||
endif
|
endif
|
||||||
|
|
||||||
check_programs = {
|
check_programs = {
|
||||||
'dump-indic-data': ['dump-indic-data.cc', 'hb-ot-shape-complex-indic-table.cc'],
|
'dump-indic-data': ['dump-indic-data.cc', 'hb-ot-shape-complex-indic-table.cc'],
|
||||||
'dump-khmer-data': ['dump-khmer-data.cc', 'hb-ot-shape-complex-indic-table.cc'],
|
'dump-khmer-data': ['dump-khmer-data.cc', 'hb-ot-shape-complex-indic-table.cc'],
|
||||||
|
@ -433,7 +435,7 @@ if get_option('tests').enabled()
|
||||||
install: false,
|
install: false,
|
||||||
)
|
)
|
||||||
endforeach
|
endforeach
|
||||||
|
|
||||||
compiled_tests = {
|
compiled_tests = {
|
||||||
'test-array': 'test-array.cc',
|
'test-array': 'test-array.cc',
|
||||||
'test-number': ['test-number.cc', 'hb-number.cc'],
|
'test-number': ['test-number.cc', 'hb-number.cc'],
|
||||||
|
@ -457,7 +459,7 @@ if get_option('tests').enabled()
|
||||||
install: false,
|
install: false,
|
||||||
))
|
))
|
||||||
endforeach
|
endforeach
|
||||||
|
|
||||||
if host_machine.system() != 'windows' and not meson.is_cross_build()
|
if host_machine.system() != 'windows' and not meson.is_cross_build()
|
||||||
# Some of them should be ported to python
|
# Some of them should be ported to python
|
||||||
dist_check_script = [
|
dist_check_script = [
|
||||||
|
@ -472,21 +474,17 @@ if get_option('tests').enabled()
|
||||||
if false # !WITH_LIBSTDCXX
|
if false # !WITH_LIBSTDCXX
|
||||||
dist_check_script += 'check-libstdc++.sh' # See https://github.com/harfbuzz/harfbuzz/issues/2276
|
dist_check_script += 'check-libstdc++.sh' # See https://github.com/harfbuzz/harfbuzz/issues/2276
|
||||||
endif
|
endif
|
||||||
|
|
||||||
env = environment()
|
env = environment()
|
||||||
env.set('srcdir', meson.current_source_dir())
|
env.set('srcdir', meson.current_source_dir())
|
||||||
env.set('builddir', meson.current_build_dir())
|
env.set('builddir', meson.current_build_dir())
|
||||||
env.set('libs', meson.current_build_dir()) # TODO: Merge this with builddir after autotools removal
|
env.set('libs', meson.current_build_dir()) # TODO: Merge this with builddir after autotools removal
|
||||||
env.set('HBSOURCES', ' '.join(hb_sources))
|
env.set('HBSOURCES', ' '.join(hb_sources))
|
||||||
env.set('HBHEADERS', ' '.join(hb_headers))
|
env.set('HBHEADERS', ' '.join(hb_headers))
|
||||||
|
|
||||||
foreach name : dist_check_script
|
foreach name : dist_check_script
|
||||||
test(name, find_program(name), env: env)
|
test(name, find_program(name), env: env)
|
||||||
endforeach
|
endforeach
|
||||||
|
|
||||||
#test('check-symbols.sh', find_program('check-symbols.sh'),
|
|
||||||
# depends: [harfbuzz_def, harfbuzz_subset_def], # TODO: harfbuzz_icu_def and harfbuzz_gobject_def also
|
|
||||||
# env: env)
|
|
||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
@ -503,6 +501,12 @@ pkgmod.generate(libharfbuzz_subset,
|
||||||
)
|
)
|
||||||
|
|
||||||
if have_icu and not have_icu_builtin
|
if have_icu and not have_icu_builtin
|
||||||
|
harfbuzz_icu_def = custom_target('harfbuzz-icu.def',
|
||||||
|
command: [gen_def, '@OUTPUT@', '@INPUT@'],
|
||||||
|
input: [hb_icu_headers],
|
||||||
|
output: 'harfbuzz-icu.def')
|
||||||
|
defs_list += [harfbuzz_icu_def]
|
||||||
|
|
||||||
libharfbuzz_icu = library('harfbuzz-icu', [hb_icu_sources, hb_icu_headers],
|
libharfbuzz_icu = library('harfbuzz-icu', [hb_icu_sources, hb_icu_headers],
|
||||||
include_directories: incconfig,
|
include_directories: incconfig,
|
||||||
dependencies: icu_dep,
|
dependencies: icu_dep,
|
||||||
|
@ -584,6 +588,7 @@ if have_gobject
|
||||||
command: [gen_def, '@OUTPUT@', '@INPUT@'],
|
command: [gen_def, '@OUTPUT@', '@INPUT@'],
|
||||||
input: [hb_gobject_headers, enum_h],
|
input: [hb_gobject_headers, enum_h],
|
||||||
output: 'harfbuzz-gobject.def')
|
output: 'harfbuzz-gobject.def')
|
||||||
|
defs_list += [harfbuzz_gobject_def]
|
||||||
|
|
||||||
libharfbuzz_gobject = library('harfbuzz-gobject', [hb_gobject_sources, enum_c, enum_h],
|
libharfbuzz_gobject = library('harfbuzz-gobject', [hb_gobject_sources, enum_c, enum_h],
|
||||||
include_directories: incconfig,
|
include_directories: incconfig,
|
||||||
|
@ -639,4 +644,10 @@ else
|
||||||
libharfbuzz_gobject_dep = dependency('', required: false)
|
libharfbuzz_gobject_dep = dependency('', required: false)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
if get_option('tests').enabled() and host_machine.system() != 'windows' and not meson.is_cross_build()
|
||||||
|
test('check-symbols.sh', find_program('check-symbols.sh'),
|
||||||
|
depends: defs_list,
|
||||||
|
env: env)
|
||||||
|
endif
|
||||||
|
|
||||||
install_headers(hb_headers + hb_subset_headers, subdir: meson.project_name())
|
install_headers(hb_headers + hb_subset_headers, subdir: meson.project_name())
|
||||||
|
|
Loading…
Reference in New Issue