1 1.82 lukem # $NetBSD: bsd.man.mk,v 1.82 2003/07/18 02:52:51 lukem Exp $ 2 1.26 mikel # @(#)bsd.man.mk 8.1 (Berkeley) 6/8/93 3 1.1 cgd 4 1.64 tv .include <bsd.init.mk> 5 1.34 mycroft 6 1.64 tv ##### Basic targets 7 1.64 tv .PHONY: catinstall maninstall catpages manpages catlinks manlinks \ 8 1.64 tv cleanman html installhtml cleanhtml 9 1.32 mycroft realinstall: ${MANINSTALL} 10 1.28 mycroft 11 1.64 tv ##### Default values 12 1.66 tv .if ${USETOOLS} == "yes" 13 1.69 jmc TMACDEPDIR?= ${TOOLDIR}/share/groff/tmac 14 1.66 tv .else 15 1.69 jmc TMACDEPDIR?= ${DESTDIR}/usr/share/tmac 16 1.69 jmc .endif 17 1.66 tv 18 1.56 phil HTMLDIR?= ${DESTDIR}/usr/share/man 19 1.80 wiz CATDEPS?= ${TMACDEPDIR}/andoc.tmac \ 20 1.80 wiz ${TMACDEPDIR}/doc.tmac \ 21 1.80 wiz ${TMACDEPDIR}/mdoc/doc-common \ 22 1.80 wiz ${TMACDEPDIR}/mdoc/doc-ditroff \ 23 1.80 wiz ${TMACDEPDIR}/mdoc/doc-nroff \ 24 1.80 wiz ${TMACDEPDIR}/mdoc/doc-syms 25 1.80 wiz HTMLDEPS?= ${TMACDEPDIR}/doc2html.tmac 26 1.28 mycroft MANTARGET?= cat 27 1.66 tv 28 1.64 tv MAN?= 29 1.64 tv MLINKS?= 30 1.64 tv _MNUMBERS= 1 2 3 4 5 6 7 8 9 31 1.64 tv .SUFFIXES: ${_MNUMBERS:@N@.$N@} 32 1.64 tv 33 1.82 lukem .if ${MKMANZ} == "no" 34 1.82 lukem MANCOMPRESS?= 35 1.82 lukem MANSUFFIX?= 36 1.82 lukem .else 37 1.82 lukem MANCOMPRESS?= gzip -cf 38 1.82 lukem MANSUFFIX?= .gz 39 1.82 lukem .endif 40 1.64 tv 41 1.64 tv # make MANCOMPRESS a filter, so it can be inserted on an as-needed basis 42 1.64 tv .if !empty(MANCOMPRESS) 43 1.64 tv MANCOMPRESS:= | ${MANCOMPRESS} 44 1.20 cgd .endif 45 1.1 cgd 46 1.25 christos __installpage: .USE 47 1.60 simonb @cmp -s ${.ALLSRC} ${.TARGET} > /dev/null 2>&1 || \ 48 1.64 tv (echo "${INSTALL_FILE} -o ${MANOWN} -g ${MANGRP} -m ${MANMODE} \ 49 1.79 perry ${SYSPKGDOCTAG} ${.ALLSRC} ${.TARGET}" && \ 50 1.64 tv ${INSTALL_FILE} -o ${MANOWN} -g ${MANGRP} -m ${MANMODE} \ 51 1.79 perry ${SYSPKGDOCTAG} ${.ALLSRC} ${.TARGET}) 52 1.25 christos 53 1.64 tv ##### Build and install rules (source form pages) 54 1.25 christos 55 1.64 tv .if ${MKMAN} != "no" 56 1.64 tv maninstall: manlinks 57 1.64 tv manpages:: # ensure target exists 58 1.65 enami MANPAGES= ${MAN:C/.$/&${MANSUFFIX}/} 59 1.64 tv 60 1.72 tv realall: ${MANPAGES} 61 1.64 tv .if !empty(MANSUFFIX) 62 1.64 tv .NOPATH: ${MANPAGES} 63 1.64 tv .SUFFIXES: ${_MNUMBERS:@N@.$N${MANSUFFIX}@} 64 1.64 tv 65 1.64 tv ${_MNUMBERS:@N@.$N.$N${MANSUFFIX}@}: # build rule 66 1.73 mrg cat ${.IMPSRC} ${MANCOMPRESS} > ${.TARGET}.tmp && mv ${.TARGET}.tmp ${.TARGET} 67 1.64 tv .endif # !empty(MANSUFFIX) 68 1.64 tv 69 1.64 tv .for F in ${MANPAGES:S/${MANSUFFIX}$//:O:u} 70 1.64 tv _F:= ${DESTDIR}${MANDIR}/man${F:T:E}${MANSUBDIR}/${F}${MANSUFFIX} 71 1.64 tv 72 1.78 mycroft .if !defined(UPDATE) 73 1.78 mycroft ${_F}! ${F}${MANSUFFIX} __installpage # install rule 74 1.78 mycroft .if !defined(BUILD) && !make(all) && !make(${F}) 75 1.78 mycroft ${_F}! .MADE # no build at install 76 1.78 mycroft .endif 77 1.78 mycroft .else 78 1.64 tv ${_F}: ${F}${MANSUFFIX} __installpage # install rule 79 1.64 tv .if !defined(BUILD) && !make(all) && !make(${F}) 80 1.64 tv ${_F}: .MADE # no build at install 81 1.53 mycroft .endif 82 1.78 mycroft .endif 83 1.78 mycroft 84 1.78 mycroft manpages:: ${_F} 85 1.78 mycroft .PRECIOUS: ${_F} # keep if install fails 86 1.64 tv .endfor 87 1.52 mycroft 88 1.64 tv manlinks: manpages # symlink install 89 1.64 tv .if !empty(MLINKS) 90 1.25 christos @set ${MLINKS}; \ 91 1.25 christos while test $$# -ge 2; do \ 92 1.64 tv name=$$1; shift; \ 93 1.64 tv dir=${DESTDIR}${MANDIR}/man$${name##*.}; \ 94 1.64 tv l=$${dir}${MANSUBDIR}/$${name}${MANSUFFIX}; \ 95 1.64 tv name=$$1; shift; \ 96 1.64 tv dir=${DESTDIR}${MANDIR}/man$${name##*.}; \ 97 1.64 tv t=$${dir}${MANSUBDIR}/$${name}${MANSUFFIX}; \ 98 1.55 itojun if test $$l -nt $$t -o ! -f $$t; then \ 99 1.55 itojun echo $$t -\> $$l; \ 100 1.79 perry ${INSTALL_LINK} ${SYSPKGDOCTAG} $$l $$t; \ 101 1.55 itojun fi; \ 102 1.19 brezak done 103 1.19 brezak .endif 104 1.64 tv .endif # ${MKMAN} != "no" 105 1.64 tv 106 1.64 tv ##### Build and install rules (plaintext pages) 107 1.64 tv 108 1.64 tv .if (${MKCATPAGES} != "no") && (${MKMAN} != "no") 109 1.64 tv catinstall: catlinks 110 1.64 tv catpages:: # ensure target exists 111 1.64 tv CATPAGES= ${MAN:C/\.([1-9])$/.cat\1${MANSUFFIX}/} 112 1.64 tv 113 1.64 tv realall: ${CATPAGES} 114 1.64 tv .NOPATH: ${CATPAGES} 115 1.64 tv .SUFFIXES: ${_MNUMBERS:@N@.cat$N${MANSUFFIX}@} 116 1.75 christos .MADE: ${CATDEPS} 117 1.76 ross .MADE: ${HTMLDEPS} 118 1.64 tv 119 1.64 tv ${_MNUMBERS:@N@.$N.cat$N${MANSUFFIX}@}: ${CATDEPS} # build rule 120 1.64 tv .if defined(USETBL) 121 1.81 lukem ${TOOL_TBL} ${.IMPSRC} | ${TOOL_ROFF_ASCII} -mandoc ${MANCOMPRESS} \ 122 1.81 lukem > ${.TARGET}.tmp && mv ${.TARGET}.tmp ${.TARGET} 123 1.64 tv .else 124 1.81 lukem ${TOOL_ROFF_ASCII} -mandoc ${.IMPSRC} ${MANCOMPRESS} \ 125 1.81 lukem > ${.TARGET}.tmp && mv ${.TARGET}.tmp ${.TARGET} 126 1.64 tv .endif 127 1.64 tv 128 1.64 tv .for F in ${CATPAGES:S/${MANSUFFIX}$//:O:u} 129 1.64 tv _F:= ${DESTDIR}${MANDIR}/${F:T:E}${MANSUBDIR}/${F:R}.0${MANSUFFIX} 130 1.78 mycroft 131 1.78 mycroft .if !defined(UPDATE) 132 1.78 mycroft ${_F}! ${F}${MANSUFFIX} __installpage # install rule 133 1.78 mycroft .if !defined(BUILD) && !make(all) && !make(${F}) 134 1.78 mycroft ${_F}! .MADE # no build at install 135 1.78 mycroft .endif 136 1.78 mycroft .else 137 1.64 tv ${_F}: ${F}${MANSUFFIX} __installpage # install rule 138 1.64 tv .if !defined(BUILD) && !make(all) && !make(${F}) 139 1.64 tv ${_F}: .MADE # no build at install 140 1.43 lukem .endif 141 1.78 mycroft .endif 142 1.78 mycroft 143 1.78 mycroft catpages:: ${_F} 144 1.78 mycroft .PRECIOUS: ${_F} # keep if install fails 145 1.64 tv .endfor 146 1.25 christos 147 1.64 tv catlinks: catpages # symlink install 148 1.64 tv .if !empty(MLINKS) 149 1.1 cgd @set ${MLINKS}; \ 150 1.1 cgd while test $$# -ge 2; do \ 151 1.64 tv name=$$1; shift; \ 152 1.64 tv dir=${DESTDIR}${MANDIR}/cat$${name##*.}; \ 153 1.64 tv l=$${dir}${MANSUBDIR}/$${name%.*}.0${MANSUFFIX}; \ 154 1.64 tv name=$$1; shift; \ 155 1.64 tv dir=${DESTDIR}${MANDIR}/cat$${name##*.}; \ 156 1.64 tv t=$${dir}${MANSUBDIR}/$${name%.*}.0${MANSUFFIX}; \ 157 1.55 itojun if test $$l -nt $$t -o ! -f $$t; then \ 158 1.55 itojun echo $$t -\> $$l; \ 159 1.79 perry ${INSTALL_LINK} ${SYSPKGDOCTAG} $$l $$t; \ 160 1.55 itojun fi; \ 161 1.20 cgd done 162 1.8 mycroft .endif 163 1.64 tv .endif # (${MKCATPAGES} != "no") && (${MKMAN} != "no") 164 1.56 phil 165 1.64 tv ##### Build and install rules (HTML pages) 166 1.56 phil 167 1.82 lukem .if ${MKHTML} != "no" # { 168 1.64 tv installhtml: htmlpages 169 1.64 tv htmlpages:: # ensure target exists 170 1.64 tv HTMLPAGES= ${MAN:C/\.([1-9])$/.html\1/} 171 1.64 tv 172 1.64 tv html: ${HTMLPAGES} 173 1.64 tv .NOPATH: ${HTMLPAGES} 174 1.64 tv .SUFFIXES: ${_MNUMBERS:@N@.html$N@} 175 1.64 tv 176 1.76 ross ${_MNUMBERS:@N@.$N.html$N@}: ${HTMLDEPS} # build rule 177 1.81 lukem ${TOOL_ROFF_HTML} ${.IMPSRC} > ${.TARGET}.tmp && \ 178 1.81 lukem mv ${.TARGET}.tmp ${.TARGET} 179 1.64 tv 180 1.64 tv .for F in ${HTMLPAGES:O:u} 181 1.77 ross # construct installed path 182 1.77 ross _F:= ${HTMLDIR}/${F:T:E}${MANSUBDIR}/${F:R:S-/index$-/x&-}.html 183 1.78 mycroft 184 1.78 mycroft .if !defined(UPDATE) 185 1.78 mycroft ${_F}! ${F} __installpage # install rule 186 1.78 mycroft .if !defined(BUILD) && !make(all) && !make(${F}) 187 1.78 mycroft ${_F}! .MADE # no build at install 188 1.78 mycroft .endif 189 1.78 mycroft .else 190 1.64 tv ${_F}: ${F} __installpage # install rule 191 1.64 tv .if !defined(BUILD) && !make(all) && !make(${F}) 192 1.64 tv ${_F}: .MADE # no build at install 193 1.64 tv .endif 194 1.78 mycroft .endif 195 1.78 mycroft 196 1.78 mycroft htmlpages:: ${_F} 197 1.78 mycroft .PRECIOUS: ${_F} # keep if install fails 198 1.56 phil .endfor 199 1.56 phil 200 1.56 phil cleanhtml: 201 1.56 phil rm -f ${HTMLPAGES} 202 1.82 lukem .endif # } 203 1.31 mycroft 204 1.64 tv ##### Clean rules 205 1.64 tv .undef _F 206 1.8 mycroft 207 1.64 tv cleandir: cleanman 208 1.8 mycroft cleanman: 209 1.64 tv .if !empty(MAN) && (${MKMAN} != "no") 210 1.64 tv .if (${MKCATPAGES} != "no") 211 1.25 christos rm -f ${CATPAGES} 212 1.1 cgd .endif 213 1.64 tv .if !empty(MANSUFFIX) 214 1.64 tv rm -f ${MANPAGES} ${CATPAGES:S/${MANSUFFIX}$//} 215 1.64 tv .endif 216 1.64 tv .endif 217 1.64 tv # (XXX ${CATPAGES:S...} cleans up old .catN files where .catN.gz now used) 218 1.64 tv 219 1.64 tv ##### Pull in related .mk logic 220 1.64 tv .include <bsd.obj.mk> 221 1.67 thorpej .include <bsd.sys.mk> 222 1.34 mycroft 223 1.64 tv ${TARGETS} catinstall maninstall: # ensure existence 224