[project @ 1998-01-29 11:38:20 by simonm]
[ghc-hetmet.git] / mk / suffix.mk
index 8b69b15..8fc22b7 100644 (file)
@@ -30,22 +30,26 @@ endif
 #-----------------------------------------------------------------------------
 # Haskell Suffix Rules
 
-HASKELL_SPLIT_PRE= \
+HC_SPLIT_PRE= \
  $(RM) $@ ; if [ ! -d $(basename $@) ]; then mkdir $(basename $@); else \
  find $(basename $@) -name '*.$(way_)o' -print | xargs $(RM) __rm_food ; fi
-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_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
-       $(HASKELL_PRE_COMPILE)
+       $(SRC_HC_PRE)
        $(HC) $(HC_OPTS) -c $< -o $@ -osuf $(subst .,,$(suffix $@))
-       $(HASKELL_POST_COMPILE)
+       $(SRC_HC_POST)
                         
 %.$(way_)o : %.lhs      
-       $(HASKELL_PRE_COMPILE)
+       $(SRC_HC_PRE)
        $(HC) $(HC_OPTS) -c $< -o $@ -osuf $(subst .,,$(suffix $@))
-       $(HASKELL_POST_COMPILE)
+       $(SRC_HC_POST)
                         
 %.$(way_)hc : %.lhs     
        $(RM) $@
@@ -56,9 +60,9 @@ HASKELL_POST_COMPILE=$(patsubst %,$(HASKELL_SPLIT_POST),$(filter -split-objs,$(H
        $(HC) $(HC_OPTS) -C $< -o $@
                         
 %.$(way_)o : %.$(way_)hc 
-       $(HASKELL_PRE_COMPILE)
+       $(SRC_HC_PRE)
        $(HC) $(HC_OPTS) -c $< -o $@ -osuf $(subst .,,$(suffix $@))
-       $(HASKELL_POST_COMPILE)
+       $(SRC_HC_POST)
 
 %.$(way_)hc : %.lhc
        @$(RM) $@
@@ -188,12 +192,21 @@ HASKELL_POST_COMPILE=$(patsubst %,$(HASKELL_SPLIT_POST),$(filter -split-objs,$(H
 
 %.sgml : %.vsgml
        @$(RM) $@
-       expand $*.verb | $(SGMLVERB) > $@
+       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) $<