1SUMMARY = "Documentation generator for glib-based software" 2DESCRIPTION = "Gtk-doc is a set of scripts that extract specially formatted comments \ 3 from glib-based software and produce a set of html documentation files from them" 4HOMEPAGE = "https://www.gtk.org/docs/" 5LICENSE = "GPL-2.0-only" 6LIC_FILES_CHKSUM = "file://COPYING;md5=94d55d512a9ba36caa9b7df079bae19f" 7 8inherit gnomebase 9 10# Configure the scripts correctly (and build their dependencies) only if they are actually 11# going to be used; otheriwse we need only the m4/makefile includes from the gtk-doc tarball. 12PACKAGECONFIG ??= "${@bb.utils.contains("DISTRO_FEATURES", "api-documentation", "working-scripts", "", d)}" 13 14# This will cause target gtk-doc to hardcode paths of native dependencies 15# into its scripts. This means that target gtk-doc package is broken; 16# hopefully no one minds because its scripts are not used for anything during build 17# and shouldn't be used on targets. 18PACKAGECONFIG[working-scripts] = ",,libxslt-native xmlto-native python3-six python3-pygments" 19PACKAGECONFIG[tests] = "--enable-tests,--disable-tests,glib-2.0" 20 21CACHED_CONFIGUREVARS += "ac_cv_path_XSLTPROC=xsltproc" 22 23SRC_URI[archive.sha256sum] = "cc1b709a20eb030a278a1f9842a362e00402b7f834ae1df4c1998a723152bf43" 24SRC_URI += "file://0001-Do-not-hardocode-paths-to-perl-python-in-scripts.patch \ 25 file://0001-Do-not-error-out-if-xsltproc-is-not-found.patch \ 26 file://conditionaltests.patch \ 27 file://no-clobber.patch \ 28 " 29SRC_URI:append:class-native = " file://pkg-config-native.patch" 30 31BBCLASSEXTEND = "native nativesdk" 32 33# Do not check for XML catalogs when building because that 34# information is not used for anything during build. Recipe 35# dependencies make sure we have all the right bits. 36do_configure:prepend() { 37 sed -i -e 's,^JH_CHECK_XML_CATALOG.*,,' ${S}/configure.ac 38} 39 40do_install:append () { 41 # configure values for python3 and pkg-config encoded in scripts 42 for fn in ${bindir}/gtkdoc-depscan \ 43 ${bindir}/gtkdoc-mkhtml2 \ 44 ${datadir}/gtk-doc/python/gtkdoc/config_data.py \ 45 ${datadir}/gtk-doc/python/gtkdoc/config.py; do 46 sed -e 's,${RECIPE_SYSROOT_NATIVE}/usr/bin/pkg-config,${bindir}/pkg-config,' \ 47 -e 's,${HOSTTOOLS_DIR}/python3,${bindir}/python3,' \ 48 -e '1s|^#!.*|#!/usr/bin/env python3|' \ 49 -i ${D}$fn 50 done 51} 52 53FILES:${PN} += "${datadir}/sgml" 54FILES:${PN}-doc = "" 55 56SYSROOT_PREPROCESS_FUNCS:append:class-native = " gtkdoc_makefiles_sysroot_preprocess" 57gtkdoc_makefiles_sysroot_preprocess() { 58 # Patch the gtk-doc makefiles so that the qemu wrapper is used to run transient binaries 59 # instead of libtool wrapper or running them directly 60 sed -i \ 61 -e "s|GTKDOC_RUN =.*|GTKDOC_RUN = \$(top_builddir)/gtkdoc-qemuwrapper|" \ 62 ${SYSROOT_DESTDIR}${datadir}/gtk-doc/data/gtk-doc*make 63} 64