From: John Prevost <j.prevost@cs.cmu.edu>
To: "Caml-list" <caml-list@inria.fr>
Subject: [Caml-list] Serious typechecking error involving new polymorphism (crash)
Date: 30 Jul 2002 03:46:31 -0400 (32.397 UMT) [thread overview]
Message-ID: <86vg6xlktk.fsf_-_@laurelin.dementia.org> (raw)
In-Reply-To: <000f01c2377c$36263060$2097fea9@janxp>
I've discovered a fairly serious typechecking bug in 3.05. I'm
reporting it on the webpage, but also want to mention it here so that
people are aware.
You can do the following:
# type bad = { x : 'a . 'a option ref };;
type bad = { x : 'a. 'a option ref; }
# let bv = { x = ref None };;
val bv : bad = {x = {contents = None}}
# bv.x := Some 5;;
- : unit = ()
# let extra_bad = !(bv.x);;
val extra_bad : '_a option = Some <poly>
# f extra_bad;;
***CRASH***
It looks like mutable fields are handled correctly and catch that the
value is not, in fact, general enough. But when the mutable field is
part of the value (in this case, part of the ref), the check is not
done.
To be safe, I recommend being very wary of using field types like:
'a . <type expression involving 'a>
In which values of the type involve mutable portions of type 'a. As
long as any mutable portion is not also polymorphic, things are fine.
Mutable fields are fine as well, as long as you are careful as
described above.
As an example, Using
mutable x : 'a . 'a option
instead of
x : 'a . 'a option ref
in the above example prevents any poorly typed expressions from
appearing. No value may be put in the "good" example except None,
since None is the only fully polymorphic option value.
John.
-------------------
To unsubscribe, mail caml-list-request@inria.fr Archives: http://caml.inria.fr
Bug reports: http://caml.inria.fr/bin/caml-bugs FAQ: http://caml.inria.fr/FAQ/
Beginner's list: http://groups.yahoo.com/group/ocaml_beginners
next prev parent reply other threads:[~2002-07-30 7:39 UTC|newest]
Thread overview: 25+ messages / expand[flat|nested] mbox.gz Atom feed top
2002-07-29 12:45 [Caml-list] OCaml 3.05 released Xavier Leroy
2002-07-29 14:36 ` Nicolas Cannasse
2002-07-30 0:46 ` Shawn Wagner
2002-07-30 3:50 ` Scott J.
2002-07-30 7:34 ` John Prevost
2002-07-30 7:46 ` John Prevost [this message]
2002-07-30 7:58 ` [Caml-list] Serious typechecking error involving new polymorphism (crash) Xavier Leroy
2002-07-30 8:22 ` John Prevost
2002-07-30 8:47 ` Xavier Leroy
2002-07-30 8:37 ` Sven LUTHER
2002-07-30 14:11 ` [Caml-list] bug-fix branches Xavier Leroy
2002-07-30 16:15 ` Sven LUTHER
2002-08-01 9:37 ` [Caml-list] 3.05 and future 3.06 binary compatibility ? root
2002-08-01 12:09 ` [Caml-list] " Xavier Leroy
2002-08-01 15:56 ` Sven LUTHER
2002-08-08 8:37 ` Sven LUTHER
2002-08-09 12:25 ` Xavier Leroy
2002-08-09 13:16 ` Sven LUTHER
2002-07-30 7:51 ` [Caml-list] OCaml 3.05 released Dmitry Bely
2002-07-30 15:01 ` Scott J.
2002-07-30 15:11 ` Dmitry Bely
2002-08-02 5:31 ` Jacques Garrigue
2002-08-02 11:15 ` Tim Freeman
2002-07-30 7:48 ` [Caml-list] Record with one non mutable filed Christophe Raffalli
2002-07-30 11:49 ` [Caml-list] OCaml 3.05 released Yaron M. Minsky
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=86vg6xlktk.fsf_-_@laurelin.dementia.org \
--to=j.prevost@cs.cmu.edu \
--cc=caml-list@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