mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-25 16:48:11 +00:00
e412e146f6
Original commit message from CVS: fix for case where none of the tools for docbuilding are there but validity check needs image.entities
183 lines
5.1 KiB
Makefile
183 lines
5.1 KiB
Makefile
# rewritten by Thomas to be more simple and working
|
|
|
|
# SF username
|
|
USERNAME ?= thomasvs
|
|
|
|
### These are all generic; we set all the variables we need
|
|
|
|
# intermediary build path
|
|
BUILDDIR = build
|
|
# same for images
|
|
BUILDIMAGESDIR = $(BUILDDIR)/images
|
|
|
|
# images
|
|
# right now, we only allow .png and .fig as source
|
|
# we might add more later if we feel the need
|
|
|
|
# PNG's can be source or built from .fig
|
|
PNG = $(strip $(PNG_SRC) $(FIG_SRC:.fig=.png))
|
|
# EPS .ps files can be built from .png or .fig
|
|
EPS = $(strip $(FIG_SRC:.fig=.ps) $(PNG_SRC:.png=.ps))
|
|
# PDF .pdf files can be built from .png or .fig
|
|
PDF = $(strip $(FIG_SRC:.fig=.pdf) $(PNG_SRC:.png=.pdf))
|
|
|
|
# where we expect to find images during building, whether by copying
|
|
# or by generating them
|
|
PNG_BUILT = $(foreach file, $(PNG), $(BUILDIMAGESDIR)/$(file))
|
|
EPS_BUILT = $(foreach file, $(EPS), $(BUILDIMAGESDIR)/$(file))
|
|
PDF_BUILT = $(foreach file, $(PDF), $(BUILDIMAGESDIR)/$(file))
|
|
|
|
# everything considered source
|
|
SRC = $(XML) $(PNG_SRC) $(FIG_SRC) $(CSS)
|
|
|
|
# generate A4 docs
|
|
PAPER_LOCALE = nl_NL
|
|
|
|
### generate all documentation by default
|
|
all: html ps pdf
|
|
|
|
# can we generate HTML ?
|
|
if DOC_HTML
|
|
HTML_DAT = html
|
|
html: html/index.html
|
|
else #!DOC_HTML
|
|
HTML_DAT =
|
|
html:
|
|
endif #DOC_HTML
|
|
|
|
# can we generate PS ?
|
|
if DOC_PS
|
|
PS_DAT = $(DOC).ps
|
|
ps: $(DOC).ps
|
|
else #!DOC_PS
|
|
PS_DAT =
|
|
ps:
|
|
endif #DOC_PS
|
|
|
|
# can we generate PDF ?
|
|
if DOC_PDF
|
|
PDF_DAT = $(DOC).pdf
|
|
pdf: $(DOC).pdf
|
|
else #!DOC_PDF
|
|
PDF_DAT =
|
|
pdf:
|
|
endif #DOC_PDF
|
|
|
|
debug:
|
|
@echo "outputting some useful debug information"
|
|
@echo "Source XML:"
|
|
@echo "XML: '$(XML)'"
|
|
@echo "CSS: '$(CSS)'"
|
|
@echo "Source image files:"
|
|
@echo "PNG_SRC: '$(PNG_SRC)'"
|
|
@echo "FIG_SRC: '$(FIG_SRC)'"
|
|
@echo "All used image files:"
|
|
@echo "PNG: '$(PNG)'"
|
|
@echo "EPS: '$(EPS)'"
|
|
@echo "PDF: '$(PDF)'"
|
|
@echo "All used image files in their built path:"
|
|
@echo "PNG_BUILT: '$(PNG_BUILT)'"
|
|
@echo "EPS_BUILT: '$(EPS_BUILT)'"
|
|
@echo "PDF_BUILT: '$(PDF_BUILT)'"
|
|
@echo "End result products:"
|
|
@echo "HTML_DAT: '$(HTML_DAT)'"
|
|
@echo "PS_DAT: '$(PS_DAT)'"
|
|
@echo "PDF_DAT: '$(PDF_DAT)'"
|
|
|
|
# a rule to copy all of the source for docs into $(builddir)/build
|
|
$(BUILDDIR)/$(MAIN): $(XML) $(CSS)
|
|
@-mkdir -p $(BUILDDIR)
|
|
@for a in $(XML); do cp $(srcdir)/$$a $(BUILDDIR); done
|
|
@for a in $(CSS); do cp $(srcdir)/$$a $(BUILDDIR); done
|
|
@cp ../version.entities $(BUILDDIR)
|
|
|
|
html/index.html: $(BUILDDIR)/$(MAIN) $(PNG_BUILT) $(FIG_SRC)
|
|
@echo "*** Generating HTML output ***"
|
|
@-mkdir -p html
|
|
@cp -f $(srcdir)/../image-png $(BUILDDIR)/image.entities
|
|
@cd $(BUILDDIR) && docbook2html -o ../html -V '%use-id-as-filename%' $(MAIN)
|
|
@test "x$(CSS)" != "x" && \
|
|
echo "Copying .css files: $(CSS)" && \
|
|
cp $(srcdir)/$(CSS) html
|
|
@test "x$(PNG)" != "x" && \
|
|
echo "Copying .png images: $(PNG_BUILT)" && \
|
|
mkdir -p html/images && \
|
|
cp $(PNG_BUILT) html/images || true
|
|
|
|
$(DOC).ps: $(BUILDDIR)/$(MAIN) $(EPS_BUILT) $(PNG_SRC) $(FIG_SRC)
|
|
@echo "*** Generating PS output ***"
|
|
@cp -f $(srcdir)/../image-eps $(BUILDDIR)/image.entities
|
|
cd $(BUILDDIR) && docbook2ps -o .. $(MAIN)
|
|
# export LC_PAPER=$(PAPER_LOCALE) && cd $(BUILDDIR) && xmlto ps -o .. $(MAIN)
|
|
|
|
$(DOC).pdf: $(DOC).ps
|
|
@echo "*** Generating PDF output ***"
|
|
@ps2pdf $(DOC).ps
|
|
|
|
#$(DOC).pdf: $(MAIN) $(PDF) $(FIG_SRC)
|
|
# @echo "*** Generating PDF output ***"
|
|
# @cp -f $(srcdir)/../image-pdf image.entities
|
|
# @export LC_PAPER=$(PAPER_LOCALE) && xmlto pdf $(MAIN)
|
|
# @rm image.entities
|
|
|
|
clean-local:
|
|
-$(RM) -r $(BUILDDIR)
|
|
-$(RM) -r html
|
|
-$(RM) $(DOC).ps
|
|
-$(RM) $(DOC).pdf
|
|
-$(RM) -r www
|
|
|
|
### image generation
|
|
|
|
# copy png from source dir png
|
|
$(BUILDIMAGESDIR)/%.png: $(srcdir)/%.png
|
|
@echo "Copying $< to $@"
|
|
@mkdir -p $(BUILDIMAGESDIR)
|
|
@cp $< $@
|
|
# make png from fig
|
|
$(BUILDIMAGESDIR)/%.png: %.fig
|
|
@echo "Generating $@ from $<"
|
|
@mkdir -p $(BUILDIMAGESDIR)
|
|
@fig2dev -Lpng $< $@
|
|
|
|
# make ps(EPS) from fig
|
|
$(BUILDIMAGESDIR)/%.ps: %.fig
|
|
@echo "Generating $@ from $<"
|
|
@mkdir -p $(BUILDIMAGESDIR)
|
|
@fig2dev -Leps $< $@
|
|
|
|
# make pdf from fig
|
|
$(BUILDIMAGESDIR)/%.pdf: %.fig
|
|
@echo "Generating $@ from $<"
|
|
@mkdir -p $(BUILDIMAGESDIR)
|
|
@fig2dev -Lpdf $< $@
|
|
|
|
# make pdf from png
|
|
$(BUILDIMAGESDIR)/%.pdf: %.png
|
|
@echo "Generating $@ from $<"
|
|
@mkdir -p $(BUILDIMAGESDIR)
|
|
@cat $< | pngtopnm | pnmtops -noturn 2> /dev/null | epstopdf --filter --outfile $@ 2> /dev/null
|
|
|
|
# make ps(EPS) from png
|
|
$(BUILDIMAGESDIR)/%.ps: %.png
|
|
@echo "Generating $@ from $<"
|
|
@mkdir -p $(BUILDIMAGESDIR)
|
|
@cat $< | pngtopnm | pnmtops -noturn > $@ 2> /dev/null
|
|
|
|
# make sure xml validates properly
|
|
check-local: $(BUILDDIR)/$(MAIN)
|
|
@cp -f $(srcdir)/../image-png $(BUILDDIR)/image.entities
|
|
cd $(BUILDDIR) && xmllint -noout -valid $(MAIN)
|
|
|
|
### this is a website upload target
|
|
|
|
upload: html ps pdf
|
|
@export RSYNC_RSH=ssh; \
|
|
if test "x$$GST_PLUGINS_VERSION_NANO" = x0; then \
|
|
export DOCVERSION=$(VERSION); \
|
|
else export DOCVERSION=cvs; \
|
|
fi; \
|
|
echo Uploading docs to shell.sf.net/home/groups/g/gs/gstreamer/htdocs/docs/$$DOCVERSION; \
|
|
ssh $(USERNAME)@shell.sf.net mkdir -p /home/groups/g/gs/gstreamer/htdocs/docs/$$DOCVERSION/$(DOC); \
|
|
rsync -arv $(DOC).ps $(DOC).pdf html $(USERNAME)@shell.sf.net:/home/groups/g/gs/gstreamer/htdocs/docs/$$DOCVERSION/$(DOC)
|
|
|