From: Jacques Garrigue <garrigue@kurims.kyoto-u.ac.jp>
To: Judicael.Courant@lri.fr
Cc: caml-list@pauillac.inria.fr
Subject: Re: Typechecking of recursive variants
Date: Mon, 15 May 2000 09:33:35 +0900 [thread overview]
Message-ID: <20000515093335H.garrigue@kurims.kyoto-u.ac.jp> (raw)
In-Reply-To: Your message of "Fri, 12 May 2000 16:34:08 +0200 (MEST)" <200005121434.QAA12123@pc87.lri.fr>
From: Judicael Courant <Judicael.Courant@lri.fr>
> Objective Caml version 3.00
>
> # let rec x n = if n = 0 then `Y else `X (x (n-1));;
> val x : int -> ([> `Y | `X of 'a] as 'a) = <fun>
> # x 3;;
> - : _[> `Y | `X of '_a] as 'a = `X (`X (`X `Y))
> # match x 4 with `X z -> z | `Y -> assert false;;
> - : [ `Y | `X of '_a] as 'a = `X (`X (`X `Y))
>
>
> What do these underscores mean ? Anything to do with monomorphic type
> variables ?
Exactly. Since "x 3" is an application, its result must be
monomorphic.
But in fact the _ in '_a is a bug :-)
In recursive variants, the monomorphism is not indicated on the
abbreviation, but on the variant type itself (like for objects).
So the right types would be
# x 3;;
- : _[> `Y | `X of 'a] as 'a = `X (`X (`X `Y))
# match x 4 with `X z -> z | `Y -> assert false;;
- : [ `Y | `X of 'a] as 'a = `X (`X (`X `Y))
Notice that there is no monomorphism annotation in the second type,
since it cannot be refined anymore.
> Why is not there any ">" at the beginning of the latest
> type ?
Your original type was [> `Y | `X of 'a], and you matched it with
cases producing the type [< `Y | `X of 'a]. By unification, the
result is [< `Y | `X of 'a > `Y | `X], or, in abbreviated form,
[`Y | `X of 'a] since all constructors are required.
Since you type was monomorphic, this unification affects the type
of "x 4", which is also the type of the argument of `X.
Jacques
---------------------------------------------------------------------------
Jacques Garrigue Kyoto University garrigue at kurims.kyoto-u.ac.jp
<A HREF=http://wwwfun.kurims.kyoto-u.ac.jp/~garrigue/>JG</A>
prev parent reply other threads:[~2000-05-15 20:09 UTC|newest]
Thread overview: 2+ messages / expand[flat|nested] mbox.gz Atom feed top
2000-05-12 14:34 Judicael Courant
2000-05-15 0:33 ` Jacques Garrigue [this message]
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=20000515093335H.garrigue@kurims.kyoto-u.ac.jp \
--to=garrigue@kurims.kyoto-u.ac.jp \
--cc=Judicael.Courant@lri.fr \
--cc=caml-list@pauillac.inria.fr \
/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