Simon Peyton-Jones wrote:
| However, whenever I change a data type or class even if they are not
| exported, it seems to force a full rebuild of everything that depends on
| that file. Is there any fundamental reason this can't be fixed? why do
| the non exported classes and data types end up in the hi file anyway
| (assuming they appear in no exported functions type signature of course)

There's no fundamental reason.  I think I just thought that it'd be seldom for 
a data type or class to be defined only internally to a module, and not 
exported at all.

Somewhat more common is for the *implementation* of the data type (i.e. its 
data constructors) to be internal, but the type itself is exported.  So then 
one would want to have a partial spec in the interface file, giving the kind 
but not the constructors.  Again, I didn’t work on this case.

That's funny, I was under the impression that we had fixed this at some stage in the past - that is, a data type can be exported without its constructors in an interface. I remember because it caused a bunch of bugs when the code generator couldn't figure out how to evaluate a type because it had no constructors. Maybe we should look at the code :-)

Cheers,
        Simon
_______________________________________________
Glasgow-haskell-users mailing list
[email protected]
http://www.haskell.org/mailman/listinfo/glasgow-haskell-users

Reply via email to