1 1.97 lukem # $NetBSD: bsd.man.mk,v 1.97 2008/08/27 02:28:34 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.96 dbj .PHONY: catinstall maninstall catpages manpages catlinks manlinks 8 1.97 lukem .PHONY: htmlinstall htmlpages htmllinks 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.93 jmc TMACDEPDIR?= /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.90 lukem (${_MKSHMSG_INSTALL} ${.TARGET}; \ 49 1.87 lukem ${_MKSHECHO} "${INSTALL_FILE} -o ${MANOWN} -g ${MANGRP} -m ${MANMODE} \ 50 1.95 jwise ${.ALLSRC} ${.TARGET}" && \ 51 1.64 tv ${INSTALL_FILE} -o ${MANOWN} -g ${MANGRP} -m ${MANMODE} \ 52 1.95 jwise ${.ALLSRC} ${.TARGET}) 53 1.25 christos 54 1.96 dbj # XXX consider including bsd.links.mk and using __linkinstall instead 55 1.96 dbj __linkinstallpage: .USE 56 1.96 dbj ${_MKSHMSG_INSTALL} ${.TARGET}; \ 57 1.96 dbj ${_MKSHECHO} "${INSTALL_LINK} ${.ALLSRC} ${.TARGET}" && \ 58 1.96 dbj ${INSTALL_LINK} ${.ALLSRC} ${.TARGET} 59 1.96 dbj 60 1.64 tv ##### Build and install rules (source form pages) 61 1.25 christos 62 1.64 tv .if ${MKMAN} != "no" 63 1.96 dbj maninstall: manpages manlinks 64 1.64 tv manpages:: # ensure target exists 65 1.65 enami MANPAGES= ${MAN:C/.$/&${MANSUFFIX}/} 66 1.64 tv 67 1.72 tv realall: ${MANPAGES} 68 1.64 tv .if !empty(MANSUFFIX) 69 1.64 tv .NOPATH: ${MANPAGES} 70 1.64 tv .SUFFIXES: ${_MNUMBERS:@N@.$N${MANSUFFIX}@} 71 1.64 tv 72 1.64 tv ${_MNUMBERS:@N@.$N.$N${MANSUFFIX}@}: # build rule 73 1.97 lukem ${_MKTARGET_FORMAT} 74 1.73 mrg cat ${.IMPSRC} ${MANCOMPRESS} > ${.TARGET}.tmp && mv ${.TARGET}.tmp ${.TARGET} 75 1.64 tv .endif # !empty(MANSUFFIX) 76 1.64 tv 77 1.64 tv .for F in ${MANPAGES:S/${MANSUFFIX}$//:O:u} 78 1.64 tv _F:= ${DESTDIR}${MANDIR}/man${F:T:E}${MANSUBDIR}/${F}${MANSUFFIX} 79 1.64 tv 80 1.83 lukem .if ${MKUPDATE} == "no" 81 1.78 mycroft ${_F}! ${F}${MANSUFFIX} __installpage # install rule 82 1.78 mycroft .if !defined(BUILD) && !make(all) && !make(${F}) 83 1.78 mycroft ${_F}! .MADE # no build at install 84 1.78 mycroft .endif 85 1.78 mycroft .else 86 1.64 tv ${_F}: ${F}${MANSUFFIX} __installpage # install rule 87 1.64 tv .if !defined(BUILD) && !make(all) && !make(${F}) 88 1.64 tv ${_F}: .MADE # no build at install 89 1.53 mycroft .endif 90 1.78 mycroft .endif 91 1.78 mycroft 92 1.78 mycroft manpages:: ${_F} 93 1.78 mycroft .PRECIOUS: ${_F} # keep if install fails 94 1.64 tv .endfor 95 1.52 mycroft 96 1.96 dbj manlinks:: # link install 97 1.96 dbj 98 1.96 dbj .for _src _dst in ${MLINKS} 99 1.96 dbj _l:=${DESTDIR}${MANDIR}/man${_src:T:E}${MANSUBDIR}/${_src}${MANSUFFIX} 100 1.96 dbj _t:=${DESTDIR}${MANDIR}/man${_dst:T:E}${MANSUBDIR}/${_dst}${MANSUFFIX} 101 1.96 dbj 102 1.96 dbj # Handle case conflicts carefully, when _dst occurs 103 1.96 dbj # more than once after case flattening 104 1.96 dbj .if ${MKUPDATE} == "no" || ${MLINKS:tl:M${_dst:tl:Q}:[\#]} > 1 105 1.96 dbj ${_t}! ${_l} __linkinstallpage 106 1.96 dbj .else 107 1.96 dbj ${_t}: ${_l} __linkinstallpage 108 1.19 brezak .endif 109 1.96 dbj 110 1.96 dbj manlinks:: ${_t} 111 1.96 dbj .PRECIOUS: ${_t} 112 1.96 dbj .endfor 113 1.64 tv .endif # ${MKMAN} != "no" 114 1.64 tv 115 1.64 tv ##### Build and install rules (plaintext pages) 116 1.64 tv 117 1.64 tv .if (${MKCATPAGES} != "no") && (${MKMAN} != "no") 118 1.96 dbj catinstall: catpages catlinks 119 1.64 tv catpages:: # ensure target exists 120 1.64 tv CATPAGES= ${MAN:C/\.([1-9])$/.cat\1${MANSUFFIX}/} 121 1.64 tv 122 1.64 tv realall: ${CATPAGES} 123 1.64 tv .NOPATH: ${CATPAGES} 124 1.64 tv .SUFFIXES: ${_MNUMBERS:@N@.cat$N${MANSUFFIX}@} 125 1.75 christos .MADE: ${CATDEPS} 126 1.64 tv 127 1.64 tv ${_MNUMBERS:@N@.$N.cat$N${MANSUFFIX}@}: ${CATDEPS} # build rule 128 1.88 lukem ${_MKTARGET_FORMAT} 129 1.64 tv .if defined(USETBL) 130 1.81 lukem ${TOOL_TBL} ${.IMPSRC} | ${TOOL_ROFF_ASCII} -mandoc ${MANCOMPRESS} \ 131 1.81 lukem > ${.TARGET}.tmp && mv ${.TARGET}.tmp ${.TARGET} 132 1.64 tv .else 133 1.81 lukem ${TOOL_ROFF_ASCII} -mandoc ${.IMPSRC} ${MANCOMPRESS} \ 134 1.81 lukem > ${.TARGET}.tmp && mv ${.TARGET}.tmp ${.TARGET} 135 1.64 tv .endif 136 1.64 tv 137 1.64 tv .for F in ${CATPAGES:S/${MANSUFFIX}$//:O:u} 138 1.64 tv _F:= ${DESTDIR}${MANDIR}/${F:T:E}${MANSUBDIR}/${F:R}.0${MANSUFFIX} 139 1.78 mycroft 140 1.83 lukem .if ${MKUPDATE} == "no" 141 1.78 mycroft ${_F}! ${F}${MANSUFFIX} __installpage # install rule 142 1.78 mycroft .if !defined(BUILD) && !make(all) && !make(${F}) 143 1.78 mycroft ${_F}! .MADE # no build at install 144 1.78 mycroft .endif 145 1.78 mycroft .else 146 1.64 tv ${_F}: ${F}${MANSUFFIX} __installpage # install rule 147 1.64 tv .if !defined(BUILD) && !make(all) && !make(${F}) 148 1.64 tv ${_F}: .MADE # no build at install 149 1.43 lukem .endif 150 1.78 mycroft .endif 151 1.78 mycroft 152 1.78 mycroft catpages:: ${_F} 153 1.78 mycroft .PRECIOUS: ${_F} # keep if install fails 154 1.64 tv .endfor 155 1.25 christos 156 1.96 dbj catlinks:: # link install 157 1.96 dbj 158 1.96 dbj .for _src _dst in ${MLINKS} 159 1.96 dbj _l:=${DESTDIR}${MANDIR}/cat${_src:T:E}${MANSUBDIR}/${_src:R}.0${MANSUFFIX} 160 1.96 dbj _t:=${DESTDIR}${MANDIR}/cat${_dst:T:E}${MANSUBDIR}/${_dst:R}.0${MANSUFFIX} 161 1.96 dbj 162 1.96 dbj # Handle case conflicts carefully, when _dst occurs 163 1.96 dbj # more than once after case flattening 164 1.96 dbj .if ${MKUPDATE} == "no" || ${MLINKS:tl:M${_dst:tl:Q}:[\#]} > 1 165 1.96 dbj ${_t}! ${_l} __linkinstallpage 166 1.96 dbj .else 167 1.96 dbj ${_t}: ${_l} __linkinstallpage 168 1.8 mycroft .endif 169 1.96 dbj 170 1.96 dbj catlinks:: ${_t} 171 1.96 dbj .PRECIOUS: ${_t} 172 1.96 dbj .endfor 173 1.64 tv .endif # (${MKCATPAGES} != "no") && (${MKMAN} != "no") 174 1.56 phil 175 1.64 tv ##### Build and install rules (HTML pages) 176 1.56 phil 177 1.97 lukem .if (${MKHTML} != "no") && (${MKMAN} != "no") # { 178 1.97 lukem htmlinstall: htmlpages htmllinks 179 1.64 tv htmlpages:: # ensure target exists 180 1.64 tv HTMLPAGES= ${MAN:C/\.([1-9])$/.html\1/} 181 1.64 tv 182 1.97 lukem realall: ${HTMLPAGES} 183 1.64 tv .NOPATH: ${HTMLPAGES} 184 1.64 tv .SUFFIXES: ${_MNUMBERS:@N@.html$N@} 185 1.97 lukem .MADE: ${HTMLDEPS} 186 1.64 tv 187 1.76 ross ${_MNUMBERS:@N@.$N.html$N@}: ${HTMLDEPS} # build rule 188 1.88 lukem ${_MKTARGET_FORMAT} 189 1.81 lukem ${TOOL_ROFF_HTML} ${.IMPSRC} > ${.TARGET}.tmp && \ 190 1.81 lukem mv ${.TARGET}.tmp ${.TARGET} 191 1.64 tv 192 1.64 tv .for F in ${HTMLPAGES:O:u} 193 1.77 ross # construct installed path 194 1.77 ross _F:= ${HTMLDIR}/${F:T:E}${MANSUBDIR}/${F:R:S-/index$-/x&-}.html 195 1.78 mycroft 196 1.83 lukem .if ${MKUPDATE} == "no" 197 1.78 mycroft ${_F}! ${F} __installpage # install rule 198 1.78 mycroft .if !defined(BUILD) && !make(all) && !make(${F}) 199 1.78 mycroft ${_F}! .MADE # no build at install 200 1.78 mycroft .endif 201 1.78 mycroft .else 202 1.64 tv ${_F}: ${F} __installpage # install rule 203 1.64 tv .if !defined(BUILD) && !make(all) && !make(${F}) 204 1.64 tv ${_F}: .MADE # no build at install 205 1.64 tv .endif 206 1.78 mycroft .endif 207 1.78 mycroft 208 1.78 mycroft htmlpages:: ${_F} 209 1.78 mycroft .PRECIOUS: ${_F} # keep if install fails 210 1.56 phil .endfor 211 1.56 phil 212 1.97 lukem htmllinks:: # link install 213 1.97 lukem 214 1.97 lukem .for _src _dst in ${MLINKS} 215 1.97 lukem _l:=${HTMLDIR}/html${_src:T:E}${MANSUBDIR}/${_src:R:S-/index$-/x&-}.html 216 1.97 lukem _t:=${HTMLDIR}/html${_dst:T:E}${MANSUBDIR}/${_dst:R:S-/index$-/x&-}.html 217 1.97 lukem 218 1.97 lukem # Handle case conflicts carefully, when _dst occurs 219 1.97 lukem # more than once after case flattening 220 1.97 lukem .if ${MKUPDATE} == "no" || ${MLINKS:tl:M${_dst:tl:Q}:[\#]} > 1 221 1.97 lukem ${_t}! ${_l} __linkinstallpage 222 1.97 lukem .else 223 1.97 lukem ${_t}: ${_l} __linkinstallpage 224 1.97 lukem .endif 225 1.97 lukem 226 1.97 lukem htmllinks:: ${_t} 227 1.97 lukem .PRECIOUS: ${_t} 228 1.97 lukem .endfor 229 1.97 lukem 230 1.82 lukem .endif # } 231 1.31 mycroft 232 1.64 tv ##### Clean rules 233 1.64 tv .undef _F 234 1.8 mycroft 235 1.64 tv cleandir: cleanman 236 1.94 tron .if !empty(CLEANFILES) 237 1.94 tron rm -f ${CLEANFILES} 238 1.94 tron .endif 239 1.94 tron 240 1.91 lukem cleanman: .PHONY 241 1.64 tv .if !empty(MAN) && (${MKMAN} != "no") 242 1.64 tv .if (${MKCATPAGES} != "no") 243 1.25 christos rm -f ${CATPAGES} 244 1.1 cgd .endif 245 1.64 tv .if !empty(MANSUFFIX) 246 1.64 tv rm -f ${MANPAGES} ${CATPAGES:S/${MANSUFFIX}$//} 247 1.64 tv .endif 248 1.97 lukem .if ${MKHTML} != "no" 249 1.97 lukem rm -f ${HTMLPAGES} 250 1.97 lukem .endif 251 1.64 tv .endif 252 1.64 tv # (XXX ${CATPAGES:S...} cleans up old .catN files where .catN.gz now used) 253 1.64 tv 254 1.64 tv ##### Pull in related .mk logic 255 1.64 tv .include <bsd.obj.mk> 256 1.84 lukem .include <bsd.files.mk> 257 1.67 thorpej .include <bsd.sys.mk> 258 1.34 mycroft 259 1.97 lukem ${TARGETS} catinstall maninstall htmlinstall: # ensure existence 260