From: Alessandro Baretta <alex@baretta.com>
To: Ocaml <caml-list@inria.fr>
Subject: Re: [Caml-list] record declaration, SML
Date: Fri, 10 Jan 2003 08:45:42 +0100 [thread overview]
Message-ID: <3E1E7A26.301@baretta.com> (raw)
In-Reply-To: <Pine.LNX.4.44.0301091915280.23221-100000@grace.speakeasy.net>
brogoff@speakeasy.net wrote:
> On Fri, 10 Jan 2003, Alessandro Baretta wrote:
>>So, in order to define just one value one needs to define an
>>entire class as in the following example.
>>
>>class f_one = object method f = 1 end
>>let res = C (new f_one)
>
>
> Is this such a big problem? I imagine we're more likely to provide a
> smart constructor for t, something like
>
> let mkC o = C(o :> < f : int >)
No, it's not a bit problem. I was just wondering
> and just stuff any object with method f : int in there. If we only want there
> to be one kind of thing, we're better off using a record. Of course, Daniel
> doesn't have that option since he is discussing a syntactic transformation
> from SML records into OCaml constructs, and hence using the class system makes
> sense on account of the differences between SML record typing and that of
> OCaml.
Besides, Daniel showed us that you can actually define a
record on the fly without cluttering the class namespace.
let module M =
struct
class a = object val f = 1 method f = f end
end
in
C (new M.a)
This raises one more question:
let module P =
struct type t = { f : int } let x = { f = 1 } end
in P.x;;
The above is not valid Ocaml because P.x has a type which
escapes its scope. This is quite evident. Now I would expect
Daniel's code to be rejected by the same standards, but it
is not. Why? Does class a not escape its scope?
>
>>BTW, why is something like the above not in the language? It
>>seems only natural to have such a feature since an analogous
>>construct exists for structs.
>
>
> There are no anonymous records (like SML has) either, so if you see classes as
> analogous to records rather than structs it doesn't seem so unnatural. No, I
> realize that's not a real explanation.
Right. Even unnamed records are missing. But it's different
because the Ocaml type system does not support record
subtyping--even if record type b in module B defines all
fields of record type a in module A with the same types, B
is not a subtype of A. On the other hand, object subtyping
exists already in the language, so on-the-fly definitions of
objects à la façon de Daniel are more meaningful and useful.
Alex
-------------------
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
prev parent reply other threads:[~2003-01-10 7:43 UTC|newest]
Thread overview: 10+ messages / expand[flat|nested] mbox.gz Atom feed top
2003-01-09 13:56 A. Ozmen
2003-01-09 18:27 ` brogoff
2003-01-09 23:15 ` A. Ozmen
2003-01-10 9:21 ` Xavier Leroy
2003-01-10 14:34 ` brogoff
2003-01-09 22:42 ` Daniel de Rauglaudre
2003-01-09 23:14 ` Alessandro Baretta
2003-01-10 2:59 ` Daniel de Rauglaudre
2003-01-10 3:45 ` brogoff
2003-01-10 7:45 ` Alessandro Baretta [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=3E1E7A26.301@baretta.com \
--to=alex@baretta.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