2021-12-11 17:16:05 -05:00
|
|
|
DOC_OUT := manual/$(OUTPUT_DIR)
|
|
|
|
S_HTML_OUT := $(DOC_OUT)/singlehtml
|
|
|
|
S_HTML_TARGET := $(S_HTML_OUT)/index.html
|
|
|
|
HTML_OUT := $(DOC_OUT)/html
|
|
|
|
HTML_TARGET := $(HTML_OUT)/index.html
|
|
|
|
PDF_OUT := $(DOC_OUT)/latex
|
|
|
|
PDF_TARGET := $(PDF_OUT)/qpdf.pdf
|
2008-04-29 12:55:25 +00:00
|
|
|
|
2021-12-21 09:23:20 -05:00
|
|
|
TARGETS_manual := \
|
|
|
|
$(DOC_OUT)/qpdf.1 \
|
|
|
|
$(DOC_OUT)/fix-qdf.1 \
|
|
|
|
$(DOC_OUT)/zlib-flate.1
|
2008-04-29 12:55:25 +00:00
|
|
|
ifeq ($(BUILD_HTML),1)
|
2021-12-18 11:19:20 -05:00
|
|
|
TARGETS_manual += $(HTML_TARGET) $(S_HTML_TARGET)
|
2008-04-29 12:55:25 +00:00
|
|
|
endif
|
|
|
|
ifeq ($(BUILD_PDF),1)
|
2021-12-18 11:19:20 -05:00
|
|
|
TARGETS_manual += $(PDF_TARGET)
|
2008-04-29 12:55:25 +00:00
|
|
|
endif
|
|
|
|
|
2022-01-11 11:49:33 -05:00
|
|
|
MANUAL_DEPS = $(wildcard manual/*.rst) manual/conf.py manual/_ext/qpdf.py
|
2021-12-18 08:27:31 -05:00
|
|
|
|
2021-12-11 17:16:05 -05:00
|
|
|
# Prevent targets that run $(SPHINX) from running in parallel by using
|
|
|
|
# order-only dependencies (the dependencies listed after the |) to
|
|
|
|
# avoid clashes in temporary files that cause the build to fail with
|
|
|
|
# the error "_pickle.UnpicklingError: pickle data was truncated"
|
2021-12-18 08:27:31 -05:00
|
|
|
$(HTML_TARGET): $(MANUAL_DEPS)
|
2021-12-11 17:16:05 -05:00
|
|
|
$(SPHINX) -M html manual $(DOC_OUT) -W
|
|
|
|
|
2021-12-18 08:27:31 -05:00
|
|
|
$(S_HTML_TARGET): $(MANUAL_DEPS) | $(HTML_TARGET)
|
2021-12-11 17:16:05 -05:00
|
|
|
$(SPHINX) -M singlehtml manual $(DOC_OUT) -W
|
|
|
|
|
2021-12-18 08:27:31 -05:00
|
|
|
$(PDF_TARGET): $(MANUAL_DEPS) | $(S_HTML_TARGET) $(HTML_TARGET)
|
2021-12-11 17:16:05 -05:00
|
|
|
$(SPHINX) -M latexpdf manual $(DOC_OUT) -W
|
2008-04-29 12:55:25 +00:00
|
|
|
|
2021-12-21 09:23:20 -05:00
|
|
|
$(DOC_OUT)/%.1: manual/%.1.in
|
|
|
|
sed -e 's:@PACKAGE_VERSION@:$(PACKAGE_VERSION):g' < $< > $@
|
|
|
|
|
|
|
|
# The doc-dist target must not removed $(DOC_DEST) so that it works to
|
|
|
|
# do stuff like make doc-dist DOC_DEST=$(DESTDIR)/$(docdir). Make sure
|
|
|
|
# what this does is consistent with ../README-doc.txt and the
|
|
|
|
# information in the manual and ../README.md.
|
|
|
|
.PHONY: doc-dist
|
|
|
|
doc-dist: build_manual
|
|
|
|
@if test x"$(DOC_DEST)" = x; then \
|
|
|
|
echo DOC_DEST must be set 1>& 2; \
|
|
|
|
false; \
|
|
|
|
fi
|
|
|
|
if test -d $(DOC_DEST); then \
|
|
|
|
$(RM) -rf $(DOC_DEST)/*html $(DOC_DEST)/*.pdf; \
|
|
|
|
else \
|
|
|
|
mkdir -p $(DOC_DEST); \
|
|
|
|
fi
|
2022-02-08 13:52:01 -05:00
|
|
|
if [ -d $(DOC_OUT)/html ]; then \
|
|
|
|
cp -r $(DOC_OUT)/html $(DOC_DEST); \
|
|
|
|
fi
|
|
|
|
if [ -d $(DOC_OUT)/singlehtml ]; then \
|
|
|
|
cp -r $(DOC_OUT)/singlehtml $(DOC_DEST); \
|
|
|
|
fi
|
|
|
|
if [ -f $(PDF_TARGET) ]; then \
|
|
|
|
cp $(PDF_TARGET) $(DOC_DEST)/qpdf-manual.pdf; \
|
|
|
|
fi
|