Ian Lynagh wrote:
Context if you haven't been following:
http://hackage.haskell.org/trac/ghc/ticket/1215

On Tue, Mar 13, 2007 at 03:12:33PM -0000, GHC wrote:
 Interesting.  It turns out I misinterpreted the Haskell lexical syntax:
 GHC lexes `M.default` as `M` `.` `default`, because `M.default` is not a
 valid qvarid but I neglected to take into account the maximal munch rule.

 We have an open ticket for Haskell' about this:
 
http://hackage.haskell.org/cgi-bin/haskell-prime/trac.cgi/wiki/QualifiedIdentifiers
 which was until just now
 inaccurate (I've now fixed it).  I propose to fix GHC in 6.8 to match the
 Haskell' proposal.

If I understand correctly then the proposal would make e.g.

    foo = Bar.where

a syntactically valid program, but one which would be guaranteed to fail
to compile with a not-in-scope error?

Wouldn't it be cleaner for it to be a lexical error? Unfortunately I'm
not sure how to say this in the grammar; the best I can come up with is:

    program      ->      {lexeme | whitespace | error }
    error        ->      [ modid . ] reservedid

Or make lexeme overlap with error, and do this:

     program  -> { lexeme_<error> | whitespace }

to make it clear that a valid program doesn't contain any error lexemes. But then people might wonder why the error production doesn't contain all the lexical errors.

I don't really have a strong opinion here, but I lean towards not doing this, on the grounds that it's not strictly necessary and I'm a bit of a minimalist. The compiler is already free to report the error as a lexical error if it likes.

Cheers,
        Simon
_______________________________________________
Haskell-prime mailing list
Haskell-prime@haskell.org
http://www.haskell.org/mailman/listinfo/haskell-prime

Reply via email to