[Haskell-cafe] Re: [Haskell] Top Level <-

Jonathan Cast jonathanccast at fastmail.fm
Thu Aug 28 17:53:19 EDT 2008


On Thu, 2008-08-28 at 14:45 -0700, Jonathan Cast wrote:
> On Thu, 2008-08-28 at 22:24 +0100, Adrian Hey wrote:
> > Jonathan Cast wrote:
> > > This has been answered repeatedly, at least implicitly.  Unless you
> > > insist that getWhatever should live in the IO monad and have no
> > > functional arguments (why?), there is no reason why this should be
> > > impossible.
> > > 
> > >> What's more, there seems to be no good *semantic* reason why this should
> > >> not be possible. The only objections seem dogmatic to me.
> > > 
> > > I haven't seen you give a non-dogmatic reason for wanting global
> > > variables yet, either.
> > 
> > You consider real examples from real *standard* libs that we're all 
> > using (and presumably not written by clueless hackers such as myself)
> > to be dogmatic?
> 
> Yeah.  Same as if the examples were APIs from ML, or Lisp.  The neat
> thing about Haskell is *precisely* that the ML I/O system has an API
> that is illegal in Haskell.  I see no reason, in principle, why the
> Haskell standard libraries shouldn't contain APIs that should be illegal
> in new-and-improved Future Haskell.
> 
> > I would call that pragmatic myself. These are the
> > standard libs after all. Shouldn't we expect them to be the perfect
> > examples of how to do things rite?
> > 
> > >> But even if someone does produce an entirely unsafePerformIO hack
> > >> free set of standard libs, I have to ask why jump through all these
> > >> hoops?
> > > 
> > > To improve the APIs available?
> > 
> > There's nothing wrong with the APIs as they are as far as I am
> > concerned.
> 
> Right.  That's exactly what we're arguing about.  We maintain they are
> inferior.  You haven't really given any defense of them at all, other
> than their existence.  I consider that a rather weak argument.
> 
> >  It's their implemenation that's the problem.
> > 
> > >  You're advocating an extension to a
> > > *purely functional programming language*.
> > 
> > So? What's being proposed doesn't compromise referential transparency
> > (at least no more that the IO monad already does, as some might argue).
> 
> What's a referential transparency?  I just want a language completely
> specified by its denotational semantics, in the obvious fashion (e.g.,
> (->) maps to an exponential in a real category).
> 
> If IO compromises that (heck, who am I kidding, *since* IO compromises
> that), I'm arguing we get rid of whatever features it has that are
> questionable.
> 
> > >> There's no semantic difficulty with the proposed language
> > >> extension,
> > > 
> > > Although I've noticed it's grossly under-powered compared to what's
> > > needed to implement stdin the way you want to.
> > 
> > Can't recall expressing any opinion about how stdin should be
> > implemented so I don't know what your on about here.
> 
> Well, you didn't like *my* implementation.  You seem to be rather keen
> on the current implementation GHC happens to use, where stdin contains
> internally a mutable buffer.  You also seem to be rather insistent that,
> whatever mechanism GHC uses to get that mutable buffer, be useable to
> create *any other top-level handle* I want.  Now, I happen to know that
> the only top-level handles that can be established without issuing an
> open system call are
> 
> stdin
> stdout
> stderr
> 
> (unless you're happy to have your global nonStdErr start its life
> attached to an unopened FD).  I really don't see what your point is,
> unless you want to be able to `call open at the top level'.
> 
> On Thu, 2008-08-28 at 22:01 +0100, Adrian Hey wrote: 
> > Ganesh Sittampalam wrote:
> > > On Thu, 28 Aug 2008, Adrian Hey wrote:
> > > 
> > >> implicit parameters (a highly dubious language feature IMO).
> > > 
> > > How can you say that with a straight face at the same time as advocating 
> > > global variables? :-)
> > 
> > Quite easily, what's the problem? IORefs, Chans etc are perfectly
> > ordinary values. Why should they not exist at the top level?
> 
> They aren't the denotations of any closed Haskell expressions.  Scarcely
> `perfectly ordinary'.
> 
> > The "global variable" lives in "the world", not the IORef. The
> > IORef is just a reference, no different from filepaths in principle
> 
> You didn't like my implementation of stdout along those lines, though...
> 
> > (and if having them at the top level is also evil then making this
> > so easy and not screaming about it seems a little inconsistent to me).
> 
> Good point.  We don't just pretend that filepaths make sense in
> themselves, independently of context.  (Or would you like to tell me
> what the contents of
> ~/src/globalscript-0.0.1/Language/GlobalScript/Syntax.lhs are?)  In
> fact, this mailing list is dedicated to a language that has the radical
> idea that you should have to use a whole different type (built using
> this scary category-theoretical concept called a `monad') just to
> associate filepaths with file contents. 

All true.  But nevertheless reading it over I think I need to step away
from this and cool down a little.

jcc




More information about the Haskell-Cafe mailing list