1 #################################################################################
5 # Suffix rules for fptools
7 #################################################################################
10 # This file contain the default suffix rules for all the fptools projects.
14 # No need to define .SUFFIXES because we don't use any suffix rules
15 # Instead we use gmake's pattern rules exlusively
19 # However, if $(way) is set then we have to define $(way_) and $(_way)
20 # from it in the obvious fashion.
21 # This must be done here (or earlier), but not in target.mk with the other
22 # way management, because the pattern rules in this file take a snapshot of
23 # the value of $(way_) and $(_way), and it's no good setting them later!
30 #-----------------------------------------------------------------------------
31 # Haskell Suffix Rules
33 # Turn off all the Haskell suffix rules if we're booting from .hc
34 # files. The file bootstrap.mk contains alternative suffix rules in
36 ifneq "$(BootingFromHc)" "YES"
40 $(HC) $(HC_OPTS) -c $< -o $@
45 $(HC) $(HC_OPTS) -c $< -o $@
50 $(HC) $(HC_OPTS) -C $< -o $@
54 $(HC) $(HC_OPTS) -C $< -o $@
56 %.$(way_)o : %.$(way_)hc
58 $(HC) $(HC_OPTS) -c $< -o $@
63 $(HC) $(HC_OPTS) -c $< -o $@
66 %.$(way_)s : %.$(way_)hc
68 $(HC) $(HC_OPTS) -S $< -o $@
77 # Here's an interesting rule!
78 # The .hi file depends on the .o file,
79 # so if the .hi file is dated earlier than the .o file (commonly the case,
80 # when interfaces are stable) this rule just makes sure that the .o file,
81 # is up to date. Then it does nothing to generate the .hi file from the
82 # .o file, because the act of making sure the .o file is up to date also
83 # updates the .hi file (if necessary).
85 %.$(way_)hi : %.$(way_)o
86 @if [ ! -f $@ ] ; then \
87 echo Panic! $< exists, but $@ does not.; \
92 %.$(way_)hi : %.$(way_)hc
93 @if [ ! -f $@ ] ; then \
94 echo Panic! $< exists, but $@ does not.; \
101 #-----------------------------------------------------------------------------
107 $(HAPPY) $(HAPPY_OPTS) $<
110 $(HAPPY) $(HAPPY_OPTS) $<
112 #-----------------------------------------------------------------------------
113 # hsc2hs Suffix Rules
115 ifneq "$(BootingFromHc)" "YES"
116 %_hsc.c %_hsc.h %.hs : %.hsc
117 $(HSC2HS) $(HSC2HS_OPTS) $<
118 @touch $(patsubst %.hsc,%_hsc.c,$<)
121 #-----------------------------------------------------------------------------
128 #-----------------------------------------------------------------------------
129 # Green-card Suffix Rules
135 $(GREENCARD) $(GC_OPTS) $< -o $@
138 $(GREENCARD) $(GC_OPTS) $< -o $@
141 $(CPP) $(GC_CPP_OPTS) $< | perl -pe 's#\\n#\n#g' > $@
143 #-----------------------------------------------------------------------------
144 # C-related suffix rules
146 ifeq "$(UseGhcForCc)" "YES"
148 %.$(way_)o : %.$(way_)s
150 $(HC) $(GHC_CC_OPTS) -c $< -o $@
154 $(HC) $(GHC_CC_OPTS) -c $< -o $@
158 $(HC) $(GHC_CC_OPTS) -c $< -o $@
162 $(HC) $(GHC_CC_OPTS) -c $< -o $@
166 %.$(way_)o : %.$(way_)s
168 $(AS) $(AS_OPTS) -o $@ $< || ( $(RM) $@ && exit 1 )
172 $(CC) $(CC_OPTS) -c $< -o $@
176 $(CC) $(CC_OPTS) -c $< -o $@
180 $(CC) $(CC_OPTS) -S $< -o $@
184 # stubs are automatically generated and compiled by GHC
188 # -----------------------------------------------------------------------------
193 $(FLEX) -t $(FLEX_OPTS) $< > $@ || ( $(RM) $@ && exit 1 )
196 $(FLEX) -t $(FLEX_OPTS) $< > $@ || ( $(RM) $@ && exit 1 )
198 #-----------------------------------------------------------------------------
201 %.tab.c %.tab.h : %.y
202 @$(RM) $*.tab.h $*.tab.c y.tab.c y.tab.h y.output
203 $(YACC) $(YACC_OPTS) $<
204 $(MV) y.tab.c $*.tab.c
206 $(MV) y.tab.h $*.tab.h
210 #-----------------------------------------------------------------------------
211 # Runtest rules for calling $(HC) on a single-file Haskell program
214 $(TIME) $(RUNTEST) $(HC) $(RUNTEST_OPTS) $<
216 #-----------------------------------------------------------------------------
217 # Doc processing suffix rules
219 # ToDo: make these more robust
226 @$(RM) $*.tex $*.verb-t.tex
228 expand $*.tib-t.tex | $(VERBATIM) > $*.tex
237 fig2dev -L latex $< $@
239 #-----------------------------------------------------------------------------
244 $(SGML2DVI) $(SGML2DVI_OPTS) $<
248 $(SGML2PS) $(SGML2PS_OPTS) $<
252 # $(PERL) $(COLLATEINDEX) -N -o index.sgml
253 # $(JADE) -t sgml -V html-index -d $(SGMLSTYLESHEET) -c $(DOCBOOK_CATALOG) $<
254 # $(PERL) $(COLLATEINDEX) -N -o index.sgml
255 $(SGML2HTML) $(SGML2HTML_OPTS) $<
256 # touch the .html file so that it is seen to be built
261 $(HEVEA) $(HEVEA_OPTS) $(patsubst %.tex,%.hva,$<) $<
262 $(HEVEA) $(HEVEA_OPTS) $(patsubst %.tex,%.hva,$<) $<
263 $(HACHA) $(HACHA_OPTS) $(patsubst %.tex,%.html,$<)
264 # Run HeVeA twice to resolve labels
268 $(SGML2RTF) $(SGML2RTF_OPTS) $<
272 $(SGML2PDF) $(SGML2PDF_OPTS) $<
274 #-----------------------------------------------------------------------------
275 # Literate suffix rules
279 $(UNLIT) $(UNLIT_OPTS) $< $@
284 $(UNLIT) $(UNLIT_OPTS) $< $@
289 $(UNLIT) $(UNLIT_OPTS) $< $@
292 #-----------------------------------------------------------------------------
293 # Win32 resource files
295 # The default is to use the GNU resource compiler.
298 %.$(way_)o : %.$(way_)rc
302 #-----------------------------------------------------------------------------
303 # Preprocessor suffix rule
307 $(CPP) $(CPP_OPTS) -x c $< | $(SED) -e '/^#/d' > $@