Makefile revision 1.76
1# $NetBSD: Makefile,v 1.76 2020/07/29 20:57:31 rillig Exp $ 2# @(#)Makefile 5.2 (Berkeley) 12/28/90 3 4PROG= make 5SRCS= arch.c buf.c compat.c cond.c dir.c for.c hash.c job.c lst.c main.c 6SRCS+= make.c make_malloc.c metachar.c parse.c 7SRCS+= str.c strlist.c suff.c targ.c trace.c var.c util.c 8 9USE_COVERAGE?= no # works only with gcc; clang9 fails to link 10.if ${USE_COVERAGE} == "yes" 11COPTS= --coverage -O0 -ggdb 12LDADD= --coverage 13CLEANFILES+= ${SRCS:.c=.gcda} ${SRCS:.c=.gcno} ${SRCS:=.gcov} 14.endif 15 16USE_META?= yes 17.if ${USE_META:tl} != "no" 18 19SRCS+= meta.c 20CPPFLAGS+= -DUSE_META 21 22USE_FILEMON?= ktrace 23. if ${USE_FILEMON:tl} != "no" 24 25.PATH: ${.CURDIR}/filemon 26SRCS+= filemon_${USE_FILEMON}.c 27CPPFLAGS+= -DUSE_FILEMON 28CPPFLAGS+= -DUSE_FILEMON_${USE_FILEMON:tu} 29 30. if ${USE_FILEMON} == "dev" 31FILEMON_H?= /usr/include/dev/filemon/filemon.h 32. if exists(${FILEMON_H}) && ${FILEMON_H:T} == "filemon.h" 33COPTS.filemon_dev.c+= \ 34 -DHAVE_FILEMON_H -I${FILEMON_H:H} 35. endif 36. endif 37. endif 38.endif 39 40SUBDIR.roff+= PSD.doc 41.if make(obj) || make(clean) 42SUBDIR+= unit-tests 43.endif 44 45${SRCS:M*.c:.c=.o}: buf.h config.h dir.h hash.h job.h lst.h make.h make_malloc.h 46${SRCS:M*.c:.c=.o}: meta.h metachar.h nonints.h pathnames.h sprite.h strlist.h trace.h 47 48.include <bsd.prog.mk> 49.include <bsd.subdir.mk> 50 51CPPFLAGS+= -DMAKE_NATIVE 52COPTS.var.c+= -Wno-cast-qual 53COPTS.job.c+= -Wno-format-nonliteral 54COPTS.parse.c+= -Wno-format-nonliteral 55COPTS.var.c+= -Wno-format-nonliteral 56 57.if defined(TOOLDIR) 58# This is a native NetBSD build, use libutil rather than the local emalloc etc. 59CPPFLAGS+= -DUSE_EMALLOC 60LDADD+= -lutil 61DPADD+= ${LIBUTIL} 62.endif 63 64COPTS.arch.c+= ${GCC_NO_FORMAT_TRUNCATION} 65COPTS.dir.c+= ${GCC_NO_FORMAT_TRUNCATION} 66COPTS.main.c+= ${GCC_NO_FORMAT_TRUNCATION} ${GCC_NO_STRINGOP_TRUNCATION} 67COPTS.meta.c+= ${GCC_NO_FORMAT_TRUNCATION} 68COPTS.parse.c+= ${GCC_NO_FORMAT_TRUNCATION} 69 70# A simple unit-test driver to help catch regressions 71test: .MAKE 72 cd ${.CURDIR}/unit-tests \ 73 && MAKEFLAGS= ${.MAKE} -r -m / TEST_MAKE=${TEST_MAKE:U${.OBJDIR}/${PROG:T}} ${.TARGET} 74.if ${USE_COVERAGE} == yes 75 gcov ${SRCS} 76.endif 77 78accept: .MAKE 79 cd ${.CURDIR}/unit-tests && ${.MAKE} ${.TARGET} 80 81retest: 82 ${.MAKE} -C ${.CURDIR}/unit-tests cleandir 83.if ${USE_COVERAGE} == yes 84 rm -f *.gcov *.gcda 85.endif 86 ${.MAKE} test 87