projects
/
ghc-hetmet.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Haskell Program Coverage
[ghc-hetmet.git]
/
compiler
/
coreSyn
/
CoreSyn.lhs
diff --git
a/compiler/coreSyn/CoreSyn.lhs
b/compiler/coreSyn/CoreSyn.lhs
index
3c98f28
..
3f74dc5
100644
(file)
--- a/
compiler/coreSyn/CoreSyn.lhs
+++ b/
compiler/coreSyn/CoreSyn.lhs
@@
-60,6
+60,7
@@
import DataCon
import BasicTypes
import FastString
import Outputable
import BasicTypes
import FastString
import Outputable
+import Module
infixl 4 `mkApps`, `mkValApps`, `mkTyApps`, `mkVarApps`
-- Left associative, so that we can say (f `mkTyApps` xs `mkVarApps` ys)
infixl 4 `mkApps`, `mkValApps`, `mkTyApps`, `mkVarApps`
-- Left associative, so that we can say (f `mkTyApps` xs `mkVarApps` ys)
@@
-132,6
+133,11
@@
data Note
| CoreNote String -- A generic core annotation, propagated but not used by GHC
| CoreNote String -- A generic core annotation, propagated but not used by GHC
+ | TickBox Module !Int -- ^Tick box for Hpc-style coverage
+ | BinaryTickBox Module !Int !Int
+ -- ^Binary tick box, with a tick for result = True, result = False
+
+
-- NOTE: we also treat expressions wrapped in InlineMe as
-- 'cheap' and 'dupable' (in the sense of exprIsCheap, exprIsDupable)
-- What this means is that we obediently inline even things that don't
-- NOTE: we also treat expressions wrapped in InlineMe as
-- 'cheap' and 'dupable' (in the sense of exprIsCheap, exprIsDupable)
-- What this means is that we obediently inline even things that don't
@@
-615,6
+621,9
@@
seqExprs [] = ()
seqExprs (e:es) = seqExpr e `seq` seqExprs es
seqNote (CoreNote s) = s `seq` ()
seqExprs (e:es) = seqExpr e `seq` seqExprs es
seqNote (CoreNote s) = s `seq` ()
+seqNote (TickBox m n) = m `seq` () -- no need for seq on n, because n is strict
+seqNote (BinaryTickBox m t f)
+ = m `seq` () -- likewise on t and f.
seqNote other = ()
seqBndr b = b `seq` ()
seqNote other = ()
seqBndr b = b `seq` ()