Improve avoiding C++ linkage, definition creation and cmake tests (#710)
This commit is contained in:
parent
9b693212a8
commit
00806149b9
|
@ -25,7 +25,7 @@ jobs:
|
||||||
- image: base/devel
|
- image: base/devel
|
||||||
steps:
|
steps:
|
||||||
- checkout
|
- checkout
|
||||||
- run: pacman --noconfirm -Syu freetype2 cairo icu gettext gobject-introspection gcc gcc-libs glib2 graphite pkg-config ragel
|
- run: pacman --noconfirm -Syu freetype2 cairo icu gettext gobject-introspection gcc gcc-libs glib2 graphite pkg-config ragel python
|
||||||
- run: ./autogen.sh --with-freetype --with-glib --with-gobject --with-cairo --with-icu --with-graphite2
|
- run: ./autogen.sh --with-freetype --with-glib --with-gobject --with-cairo --with-icu --with-graphite2
|
||||||
- run: make && (make check || (cat `find -name '*.log'` && false))
|
- run: make && (make check || (cat `find -name '*.log'` && false))
|
||||||
|
|
||||||
|
@ -34,7 +34,7 @@ jobs:
|
||||||
- image: fedora
|
- image: fedora
|
||||||
steps:
|
steps:
|
||||||
- checkout
|
- checkout
|
||||||
- run: dnf install -y pkg-config ragel gcc gcc-c++ automake autoconf libtool make which glib2-devel freetype-devel cairo-devel libicu-devel gobject-introspection-devel graphite2-devel redhat-rpm-config || true
|
- run: dnf install -y pkg-config ragel gcc gcc-c++ automake autoconf libtool make which glib2-devel freetype-devel cairo-devel libicu-devel gobject-introspection-devel graphite2-devel redhat-rpm-config python || true
|
||||||
- run: NOCONFIGURE=1 ./autogen.sh --with-freetype --with-glib --with-gobject --with-cairo --with-icu --with-graphite2
|
- run: NOCONFIGURE=1 ./autogen.sh --with-freetype --with-glib --with-gobject --with-cairo --with-icu --with-graphite2
|
||||||
- run: mkdir build && cd build && ../configure && make && (make check || (cat `find -name '*.log'` && false))
|
- run: mkdir build && cd build && ../configure && make && (make check || (cat `find -name '*.log'` && false))
|
||||||
|
|
||||||
|
|
|
@ -127,7 +127,7 @@ if (BUILD_SHARED_LIBS)
|
||||||
add_definitions("-DHB_EXTERN=__declspec(dllexport) extern")
|
add_definitions("-DHB_EXTERN=__declspec(dllexport) extern")
|
||||||
else ()
|
else ()
|
||||||
set (CMAKE_CXX_FLAGS "-fvisibility=hidden ${CMAKE_CXX_FLAGS}")
|
set (CMAKE_CXX_FLAGS "-fvisibility=hidden ${CMAKE_CXX_FLAGS}")
|
||||||
set (CMAKE_C_FLAGS "-fvisibility=hidden ${CMAKE_CXX_FLAGS}")
|
set (CMAKE_C_FLAGS "-fvisibility=hidden ${CMAKE_C_FLAGS}")
|
||||||
add_definitions("-DHB_EXTERN=__attribute__((visibility(\"default\"))) extern")
|
add_definitions("-DHB_EXTERN=__attribute__((visibility(\"default\"))) extern")
|
||||||
endif ()
|
endif ()
|
||||||
endif ()
|
endif ()
|
||||||
|
@ -524,11 +524,19 @@ if (UNIX OR MINGW)
|
||||||
link_libraries(-Bsymbolic-functions)
|
link_libraries(-Bsymbolic-functions)
|
||||||
|
|
||||||
# Make sure we don't link to libstdc++
|
# Make sure we don't link to libstdc++
|
||||||
|
if (BUILD_SHARED_LIBS AND (
|
||||||
|
CMAKE_CXX_COMPILER_ID STREQUAL "Clang" OR
|
||||||
|
CMAKE_CXX_COMPILER_ID STREQUAL "GNU"
|
||||||
|
))
|
||||||
set (CMAKE_CXX_FLAGS "-fno-rtti -fno-exceptions ${CMAKE_CXX_FLAGS}")
|
set (CMAKE_CXX_FLAGS "-fno-rtti -fno-exceptions ${CMAKE_CXX_FLAGS}")
|
||||||
if (NOT APPLE)
|
endif ()
|
||||||
set (CMAKE_CXX_IMPLICIT_LINK_LIBRARIES "")
|
set (CMAKE_CXX_IMPLICIT_LINK_LIBRARIES "")
|
||||||
set (CMAKE_CXX_IMPLICIT_LINK_DIRECTORIES "")
|
set (CMAKE_CXX_IMPLICIT_LINK_DIRECTORIES "")
|
||||||
set_target_properties(harfbuzz PROPERTIES LINKER_LANGUAGE C)
|
set_target_properties(harfbuzz PROPERTIES LINKER_LANGUAGE C)
|
||||||
|
|
||||||
|
# No threadsafe statics as we do it ourselves
|
||||||
|
if (BUILD_SHARED_LIBS)
|
||||||
|
set (CMAKE_CXX_FLAGS "-fno-threadsafe-statics ${CMAKE_CXX_FLAGS}")
|
||||||
endif ()
|
endif ()
|
||||||
endif ()
|
endif ()
|
||||||
|
|
||||||
|
@ -782,22 +790,20 @@ endif ()
|
||||||
## Tests
|
## Tests
|
||||||
if (UNIX OR MINGW)
|
if (UNIX OR MINGW)
|
||||||
if (BUILD_SHARED_LIBS)
|
if (BUILD_SHARED_LIBS)
|
||||||
# does some "make" stuff inside
|
string(REPLACE ";" " " space_separated_headers "${project_headers}")
|
||||||
#add_test(NAME check-defs.sh COMMAND ${PROJECT_SOURCE_DIR}/src/check-defs.sh)
|
add_custom_command(TARGET harfbuzz POST_BUILD
|
||||||
#set_tests_properties(check-defs.sh PROPERTIES ENVIRONMENT "libs=.")
|
COMMAND ${CMAKE_COMMAND} -E env "headers=${space_separated_headers}" python ${PROJECT_SOURCE_DIR}/src/gen-def.py ${PROJECT_BINARY_DIR}/harfbuzz.def
|
||||||
|
WORKING_DIRECTORY ${PROJECT_SOURCE_DIR}/src)
|
||||||
|
|
||||||
add_test(NAME check-symbols.sh COMMAND ${PROJECT_SOURCE_DIR}/src/check-symbols.sh)
|
add_test(NAME check-symbols.sh COMMAND ${PROJECT_SOURCE_DIR}/src/check-symbols.sh)
|
||||||
set_tests_properties(check-symbols.sh PROPERTIES ENVIRONMENT "libs=.")
|
|
||||||
|
|
||||||
if (NOT APPLE)
|
|
||||||
add_test(NAME check-libstdc++.sh COMMAND ${PROJECT_SOURCE_DIR}/src/check-libstdc++.sh)
|
|
||||||
add_test(NAME check-static-inits.sh
|
add_test(NAME check-static-inits.sh
|
||||||
COMMAND ${PROJECT_SOURCE_DIR}/src/check-static-inits.sh
|
COMMAND ${PROJECT_SOURCE_DIR}/src/check-static-inits.sh
|
||||||
WORKING_DIRECTORY ${PROJECT_BINARY_DIR}/CMakeFiles/harfbuzz.dir/src # ugly hack
|
WORKING_DIRECTORY ${PROJECT_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/harfbuzz.dir/src # ugly hack
|
||||||
)
|
)
|
||||||
set_tests_properties(check-libstdc++.sh check-static-inits.sh
|
add_test(NAME check-libstdc++.sh COMMAND ${PROJECT_SOURCE_DIR}/src/check-libstdc++.sh)
|
||||||
PROPERTIES ENVIRONMENT "libs=.")
|
add_test(NAME check-defs.sh COMMAND ${PROJECT_SOURCE_DIR}/src/check-defs.sh)
|
||||||
endif ()
|
set_tests_properties(check-symbols.sh check-static-inits.sh check-libstdc++.sh check-defs.sh
|
||||||
|
PROPERTIES ENVIRONMENT "libs=.;srcdir=${PROJECT_SOURCE_DIR}/src")
|
||||||
endif ()
|
endif ()
|
||||||
|
|
||||||
add_test(NAME check-c-linkage-decls.sh COMMAND ./check-c-linkage-decls.sh)
|
add_test(NAME check-c-linkage-decls.sh COMMAND ./check-c-linkage-decls.sh)
|
||||||
|
|
|
@ -83,6 +83,9 @@ if test "x$GCC" = "xyes"; then
|
||||||
# Make sure we don't link to libstdc++
|
# Make sure we don't link to libstdc++
|
||||||
CXXFLAGS="$CXXFLAGS -fno-rtti -fno-exceptions"
|
CXXFLAGS="$CXXFLAGS -fno-rtti -fno-exceptions"
|
||||||
|
|
||||||
|
# No threadsafe statics and C++ as we do it ourselves
|
||||||
|
CXXFLAGS="$CXXFLAGS -fno-threadsafe-statics"
|
||||||
|
|
||||||
# Assorted warnings
|
# Assorted warnings
|
||||||
CXXFLAGS="$CXXFLAGS -Wcast-align"
|
CXXFLAGS="$CXXFLAGS -Wcast-align"
|
||||||
|
|
||||||
|
|
|
@ -223,21 +223,14 @@ CLEANFILES += $(pkgconfig_DATA)
|
||||||
|
|
||||||
CLEANFILES += harfbuzz.def
|
CLEANFILES += harfbuzz.def
|
||||||
harfbuzz.def: $(HBHEADERS) $(HBNODISTHEADERS)
|
harfbuzz.def: $(HBHEADERS) $(HBNODISTHEADERS)
|
||||||
$(AM_V_GEN) (echo EXPORTS; \
|
$(AM_V_GEN) headers="$^" $(srcdir)/gen-def.py $@
|
||||||
(cat $^ || echo 'hb_ERROR ()' ) | \
|
|
||||||
$(EGREP) '^hb_.* \(' | \
|
|
||||||
sed -e 's/ (.*//' | \
|
|
||||||
LC_ALL=C sort; \
|
|
||||||
echo LIBRARY libharfbuzz-0.dll; \
|
|
||||||
) >"$@"
|
|
||||||
@ ! grep -q hb_ERROR "$@" \
|
|
||||||
|| ($(RM) "$@"; false)
|
|
||||||
|
|
||||||
|
|
||||||
GENERATORS = \
|
GENERATORS = \
|
||||||
gen-arabic-table.py \
|
gen-arabic-table.py \
|
||||||
gen-indic-table.py \
|
gen-indic-table.py \
|
||||||
gen-use-table.py \
|
gen-use-table.py \
|
||||||
|
gen-def.py \
|
||||||
$(NULL)
|
$(NULL)
|
||||||
EXTRA_DIST += $(GENERATORS)
|
EXTRA_DIST += $(GENERATORS)
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,6 @@ export LC_ALL
|
||||||
|
|
||||||
test -z "$srcdir" && srcdir=.
|
test -z "$srcdir" && srcdir=.
|
||||||
test -z "$libs" && libs=.libs
|
test -z "$libs" && libs=.libs
|
||||||
test -z "$MAKE" && MAKE=make
|
|
||||||
stat=0
|
stat=0
|
||||||
|
|
||||||
if which nm 2>/dev/null >/dev/null; then
|
if which nm 2>/dev/null >/dev/null; then
|
||||||
|
@ -16,26 +15,36 @@ else
|
||||||
fi
|
fi
|
||||||
|
|
||||||
defs="harfbuzz.def"
|
defs="harfbuzz.def"
|
||||||
$MAKE $defs > /dev/null
|
if ! test -f "$defs"; then
|
||||||
|
echo "check-defs.sh: '$defs' not found; skipping test"
|
||||||
|
exit 77
|
||||||
|
fi
|
||||||
|
|
||||||
tested=false
|
tested=false
|
||||||
for def in $defs; do
|
for def in $defs; do
|
||||||
lib=`echo "$def" | sed 's/[.]def$//;s@.*/@@'`
|
lib=`echo "$def" | sed 's/[.]def$//;s@.*/@@'`
|
||||||
so=$libs/lib${lib}.so
|
for suffix in so dylib; do
|
||||||
|
so=$libs/lib${lib}.$suffix
|
||||||
|
if ! test -f "$so"; then continue; fi
|
||||||
|
|
||||||
EXPORTED_SYMBOLS="`nm "$so" | grep ' [BCDGINRSTVW] .' | grep -v ' _fini\>\| _init\>\| _fdata\>\| _ftext\>\| _fbss\>\| __bss_start\>\| __bss_start__\>\| __bss_end__\>\| _edata\>\| _end\>\| _bss_end__\>\| __end__\>\| __gcov_flush\>\| llvm_' | cut -d' ' -f3`"
|
EXPORTED_SYMBOLS="`nm "$so" | grep ' [BCDGINRSTVW] .' | grep -v ' _fini\>\| _init\>\| _fdata\>\| _ftext\>\| _fbss\>\| __bss_start\>\| __bss_start__\>\| __bss_end__\>\| _edata\>\| _end\>\| _bss_end__\>\| __end__\>\| __gcov_flush\>\| llvm_' | cut -d' ' -f3`"
|
||||||
|
|
||||||
|
# On mac, C symbols are prefixed with _
|
||||||
|
if test $suffix = dylib; then prefix="_"; fi
|
||||||
|
|
||||||
if test -f "$so"; then
|
if test -f "$so"; then
|
||||||
|
|
||||||
echo "Checking that $so has the same symbol list as $def"
|
echo "Checking that $so has the same symbol list as $def"
|
||||||
{
|
{
|
||||||
echo EXPORTS
|
echo EXPORTS
|
||||||
echo "$EXPORTED_SYMBOLS"
|
echo "$EXPORTED_SYMBOLS" | sed -e "s/^${prefix}hb/hb/g"
|
||||||
# cheat: copy the last line from the def file!
|
# cheat: copy the last line from the def file!
|
||||||
tail -n1 "$def"
|
tail -n1 "$def"
|
||||||
} | diff "$def" - >&2 || stat=1
|
} | diff "$def" - >&2 || stat=1
|
||||||
|
|
||||||
tested=true
|
tested=true
|
||||||
fi
|
fi
|
||||||
|
done
|
||||||
done
|
done
|
||||||
if ! $tested; then
|
if ! $tested; then
|
||||||
echo "check-defs.sh: libharfbuzz shared library not found; skipping test"
|
echo "check-defs.sh: libharfbuzz shared library not found; skipping test"
|
||||||
|
|
|
@ -0,0 +1,16 @@
|
||||||
|
#!/usr/bin/env python
|
||||||
|
|
||||||
|
from __future__ import print_function
|
||||||
|
|
||||||
|
import io, os, re, sys
|
||||||
|
|
||||||
|
headers_content = []
|
||||||
|
for h in os.environ["headers"].split (' '):
|
||||||
|
if h.endswith (".h"):
|
||||||
|
with io.open(h, encoding='utf8') as f: headers_content.append (f.read ())
|
||||||
|
|
||||||
|
result = ("EXPORTS\n" +
|
||||||
|
"\n".join (sorted (re.findall (r"^hb_\w+(?= \()", "\n".join (headers_content), re.M))) +
|
||||||
|
"\nLIBRARY libharfbuzz-0.dll")
|
||||||
|
|
||||||
|
with open (sys.argv[1], "w") as f: f.write (result)
|
Loading…
Reference in New Issue