caml-list - the Caml user's mailing list
 help / color / mirror / Atom feed
From: Luc Maranget <Luc.Maranget@inria.fr>
To: dsyme@microsoft.com (Don Syme)
Cc: caml-list@inria.fr
Subject: Re: [Caml-list] Multi-matches & "when", also binding values in "when" clauses
Date: Tue, 3 Apr 2001 17:06:42 +0200 (MET DST)	[thread overview]
Message-ID: <200104031506.RAA0000012691@beaune.inria.fr> (raw)
In-Reply-To: <0C682B70CE37BC4EADED9D375809768A48FD8B@red-msg-04.redmond.corp.microsoft.com> from "Don Syme" at avr 03, 2001 05:54:16

> 
> 
> Some questions on pattern matching....
> 
> 1. - Multi-matches & "when"
> 
> I've just discovered that one can write
> 
> match x with
>   | C _   | D _ -> ...
>   | E | F -> ...
> 
> to catch multiple patterns by single cases.  However, if you guard the
> patterns with "when" clauses, you must guard all the patterns att once
> 
> match x with
>   | C _   | D _ when !foo =3D 3 -> ...
>   | E | F -> ...
> 
> Here the "when" clause covers matches against both C and D.  Is there
> any good reason for this?  It seems reasonable to be able to write
> 
> match x with
>   | C _  when !foo =3D 4 | D _ when !foo =3D 3 -> ...
>   | E | F -> ...
> 
> Are there any plans for this?
No. For the moment, you can see
``when expr'' as part of  the r.h.s, not as part of the pattern.
Your idea is new to me.
The concrete syntax is misleading.



> 
> 
> 2. - Multiple binding in patterns
> 
> It would sometimes be nice to bind variables twice in different
> patterns, as in=20
> 
> match x with
>   | C y | D y -> ...
>   | E | F -> ...
> 
> Are there any plans for this?
This feature is available in version 3.01.


> 
> 
> 3. Binding values in "when" clauses
> 
> It would be very nice to be able to bind things in the "when" clauses
> and have them visible on the r.h.s.
> 
> match x with
>   | C y  in=20
>       let z =3D y + 4 in=20
>       when !foo =3D z -> f z
>   | D _ -> ...
> 
It cannot be done either.
At some point and for other purposes we considered a ``with''
construct in patterns.
``with x = expr'' binds x to expr and always match.
(This would achieve what you what, without the let ... in when ..
which I find rather exotic)
(with could also be used in or-patterns as in
``([x] | ([] with x=0))'' for instance 
I am unsure whether this would be very useful or not, considering that
implementation effort is non-neglectible.



A first problem with your constructs would be givng them
a proper semantics.
I see a simple solution :

Consider the variables bound in pat to be accessible in expr.
Semantics is quite clear btw
 - ``pat when expr'' matches when pat matches and expr is true
 - ``pat with x=expr'' matches when pat matches and add an extra binding
   As regards PM compilation, this looks feasible.
  Additionnaly the scope of the variables bound in pat includes expr.
  Compilation of these two constructs looks feasible.


A second, practical, problem would be that patterns syntax would now
include expressions, which would probably involve serious modifications
of all passes in the front end of the compiler (before PM
compilation).



Cheers, thank you for your interest in Caml

> Don

--Luc 
-------------------
To unsubscribe, mail caml-list-request@inria.fr.  Archives: http://caml.inria.fr


  parent reply	other threads:[~2001-04-03 15:06 UTC|newest]

Thread overview: 4+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2001-04-03 12:54 Don Syme
2001-04-03 13:00 ` Nicolas barnier
2001-04-03 15:06 ` Luc Maranget [this message]
2001-04-03 17:57 ` Pierre Weis

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=200104031506.RAA0000012691@beaune.inria.fr \
    --to=luc.maranget@inria.fr \
    --cc=caml-list@inria.fr \
    --cc=dsyme@microsoft.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).