| Commit message (Collapse) | Author | Age | Files | Lines |
| |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
----------------
Nuke ClassContext
----------------
This commit tidies up a long-standing inconsistency in GHC.
The context of a class or instance decl used to be restricted
to predicates of the form
C t1 .. tn
with
type ClassContext = [(Class,[Type])]
but everywhere else in the compiler we used
type ThetaType = [PredType]
where PredType can be any sort of constraint (= predicate).
The inconsistency actually led to a crash, when compiling
class (?x::Int) => C a where {}
I've tidied all this up by nuking ClassContext altogether, and using
PredType throughout. Lots of modified files, but all in
more-or-less trivial ways.
I've also added a check that the context of a class or instance
decl doesn't include a non-inheritable predicate like (?x::Int).
Other things
* rename constructor 'Class' from type TypeRep.Pred to 'ClassP'
(makes it easier to grep for)
* rename constructor HsPClass => HsClassP
HsPIParam => HsIParam
|
| |
|
|
| |
re-instate an ASSERT that was temporarily commented out.
|
| |
|
|
| |
Fix let-no-escapes again.
|
| |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
Some rearrangements that Simon & I have been working on recently:
- CoreSat is now CorePrep, and is a general "prepare-for-code-
generation" pass. It does cloning, saturation of constructors &
primops, A-normal form, and a couple of other minor fiddlings.
- CoreTidy no longer does cloning, and minor fiddlings. It doesn't
need the unique supply any more, so that's removed.
- CoreToStg now collects CafInfo and the list of CafRefs for each
binding. The SRT pass is much simpler now.
- IdInfo now has a CgInfo field for "code generator info". It currently
contains arity (the actual code gen arity which affects the calling
convention as opposed to the ArityInfo which is a measure of how
many arguments the Id can be applied to before it does any work), and
CafInfo.
Previously we overloaded the ArityInfo field to contain both
codegen arity and simplifier arity. Things are cleaner now.
- CgInfo is collected by CoreToStg, and passed back into CoreTidy in
a loop. The compiler will complain rather than going into a black
hole if the CgInfo is pulled on too early.
- Worker info in an interface file now comes with arity info attached.
Previously the main arity info was overloaded for this purpose, but
it lead to a few hacks in the compiler, this tidies things up somewhat.
Bottom line: we removed several fragilities, and tidied up a number of
things. Code size should be smaller, but we'll see...
|
| |
|
|
| |
Make a better CPR wrapper when profiling is in use
|
| |
|
|
| |
Fix overenthusiatic import GCing, I presume.
|
| |
|
|
|
|
|
|
|
|
|
|
|
|
| |
----------------
First cut at ILX
----------------
This commit puts the ILX .NET code generator into the head.
It's entirely untested, mind you.
Some changes to the Module/Package strutures, mainly of a
naming variety. In particular:
Package ===> PackageConfig
|
| |
|
|
| |
Remove -funfolding-interface-threshold
|
| |
|
|
|
| |
infix declarations for unknown identifiers aren't allowed (contrary to
what GHC thinks).
|
| |
|
|
| |
s/setIdGlobalDetails/sedGlobalIdDetails/, and import it.
|
| |
|
|
| |
Fix names imported from Id.
|
| |
|
|
| |
add expected output
|
| |
|
|
| |
update for blocking putMVar
|
| |
|
|
| |
Add NameEnv!
|
| |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
--------------------
A major hygiene pass
--------------------
1. The main change here is to
Move what was the "IdFlavour" out of IdInfo,
and into the varDetails field of a Var
It was a mess before, because the flavour was a permanent attribute
of an Id, whereas the rest of the IdInfo was ephemeral. It's
all much tidier now.
Main places to look:
Var.lhs Defn of VarDetails
IdInfo.lhs Defn of GlobalIdDetails
The main remaining infelicity is that SpecPragmaIds are right down
in Var.lhs, which seems unduly built-in for such an ephemeral thing.
But that is no worse than before.
2. Tidy up the HscMain story a little. Move mkModDetails from MkIface
into CoreTidy (where it belongs more nicely)
This was partly forced by (1) above, because I didn't want to make
DictFun Ids into a separate kind of Id (which is how it was before).
Not having them separate means we have to keep a list of them right
through, rather than pull them out of the bindings at the end.
3. Add NameEnv as a separate module (to join NameSet).
4. Remove unnecessary {-# SOURCE #-} imports from FieldLabel.
|
| |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
-------------------------
Remove function coercions
-------------------------
(coerce (T1->T2) (S1->S2) F) E
===>
coerce T2 S2 (F (coerce S1 T1 E))
This is a generally good transformation, but it
still doesn't solve the problem I was after. Consider
newtype T = MkT (Int -> Int)
p :: T->T; p = ...
q :: T; q = ...
foo :: T
{-# INLINE foo #-}
foo = p $ q
f = \y -> ...((coerce (Int->Int) foo) 3)...
Trouble is, foo doesn't see the argument because of the coerce, so it
thinks it's a lone variable and doesn't inline.
Another problem is that since $ ins't inlined into foo's RHS, foo
looks like a redex, which we are reluctant to inline inside a lambda,
even with an INLINE pragma. Maybe we should be bolder?
Anyway, this commit is an improvement to Simplify, but the story is not
over!
|
| |
|
|
| |
remove cyclic dependency
|
| |
|
|
| |
rearrange slightly to make this compile again.
|
| |
|
|
| |
Remove DOS Ctrl-Ms
|
| |
|
|
| |
Import v_TmpDir.
|
| |
|
|
|
|
| |
On mingwin, remove CRs from input file, to prevent problems when
reading from unmounted partitions. (This shouldn't be a problem, but
it is; this fix makes the mangler a bit more robust anyway.)
|
| |
|
|
| |
undo accidental change
|
| |
|
|
| |
changes to build new ParsePkgConf module
|
| |
|
|
| |
Use TMPDIR, not /tmp.
|
| |
|
|
|
|
|
|
|
|
|
|
| |
- Add a Happy parser for the package config file. This is faster and
compiles to less code than the derived Read instance we had before.
- Add a source_dirs field to the package spec. This isn't used by
GHC, because we currently assume all packages are compiled. It could
be used by Hugs, though.
- Make unspecified fields of type [String] default to the empty list
in a package spec.
|
| |
|
|
| |
import wibbles
|
| |
|
|
| |
Fix minor bug in SpecConstr; failed to deal with DEFAULT case
|
| |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
Exploit the 1-shot lambda HACK in etaExpandArity
We often find code like
f :: Int -> IO ()
f = \ x -> case ... of
p1 -> \s -> ...rhs1...
p2 -> \s -> ...rhs2...
where the \s is a state transformer lambda. Almost invariably
these \s things are one-shot; that is, we virtually never say
let
h = f 3
in
h >> h >> h
In this case we'd be much better off eta-expanding f, to
f :: Int -> IO ()
f = \ x \ s -> case ... of
p1 -> ...rhs1...
p2 -> ...rhs2...
GHC already has a MAJOR HACK in
Id.isOneShotLambda
which declares that any \s::State# T is a one-shot lambda. It's
almost always true, and it makes a big difference.
This commit simply makes use of isOneShotLambda to improve the
results of CoreUtils.etaExpandArity. Which has the desired effect.
There isn't a flag to control the MAJOR HACK yet. Maybe there should be.
Anyway, some of Manuel's array code should improve a lot.
|
| |
|
|
| |
Print debug uniques consistently in base64
|
| |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
Improve SpecConstr
This commit fixes SpecConstr so that it can see the effect of
enclosing case expressions properly. That's what the "cons" field
in ScEnv is for.
As a result, consider this function:
data AccessPath = Cont AccessPath
| Value Int
demandAll n ap@(Cont (Value (I# i1)))
= case n of
0 -> i1
other -> i1 +# demandAll (n-1) ap
SpecConstr now successfully compiles it to this:
$s$wdemandAll
= \ i1 :: PrelGHC.Int# sc :: PrelGHC.Int# ->
case sc of ds {
0 -> i1;
__DEFAULT -> PrelGHC.+# i1 (Foo.$s$wdemandAll i1 (PrelGHC.-# ds 1))
}
with the rule
"SC:$wdemandAll1" __forall i1 :: PrelGHC.Int# ,
sc :: PrelGHC.Int# .
Foo.$wdemandAll sc (Foo.$wCont (Foo.$wValue (PrelBase.$wI# i1)))
= Foo.$s$wdemandAll i1 sc ;
|
| |
|
|
| |
Better dump of transformation rules
|
| |
|
|
| |
Remove debug trace
|
| |
|
|
| |
Make error message more helpful
|
| |
|
|
| |
Remove dead isSysOcc
|
| |
|
|
| |
Add a test that Hugs-Feb-2001 fails
|
| |
|
|
| |
remove cruft
|
| |
|
|
| |
small rearrangement
|
| |
|
|
| |
fix -fgenerics
|
| |
|
|
|
|
|
|
|
|
|
|
|
|
| |
Use custom parser monad instead of Parsec. It remembers the text which
has been parsed, so it needs not to be reconstructed after parsing.
Operators containing '--' are now handled correctly. '#' triggers
special processing only if it's not a part of an operator, i.e. if
a varsym token is exactly a single '#'.
Backslash-newline pairs in C lexical world are now handled correctly
(removed at an early stage).
Option --keep replaced with --no-compile (stop after writing *.hs_make.c).
|
| |
|
|
| |
Fix #{stuff} parsing when stuff contains end of line.
|
| |
|
|
| |
Properly clean PrelPrimopWrappers for all ways.
|
| |
|
|
| |
Slightly more compact ppr for Core (makes it easier to read large functions).
|
| |
|
|
|
| |
Fix :type again, by resurrecting typecheckExpr. Now the expression
doesn't get the monomorphism restriction applied to it.
|
| |
|
|
|
|
|
|
|
|
|
|
|
|
| |
ASSERT in updateWithIndirection() that we haven't already updated this
object with an indirection, and fix two places in the RTS where this
could happen.
The problem only occurs when we're in a black-hole-style loop, and
there are multiple update frames on the stack pointing to the same
object (this is possible because of lazy black-holing). Both stack
squeezing and asynchronous exception raising walk down the stack and
remove update frames, updating their contents with indirections. If
we don't protect against multiple updates, the mutable list in the old
generation may get into a bogus state.
|
| |
|
|
| |
Add a new closure flag, IND, to identify indirections.
|
| |
|
|
| |
Add some ASSERT()s so we can catch updates where updatee==target.
|
| |
|
|
|
|
|
|
|
|
|
| |
Yet another good bug (I'm on a roll today! :-)
When squeezing update frames, make sure the updatee pointers aren't
identical before updating one to point to the other. This is mostly
harmless, but in one example I have caused the program to go into an
infinite loop rather than fall down a black hole.
To be merged into the 4.08 branch.
|
| |
|
|
|
|
|
| |
Another good bug: the stack check in the AP_UPD entry code was wrong.
This one is a definite source of crashes.
To be merged into the 4.08 branch.
|
| |
|
|
|
|
|
|
| |
A good bug: detectBlackHoles wasn't checking for ThreadRelocated,
which is why we sometimes get "no threads to run: infinite loop or
deadlock?" when we should get a NonTermination exception.
To be merged into the 4.08 branch.
|
| |
|
|
|
|
|
| |
Don't context switch on the timer if the flag +RTS -C0 is given. This
gives us reliable/repeatable runs with -C0 (I've been running with a
similar change for months now, debugging is virtually impossible
without it).
|