Mailing list for all users of the OCaml language and system.
 help / color / mirror / Atom feed
From: Dmitry Lomov <dmitry.lomov@jetbrains.com>
To: caml-list@inria.fr
Subject: Re: [Caml-list] Observations on OCaml vs. Haskell
Date: Wed, 29 Sep 2004 19:03:01 +0400	[thread overview]
Message-ID: <415ACEA5.50800@jetbrains.com> (raw)
In-Reply-To: <Pine.LNX.4.44.0409290925010.5809-100000@localhost.localdomain>

Brian Hurt wrote:
> On Tue, 28 Sep 2004, Jon Harrop wrote:
> 
> 
>>On Tuesday 28 September 2004 08:22, Ville-Pertti Keinonen wrote:
>>
>>>I'm fairly certain that type safety is a significant part of the reason;
>>>if they were polymorphic, they'd accept any kind of arguments, not just
>>>numbers.  What's the product of two strings?  A run-time type error?
>>
>>It seems odd then, that the polymorphic comparisons do raise run-time type 
>>errors (on functions). I guess that's just the way the cookie crumbled...
>>
>>I think a static analysis program to pick up on such problems could be very 
>>useful...
> 
> 
> This gets tricky, I would think.  One thing I don't want to lose is the 
> ability to make ('a -> 'b) list types.  Comparing two functions is 
> obviously bogus, but in most other places being able to handle both 
> functions and data is a usefull thing.
> 
Apparently one needs some sort of bounded quantification on polymorphic 
functions, bound being "'a can be anything but a function".

Interestingly, one already can have the quantification bounded other way 
round ("'a can be any function") - just write 'b -> 'c instead of 'a. 
This bounding corresponds, of course,  to partial order imposed by type 
unification.

Friendly,
Dmitry
-- 
Dmitry Lomov
JetBrains Inc.
http://www.jetbrains.com
"Develop With Pleasure!"

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


  parent reply	other threads:[~2004-09-29 15:03 UTC|newest]

Thread overview: 18+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2004-09-27 19:08 John Goerzen
2004-09-27 20:24 ` Rafael 'Dido' Sevilla
2004-09-27 21:34   ` Danny Yoo
2004-09-28  7:22     ` Ville-Pertti Keinonen
2004-09-28 18:02       ` Jon Harrop
2004-09-29 14:26         ` Brian Hurt
2004-09-29 14:20           ` Jon Harrop
2004-09-29 15:03           ` Dmitry Lomov [this message]
2004-09-28 10:10     ` [Caml-list] Caml monomorphisation (was Observations on OCaml vs. Haskell) Diego Olivier Fernandez Pons
2004-09-28 12:01       ` Richard Jones
2004-09-28 17:50       ` Jon Harrop
2004-09-28  1:56   ` [Caml-list] Observations on OCaml vs. Haskell skaller
2004-09-28  9:31   ` Keith Wansbrough
2004-09-28  9:55     ` Rafael 'Dido' Sevilla
2004-09-27 21:11 ` Christophe TROESTLER
2004-09-28  1:32 ` Jacques GARRIGUE
2004-09-28  1:46 ` skaller
2004-09-28  8:27 ` Richard Jones

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=415ACEA5.50800@jetbrains.com \
    --to=dmitry.lomov@jetbrains.com \
    --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