summaryrefslogtreecommitdiff
path: root/mk
diff options
context:
space:
mode:
authorhubertf <hubertf>1997-10-07 00:30:31 +0000
committerhubertf <hubertf>1997-10-07 00:30:31 +0000
commitad8cc77b90324e22464dffa9f67a0ffcb11665b3 (patch)
tree84fb80487fce7c9588d5cad5878984c883a31434 /mk
parent7f4436ca13040636d6ce930ab0699c4d030425f5 (diff)
downloadpkgsrc-ad8cc77b90324e22464dffa9f67a0ffcb11665b3.tar.gz
Be correct about manpage compression by regarding MANZ and fixing
PLIST before applying. It is assumed that ports do install manpages uncompressed, if not they have to set MANCOMPRESSED. Upon that, the pages will be (un)compressed according to the setting of MANZ.
Diffstat (limited to 'mk')
-rw-r--r--mk/bsd.pkg.mk49
-rw-r--r--mk/bsd.port.mk49
2 files changed, 66 insertions, 32 deletions
diff --git a/mk/bsd.pkg.mk b/mk/bsd.pkg.mk
index bc2aec50976..f8079e4a3fd 100644
--- a/mk/bsd.pkg.mk
+++ b/mk/bsd.pkg.mk
@@ -2,7 +2,7 @@
# ex:ts=4
#
# Id: bsd.port.mk,v 1.263 1997/07/17 17:47:36 markm Exp
-# $NetBSD: bsd.pkg.mk,v 1.9 1997/10/03 09:16:15 agc Exp $
+# $NetBSD: bsd.pkg.mk,v 1.10 1997/10/07 00:30:31 hubertf Exp $
#
# bsd.port.mk - 940820 Jordan K. Hubbard.
# This file is in the public domain.
@@ -232,10 +232,13 @@ NetBSD_MAINTAINER= agc@netbsd.org
# INSTALL_DATA - A command to install sharable data.
# INSTALL_MAN - A command to install manpages (doesn't compress).
#
-# If your port doesn't automatically compress manpages, set the following.
-# Depending on the setting of NOMANCOMPRESS, the make rules will compress
-# the manpages for you.
+# It is assumed that the port installs manpages uncompressed. If this is
+# not the case, set MANCOMPRESSED in the port. Depending on the setting of
+# MANZ, the make rules will then compress the manpages for you with the
+# following information.
#
+# MANCOMPRESSED - Indicates that the port installs manpages in a compressed
+# form (default: port installs manpages uncompressed).
# MAN<sect> - A list of manpages, categorized by section. For
# example, if your port has "man/man1/foo.1" and
# "man/mann/bar.n", set "MAN1=foo.1" and "MANN=bar.n".
@@ -306,7 +309,6 @@ OPSYS!= uname -s
NOMANCOMPRESS?= yes
DEF_UMASK?= 022
.elif (${OPSYS} == "NetBSD")
-NOMANCOMPRESS?= no # XXX should be yes(?) - hubertf
DEF_UMASK?= 0022
.else
DEF_UMASK?= 0022
@@ -544,7 +546,7 @@ SCRIPTS_ENV+= ${INSTALL_MACROS}
COMMENT?= ${PKGDIR}/COMMENT
DESCR?= ${PKGDIR}/DESCR
-PLIST?= ${PKGDIR}/PLIST
+PLIST= ${WRKDIR}/.PLIST
PKG_CMD?= /usr/sbin/pkg_create
.if !defined(PKG_ARGS)
@@ -773,10 +775,6 @@ _MANPAGES+= ${MANN:S%^%${MANNPREFIX}/man/${lang}/mann/%}
.endfor
-.if defined(_MANPAGES) && defined(MANCOMPRESSED)
-_MANPAGES:= ${_MANPAGES:S/$/.gz/}
-.endif
-
.MAIN: all
################################################################
@@ -1113,7 +1111,7 @@ do-install:
# Package
.if !target(do-package)
-do-package:
+do-package: ${PLIST}
@if [ -e ${PLIST} ]; then \
${ECHO_MSG} "===> Building package for ${PKGNAME}"; \
if [ -d ${PACKAGES} ]; then \
@@ -1221,12 +1219,12 @@ _PORT_USE: .USE
${SCRIPTDIR}/${.TARGET:S/^real-/post-/}; \
fi
.if make(real-install) && defined(_MANPAGES)
-.if defined(MANCOMPRESSED) && defined(NOMANCOMPRESS)
+.if defined(MANCOMPRESSED) && !defined(MANZ)
@${ECHO_MSG} "===> Uncompressing manual pages for ${PKGNAME}"
.for manpage in ${_MANPAGES}
- @${GUNZIP_CMD} ${manpage}
+ @${GUNZIP_CMD} ${manpage}.gz
.endfor
-.elif !defined(MANCOMPRESSED) && !defined(NOMANCOMPRESS)
+.elif !defined(MANCOMPRESSED) && defined(MANZ)
@${ECHO_MSG} "===> Compressing manual pages for ${PKGNAME}"
.for manpage in ${_MANPAGES}
@${GZIP_CMD} ${manpage}
@@ -1760,7 +1758,7 @@ print-package-depends:
# accordance to the @pkgdep directive in the packing lists
.if !target(fake-pkg)
-fake-pkg:
+fake-pkg: ${PLIST}
@if [ ! -f ${PLIST} -o ! -f ${COMMENT} -o ! -f ${DESCR} ]; then ${ECHO} "** Missing package files for ${PKGNAME} - installation not recorded."; exit 1; fi
@if [ ! -d ${PKG_DBDIR} ]; then ${RM} -f ${PKG_DBDIR}; ${MKDIR} ${PKG_DBDIR}; fi
.if defined(FORCE_PKG_REGISTER)
@@ -1805,7 +1803,26 @@ depend:
tags:
.endif
-.endif
+
+# generate ${PLIST} from ${PKGDIR}/PLIST, by
+# - fixing list of man-pages according to MANCOMPRESSED/MANZ
+# (we don't regard MANCOMPRESSED as many ports seem to have .gz pages in
+# PLIST even when they install manpages without compressing them)
+${PLIST}: ${PKGDIR}/PLIST
+.if defined(MANZ)
+ @sed \
+ -e '/man\/man.*[^g][^z]$$/s/$$/.gz/g' \
+ -e '/man\/cat.*[^g][^z]$$/s/$$/.gz/g' \
+ <${PKGDIR}/PLIST >${PLIST}
+.else # !MANZ
+ @sed \
+ -e '/man\/man/s/\.gz$$//g' \
+ -e '/man\/cat/s/\.gz$$//g' \
+ <${PKGDIR}/PLIST >${PLIST}
+.endif # MANZ
+
+
+.endif # __ARCH_OK
.if (${OPSYS} == "NetBSD")
.include <bsd.own.mk>
diff --git a/mk/bsd.port.mk b/mk/bsd.port.mk
index 8ce344fbeb8..d50e5e5ce63 100644
--- a/mk/bsd.port.mk
+++ b/mk/bsd.port.mk
@@ -2,7 +2,7 @@
# ex:ts=4
#
# Id: bsd.port.mk,v 1.263 1997/07/17 17:47:36 markm Exp
-# $NetBSD: bsd.port.mk,v 1.9 1997/10/03 09:16:15 agc Exp $
+# $NetBSD: bsd.port.mk,v 1.10 1997/10/07 00:30:31 hubertf Exp $
#
# bsd.port.mk - 940820 Jordan K. Hubbard.
# This file is in the public domain.
@@ -232,10 +232,13 @@ NetBSD_MAINTAINER= agc@netbsd.org
# INSTALL_DATA - A command to install sharable data.
# INSTALL_MAN - A command to install manpages (doesn't compress).
#
-# If your port doesn't automatically compress manpages, set the following.
-# Depending on the setting of NOMANCOMPRESS, the make rules will compress
-# the manpages for you.
+# It is assumed that the port installs manpages uncompressed. If this is
+# not the case, set MANCOMPRESSED in the port. Depending on the setting of
+# MANZ, the make rules will then compress the manpages for you with the
+# following information.
#
+# MANCOMPRESSED - Indicates that the port installs manpages in a compressed
+# form (default: port installs manpages uncompressed).
# MAN<sect> - A list of manpages, categorized by section. For
# example, if your port has "man/man1/foo.1" and
# "man/mann/bar.n", set "MAN1=foo.1" and "MANN=bar.n".
@@ -306,7 +309,6 @@ OPSYS!= uname -s
NOMANCOMPRESS?= yes
DEF_UMASK?= 022
.elif (${OPSYS} == "NetBSD")
-NOMANCOMPRESS?= no # XXX should be yes(?) - hubertf
DEF_UMASK?= 0022
.else
DEF_UMASK?= 0022
@@ -544,7 +546,7 @@ SCRIPTS_ENV+= ${INSTALL_MACROS}
COMMENT?= ${PKGDIR}/COMMENT
DESCR?= ${PKGDIR}/DESCR
-PLIST?= ${PKGDIR}/PLIST
+PLIST= ${WRKDIR}/.PLIST
PKG_CMD?= /usr/sbin/pkg_create
.if !defined(PKG_ARGS)
@@ -773,10 +775,6 @@ _MANPAGES+= ${MANN:S%^%${MANNPREFIX}/man/${lang}/mann/%}
.endfor
-.if defined(_MANPAGES) && defined(MANCOMPRESSED)
-_MANPAGES:= ${_MANPAGES:S/$/.gz/}
-.endif
-
.MAIN: all
################################################################
@@ -1113,7 +1111,7 @@ do-install:
# Package
.if !target(do-package)
-do-package:
+do-package: ${PLIST}
@if [ -e ${PLIST} ]; then \
${ECHO_MSG} "===> Building package for ${PKGNAME}"; \
if [ -d ${PACKAGES} ]; then \
@@ -1221,12 +1219,12 @@ _PORT_USE: .USE
${SCRIPTDIR}/${.TARGET:S/^real-/post-/}; \
fi
.if make(real-install) && defined(_MANPAGES)
-.if defined(MANCOMPRESSED) && defined(NOMANCOMPRESS)
+.if defined(MANCOMPRESSED) && !defined(MANZ)
@${ECHO_MSG} "===> Uncompressing manual pages for ${PKGNAME}"
.for manpage in ${_MANPAGES}
- @${GUNZIP_CMD} ${manpage}
+ @${GUNZIP_CMD} ${manpage}.gz
.endfor
-.elif !defined(MANCOMPRESSED) && !defined(NOMANCOMPRESS)
+.elif !defined(MANCOMPRESSED) && defined(MANZ)
@${ECHO_MSG} "===> Compressing manual pages for ${PKGNAME}"
.for manpage in ${_MANPAGES}
@${GZIP_CMD} ${manpage}
@@ -1760,7 +1758,7 @@ print-package-depends:
# accordance to the @pkgdep directive in the packing lists
.if !target(fake-pkg)
-fake-pkg:
+fake-pkg: ${PLIST}
@if [ ! -f ${PLIST} -o ! -f ${COMMENT} -o ! -f ${DESCR} ]; then ${ECHO} "** Missing package files for ${PKGNAME} - installation not recorded."; exit 1; fi
@if [ ! -d ${PKG_DBDIR} ]; then ${RM} -f ${PKG_DBDIR}; ${MKDIR} ${PKG_DBDIR}; fi
.if defined(FORCE_PKG_REGISTER)
@@ -1805,7 +1803,26 @@ depend:
tags:
.endif
-.endif
+
+# generate ${PLIST} from ${PKGDIR}/PLIST, by
+# - fixing list of man-pages according to MANCOMPRESSED/MANZ
+# (we don't regard MANCOMPRESSED as many ports seem to have .gz pages in
+# PLIST even when they install manpages without compressing them)
+${PLIST}: ${PKGDIR}/PLIST
+.if defined(MANZ)
+ @sed \
+ -e '/man\/man.*[^g][^z]$$/s/$$/.gz/g' \
+ -e '/man\/cat.*[^g][^z]$$/s/$$/.gz/g' \
+ <${PKGDIR}/PLIST >${PLIST}
+.else # !MANZ
+ @sed \
+ -e '/man\/man/s/\.gz$$//g' \
+ -e '/man\/cat/s/\.gz$$//g' \
+ <${PKGDIR}/PLIST >${PLIST}
+.endif # MANZ
+
+
+.endif # __ARCH_OK
.if (${OPSYS} == "NetBSD")
.include <bsd.own.mk>