Mailing list for all users of the OCaml language and system.
 help / color / mirror / Atom feed
From: "John Hughes" <jfh@cs.brown.edu>
To: "'Xavier Leroy'" <xavier.leroy@inria.fr>
Cc: "'caml-list'" <caml-list@inria.fr>
Subject: RE: [Caml-list] Why must types be always defined at the top level?
Date: Thu, 24 Jun 2004 21:46:11 +0200	[thread overview]
Message-ID: <20040624194603.2A91010EF06@clark.cs.brown.edu> (raw)
In-Reply-To: <20040624194553.A27745@pauillac.inria.fr>

Thanks for the answers.  
> > 1. Why no eqtypes? 
> 
> Eqtypes have been hotly debated even among the SML designers. 
>  My feeling is that it's not worthwhile to have a special, 
> hard-wired mechanism in the type checker just for the sake of 
> equality.  

Agreed. One of our students, a year ago, after being told about
eqtypes, asked "is there something like 'numtype' too, so
that we can tell whether it's OK to do arithmetic?" (Recall
this was SML, where "+" is overloaded.) It was clear that
the idea *behind* eqtypes should be extended ... but the alternative,
of removing them entirely, is just as consistent, I suppose. 

> > 2. Why no "end" on "let" expressions, i.e.,
> [History]
> 
> > 3. Why semicolons for separating list items, so that
> > 
> >   [2,3] is interpreted as [(2,3)] ? 
> 
> [Why not?]

Fair enough. 
 
> > 4. Why expose the hardware with "float" ...
> 
> Unless a language offers exact-precision arithmetic on 
> computable reals, I strongly object to the use of the word 
> "real" to refer to what's merely floating-point numbers.  

This from someone who uses "int" to mean something other than
"integer"! :-)

> Floats aren't reals by any stretch of the imagination, and 
> the earlier the programmer realizes this, the better.  

Agreed. And deference to Bill Kahan is generally a good idea. 

---
I have one more question, though: 

5. Why can I no longer type-annotate things I've written, so that

let f x y z = (x = y) & (y = z)

defines a function applicable to ALL types? I actually *liked*
being able to say something like

let f x y z:int = (x = y) && (y = z)

so that it would be restricted to ints. (It frequently helped me to 
untangle cryptic error messages that ML produced, AND to document
my intent as I wrote code). I can still 
trick it into doing that, by something like

let f = function
  | (x,y,z) -> (x==y) && (y == z)
  | (a,b,_) -> (a-b) = 0;;

which will turn out to never invoke the second case, but still
restrict the 
type. But surely this is not more readable/maintainable code...(Yes, I
know
it has a slightly different signature, but I didn't have the heart to 
work around that just now). 

Thanks again for the informative answers. 

-John Hughes

-------------------
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


  reply	other threads:[~2004-06-24 19:46 UTC|newest]

Thread overview: 37+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2004-06-22 22:41 Richard Jones
2004-06-22 22:53 ` Markus Mottl
2004-06-22 23:32   ` skaller
2004-06-23 12:01     ` Andreas Rossberg
2004-06-23 14:45       ` skaller
2004-06-23 16:28         ` Andreas Rossberg
2004-06-23 20:21           ` skaller
2004-06-23 20:52             ` skaller
2004-06-24 14:27               ` John Hughes
2004-06-24 16:47                 ` Andreas Rossberg
2004-06-24 17:30                   ` Markus Mottl
2004-06-24 17:45                 ` Xavier Leroy
2004-06-24 19:46                   ` John Hughes [this message]
2004-06-24 19:56                     ` David Brown
2004-06-24 19:57                     ` William D. Neumann
2004-06-24 20:13                       ` Olivier Andrieu
2004-06-24 23:26                     ` Brian Hurt
2004-06-25 10:20                     ` skaller
2004-06-25 11:07                       ` Basile Starynkevitch [local]
2004-06-25 12:30                         ` skaller
2004-06-25 14:38                           ` [Caml-list] Thread and kernel 2.6 pb still there in CVS Christophe Raffalli
2004-06-25 16:08                             ` [Caml-list] " Marco Maggesi
2004-06-25 16:32                               ` Markus Mottl
2004-06-28 15:08                             ` [Caml-list] " Xavier Leroy
2004-06-28 18:50                               ` Benjamin Geer
2004-06-29  2:26                               ` Christophe Raffalli
     [not found]                                 ` <7AFB5F64-C944-11D8-975C-00039310CAE8@inria.fr>
     [not found]                                   ` <40E11621.3050709@univ-savoie.fr>
2004-07-05 15:14                                     ` Christophe Raffalli
2004-07-05 16:34                                       ` Xavier Leroy
2004-07-06  9:33                                         ` Alex Baretta
2004-07-08 13:51                                           ` Christophe Raffalli
2004-07-08 15:03                                             ` Xavier Leroy
2004-07-09 23:21                               ` Donald Wakefield
2004-07-10 10:56                                 ` Damien Doligez
2004-06-24 23:23                   ` [Caml-list] Why must types be always defined at the top level? Brian Hurt
     [not found]                     ` <Pine.LNX.4.44.0406241813370.4202-100000@localhost.localdom ain>
2004-06-26 23:08                       ` Dave Berry
2004-06-25  1:59                   ` Yaron Minsky
2004-06-24 23:08                 ` Brian Hurt

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=20040624194603.2A91010EF06@clark.cs.brown.edu \
    --to=jfh@cs.brown.edu \
    --cc=caml-list@inria.fr \
    --cc=xavier.leroy@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