115 lines
4.5 KiB
Bash
115 lines
4.5 KiB
Bash
|
#!/bin/sh -e
|
||
|
# Generate HTML documentation
|
||
|
#
|
||
|
# Copyright (C) 2014 Red Hat, Inc.
|
||
|
#
|
||
|
# This copyrighted material is made available to anyone wishing to use,
|
||
|
# modify, copy, or redistribute it subject to the terms and conditions of
|
||
|
# the GNU General Public License v.2, or (at your option) any later version.
|
||
|
# This program is distributed in the hope that it will be useful, but WITHOUT
|
||
|
# ANY WARRANTY expressed or implied, including the implied warranties of
|
||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General
|
||
|
# Public License for more details. You should have received a copy of the
|
||
|
# GNU General Public License along with this program; if not, write to the
|
||
|
# Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
|
||
|
# 02110-1301, USA. Any Red Hat trademarks that are incorporated in the
|
||
|
# source code or documentation are not subject to the GNU General Public
|
||
|
# License and may only be used or replicated with the express permission of
|
||
|
# Red Hat, Inc.
|
||
|
#
|
||
|
|
||
|
# Using make to run tools with multiple outputs is a recipe for disaster, so
|
||
|
# use make to run this instead. It's not like any of it can be parallelized
|
||
|
# anyway, and if anything changes we more than likely have to start at the
|
||
|
# beginning. This script will run all of the various gtkdoc programs and create
|
||
|
# a single output file, $DOC_OUTPUT_DIR/gtkdoc.stamp
|
||
|
|
||
|
# ---- ENVIRONMENT VARIABLES -----
|
||
|
# DOC_MODULE: the name of the module
|
||
|
# DOC_MAIN_SGML_FILE: the top-level SGML file
|
||
|
# DOC_SOURCE_DIR: directories containing the source code
|
||
|
# IGNORE_HFILES: header files to ignore while scanning
|
||
|
# SCAN_OPTIONS: Extra options to supply to gtkdoc-scan
|
||
|
# MKDB_OPTIONS: Extra options to supply to gtkdoc-mkdb
|
||
|
# HTML_DIR: The gtk-doc html directory
|
||
|
# GTKDOC_CC: compiler to use with gtkdoc-scangobj (e.g., $(LTCOMPILE))
|
||
|
# GTKDOC_LD: linker to use with gtkdoc-scangobj (e.g., $(LINK))
|
||
|
# GTKDOC_RUN: Wrapper to run whatever gtdkco-scangobj made (e.g., $(LIBTOOL) --mode=execute)
|
||
|
# GTKDOC_CFLAGS: CFLAGS to pass to gtkdoc-scangobj (e.g., $(GTK_CFLAGS))
|
||
|
# GTKDOC_LIBS: LIBS to pass to gtkdoc-scangobj (e.g., $(GTK_LIB) plus the .la file to scan)
|
||
|
|
||
|
# Everything will be output in the current directory because these tools are
|
||
|
# awful at communicating paths to each other, and all of the paths in
|
||
|
# $DOC_MAIN_SGML_FILE need to be relative to the output directory. Which
|
||
|
# also means that $DOC_MAIN_SGML_FILE needs to be copied into $builddir.
|
||
|
|
||
|
# This script should be run any time the source files or the main SGML file
|
||
|
# change.
|
||
|
|
||
|
if [ -n "$V" ]; then
|
||
|
set -x
|
||
|
fi
|
||
|
|
||
|
# Remove the old stamp file
|
||
|
rm -f gtkdoc.stamp
|
||
|
|
||
|
# Generate --source-dir args for gtkdoc-scan and gtkdoc-mkdb
|
||
|
# Use realpath to convert to absolute paths because whoever wrote gtkdoc-mkdb
|
||
|
# couldn't imagine a world in which input file aren't in the current directory
|
||
|
_source_dir=
|
||
|
for d in $DOC_SOURCE_DIR ; do
|
||
|
_source_dir="${_source_dir} --source-dir=$(realpath $d)"
|
||
|
done
|
||
|
|
||
|
# Convert DOC_MAIN_SGML_FILE to an absolute path because gtkdoc-mkhtml can't
|
||
|
# specify an output directory
|
||
|
DOC_MAIN_SGML_FILE=$(realpath ${DOC_MAIN_SGML_FILE})
|
||
|
|
||
|
# Clean up files from gtkdoc-scan and run
|
||
|
rm -f ${DOC_MODULE}-decl-list.txt ${DOC_MODULE}-decl.txt ${DOC_MODULE}-overrides.txt \
|
||
|
${DOC_MODULE}-sections.txt ${DOC_MODULE}.types
|
||
|
|
||
|
gtkdoc-scan \
|
||
|
--module=${DOC_MODULE} \
|
||
|
--ignore-headers="${IGNORE_HFILES}" ${_source_dir} \
|
||
|
--output-dir=. \
|
||
|
${SCAN_OPTIONS}
|
||
|
|
||
|
# Clean up files from gtkdoc-scangobj and run
|
||
|
rm -f ${DOC_MODULE}.args ${DOC_MODULE}.hierarchy ${DOC_MODULE}.interfaces \
|
||
|
${DOC_MODULE}.prerequisites ${DOC_MODULE}.signals
|
||
|
|
||
|
gtkdoc-scangobj \
|
||
|
--module=${DOC_MODULE} \
|
||
|
--types=${DOC_MODULE}.types \
|
||
|
--output-dir=. \
|
||
|
--cc="${GTKDOC_CC}" \
|
||
|
--run="${GTKDOC_RUN}" \
|
||
|
--ld="${GTKDOC_LD}" \
|
||
|
--cflags="${GTKDOC_CFLAGS}" \
|
||
|
--ldflags="${GTKDOC_LIBS}"
|
||
|
|
||
|
# Clean up files from gtkdoc-mkdb and run
|
||
|
rm -rf ${DOC_MODULE}-doc.bottom ${DOC_MODULE}-doc.top \
|
||
|
${DOC_MODULE}-undeclared.txt ${DOC_MODULE}-undocumented.txt \
|
||
|
${DOC_MODULE}-unused.txt sgml.stamp xml
|
||
|
|
||
|
gtkdoc-mkdb --module=${DOC_MODULE} \
|
||
|
--source-suffixes=c,h \
|
||
|
--ignore-files="${IGNORE_HFILES}" \
|
||
|
--output-dir=xml \
|
||
|
--main-sgml-file=${DOC_MAIN_SGML_FILE} \
|
||
|
--output-format=xml \
|
||
|
${_source_dir} \
|
||
|
${MKDB_OPTIONS}
|
||
|
|
||
|
# We almost have something useful! gtkdoc-mkhtml is next
|
||
|
rm -rf html
|
||
|
mkdir html
|
||
|
( cd html && gtkdoc-mkhtml ${DOC_MODULE} ${DOC_MAIN_SGML_FILE} )
|
||
|
|
||
|
gtkdoc-fixxref --module=${DOC_MODULE} --module-dir=html --html-dir=${HTML_DIR}
|
||
|
|
||
|
# All done, new stamp file
|
||
|
touch gtkdoc.stamp
|