1 #################################################################
5 # A number of Make variables are used to generate the crunchgen config file.
7 # CRUNCH_SRCDIRS: lists directories to search for included programs
8 # CRUNCH_PROGS: lists programs to be included
9 # CRUNCH_LIBS: libraries to statically link with
10 # CRUNCH_SHLIBS: libraries to dynamically link with
11 # CRUNCH_BUILDOPTS: generic build options to be added to every program
12 # CRUNCH_BUILDTOOLS: lists programs that need build tools built in the
15 # Special options can be specified for individual programs
16 # CRUNCH_SRCDIR_$(P): base source directory for program $(P)
17 # CRUNCH_BUILDOPTS_$(P): additional build options for $(P)
18 # CRUNCH_ALIAS_$(P): additional names to be used for $(P)
20 # By default, any name appearing in CRUNCH_PROGS or CRUNCH_ALIAS_${P}
21 # will be used to generate a hard link to the resulting binary.
22 # Specific links can be suppressed by setting
23 # CRUNCH_SUPPRESS_LINK_$(NAME) to 1.
25 # If CRUNCH_GENERATE_LINKS is set to no, no links will be generated.
30 ##################################################################
31 # The following is pretty nearly a generic crunchgen-handling makefile
37 OUTPUTS=$(OUTMK) $(OUTC) $(PROG).cache
38 CRUNCHOBJS= ${.OBJDIR}
39 .if defined(MAKEOBJDIRPREFIX)
40 CANONICALOBJDIR:= ${MAKEOBJDIRPREFIX}${.CURDIR}
41 .elif defined(MAKEOBJDIR) && ${MAKEOBJDIR:M/*} != ""
42 CANONICALOBJDIR:=${MAKEOBJDIR}
44 CANONICALOBJDIR:= /usr/obj${.CURDIR}
46 CRUNCH_GENERATE_LINKS?= yes
48 CLEANFILES+= $(CONF) *.o *.lo *.c *.mk *.cache *.a *.h
50 # Don't try to extract debug info from ${PROG}.
53 # Program names and their aliases contribute hardlinks to 'rescue' executable,
54 # except for those that get suppressed.
55 .for D in $(CRUNCH_SRCDIRS)
56 .for P in $(CRUNCH_PROGS_$(D))
57 .ifdef CRUNCH_SRCDIR_${P}
58 $(OUTPUTS): $(CRUNCH_SRCDIR_${P})/Makefile
60 $(OUTPUTS): $(.CURDIR)/../../$(D)/$(P)/Makefile
62 .if ${CRUNCH_GENERATE_LINKS} == "yes"
63 .ifndef CRUNCH_SUPPRESS_LINK_${P}
64 LINKS+= $(BINDIR)/$(PROG) $(BINDIR)/$(P)
66 .for A in $(CRUNCH_ALIAS_$(P))
67 .ifndef CRUNCH_SUPPRESS_LINK_${A}
68 LINKS+= $(BINDIR)/$(PROG) $(BINDIR)/$(A)
79 echo \# Auto-generated, do not edit >$(.TARGET)
80 .ifdef CRUNCH_BUILDOPTS
81 echo buildopts $(CRUNCH_BUILDOPTS) >>$(.TARGET)
84 echo libs $(CRUNCH_LIBS) >>$(.TARGET)
87 echo libs_so $(CRUNCH_SHLIBS) >>$(.TARGET)
89 .for D in $(CRUNCH_SRCDIRS)
90 .for P in $(CRUNCH_PROGS_$(D))
91 echo progs $(P) >>$(.TARGET)
92 .ifdef CRUNCH_SRCDIR_${P}
93 echo special $(P) srcdir $(CRUNCH_SRCDIR_${P}) >>$(.TARGET)
95 echo special $(P) srcdir $(.CURDIR)/../../$(D)/$(P) >>$(.TARGET)
97 .ifdef CRUNCH_BUILDOPTS_${P}
98 echo special $(P) buildopts DIRPRFX=${DIRPRFX}${P}/ \
99 $(CRUNCH_BUILDOPTS_${P}) >>$(.TARGET)
101 echo special $(P) buildopts DIRPRFX=${DIRPRFX}${P}/ >>$(.TARGET)
103 .for A in $(CRUNCH_ALIAS_$(P))
104 echo ln $(P) $(A) >>$(.TARGET)
109 # XXX Make sure we don't pass -P to crunchgen(1).
110 .MAKEFLAGS:= ${.MAKEFLAGS:N-P}
111 .ORDER: $(OUTPUTS) objs
113 MAKE=${MAKE} MAKEOBJDIRPREFIX=${CRUNCHOBJS} crunchgen -fq -m $(OUTMK) \
116 $(PROG): $(OUTPUTS) objs
117 MAKEOBJDIRPREFIX=${CRUNCHOBJS} ${MAKE} -f $(OUTMK) exe
120 MAKEOBJDIRPREFIX=${CRUNCHOBJS} ${MAKE} -f $(OUTMK) objs
122 # <sigh> Someone should replace the bin/csh and bin/sh build-tools with
123 # shell scripts so we can remove this nonsense.
125 .for _tool in $(CRUNCH_BUILDTOOLS)
126 cd $(.CURDIR)/../../${_tool}; \
127 MAKEOBJDIRPREFIX=${CRUNCHOBJS} ${MAKE} obj; \
128 MAKEOBJDIRPREFIX=${CRUNCHOBJS} ${MAKE} build-tools
131 # Use a separate build tree to hold files compiled for this crunchgen binary
132 # Yes, this does seem to partly duplicate bsd.subdir.mk, but I can't
133 # get that to cooperate with bsd.prog.mk. Besides, many of the standard
134 # targets should NOT be propagated into the components.
135 cleandepend cleandir obj objlink:
136 .for D in $(CRUNCH_SRCDIRS)
137 .for P in $(CRUNCH_PROGS_$(D))
138 .ifdef CRUNCH_SRCDIR_${P}
139 cd ${CRUNCH_SRCDIR_$(P)} && \
140 MAKEOBJDIRPREFIX=${CANONICALOBJDIR} ${MAKE} \
141 DIRPRFX=${DIRPRFX}${P}/ ${CRUNCH_BUILDOPTS} ${.TARGET}
143 cd $(.CURDIR)/../../${D}/${P} && \
144 MAKEOBJDIRPREFIX=${CANONICALOBJDIR} ${MAKE} \
145 DIRPRFX=${DIRPRFX}${P}/ ${CRUNCH_BUILDOPTS} ${.TARGET}
152 if [ -e ${.OBJDIR}/$(OUTMK) ]; then \
153 MAKEOBJDIRPREFIX=${CRUNCHOBJS} ${MAKE} -f $(OUTMK) clean; \
155 .for D in $(CRUNCH_SRCDIRS)
156 .for P in $(CRUNCH_PROGS_$(D))
157 .ifdef CRUNCH_SRCDIR_${P}
158 cd ${CRUNCH_SRCDIR_$(P)} && \
159 MAKEOBJDIRPREFIX=${CANONICALOBJDIR} ${MAKE} \
160 DIRPRFX=${DIRPRFX}${P}/ ${CRUNCH_BUILDOPTS} ${.TARGET}
162 cd $(.CURDIR)/../../${D}/${P} && \
163 MAKEOBJDIRPREFIX=${CANONICALOBJDIR} ${MAKE} \
164 DIRPRFX=${DIRPRFX}${P}/ ${CRUNCH_BUILDOPTS} ${.TARGET}