1*3bebe729SSimon J. Gerraty# $Id: meta.autodep.mk,v 1.41 2016/03/11 01:29:38 sjg Exp $ 23cbdda60SSimon J. Gerraty 33cbdda60SSimon J. Gerraty# 43cbdda60SSimon J. Gerraty# @(#) Copyright (c) 2010, Simon J. Gerraty 53cbdda60SSimon J. Gerraty# 63cbdda60SSimon J. Gerraty# This file is provided in the hope that it will 73cbdda60SSimon J. Gerraty# be of use. There is absolutely NO WARRANTY. 83cbdda60SSimon J. Gerraty# Permission to copy, redistribute or otherwise 93cbdda60SSimon J. Gerraty# use this file is hereby granted provided that 103cbdda60SSimon J. Gerraty# the above copyright notice and this notice are 113cbdda60SSimon J. Gerraty# left intact. 123cbdda60SSimon J. Gerraty# 133cbdda60SSimon J. Gerraty# Please send copies of changes and bug-fixes to: 143cbdda60SSimon J. Gerraty# sjg@crufty.net 153cbdda60SSimon J. Gerraty# 163cbdda60SSimon J. Gerraty 173cbdda60SSimon J. Gerraty_this ?= ${.PARSEFILE} 183cbdda60SSimon J. Gerraty.if !target(__${_this}__) 193cbdda60SSimon J. Gerraty__${_this}__: .NOTMAIN 203cbdda60SSimon J. Gerraty 213cbdda60SSimon J. Gerraty.-include "local.autodep.mk" 223cbdda60SSimon J. Gerraty 233cbdda60SSimon J. Gerraty.if defined(SRCS) 243cbdda60SSimon J. Gerraty# it would be nice to be able to query .SUFFIXES 253cbdda60SSimon J. GerratyOBJ_EXTENSIONS+= .o .po .lo .So 263cbdda60SSimon J. Gerraty 273cbdda60SSimon J. Gerraty# explicit dependencies help short-circuit .SUFFIX searches 283cbdda60SSimon J. GerratySRCS_DEP_FILTER+= N*.[hly] 293cbdda60SSimon J. Gerraty.for s in ${SRCS:${SRCS_DEP_FILTER:O:u:ts:}} 303cbdda60SSimon J. Gerraty.for e in ${OBJ_EXTENSIONS:O:u} 313cbdda60SSimon J. Gerraty.if !target(${s:T:R}$e) 323cbdda60SSimon J. Gerraty${s:T:R}$e: $s 333cbdda60SSimon J. Gerraty.endif 343cbdda60SSimon J. Gerraty.endfor 353cbdda60SSimon J. Gerraty.endfor 363cbdda60SSimon J. Gerraty.endif 373cbdda60SSimon J. Gerraty 383cbdda60SSimon J. Gerraty.if make(gendirdeps) 393cbdda60SSimon J. Gerraty# you are supposed to know what you are doing! 403cbdda60SSimon J. GerratyUPDATE_DEPENDFILE = yes 413cbdda60SSimon J. Gerraty.elif !empty(.TARGETS) && !make(all) 423cbdda60SSimon J. Gerraty# do not update the *depend* files 433cbdda60SSimon J. Gerraty# unless we are building the entire directory or the default target. 443cbdda60SSimon J. Gerraty# NO means don't update .depend - or Makefile.depend* 453cbdda60SSimon J. Gerraty# no means update .depend but not Makefile.depend* 463cbdda60SSimon J. GerratyUPDATE_DEPENDFILE = NO 473cbdda60SSimon J. Gerraty.elif ${.MAKEFLAGS:M-k} != "" 483cbdda60SSimon J. Gerraty# it is a bad idea to update anything 493cbdda60SSimon J. GerratyUPDATE_DEPENDFILE = NO 503cbdda60SSimon J. Gerraty.endif 513cbdda60SSimon J. Gerraty 523cbdda60SSimon J. Gerraty_CURDIR ?= ${.CURDIR} 53ac3446e9SSimon J. Gerraty_OBJDIR ?= ${.OBJDIR} 54ac3446e9SSimon J. Gerraty_OBJTOP ?= ${OBJTOP} 55ac3446e9SSimon J. Gerraty_OBJROOT ?= ${OBJROOT:U${_OBJTOP}} 563cbdda60SSimon J. Gerraty_DEPENDFILE := ${_CURDIR}/${.MAKE.DEPENDFILE:T} 573cbdda60SSimon J. Gerraty 583cbdda60SSimon J. Gerraty.if ${.MAKE.LEVEL} == 0 593cbdda60SSimon J. Gerraty.if ${BUILD_AT_LEVEL0:Uyes:tl} == "no" 603cbdda60SSimon J. GerratyUPDATE_DEPENDFILE = NO 613cbdda60SSimon J. Gerraty.endif 623cbdda60SSimon J. Gerraty.endif 633cbdda60SSimon J. Gerraty.if !exists(${_DEPENDFILE}) 643cbdda60SSimon J. Gerraty_bootstrap_dirdeps = yes 653cbdda60SSimon J. Gerraty.endif 663cbdda60SSimon J. Gerraty_bootstrap_dirdeps ?= no 673cbdda60SSimon J. GerratyUPDATE_DEPENDFILE ?= yes 683cbdda60SSimon J. Gerraty 693cbdda60SSimon J. Gerraty.if ${DEBUG_AUTODEP:Uno:@m@${RELDIR:M$m}@} != "" 703cbdda60SSimon J. Gerraty.info ${_DEPENDFILE:S,${SRCTOP}/,,} update=${UPDATE_DEPENDFILE} 713cbdda60SSimon J. Gerraty.endif 723cbdda60SSimon J. Gerraty 733cbdda60SSimon J. Gerraty.if !empty(XMAKE_META_FILE) 743cbdda60SSimon J. Gerraty.if exists(${.OBJDIR}/${XMAKE_META_FILE}) 753cbdda60SSimon J. Gerraty# we cannot get accurate dependencies from an update build 763cbdda60SSimon J. GerratyUPDATE_DEPENDFILE = NO 773cbdda60SSimon J. Gerraty.else 783cbdda60SSimon J. GerratyMETA_XTRAS += ${XMAKE_META_FILE} 793cbdda60SSimon J. Gerraty.endif 803cbdda60SSimon J. Gerraty.endif 813cbdda60SSimon J. Gerraty 823cbdda60SSimon J. Gerraty.if ${_bootstrap_dirdeps} == "yes" || exists(${_DEPENDFILE}) 833cbdda60SSimon J. Gerraty# if it isn't supposed to be touched by us the Makefile should have 843cbdda60SSimon J. Gerraty# UPDATE_DEPENDFILE = no 853cbdda60SSimon J. GerratyWANT_UPDATE_DEPENDFILE ?= yes 863cbdda60SSimon J. Gerraty.endif 873cbdda60SSimon J. Gerraty 883cbdda60SSimon J. Gerraty.if ${WANT_UPDATE_DEPENDFILE:Uno:tl} != "no" 89be19d90bSSimon J. Gerraty.if ${.MAKE.MODE:Uno:Mmeta*} == "" || ${.MAKE.MODE:Uno:M*read*} != "" 903cbdda60SSimon J. GerratyUPDATE_DEPENDFILE = no 913cbdda60SSimon J. Gerraty.endif 923cbdda60SSimon J. Gerraty 933cbdda60SSimon J. Gerraty.if ${DEBUG_AUTODEP:Uno:@m@${RELDIR:M$m}@} != "" 943cbdda60SSimon J. Gerraty.info ${_DEPENDFILE:S,${SRCTOP}/,,} update=${UPDATE_DEPENDFILE} 953cbdda60SSimon J. Gerraty.endif 963cbdda60SSimon J. Gerraty 973cbdda60SSimon J. Gerraty.if ${UPDATE_DEPENDFILE:tl} == "yes" 983cbdda60SSimon J. Gerraty# sometimes we want .meta files generated to aid debugging/error detection 993cbdda60SSimon J. Gerraty# but do not want to consider them for dependencies 1003cbdda60SSimon J. Gerraty# for example the result of running configure 1013cbdda60SSimon J. Gerraty# just make sure this is not empty 1023cbdda60SSimon J. GerratyMETA_FILE_FILTER ?= N.meta 1034c620fe5SSimon J. Gerraty# never consider these 1044c620fe5SSimon J. GerratyMETA_FILE_FILTER += Ndirdeps.cache* 1053cbdda60SSimon J. Gerraty 1063cbdda60SSimon J. Gerraty.if !empty(DPADD) 1073cbdda60SSimon J. Gerraty# if we have any non-libs in DPADD, 1083cbdda60SSimon J. Gerraty# they probably need to be paid attention to 1093cbdda60SSimon J. Gerraty.if !empty(DPLIBS) 1103cbdda60SSimon J. GerratyFORCE_DPADD = ${DPADD:${DPLIBS:${M_ListToSkip}}:${DPADD_LAST:${M_ListToSkip}}} 1113cbdda60SSimon J. Gerraty.else 1123cbdda60SSimon J. Gerraty_nonlibs := ${DPADD:T:Nlib*:N*include} 1133cbdda60SSimon J. Gerraty.if !empty(_nonlibs) 1143cbdda60SSimon J. GerratyFORCE_DPADD += ${_nonlibs:@x@${DPADD:M*/$x}@} 1153cbdda60SSimon J. Gerraty.endif 1163cbdda60SSimon J. Gerraty.endif 1173cbdda60SSimon J. Gerraty.endif 1183cbdda60SSimon J. Gerraty 1193cbdda60SSimon J. Gerraty.if !make(gendirdeps) 1203cbdda60SSimon J. Gerraty.END: gendirdeps 1213cbdda60SSimon J. Gerraty.endif 1223cbdda60SSimon J. Gerraty 1233cbdda60SSimon J. Gerraty# if we don't have OBJS, then .depend isn't useful 1243cbdda60SSimon J. Gerraty.if !target(.depend) && (!empty(OBJS) || ${.ALLTARGETS:M*.o} != "") 1253cbdda60SSimon J. Gerraty# some makefiles and/or targets contain 1263cbdda60SSimon J. Gerraty# circular dependencies if you dig too deep 1273cbdda60SSimon J. Gerraty# (as meta mode is apt to do) 1285bcb7424SSimon J. Gerraty# so we provide a means of suppressing them. 1293cbdda60SSimon J. Gerraty# the input to the loop below is target: dependency 1303cbdda60SSimon J. Gerraty# with just one dependency per line. 1313cbdda60SSimon J. Gerraty# Also some targets are not really local, or use random names. 1323cbdda60SSimon J. Gerraty# Use local.autodep.mk to provide local additions! 1333cbdda60SSimon J. GerratySUPPRESS_DEPEND += \ 1343cbdda60SSimon J. Gerraty ${SB:S,/,_,g}* \ 1353cbdda60SSimon J. Gerraty *:y.tab.c \ 1363cbdda60SSimon J. Gerraty *.c:*.c \ 1373cbdda60SSimon J. Gerraty *.h:*.h 1383cbdda60SSimon J. Gerraty 1393cbdda60SSimon J. Gerraty.NOPATH: .depend 1403cbdda60SSimon J. Gerraty# we use ${.MAKE.META.CREATED} to trigger an update but 1413cbdda60SSimon J. Gerraty# we process using ${.MAKE.META.FILES} 1423cbdda60SSimon J. Gerraty# the double $$ defers initial evaluation 1433cbdda60SSimon J. Gerraty# if necessary, we fake .po dependencies, just so the result 1443cbdda60SSimon J. Gerraty# in Makefile.depend* is stable 1455bcb7424SSimon J. Gerraty# The current objdir may be referred to in various ways 1463cbdda60SSimon J. GerratyOBJDIR_REFS += ${.OBJDIR} ${.OBJDIR:tA} ${_OBJDIR} ${RELOBJTOP}/${RELDIR} 1473cbdda60SSimon J. Gerraty_depend = .depend 1483cbdda60SSimon J. Gerraty# it would be nice to be able to get .SUFFIXES as ${.SUFFIXES} 1493cbdda60SSimon J. Gerraty# we actually only care about the .SUFFIXES of files that might be 1503cbdda60SSimon J. Gerraty# generated by tools like yacc. 1513cbdda60SSimon J. GerratyDEPEND_SUFFIXES += .c .h .cpp .hpp .cxx .hxx .cc .hh 1523cbdda60SSimon J. Gerraty.depend: .NOMETA $${.MAKE.META.CREATED} ${_this} 1533cbdda60SSimon J. Gerraty @echo "Updating $@: ${.OODATE:T:[1..8]}" 1543cbdda60SSimon J. Gerraty @egrep -i '^R .*\.(${DEPEND_SUFFIXES:tl:O:u:S,^.,,:ts|})$$' /dev/null ${.MAKE.META.FILES:T:O:u:${META_FILE_FILTER:ts:}:M*o.meta} | \ 1553cbdda60SSimon J. Gerraty sed -e 's, \./, ,${OBJDIR_REFS:O:u:@d@;s, $d/, ,@};/\//d' \ 1563cbdda60SSimon J. Gerraty -e 's,^\([^/][^/]*\).meta...[0-9]* ,\1: ,' | \ 1573cbdda60SSimon J. Gerraty sort -u | \ 1583cbdda60SSimon J. Gerraty while read t d; do \ 1593cbdda60SSimon J. Gerraty case "$$d:" in $$t) continue;; esac; \ 1603cbdda60SSimon J. Gerraty case "$$t$$d" in ${SUPPRESS_DEPEND:U.:O:u:ts|}) continue;; esac; \ 1613cbdda60SSimon J. Gerraty echo $$t $$d; \ 1623cbdda60SSimon J. Gerraty done > $@.${.MAKE.PID} 1633cbdda60SSimon J. Gerraty @case "${.MAKE.META.FILES:T:M*.po.*}" in \ 1643cbdda60SSimon J. Gerraty *.po.*) mv $@.${.MAKE.PID} $@;; \ 1653cbdda60SSimon J. Gerraty *) { cat $@.${.MAKE.PID}; \ 1663cbdda60SSimon J. Gerraty sed 's,\.So:,.o:,;s,\.o:,.po:,' $@.${.MAKE.PID}; } | sort -u > $@; \ 1673cbdda60SSimon J. Gerraty rm -f $@.${.MAKE.PID};; \ 1683cbdda60SSimon J. Gerraty esac 1693cbdda60SSimon J. Gerraty.else 1703cbdda60SSimon J. Gerraty# make sure this exists 1713cbdda60SSimon J. Gerraty.depend: 1723cbdda60SSimon J. Gerraty# do _not_ assume that .depend is in any fit state for us to use 1733cbdda60SSimon J. GerratyCAT_DEPEND = /dev/null 1743cbdda60SSimon J. Gerraty.if ${.MAKE.LEVEL} > 0 1753cbdda60SSimon J. Gerraty.export CAT_DEPEND 1763cbdda60SSimon J. Gerraty.endif 1773cbdda60SSimon J. Gerraty_depend = 1783cbdda60SSimon J. Gerraty.endif 1793cbdda60SSimon J. Gerraty 1803cbdda60SSimon J. Gerraty.if ${DEBUG_AUTODEP:Uno:@m@${RELDIR:M$m}@} != "" 1813cbdda60SSimon J. Gerraty.info ${_DEPENDFILE:S,${SRCTOP}/,,} _depend=${_depend} 1823cbdda60SSimon J. Gerraty.endif 1833cbdda60SSimon J. Gerraty 1845bcb7424SSimon J. Gerraty.if ${UPDATE_DEPENDFILE} == "yes" 1853cbdda60SSimon J. Gerratygendirdeps: ${_DEPENDFILE} 1865bcb7424SSimon J. Gerraty.endif 1873cbdda60SSimon J. Gerraty 1883cbdda60SSimon J. Gerraty.if !target(${_DEPENDFILE}) 1893cbdda60SSimon J. Gerraty.if ${_bootstrap_dirdeps} == "yes" 1903cbdda60SSimon J. Gerraty# We are boot-strapping a new directory 1913cbdda60SSimon J. Gerraty# Use DPADD to seed DIRDEPS 1923cbdda60SSimon J. Gerraty.if !empty(DPADD) 1933cbdda60SSimon J. Gerraty# anything which matches ${_OBJROOT}* but not ${_OBJTOP}* 1943cbdda60SSimon J. Gerraty# needs to be qualified in DIRDEPS 1953cbdda60SSimon J. Gerraty# The pseudo machine "host" is used for HOST_TARGET 196ac3446e9SSimon J. GerratyDIRDEPS += \ 1973cbdda60SSimon J. Gerraty ${DPADD:M${_OBJTOP}*:H:C,${_OBJTOP}[^/]*/,,:N.:O:u} \ 198*3bebe729SSimon J. Gerraty ${DPADD:M${_OBJROOT}*:N${_OBJTOP}*:N${STAGE_ROOT:U${_OBJTOP}}/*:H:S,${_OBJROOT},,:C,^([^/]+)/(.*),\2.\1,:S,${HOST_TARGET}$,host,:N.*:O:u} 1993cbdda60SSimon J. Gerraty 2003cbdda60SSimon J. Gerraty.endif 2013cbdda60SSimon J. Gerraty.endif 2023cbdda60SSimon J. Gerraty 2033cbdda60SSimon J. Gerraty_gendirdeps_mutex = 2043cbdda60SSimon J. Gerraty.if defined(NEED_GENDIRDEPS_MUTEX) 2053cbdda60SSimon J. Gerraty# If a src dir gets built with multiple object dirs, 2063cbdda60SSimon J. Gerraty# we need a mutex. Obviously, this is best avoided. 2073cbdda60SSimon J. Gerraty# Note if .MAKE.DEPENDFILE is common for all ${MACHINE} 2083cbdda60SSimon J. Gerraty# you either need to mutex, or ensure only one machine builds at a time! 2093cbdda60SSimon J. Gerraty# lockf is an example of a suitable tool 2103cbdda60SSimon J. GerratyLOCKF ?= /usr/bin/lockf 2113cbdda60SSimon J. Gerraty.if exists(${LOCKF}) 2123cbdda60SSimon J. GerratyGENDIRDEPS_MUTEXER ?= ${LOCKF} -k 2133cbdda60SSimon J. Gerraty.endif 2143cbdda60SSimon J. Gerraty.if empty(GENDIRDEPS_MUTEXER) 2153cbdda60SSimon J. Gerraty.error NEED_GENDIRDEPS_MUTEX defined, but GENDIRDEPS_MUTEXER not set 2163cbdda60SSimon J. Gerraty.else 2173cbdda60SSimon J. Gerraty_gendirdeps_mutex = ${GENDIRDEPS_MUTEXER} ${GENDIRDEPS_MUTEX:U${_CURDIR}/Makefile} 2183cbdda60SSimon J. Gerraty.endif 2193cbdda60SSimon J. Gerraty.endif 2203cbdda60SSimon J. Gerraty 2213cbdda60SSimon J. Gerraty# If we have META_XTRAS we most likely did not create them 2223cbdda60SSimon J. Gerraty# but we need to behave as if we did. 2233cbdda60SSimon J. Gerraty# Avoid adding glob patterns to .MAKE.META.CREATED though. 2243cbdda60SSimon J. Gerraty.MAKE.META.CREATED += ${META_XTRAS:N*\**:O:u} 2253cbdda60SSimon J. Gerraty 2263cbdda60SSimon J. Gerraty.if make(gendirdeps) 2273cbdda60SSimon J. GerratyMETA_FILES = *.meta 2283cbdda60SSimon J. Gerraty.elif ${OPTIMIZE_OBJECT_META_FILES:Uno:tl} == "no" 2293cbdda60SSimon J. GerratyMETA_FILES = ${.MAKE.META.FILES:T:N.depend*:O:u} 2303cbdda60SSimon J. Gerraty.else 2313cbdda60SSimon J. Gerraty# if we have 1000's of .o.meta, .So.meta etc we need only look at one set 2323cbdda60SSimon J. Gerraty# it is left as an exercise for the reader to work out what this does 2333cbdda60SSimon J. GerratyMETA_FILES = ${.MAKE.META.FILES:T:N.depend*:N*o.meta:O:u} \ 2343cbdda60SSimon J. Gerraty ${.MAKE.META.FILES:T:M*.${.MAKE.META.FILES:M*o.meta:R:E:O:u:[1]}.meta:O:u} 2353cbdda60SSimon J. Gerraty.endif 2363cbdda60SSimon J. Gerraty 2373cbdda60SSimon J. Gerraty.if ${DEBUG_AUTODEP:Uno:@m@${RELDIR:M$m}@} != "" 2383cbdda60SSimon J. Gerraty.info ${_DEPENDFILE:S,${SRCTOP}/,,}: ${_depend} ${.PARSEDIR}/gendirdeps.mk ${META2DEPS} xtras=${META_XTRAS} 2393cbdda60SSimon J. Gerraty.endif 2403cbdda60SSimon J. Gerraty 2413cbdda60SSimon J. Gerraty.if ${.MAKE.LEVEL} > 0 && !empty(GENDIRDEPS_FILTER) 2423cbdda60SSimon J. Gerraty.export GENDIRDEPS_FILTER 2433cbdda60SSimon J. Gerraty.endif 2443cbdda60SSimon J. Gerraty 2453cbdda60SSimon J. Gerraty# we might have .../ in MAKESYSPATH 2463cbdda60SSimon J. Gerraty_makesyspath:= ${_PARSEDIR} 2473cbdda60SSimon J. Gerraty${_DEPENDFILE}: ${_depend} ${.PARSEDIR}/gendirdeps.mk ${META2DEPS} $${.MAKE.META.CREATED} 2483cbdda60SSimon J. Gerraty @echo Checking $@: ${.OODATE:T:[1..8]} 2493cbdda60SSimon J. Gerraty @(cd . && \ 2503cbdda60SSimon J. Gerraty SKIP_GENDIRDEPS='${SKIP_GENDIRDEPS:O:u}' \ 2513cbdda60SSimon J. Gerraty DPADD='${FORCE_DPADD:O:u}' ${_gendirdeps_mutex} \ 2523cbdda60SSimon J. Gerraty MAKESYSPATH=${_makesyspath} \ 2533cbdda60SSimon J. Gerraty ${.MAKE} -f gendirdeps.mk RELDIR=${RELDIR} _DEPENDFILE=${_DEPENDFILE} \ 2543cbdda60SSimon J. Gerraty META_FILES='${META_XTRAS:T:O:u} ${META_FILES:T:O:u:${META_FILE_FILTER:ts:}}') 2553cbdda60SSimon J. Gerraty @test -s $@ && touch $@; : 2563cbdda60SSimon J. Gerraty.endif 2573cbdda60SSimon J. Gerraty 2583cbdda60SSimon J. Gerraty.endif 2593cbdda60SSimon J. Gerraty.endif 2603cbdda60SSimon J. Gerraty 2613cbdda60SSimon J. Gerraty.if ${_bootstrap_dirdeps} == "yes" 262db29cad8SSimon J. Gerraty.if ${BUILD_AT_LEVEL0:Uno} == "no" 263db29cad8SSimon J. GerratyDIRDEPS+= ${RELDIR}.${TARGET_SPEC:U${MACHINE}} 264db29cad8SSimon J. Gerraty.endif 2653cbdda60SSimon J. Gerraty# make sure this is included at least once 2663cbdda60SSimon J. Gerraty.include <dirdeps.mk> 2673cbdda60SSimon J. Gerraty.else 2683cbdda60SSimon J. Gerraty${_DEPENDFILE}: .PRECIOUS 2693cbdda60SSimon J. Gerraty.endif 2703cbdda60SSimon J. Gerraty 2713cbdda60SSimon J. GerratyCLEANFILES += *.meta filemon.* *.db 2725bcb7424SSimon J. Gerraty 2735bcb7424SSimon J. Gerraty# these make it easy to gather some stats 2745bcb7424SSimon J. Gerratynow_utc = ${%s:L:gmtime} 2755bcb7424SSimon J. Gerratystart_utc := ${now_utc} 2765bcb7424SSimon J. Gerraty 2775bcb7424SSimon J. Gerratymeta_stats= meta=${empty(.MAKE.META.FILES):?0:${.MAKE.META.FILES:[#]}} \ 2785bcb7424SSimon J. Gerraty created=${empty(.MAKE.META.CREATED):?0:${.MAKE.META.CREATED:[#]}} 2795bcb7424SSimon J. Gerraty 2805bcb7424SSimon J. Gerraty#.END: _reldir_finish 2815bcb7424SSimon J. Gerraty.if target(gendirdeps) 2825bcb7424SSimon J. Gerraty_reldir_finish: gendirdeps 2835bcb7424SSimon J. Gerraty.endif 2845bcb7424SSimon J. Gerraty_reldir_finish: .NOMETA 2855bcb7424SSimon J. Gerraty @echo "${TIME_STAMP} Finished ${RELDIR}.${TARGET_SPEC} seconds=$$(( ${now_utc} - ${start_utc} )) ${meta_stats}" 2865bcb7424SSimon J. Gerraty 2875bcb7424SSimon J. Gerraty#.ERROR: _reldir_failed 2885bcb7424SSimon J. Gerraty_reldir_failed: .NOMETA 2895bcb7424SSimon J. Gerraty @echo "${TIME_STAMP} Failed ${RELDIR}.${TARGET_SPEC} seconds=$$(( ${now_utc} - ${start_utc} )) ${meta_stats}" 2905bcb7424SSimon J. Gerraty 2915bcb7424SSimon J. Gerraty.if defined(WITH_META_STATS) && ${.MAKE.LEVEL} > 0 2925bcb7424SSimon J. Gerraty.END: _reldir_finish 2935bcb7424SSimon J. Gerraty.ERROR: _reldir_failed 2945bcb7424SSimon J. Gerraty.endif 2955bcb7424SSimon J. Gerraty 2963cbdda60SSimon J. Gerraty.endif 297