Skip to content
Snippets Groups Projects
Commit 1f227370 authored by Julian Seward's avatar Julian Seward
Browse files

[project @ 2000-08-08 15:16:09 by sewardj]

Give the included bits of Haskell their own rules in the Makefile, so
that make boot/depend work properly.
parent 4b172698
No related merge requests found
# ----------------------------------------------------------------------------- # -----------------------------------------------------------------------------
# $Id: Makefile,v 1.86 2000/08/07 14:11:48 sewardj Exp $ # $Id: Makefile,v 1.87 2000/08/08 15:16:09 sewardj Exp $
TOP = .. TOP = ..
include $(TOP)/mk/boilerplate.mk include $(TOP)/mk/boilerplate.mk
...@@ -234,31 +234,44 @@ SRC_C_OPTS += -O -I. -IcodeGen ...@@ -234,31 +234,44 @@ SRC_C_OPTS += -O -I. -IcodeGen
GENPOC=$(TOP)/utils/genprimopcode/genprimopcode GENPOC=$(TOP)/utils/genprimopcode/genprimopcode
prelude/PrimOp.o : prelude/PrimOp.lhs prelude/primops.txt PRIMOP_BITS=primop-data-decl.hs-incl \
$(RM) primop-data-decl.hs primop-tag.hs-incl \
$(RM) primop-tag primop-list.hs-incl \
$(RM) primop-list primop-has-side-effects.hs-incl \
$(RM) primop-has-side-effects.hs primop-out-of-line.hs-incl \
$(RM) primop-out-of-line.hs primop-commutable.hs-incl \
$(RM) primop-commutable.hs primop-needs-wrapper.hs-incl \
$(RM) primop-needs-wrapper.hs primop-can-fail.hs-incl \
$(RM) primop-can-fail.hs primop-strictness.hs-incl \
$(RM) primop-strictness.hs primop-usage.hs-incl \
$(RM) primop-usage.hs primop-primop-info.hs-incl
$(RM) primop-primop-info.hs
$(GENPOC) --data-decl < prelude/primops.txt > primop-data-decl.hs prelude/PrimOp.lhs: $(PRIMOP_BITS)
$(GENPOC) --primop-tag < prelude/primops.txt > primop-tag.hs
$(GENPOC) --primop-list < prelude/primops.txt > primop-list.hs primop-data-decl.hs-incl: prelude/primops.txt
$(GENPOC) --has-side-effects < prelude/primops.txt > primop-has-side-effects.hs $(GENPOC) --data-decl < prelude/primops.txt > primop-data-decl.hs-incl
$(GENPOC) --out-of-line < prelude/primops.txt > primop-out-of-line.hs primop-tag.hs-incl: prelude/primops.txt
$(GENPOC) --commutable < prelude/primops.txt > primop-commutable.hs $(GENPOC) --primop-tag < prelude/primops.txt > primop-tag.hs-incl
$(GENPOC) --needs-wrapper < prelude/primops.txt > primop-needs-wrapper.hs primop-list.hs-incl: prelude/primops.txt
$(GENPOC) --can-fail < prelude/primops.txt > primop-can-fail.hs $(GENPOC) --primop-list < prelude/primops.txt > primop-list.hs-incl
$(GENPOC) --strictness < prelude/primops.txt > primop-strictness.hs primop-has-side-effects.hs-incl: prelude/primops.txt
$(GENPOC) --usage < prelude/primops.txt > primop-usage.hs $(GENPOC) --has-side-effects < prelude/primops.txt > primop-has-side-effects.hs-incl
$(GENPOC) --primop-primop-info < prelude/primops.txt > primop-primop-info.hs primop-out-of-line.hs-incl: prelude/primops.txt
$(RM) $@ $(GENPOC) --out-of-line < prelude/primops.txt > primop-out-of-line.hs-incl
$(HC) -c -o $@ $(HC_OPTS) prelude/PrimOp.lhs primop-commutable.hs-incl: prelude/primops.txt
$(GENPOC) --commutable < prelude/primops.txt > primop-commutable.hs-incl
primop-needs-wrapper.hs-incl: prelude/primops.txt
$(GENPOC) --needs-wrapper < prelude/primops.txt > primop-needs-wrapper.hs-incl
primop-can-fail.hs-incl: prelude/primops.txt
$(GENPOC) --can-fail < prelude/primops.txt > primop-can-fail.hs-incl
primop-strictness.hs-incl: prelude/primops.txt
$(GENPOC) --strictness < prelude/primops.txt > primop-strictness.hs-incl
primop-usage.hs-incl: prelude/primops.txt
$(GENPOC) --usage < prelude/primops.txt > primop-usage.hs-incl
primop-primop-info.hs-incl: prelude/primops.txt
$(GENPOC) --primop-primop-info < prelude/primops.txt > primop-primop-info.hs-incl
# ---------------------------------------------------------------------------- # ----------------------------------------------------------------------------
# Parsers/lexers # Parsers/lexers
...@@ -317,6 +330,7 @@ endif ...@@ -317,6 +330,7 @@ endif
# clean # clean
CLEAN_FILES += $(wildcard */*.$(way_)o */*.$(way_)hi) CLEAN_FILES += $(wildcard */*.$(way_)o */*.$(way_)hi)
CLEAN_FILES += $(PRIMOP_BITS)
# Extra tidy, remove the .hc files (if you've got them). # Extra tidy, remove the .hc files (if you've got them).
MAINTAINER_CLEAN_FILES += $(wildcard */*.hc) \ MAINTAINER_CLEAN_FILES += $(wildcard */*.hc) \
......
...@@ -62,7 +62,7 @@ These are in \tr{state-interface.verb} order. ...@@ -62,7 +62,7 @@ These are in \tr{state-interface.verb} order.
-- supplies: -- supplies:
-- data PrimOp = ... -- data PrimOp = ...
#include "primop-data-decl.hs" #include "primop-data-decl.hs-incl"
| CCallOp CCall -- and don't forget to add CCall | CCallOp CCall -- and don't forget to add CCall
\end{code} \end{code}
...@@ -74,7 +74,7 @@ primOpTag op = IBOX( tagOf_PrimOp op ) ...@@ -74,7 +74,7 @@ primOpTag op = IBOX( tagOf_PrimOp op )
-- supplies -- supplies
-- tagOf_PrimOp :: PrimOp -> FAST_INT -- tagOf_PrimOp :: PrimOp -> FAST_INT
#include "primop-tag.hs" #include "primop-tag.hs-incl"
tagOf_PrimOp op = pprPanic# "tagOf_PrimOp: pattern-match" (ppr op) tagOf_PrimOp op = pprPanic# "tagOf_PrimOp: pattern-match" (ppr op)
...@@ -101,7 +101,7 @@ An @Enum@-derived list would be better; meanwhile... (ToDo) ...@@ -101,7 +101,7 @@ An @Enum@-derived list would be better; meanwhile... (ToDo)
\begin{code} \begin{code}
allThePrimOps :: [PrimOp] allThePrimOps :: [PrimOp]
allThePrimOps = allThePrimOps =
#include "primop-list.hs" #include "primop-list.hs-incl"
-- Doesn't include CCall, which is really a family of primops -- Doesn't include CCall, which is really a family of primops
\end{code} \end{code}
...@@ -153,7 +153,7 @@ primOpStrictness :: PrimOp -> Arity -> StrictnessInfo ...@@ -153,7 +153,7 @@ primOpStrictness :: PrimOp -> Arity -> StrictnessInfo
-- See Demand.StrictnessInfo for discussion of what the results -- See Demand.StrictnessInfo for discussion of what the results
-- The arity should be the arity of the primop; that's why -- The arity should be the arity of the primop; that's why
-- this function isn't exported. -- this function isn't exported.
#include "primop-strictness.hs" #include "primop-strictness.hs-incl"
\end{code} \end{code}
%************************************************************************ %************************************************************************
...@@ -167,7 +167,7 @@ else, notably a type, can be constructed) for each @PrimOp@. ...@@ -167,7 +167,7 @@ else, notably a type, can be constructed) for each @PrimOp@.
\begin{code} \begin{code}
primOpInfo :: PrimOp -> PrimOpInfo primOpInfo :: PrimOp -> PrimOpInfo
#include "primop-primop-info.hs" #include "primop-primop-info.hs-incl"
\end{code} \end{code}
Here are a load of comments from the old primOp info: Here are a load of comments from the old primOp info:
...@@ -337,7 +337,7 @@ perform a heap check or they block. ...@@ -337,7 +337,7 @@ perform a heap check or they block.
\begin{code} \begin{code}
primOpOutOfLine (CCallOp c_call) = ccallMayGC c_call primOpOutOfLine (CCallOp c_call) = ccallMayGC c_call
#include "primop-out-of-line.hs" #include "primop-out-of-line.hs-incl"
\end{code} \end{code}
...@@ -397,7 +397,7 @@ primOpIsDupable op = not (primOpNeedsWrapper op) ...@@ -397,7 +397,7 @@ primOpIsDupable op = not (primOpNeedsWrapper op)
\begin{code} \begin{code}
primOpCanFail :: PrimOp -> Bool primOpCanFail :: PrimOp -> Bool
#include "primop-can-fail.hs" #include "primop-can-fail.hs-incl"
\end{code} \end{code}
And some primops have side-effects and so, for example, must not be And some primops have side-effects and so, for example, must not be
...@@ -406,7 +406,7 @@ duplicated. ...@@ -406,7 +406,7 @@ duplicated.
\begin{code} \begin{code}
primOpHasSideEffects :: PrimOp -> Bool primOpHasSideEffects :: PrimOp -> Bool
primOpHasSideEffects (CCallOp _) = True primOpHasSideEffects (CCallOp _) = True
#include "primop-has-side-effects.hs" #include "primop-has-side-effects.hs-incl"
\end{code} \end{code}
Inline primitive operations that perform calls need wrappers to save Inline primitive operations that perform calls need wrappers to save
...@@ -415,7 +415,7 @@ any live variables that are stored in caller-saves registers. ...@@ -415,7 +415,7 @@ any live variables that are stored in caller-saves registers.
\begin{code} \begin{code}
primOpNeedsWrapper :: PrimOp -> Bool primOpNeedsWrapper :: PrimOp -> Bool
primOpNeedsWrapper (CCallOp _) = True primOpNeedsWrapper (CCallOp _) = True
#include "primop-needs-wrapper.hs" #include "primop-needs-wrapper.hs-incl"
\end{code} \end{code}
\begin{code} \begin{code}
...@@ -481,7 +481,7 @@ primOpSig op ...@@ -481,7 +481,7 @@ primOpSig op
primOpUsg :: PrimOp -> ([TyVar],[Type],Type) primOpUsg :: PrimOp -> ([TyVar],[Type],Type)
primOpUsg p@(CCallOp _) = mangle p [] mkM primOpUsg p@(CCallOp _) = mangle p [] mkM
#include "primop-usage.hs" #include "primop-usage.hs-incl"
-- Things with no Haskell pointers inside: in actuality, usages are -- Things with no Haskell pointers inside: in actuality, usages are
-- irrelevant here (hence it doesn't matter that some of these -- irrelevant here (hence it doesn't matter that some of these
...@@ -553,7 +553,7 @@ to the right hand side for strength reduction. ...@@ -553,7 +553,7 @@ to the right hand side for strength reduction.
\begin{code} \begin{code}
commutableOp :: PrimOp -> Bool commutableOp :: PrimOp -> Bool
#include "primop-commutable.hs" #include "primop-commutable.hs-incl"
\end{code} \end{code}
Utils: Utils:
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment