[Haskell-cafe] Cyclic Inclusions

Thomas Davie tom.davie at gmail.com
Wed Aug 13 04:26:57 EDT 2008


On 13 Aug 2008, at 05:06, ajb at spamcop.net wrote:

> G'day all.
>
> Quoting Thomas Davie <tom.davie at gmail.com>:
>
>> Why is separate compilation important?
>
> I'm a little shocked that anyone on this list should have to ask this
> question.  Two people have asked it now.
>
> The simplest answer is that unless your program fits in cache, it
> takes longer to compile two modules concurrently than it takes to
> compile them separately.  This is even more true if one of those
> modules does not actually need recompilation.
>
> The longer answer is that in the Real World, programmer time is
> far, far more precious than computer time.  Every second that the
> programmer waits for the computer to finish some task, there is a
> priority inversion.

Really?  So you're using YHC then?  It after all compiles *much*  
faster than GHC, but produces slower binaries.  To be honest, ghc  
compiles things so fast (at least on any of my systems) that I  
couldn't care less if it took 10 times as long (I would however like  
some added convenience for that time spent)

> It's therefore highly desirable that jobs done by computer are as
> fast as possible or, failing that, as predictable as possible, so
> the programmer knows to do something else while waiting.
>
> Separate compilation puts a predictable upper bound on the amount
> of recompilation that has to be done given some set of changes.
> True, so does requiring recompilation of a package as a whole, but
> Haskell development would then be notorious for its sluggishness.

It does?  If I compile a module on which lots of other modules depend,  
I have to do lots of recompilation... If I compile a module which is  
in a cyclic dependancy group, I have to do lots of recompilation,  I  
don't see that there's a difference here.

>> I can understand your point
>> about a module on it's own not being analyzable, and that that's an  
>> odd
>> property -- on the other hand, the rapidly emerging "atomic" unit in
>> Haskell is the package, so I see no reason why modules within one
>> package shouldn't depend on each other.
>
> Implicit in my working definition of "module" is that a module has a
> well-defined interface.  Am I the only one who has that understanding?
> (Well, me and David Parnas, at any rate.)
>
> For the record, I have no problem with modules depending on each  
> other,
> so long as they only depend on their well-defined interfaces.

That's a fair point about programming style, otoh, I don't think it's  
a reason to restrict users to not using cyclic dependancies.

>> Finally, as chris suggests, if separate compilation is important to
>> you, why not have a flag in ghc -frequire-hi-boot or something?
>
> Well, if I wanted separate header files, and the inevitable multiple-
> maintenance headaches associated with them, I'd program in C.  Except
> for mutually recursive modules, GHC can and does generate header files
> automatically, so I don't see why my time should be wasted doing the
> job of a compiler.
>
> If something is preventing the compiler from doing that job, then that
> something should be fixed.

Something *does* prevent the compiler doing that job -- the fact that  
ghc can't deal with cyclic module includes without an hi-boot file.   
This is *exactly* my point -- I don't see why my time should be wasted  
doing the job of the compiler just because I happen to have a cyclic  
dependancy, that the compiler could quite happily sort out, by making  
my compile time in this situation slightly longer.

If I *really* think I'm going to save more time by writing a hi-boot  
file, then I would be able to turn on the option!

Bob



More information about the Haskell-Cafe mailing list