SUMMARY = "Middleware layer between GObject-using C libraries and language bindings"
|
DESCRIPTION = "GObject Introspection is a project for providing machine \
|
readable introspection data of the API of C libraries. This introspection \
|
data can be used in several different use cases, for example automatic code \
|
generation for bindings, API verification and documentation generation."
|
HOMEPAGE = "https://wiki.gnome.org/action/show/Projects/GObjectIntrospection"
|
BUGTRACKER = "https://gitlab.gnome.org/GNOME/gobject-introspection/issues"
|
SECTION = "libs"
|
LICENSE = "LGPLv2+ & GPLv2+ & MIT"
|
LIC_FILES_CHKSUM = "file://COPYING;md5=c434e8128a68bedd59b80b2ac1eb1c4a \
|
file://tools/compiler.c;endline=20;md5=fc5007fc20022720e6c0b0cdde41fabd \
|
file://giscanner/sourcescanner.c;endline=22;md5=194d6e0c1d00662f32d030ce44de8d39 \
|
file://girepository/giregisteredtypeinfo.c;endline=21;md5=661847611ae6979465415f31a759ba27 \
|
"
|
|
SRC_URI = "${GNOME_MIRROR}/${BPN}/${@oe.utils.trim_version("${PV}", 2)}/${BPN}-${PV}.tar.xz \
|
file://0001-giscanner-ignore-error-return-codes-from-ldd-wrapper.patch \
|
"
|
|
SRC_URI[sha256sum] = "d229242481a201b84a0c66716de1752bca41db4133672cfcfb37c93eb6e54a27"
|
|
SRC_URI:append:class-native = " file://0001-Relocate-the-repository-directory-for-native-builds.patch"
|
|
inherit meson pkgconfig gtk-doc python3native qemu gobject-introspection-data upstream-version-is-even multilib_script
|
|
GTKDOC_MESON_OPTION = "gtk_doc"
|
|
MULTILIB_SCRIPTS = "${PN}:${bindir}/g-ir-annotation-tool ${PN}:${bindir}/g-ir-scanner"
|
|
DEPENDS += " libffi zlib glib-2.0 python3 flex-native bison-native autoconf-archive"
|
|
# target build needs qemu to run temporary introspection binaries created
|
# on the fly by g-ir-scanner and a native version of itself to run
|
# native versions of its own tools during build.
|
# Also prelink-rtld is used to find out library dependencies of introspection binaries
|
# (standard ldd doesn't work when cross-compiling).
|
DEPENDS:append:class-target = " gobject-introspection-native qemu-native prelink-native"
|
|
# needed for writing out the qemu wrapper script
|
export STAGING_DIR_HOST
|
export B
|
|
PACKAGECONFIG ?= ""
|
PACKAGECONFIG[doctool] = "-Ddoctool=enabled,-Ddoctool=disabled,python3-mako,"
|
|
# Configure target build to use native tools of itself and to use a qemu wrapper
|
# and optionally to generate introspection data
|
EXTRA_OEMESON:class-target = " \
|
-Dgi_cross_use_prebuilt_gi=true \
|
-Dgi_cross_binary_wrapper=${B}/g-ir-scanner-qemuwrapper \
|
-Dgi_cross_ldd_wrapper=${B}/g-ir-scanner-lddwrapper \
|
-Dgi_cross_pkgconfig_sysroot_path=${PKG_CONFIG_SYSROOT_DIR} \
|
${@bb.utils.contains('GI_DATA_ENABLED', 'True', '-Dbuild_introspection_data=true', '-Dbuild_introspection_data=false', d)} \
|
${@'-Dgir_dir_prefix=${libdir}' if d.getVar('MULTILIBS') else ''} \
|
"
|
|
# Need to ensure ld.so.conf exists so prelink-native works
|
# both before we build and if we install from sstate
|
do_configure[prefuncs] += "gobject_introspection_preconfigure"
|
python gobject_introspection_preconfigure () {
|
oe.utils.write_ld_so_conf(d)
|
}
|
|
do_configure:prepend:class-native() {
|
# Tweak the native python scripts so that they don't refer to the
|
# full path of native python binary (the solution is taken from glib-2.0 recipe)
|
# This removes the risk of exceeding Linux kernel's shebang line limit (128 bytes)
|
sed -i -e '1s,#!.*,#!${USRBINPATH}/env python3,' ${S}/tools/g-ir-tool-template.in
|
}
|
|
do_configure:prepend:class-target() {
|
# Write out a qemu wrapper that will be given to gi-scanner so that it
|
# can run target helper binaries through that.
|
qemu_binary="${@qemu_wrapper_cmdline(d, '$STAGING_DIR_HOST', ['\\$GIR_EXTRA_LIBS_PATH','.libs','$STAGING_DIR_HOST/${libdir}','$STAGING_DIR_HOST/${base_libdir}'])}"
|
cat > ${B}/g-ir-scanner-qemuwrapper << EOF
|
#!/bin/sh
|
# Use a modules directory which doesn't exist so we don't load random things
|
# which may then get deleted (or their dependencies) and potentially segfault
|
export GIO_MODULE_DIR=${STAGING_LIBDIR}/gio/modules-dummy
|
|
$qemu_binary "\$@"
|
if [ \$? -ne 0 ]; then
|
echo "If the above error message is about missing .so libraries, then setting up GIR_EXTRA_LIBS_PATH in the recipe should help."
|
echo "(typically like this: GIR_EXTRA_LIBS_PATH=\"$""{B}/something/.libs\" )"
|
exit 1
|
fi
|
EOF
|
chmod +x ${B}/g-ir-scanner-qemuwrapper
|
|
# Write out a wrapper for g-ir-scanner itself, which will be used when building introspection files
|
# for glib-based packages. This wrapper calls the native version of the scanner, and tells it to use
|
# a qemu wrapper for running transient target binaries produced by the scanner, and an include directory
|
# from the target sysroot.
|
cat > ${B}/g-ir-scanner-wrapper << EOF
|
#!/bin/sh
|
# This prevents g-ir-scanner from writing cache data to user's HOME dir
|
export GI_SCANNER_DISABLE_CACHE=1
|
|
g-ir-scanner --lib-dirs-envvar=GIR_EXTRA_LIBS_PATH --use-binary-wrapper=${STAGING_BINDIR}/g-ir-scanner-qemuwrapper --use-ldd-wrapper=${STAGING_BINDIR}/g-ir-scanner-lddwrapper --add-include-path=${STAGING_DATADIR}/gir-1.0 --add-include-path=${STAGING_LIBDIR}/gir-1.0 "\$@"
|
EOF
|
chmod +x ${B}/g-ir-scanner-wrapper
|
|
# Write out a wrapper for g-ir-compiler, which runs the target version of it through qemu.
|
# g-ir-compiler writes out the raw content of a C struct to disk, and therefore is architecture dependent.
|
cat > ${B}/g-ir-compiler-wrapper << EOF
|
#!/bin/sh
|
${STAGING_BINDIR}/g-ir-scanner-qemuwrapper ${STAGING_BINDIR}/g-ir-compiler "\$@"
|
EOF
|
chmod +x ${B}/g-ir-compiler-wrapper
|
|
# Write out a wrapper to use instead of ldd, which does not work when a binary is built
|
# for a different architecture
|
cat > ${B}/g-ir-scanner-lddwrapper << EOF
|
#!/bin/sh
|
prelink-rtld --root=$STAGING_DIR_HOST "\$@"
|
EOF
|
chmod +x ${B}/g-ir-scanner-lddwrapper
|
|
# Also tweak the target python scripts so that they don't refer to the
|
# native version of python binary (the solution is taken from glib-2.0 recipe)
|
sed -i -e '1s,#!.*,#!${USRBINPATH}/env python3,' ${S}/tools/g-ir-tool-template.in
|
}
|
|
do_compile:prepend() {
|
# This prevents g-ir-scanner from writing cache data to $HOME
|
export GI_SCANNER_DISABLE_CACHE=1
|
|
# Needed to run g-ir unit tests, which won't be able to find the built libraries otherwise
|
export GIR_EXTRA_LIBS_PATH=$B/.libs
|
}
|
|
do_install:prepend() {
|
# This prevents g-ir-scanner from writing cache data to $HOME
|
export GI_SCANNER_DISABLE_CACHE=1
|
}
|
|
# Our wrappers need to be available system-wide, because they will be used
|
# to build introspection files for all other gobject-based packages
|
do_install:append:class-target() {
|
install -d ${D}${bindir}/
|
install ${B}/g-ir-scanner-qemuwrapper ${D}${bindir}/
|
install ${B}/g-ir-scanner-wrapper ${D}${bindir}/
|
install ${B}/g-ir-compiler-wrapper ${D}${bindir}/
|
install ${B}/g-ir-scanner-lddwrapper ${D}${bindir}/
|
}
|
|
# we need target versions of introspection tools in sysroot so that they can be run via qemu
|
# when building introspection files in other packages
|
SYSROOT_DIRS:append:class-target = " ${bindir}"
|
|
SYSROOT_PREPROCESS_FUNCS:append:class-target = " gi_binaries_sysroot_preprocess"
|
gi_binaries_sysroot_preprocess() {
|
# Tweak the binary names in the introspection pkgconfig file, so that it
|
# picks up our wrappers which do the cross-compile and qemu magic.
|
sed -i \
|
-e "s|g_ir_scanner=.*|g_ir_scanner=${bindir}/g-ir-scanner-wrapper|" \
|
-e "s|g_ir_compiler=.*|g_ir_compiler=${bindir}/g-ir-compiler-wrapper|" \
|
${SYSROOT_DESTDIR}${libdir}/pkgconfig/gobject-introspection-1.0.pc
|
}
|
|
SYSROOT_PREPROCESS_FUNCS:append = " gi_ldsoconf_sysroot_preprocess"
|
gi_ldsoconf_sysroot_preprocess () {
|
mkdir -p ${SYSROOT_DESTDIR}${bindir}
|
dest=${SYSROOT_DESTDIR}${bindir}/postinst-ldsoconf-${PN}
|
echo "#!/bin/sh" > $dest
|
echo "mkdir -p ${STAGING_DIR_TARGET}${sysconfdir}" >> $dest
|
echo "echo ${base_libdir} >> ${STAGING_DIR_TARGET}${sysconfdir}/ld.so.conf" >> $dest
|
echo "echo ${libdir} >> ${STAGING_DIR_TARGET}${sysconfdir}/ld.so.conf" >> $dest
|
chmod 755 $dest
|
}
|
|
# Remove wrapper files from the package, only used for cross-compiling
|
PACKAGE_PREPROCESS_FUNCS += "gi_package_preprocess"
|
gi_package_preprocess() {
|
rm -f ${PKGD}${bindir}/g-ir-scanner-qemuwrapper
|
rm -f ${PKGD}${bindir}/g-ir-scanner-wrapper
|
rm -f ${PKGD}${bindir}/g-ir-compiler-wrapper
|
rm -f ${PKGD}${bindir}/g-ir-scanner-lddwrapper
|
}
|
|
SSTATE_SCAN_FILES += "g-ir-scanner-qemuwrapper g-ir-scanner-wrapper g-ir-compiler-wrapper g-ir-scanner-lddwrapper Gio-2.0.gir postinst-ldsoconf-${PN}"
|
|
# .typelib files are needed at runtime and so they go to the main package
|
FILES:${PN}:append = " ${libdir}/girepository-*/*.typelib"
|
|
# .gir files go to dev package, as they're needed for developing (but not for running)
|
# things that depends on introspection.
|
FILES:${PN}-dev:append = " ${datadir}/gir-*/*.gir ${libdir}/gir-*/*.gir"
|
FILES:${PN}-dev:append = " ${datadir}/gir-*/*.rnc"
|
|
# These are used by gobject-based packages
|
# to generate transient introspection binaries
|
FILES:${PN}-dev:append = " ${datadir}/gobject-introspection-1.0/gdump.c \
|
${datadir}/gobject-introspection-1.0/Makefile.introspection"
|
|
# These are used by dependent packages (e.g. pygobject) to build their
|
# testsuites.
|
FILES:${PN}-dev:append = " ${datadir}/gobject-introspection-1.0/tests/*.c \
|
${datadir}/gobject-introspection-1.0/tests/*.h"
|
|
FILES:${PN}-dbg += "${libdir}/gobject-introspection/giscanner/.debug/"
|
FILES:${PN}-staticdev += "${libdir}/gobject-introspection/giscanner/*.a"
|
|
RDEPENDS:${PN} = "python3-pickle python3-xml"
|
|
BBCLASSEXTEND = "native"
|