#-----------------------------------------------------------------------------
# Haskell Suffix Rules
-HASKELL_SPLIT_PRE= \
- if [ ! -d $(basename $@) ]; then mkdir $(basename $@) ; else exit 0; fi; \
- find $(basename $@) -name '*.$(way_)o' -print | xargs $(RM) __rm_food;
-HASKELL_SPLIT_POST= touch $@
-HASKELL_PRE_COMPILE=$(patsubst %,$(HASKELL_SPLIT_PRE),$(filter -split-objs,$(HC_OPTS)))
-HASKELL_POST_COMPILE=$(patsubst %,$(HASKELL_SPLIT_POST),$(filter -split-objs,$(HC_OPTS)))
+HC_SPLIT_PRE= \
+ $(RM) $@ ; if [ ! -d $(basename $@) ]; then mkdir $(basename $@); else \
+ find $(basename $@) -name '*.$(way_)o' -print | xargs $(RM) __rm_food ; fi
+HC_SPLIT_POST = touch $@
+
+HC_PRE__ = $(patsubst %,$(HC_SPLIT_PRE) ; ,$(filter -split-objs,$(HC_OPTS)))
+HC_POST__ = $(patsubst %,$(HC_SPLIT_POST) ; ,$(filter -split-objs,$(HC_OPTS)))
+
+SRC_HC_POST += $(HC_POST__)
+SRC_HC_PRE += $(HC_PRE__)
%.$(way_)o : %.hs
- $(RM) $@
- $(HASKELL_PRE_COMPILE)
+ $(SRC_HC_PRE)
$(HC) $(HC_OPTS) -c $< -o $@ -osuf $(subst .,,$(suffix $@))
- $(HASKELL_POST_COMPILE)
+ $(SRC_HC_POST)
%.$(way_)o : %.lhs
- $(RM) $@
- $(HASKELL_PRE_COMPILE)
+ $(SRC_HC_PRE)
$(HC) $(HC_OPTS) -c $< -o $@ -osuf $(subst .,,$(suffix $@))
- $(HASKELL_POST_COMPILE)
+ $(SRC_HC_POST)
%.$(way_)hc : %.lhs
$(RM) $@
$(HC) $(HC_OPTS) -C $< -o $@
-%.$(way_)o : %.$(way_)hc
+%.$(way_)hc : %.hs
$(RM) $@
- $(HASKELL_PRE_COMPILE)
+ $(HC) $(HC_OPTS) -C $< -o $@
+
+%.$(way_)o : %.$(way_)hc
+ $(SRC_HC_PRE)
$(HC) $(HC_OPTS) -c $< -o $@ -osuf $(subst .,,$(suffix $@))
- $(HASKELL_POST_COMPILE)
+ $(SRC_HC_POST)
%.$(way_)hc : %.lhc
@$(RM) $@
#-----------------------------------------------------------------------------
# Lx Suffix Rules
#
-.PRECIOUS: %.hs
%.hs : %.lx
$(LX) $(LX_OPTS) $<
#-----------------------------------------------------------------------------
+# Green-card Suffix Rules
+#
+
+%.hs : %.gc
+ $(GREENCARD) $(GREENCARD_OPTS) $<
+
+#-----------------------------------------------------------------------------
# C-related suffix rules
%.$(way_)o : %.$(way_)s
%.c : %.flex
@$(RM) $@
$(FLEX) -t $(FLEX_OPTS) $< > $@ || ( $(RM) $@ && exit 1 )
+%.c : %.lex
+ @$(RM) $@
+ $(FLEX) -t $(FLEX_OPTS) $< > $@ || ( $(RM) $@ && exit 1 )
#-----------------------------------------------------------------------------
# Yacc stuff
#-----------------------------------------------------------------------------
# Runtest rules for calling $(HC) on a single-file Haskell program
-%.hs : %.runtest
- $(TIME) $(RUNTEST) $(HC) $(RUNTEST_FLAGS) -o2 $*.stderr $<
-
+%.runtest : %.hs
+ $(TIME) $(RUNTEST) $(HC) $(RUNTEST_OPTS) $<
#-----------------------------------------------------------------------------
# Doc processing suffix rules
-
+#
+# ToDo: make these more robust
+#
%.dvi : %.tex
@$(RM) $@
$(LTX) $<
fig2dev -L latex $< $@
#-----------------------------------------------------------------------------
+# SGML suffix rules
+#
+# make sure these don't conflict with the literate rules!
+
+%.sgml : %.vsgml
+ @$(RM) $@
+ expand $*.vsgml | $(SGMLVERB) > $@
+
+%.tex : %.sgml
+ @$(RM) $@
+ $(SGML2LATEX) -m --output=tex $<
+
+%.dvi : %.sgml
+ @$(RM) $@
+ $(SGML2LATEX) -m --output=dvi $<
+
+# Not yet: we already have a %.ps : %.dvi rule, this one would conflict.
+#%,ps : %.sgml
+# @$(RM) $@
+# $(SGML2LATEX) -m --output=ps $<
+
+%.html : %.sgml
+ @$(RM) $@
+ $(SGML2HTML) $<
+
+%.info : %.sgml
+ @$(RM) $@
+ $(SGML2INFO) $<
+
+%.txt : %.sgml
+ @$(RM) $@
+ $(SGML2TXT) $<
+
+#-----------------------------------------------------------------------------
# Literate suffix rules
# ToDo: somehow macroize this lot. (if only!)
%.txt : %.lit
@$(RM) $@
- $(LIT2TEXT) -c $(LIT2TEXT_OPTS) -o $@ $<
+ $(LIT2TEXT) $(LIT2TEXT_OPTS) -o $@ $<
@chmod 444 $@
%.ihtml : %.lit
$(TEXI2HTML) $(TEXI2HTML_OPTS) $(patsubst %.lhs,%.texi,$<)
@touch $@
+%.info:: %.texi
+ @$(RM) $@
+ $(MAKEINFO) $(MAKEINFO_OPTS) $< && $(POSTMAKEINFO) $@
+
%.hs : %.lhs
@$(RM) $@
$(LIT2PGM) $(LIT2PGM_OPTS) -o $@ $<