2019-02-24 09:51:10 +01:00
i n c l u d e . . / d e f i n e s . m k
2019-12-06 10:08:11 +01:00
GENERATED_SYNOPSIS := \
2024-10-18 17:54:23 +02:00
config/acl/roles.rst \
config/datastore/config.rst \
config/domains/config.rst \
2021-02-12 12:18:25 +01:00
config/media-pool/config.rst \
2024-10-18 17:54:23 +02:00
config/notifications-priv/config.rst \
2024-04-23 13:52:27 +02:00
config/notifications/config.rst \
2021-02-11 11:52:37 +01:00
config/remote/config.rst \
config/sync/config.rst \
2024-10-18 17:54:23 +02:00
config/tape-job/config.rst \
config/tape/config.rst \
config/user/config.rst \
2021-02-11 13:40:11 +01:00
config/verification/config.rst \
2024-10-18 17:54:23 +02:00
pmt/synopsis.rst \
pmtx/synopsis.rst \
proxmox-backup-client/catalog-shell-synopsis.rst \
proxmox-backup-client/synopsis.rst \
proxmox-backup-debug/synopsis.rst \
proxmox-backup-manager/synopsis.rst \
proxmox-file-restore/synopsis.rst \
proxmox-tape/synopsis.rst \
pxar/synopsis.rst \
2019-02-24 09:51:10 +01:00
2021-02-10 10:33:30 +01:00
MAN1_PAGES := \
2024-10-18 17:54:23 +02:00
pbs2to3.1 \
2021-02-05 11:12:52 +01:00
pmt.1 \
2024-10-18 17:54:23 +02:00
pmtx.1 \
2019-11-11 09:14:18 +01:00
proxmox-backup-client.1 \
2024-10-18 17:54:23 +02:00
proxmox-backup-debug.1 \
2021-03-31 12:21:48 +02:00
proxmox-backup-manager.1 \
2024-10-18 17:54:23 +02:00
proxmox-backup-proxy.1 \
2021-09-02 10:32:29 +02:00
proxmox-file-restore.1 \
2024-10-18 17:54:23 +02:00
proxmox-tape.1 \
pxar.1 \
2019-02-27 17:42:31 +01:00
2024-10-21 09:07:55 +02:00
# FIXME: prefix all man pages that are not directly relating to an existing executable with
# `proxmox-backup.`, like the newer added proxmox-backup.node.cfg but add backwards compatible
# symlinks, e.g. with a "5pbs" man page "suffix section".
2021-02-10 10:33:30 +01:00
MAN5_PAGES := \
2021-02-11 13:13:34 +01:00
acl.cfg.5 \
2023-02-09 14:31:21 +01:00
datastore.cfg.5 \
2024-04-23 13:52:27 +02:00
domains.cfg.5 \
2024-10-18 17:54:23 +02:00
media-pool.cfg.5 \
2024-10-21 09:07:55 +02:00
proxmox-backup.node.cfg.5 \
2024-04-23 13:52:27 +02:00
notifications-priv.cfg.5 \
2024-10-18 17:54:23 +02:00
notifications.cfg.5 \
remote.cfg.5 \
sync.cfg.5 \
tape-job.cfg.5 \
tape.cfg.5 \
user.cfg.5 \
verification.cfg.5 \
2021-02-10 10:33:30 +01:00
2020-11-03 15:28:42 +01:00
PRUNE_SIMULATOR_FILES := \
prune-simulator/index.html \
2020-11-11 10:07:03 +01:00
prune-simulator/clear-trigger.png \
2024-10-18 17:54:23 +02:00
prune-simulator/documentation.html \
prune-simulator/prune-simulator.js \
2019-02-27 17:42:31 +01:00
2021-06-04 14:35:28 +02:00
PRUNE_SIMULATOR_JS_SOURCE := \
/usr/share/javascript/proxmox-widget-toolkit-dev/Toolkit.js \
prune-simulator/prune-simulator_source.js
2021-06-04 14:35:29 +02:00
LTO_BARCODE_JS_SOURCE := \
/usr/share/javascript/proxmox-widget-toolkit-dev/Toolkit.js \
lto-barcode/code39.js \
lto-barcode/prefix-field.js \
lto-barcode/label-style.js \
lto-barcode/tape-type.js \
lto-barcode/paper-size.js \
lto-barcode/page-layout.js \
lto-barcode/page-calibration.js \
lto-barcode/label-list.js \
lto-barcode/label-setup.js \
lto-barcode/lto-barcode.js
2020-12-19 17:39:48 +01:00
LTO_BARCODE_FILES := \
lto-barcode/index.html \
2021-06-04 14:35:29 +02:00
lto-barcode/lto-barcode-generator.js
2020-12-19 17:39:48 +01:00
2021-02-21 09:00:13 +01:00
API_VIEWER_SOURCES = \
api-viewer/index.html \
api-viewer/apidoc.js
2021-06-04 14:35:30 +02:00
API_VIEWER_FILES := \
api-viewer/apidata.js \
/usr/share/javascript/proxmox-widget-toolkit-dev/APIViewer.js \
2019-02-27 17:42:31 +01:00
# Sphinx documentation setup
SPHINXOPTS =
SPHINXBUILD = sphinx-build
BUILDDIR = output
2020-07-06 14:40:58 +02:00
i f e q ( $( BUILD_MODE ) , r e l e a s e )
2024-06-19 16:38:05 +02:00
COMPILEDIR := ../target/$( DEB_HOST_RUST_TYPE) /release
2020-07-06 14:40:58 +02:00
SPHINXOPTS += -t release
e l s e
2024-06-19 16:38:05 +02:00
COMPILEDIR := ../target/$( DEB_HOST_RUST_TYPE) /debug
2020-07-06 14:40:58 +02:00
SPHINXOPTS += -t devbuild
e n d i f
2019-02-27 17:42:31 +01:00
# Sphinx internal variables.
2019-12-03 16:51:43 +01:00
ALLSPHINXOPTS = -d $( BUILDDIR) /doctrees $( SPHINXOPTS) .
2019-02-27 17:42:31 +01:00
2021-02-10 10:33:30 +01:00
all : ${MAN 1_PAGES } ${MAN 5_PAGES }
2019-02-27 17:42:31 +01:00
2022-07-14 17:56:18 +02:00
config/%/config.rst : ${COMPILEDIR }/docgen
${ COMPILEDIR } /docgen $* .cfg >$@
2021-02-11 13:40:11 +01:00
2021-02-11 13:13:34 +01:00
config/acl/roles.rst : ${COMPILEDIR }/docgen
${ COMPILEDIR } /docgen "config::acl::Role" >$@
2022-07-14 17:54:16 +02:00
%/synopsis.rst : ${COMPILEDIR }/%
$< printdoc > $@
2019-02-27 17:42:31 +01:00
2019-12-06 10:08:11 +01:00
proxmox-backup-client/catalog-shell-synopsis.rst : ${COMPILEDIR }/dump -catalog -shell -cli
${ COMPILEDIR } /dump-catalog-shell-cli > proxmox-backup-client/catalog-shell-synopsis.rst
2022-07-14 16:41:43 +02:00
${MAN1_PAGES} ${MAN5_PAGES} : man -pages
.PHONY : man -pages
man-pages : ${GENERATED_SYNOPSIS }
${ SPHINXBUILD } ${ SPHINXOPTS } -b man ./ ${ BUILDDIR } /man
2021-09-02 10:32:29 +02:00
2020-09-02 14:22:36 +02:00
.PHONY : onlinehelpinfo
onlinehelpinfo :
@echo "Generating OnlineHelpInfo.js..."
2021-05-07 11:50:29 +02:00
$( SPHINXBUILD) -b proxmox-scanrefs -Q $( ALLSPHINXOPTS) $( BUILDDIR) /scanrefs
2020-09-02 14:22:36 +02:00
@echo " Build finished. OnlineHelpInfo.js is in $( BUILDDIR) /scanrefs. "
2021-02-21 09:00:13 +01:00
api-viewer/apidata.js : ${COMPILEDIR }/docgen
${ COMPILEDIR } /docgen apidata.js >$@
2021-06-04 14:35:30 +02:00
api-viewer/apidoc.js : ${API_VIEWER_FILES }
cat ${ API_VIEWER_FILES } >$@ .tmp
mv $@ .tmp $@
2021-02-21 09:00:13 +01:00
2021-06-04 14:35:28 +02:00
prune-simulator/prune-simulator.js : ${PRUNE_SIMULATOR_JS_SOURCE }
cat ${ PRUNE_SIMULATOR_JS_SOURCE } >$@ .tmp
mv $@ .tmp $@
2021-06-04 14:35:29 +02:00
lto-barcode/lto-barcode-generator.js : ${LTO_BARCODE_JS_SOURCE }
cat ${ LTO_BARCODE_JS_SOURCE } >$@ .tmp
mv $@ .tmp $@
2019-02-27 17:42:31 +01:00
.PHONY : html
2024-03-29 16:07:36 +01:00
html : ${GENERATED_SYNOPSIS } images /proxmox -logo .svg _static /custom .css conf .py ${PRUNE_SIMULATOR_FILES } ${LTO_BARCODE_FILES } ${API_VIEWER_SOURCES }
2019-02-27 17:42:31 +01:00
$( SPHINXBUILD) -b html $( ALLSPHINXOPTS) $( BUILDDIR) /html
2024-03-29 16:07:36 +01:00
install -m 0644 _static/custom.js _static/custom.css images/proxmox-logo.svg $( BUILDDIR) /html/_static/
2020-11-03 15:28:42 +01:00
install -dm 0755 $( BUILDDIR) /html/prune-simulator
install -m 0644 ${ PRUNE_SIMULATOR_FILES } $( BUILDDIR) /html/prune-simulator
2020-12-19 17:39:48 +01:00
install -dm 0755 $( BUILDDIR) /html/lto-barcode
install -m 0644 ${ LTO_BARCODE_FILES } $( BUILDDIR) /html/lto-barcode
2021-02-21 09:00:13 +01:00
install -dm 0755 $( BUILDDIR) /html/api-viewer
install -m 0644 ${ API_VIEWER_SOURCES } $( BUILDDIR) /html/api-viewer
2019-02-27 17:42:31 +01:00
@echo
@echo " Build finished. The HTML pages are in $( BUILDDIR) /html. "
.PHONY : latexpdf
2019-06-04 17:33:12 +02:00
latexpdf : ${GENERATED_SYNOPSIS }
2020-05-04 10:15:27 +02:00
@echo "Requires python3-sphinx, texlive-xetex, xindy and texlive-fonts-extra"
2019-02-27 17:42:31 +01:00
$( SPHINXBUILD) -b latex $( ALLSPHINXOPTS) $( BUILDDIR) /latex
2020-05-03 07:47:03 +02:00
@echo "Running LaTeX files through xelatex..."
2019-02-27 17:42:31 +01:00
$( MAKE) -C $( BUILDDIR) /latex all-pdf
2020-05-03 07:47:03 +02:00
@echo " xelatex finished; the PDF files are in $( BUILDDIR) /latex. "
2019-02-24 09:51:10 +01:00
2019-02-27 17:42:31 +01:00
.PHONY : epub 3
2019-06-04 17:33:12 +02:00
epub3 : ${GENERATED_SYNOPSIS }
2019-02-27 17:42:31 +01:00
$( SPHINXBUILD) -b epub3 $( ALLSPHINXOPTS) $( BUILDDIR) /epub3
@echo
@echo " Build finished. The epub3 file is in $( BUILDDIR) /epub3. "
2019-02-24 09:51:10 +01:00
clean :
2021-02-21 09:00:13 +01:00
rm -r -f *~ *.1 ${ BUILDDIR } ${ GENERATED_SYNOPSIS } api-viewer/apidata.js
2021-07-03 21:41:09 +02:00
rm -f api-viewer/apidoc.js lto-barcode/lto-barcode-generator.js prune-simulator/prune-simulator.js
2019-02-24 09:51:10 +01:00
2022-07-14 16:41:43 +02:00
install_manual_pages : man -pages
2019-02-24 09:51:10 +01:00
install -dm755 $( DESTDIR) $( MAN1DIR)
2022-07-14 16:41:43 +02:00
for i in ${ MAN1_PAGES } ; do install -m755 ${ BUILDDIR } /man/$$ i $( DESTDIR) $( MAN1DIR) / ; done
2021-02-10 10:33:30 +01:00
install -dm755 $( DESTDIR) $( MAN5DIR)
2022-07-14 16:41:43 +02:00
for i in ${ MAN5_PAGES } ; do install -m755 ${ BUILDDIR } /man/$$ i $( DESTDIR) $( MAN5DIR) / ; done
2019-12-13 14:14:28 +01:00
install_html : html
install -dm755 $( DESTDIR) $( DOCDIR)
2019-12-20 09:34:14 +01:00
rsync -a ${ BUILDDIR } /html $( DESTDIR) $( DOCDIR)
2019-12-13 14:14:28 +01:00
install_pdf : latexpdf
install -dm755 $( DESTDIR) $( DOCDIR)
install -m 0644 output/latex/ProxmoxBackup.pdf $( DESTDIR) $( DOCDIR) /proxmox-backup.pdf
i f n e q ( $( filter nodoc ,$ ( DEB_BUILD_PROFILES ) ) , )
install : install_manual_pages
e l s e
install : install_manual_pages install_html install_pdf
e n d i f