caml-list - the Caml user's mailing list
 help / color / mirror / Atom feed
From: Aleksey Nogin <nogin@metaprl.org>
To: Nicolas Pouillard <nicolas.pouillard@gmail.com>,
	Caml List <caml-list@inria.fr>
Subject: Re: [Caml-list] 3.10+beta: Camlp4: AST mapping treats record labels as patterns; should they have type ident instead?
Date: Wed, 18 Apr 2007 09:13:49 -0700	[thread overview]
Message-ID: <462643BD.8050309@metaprl.org> (raw)
In-Reply-To: <cd67f63a0704180111m6fa1a7fx8f21c322d583b710@mail.gmail.com>

On 18.04.2007 01:11, Nicolas Pouillard wrote:

> Why do you mix the old definition of PaRec with the new definition of 
> ExRec.

Because I got confused and looked it up in the wrong place, sorry.

> I recall them:
> 
> Before:
> 
>  | PaRec of loc and list (patt * patt)
> 
>  | ExRec of loc and list (patt * expr) and option expr
> 
> Now:
> 
>    (* { p } *)
>    | PaRec of Loc.t and patt
> 
>    (* { b } or { (e) with b } *)
>    | ExRec of Loc.t and binding and expr
> 
> To fully understand here is a fragment of pattern and binding grammars:
> 
> patterns, p ::= ... | { p } | p1 = p2 | p1 ; p2
> 
> bindings, b ::= ... | p = e | b ; b
> 
>> where the binding can bind arbitrary patterns to expressions. This was
>> not a big issue prior to 3.10, but now that 3.10 provides very powerful
>> mapping and folding features, this seems a bit problematic. Namely, if I
>> define a Camlp4 filter or an AST mapping function that affects patterns,
>> the array labels will get affected as well, often in an undesired way.
> 
> It's undesired, but there is an easy workaround:
> 
> ....
> method patt p =
>  match p with
>  | ...
>  | <:patt@loc< $p1$ = $p2$ >> -> <:patt@loc< $p1$ = $super#patt p2$ >>
>  | ...
> ....

That might helps, thanks! But this will only solve the PaRec problem, 
not the ExRec one, right? There is no easy way to distinguish the real 
bindings from the record ones (other than changing the expr method to do 
something completely separate in the ExRec case).

>> Would it be better to have
>>    PaRec of loc and list (ident * patt)
>> and
>>    ExRec of loc and list (ident * expr) and expr
>> instead?
> 
> There is no more lists in the camlp4 AST, that's a price to pay to
> have consistency w.r.t quotations.
> 
> For patterns there is something doable:
> 
>    | PaEq  of Loc.t and patt and patt (* p = p *)
> Can become
>    | PaEq  of Loc.t and ident and patt (* i = p *)
> 
> Since that node is only used with an ident on his left.

Yes, this sounds like a good thing to do.

> For expressions it's more complex
>
Is it the same issue as the workaround discussion above - the "proper" 
way to make this distinction would be to introduce a separare 
rec_binding type similar, but separate from the binding one? But is it 
true that the "b; b" case in the binding type is only used for records? 
If so, it would seem that splitting the binding type would not result in 
that much duplication. Of course, I am only starting to understand the 
new setup, no I may be completely wrong here.

Aleksey


  reply	other threads:[~2007-04-18 16:13 UTC|newest]

Thread overview: 5+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2007-04-17 17:50 Aleksey Nogin
2007-04-18  8:11 ` [Caml-list] " Nicolas Pouillard
2007-04-18 16:13   ` Aleksey Nogin [this message]
2007-04-20 15:17     ` Nicolas Pouillard
2007-05-03  9:16       ` Nicolas Pouillard

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=462643BD.8050309@metaprl.org \
    --to=nogin@metaprl.org \
    --cc=caml-list@inria.fr \
    --cc=nicolas.pouillard@gmail.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).