pkgsrc/doc/guide/Makefile

161 lines
4.5 KiB
Makefile

# $NetBSD: Makefile,v 1.56 2019/07/08 10:11:38 leot Exp $
DISTNAME= pkgsrc-guide-${PKGVERSION}
CATEGORIES= # empty
MASTER_SITES= ${MASTER_SITE_LOCAL}
DISTFILES= htdocs-share-20190708.tar.gz
MAINTAINER= pkgsrc-users@NetBSD.org
HOMEPAGE= http://www.NetBSD.org/docs/pkgsrc/
COMMENT= The pkgsrc guide
# To regenerate pkgsrc/doc/pkgsrc.{html,txt} and
# htdocs/docs/pkgsrc, just run "make regen".
PKGVERSION!= date '+%Y%m%d'
DIST_SUBDIR= ${PKGBASE}
USE_LANGUAGES= # empty
MAKE_ENV+= SED=${SED:Q}
PLIST_VARS= ascii html pdf
DOCDIR= ${PREFIX}/share/doc/pkgsrc
.if exists(/usr/cvs/htdocs)
HTDOCSDIR?= /usr/cvs/htdocs
.endif
HTDOCSDIR?= ${.CURDIR}/../../../htdocs
BUILD_DEFS+= OUTPUTS
OUTPUTS?= lint html html-split ascii pdf
INSTALLATION_DIRS= ${DOCDIR}
SUBST_CLASSES+= docbook45
SUBST_STAGE.docbook45= pre-configure
SUBST_FILES.docbook45= ${WRKDIR}/htdocs/share/xml/*
SUBST_SED.docbook45= -e 's,V4\.2,V4.5,'
SUBST_SED.docbook45+= -e 's,/4\.2/,/4.5/,'
.if defined(OUTPUTS)
. if !empty(OUTPUTS:Mascii)
# the html is needed to build the ascii version.
OUTPUTS+= html
PLIST.ascii= yes
. endif
. if !empty(OUTPUTS:Mhtml) || !empty(OUTPUTS:Mhtml-split)
PLIST.html= yes
.endif
. if !empty(OUTPUTS:Mpdf)
PLIST.pdf= yes
.endif
# only override the Makefile.common default if it is explicitly set
_GUIDE_OUTPUTS= ${OUTPUTS}
.endif
.include "Makefile.common"
# The source files are only symlinked into the WRKSRC, so that they can
# be easily modified, should the "lint" phase fail.
pre-extract:
${MKDIR} ${WRKSRC}
${LN} -s ${FILESDIR}/* ${WRKSRC}
pre-configure: generate-help-topics
generate-help-topics: .PHONY
${RUN} ${MAKE} help topic=:index > ${WRKSRC}/help-topics.data
${RUN} cd ${WRKSRC} && env PKGSRCDIR=${PKGSRCDIR} python fill-placeholders.py *.xml
do-build:
.for _output_ in ${OUTPUTS}
@${ECHO} "-----> Building ${_output_} output"
@cd ${WRKSRC} && ${SETENV} ${MAKE_ENV} ${MAKE_PROGRAM} ${MAKE_FLAGS} ${_output_}
.endfor
post-build:
@${RM} -f ${WRKSRC}/pkgsrc.tmp.html
do-install:
.if !empty(OUTPUTS:Mhtml) || !empty(OUTPUTS:Mhtml-split)
${INSTALL_DATA} ${WRKSRC}/*.html ${DESTDIR}${DOCDIR}
${INSTALL_DATA} ${WRKDIR}/htdocs/global.css ${DESTDIR}${DOCDIR}
.endif
.if !empty(OUTPUTS:Mascii)
${INSTALL_DATA} ${WRKSRC}/pkgsrc.txt ${DESTDIR}${DOCDIR}
.endif
.if !empty(OUTPUTS:Mpdf)
${INSTALL_DATA} ${WRKSRC}/pkgsrc.ps ${DESTDIR}${DOCDIR}
${INSTALL_DATA} ${WRKSRC}/pkgsrc.pdf ${DESTDIR}${DOCDIR}
.endif
# install the single-file HTML and ascii output into the pkgsrc doc/
# directory, for distribution with pkgsrc.
#
# note that this uses ${CP} and not ${INSTALL_DATA} because the files
# stay in the development directories and have nothing to do with
# the permissions or ownership of installed files.
#
install-doc: build
${CP} ${WRKSRC}/pkgsrc.html ${PKGSRCDIR}/doc
${CP} ${WRKSRC}/pkgsrc.txt ${PKGSRCDIR}/doc
install-htdocs: build
cd ${WRKSRC} && ${CP} pkgsrc.txt pkgsrc.pdf pkgsrc.ps *.html \
${HTDOCSDIR}/docs/pkgsrc
.PHONY: regen regen-doc regen-htdocs
regen: regen-doc regen-htdocs
regen-doc: build
@${STEP_MSG} "Updating the files in pkgsrc/doc"
cd .. && cvs update pkgsrc.*
${MAKE} ${MAKEFLAGS} install-doc
@${STEP_MSG} "Committing the files in pkgsrc/doc"
cd .. && cvs commit -m "doc/pkgsrc.*: regen" pkgsrc.*
regen-htdocs: build
@${STEP_MSG} "Updating the files in htdocs"
cd ${HTDOCSDIR}/docs/pkgsrc && cvs update
${MAKE} ${MAKEFLAGS} install-htdocs
@${STEP_MSG} "Committing the files in htdocs"
cd ${HTDOCSDIR}/docs/pkgsrc && cvs commit -m "regen"
do-lint:
cd ${WRKSRC} && ${SETENV} ${MAKE_ENV} ${MAKE_PROGRAM} lint
DETAB_PROGRAM= \
if (/<programlisting>/ .. /<\/programlisting>/) { \
while (/(.*?)\t(.*)/s) { \
my $$filler = " " x (8 - (length($$1) % 8)); \
$$_ = "$$1$$filler$$2"; \
} \
}
# remove tabulators from the <programlisting> tags.
# TeX does not like them.
.PHONY: detab
detab:
cd ${FILESDIR} && \
perl -p -i".detab.tmp" -e '${DETAB_PROGRAM}' *.xml && \
${RM} -f *.xml.detab.tmp
# Generates a new htdocs-share-*.tar.gz archive from the current
# contents of the htdocs directory. To make it available, it should
# be copied to ftp.NetBSD.org:/pub/pkgsrc/distfiles/LOCAL_PORTS/, i.e.:
#
# % scp htdocs-share-*.tar.gz ftp.NetBSD.org:/pub/pkgsrc/distfiles/LOCAL_PORTS/
# [... adjust DISTFILES variable ...]
# % make makesum
#
.PHONY: htdocs-share
htdocs-share:
cd ${HTDOCSDIR} \
&& ${PAX} -wz -f ${.CURDIR}/htdocs-share-${PKGVERSION}.tar.gz \
-s ',^,htdocs/,' \
global.css share
PYTHON_FOR_BUILD_ONLY= tool
.include "../../lang/python/tool.mk"
.include "../../mk/bsd.pkg.mk"