From: skaller <skaller@users.sourceforge.net>
To: Alain.Frisch@ens.fr
Cc: caml-list <caml-list@inria.fr>
Subject: Re: [Caml-list] Reading a large text file
Date: 02 May 2004 06:40:08 +1000 [thread overview]
Message-ID: <1083444008.20722.135.camel@pelican.wigram> (raw)
In-Reply-To: <Pine.SOL.4.44.0405012146130.21993-100000@clipper.ens.fr>
On Sun, 2004-05-02 at 05:51, Alain.Frisch@ens.fr wrote:
> On 2 May 2004, skaller wrote:
>
> > It can now do slightly better than that. It is possible to use
> > the new 'private' keyword to *guard* your mutable list.
> >
> > module MList = struct
> > type 'a mylist = private { head : 'a; mutable tail : 'a mylist option; }
> > ..
> > let splice a b = ...(* makes a new mylist of a @ b *)
> > end
> > Here, lists are immutable *publically*.
>
> Not quite.
>
> First, the "private" keyword should be used only in the signature, not the
> structure, otherwise the implementation of the module has no special
> right. Something like:
>
> module M :
> sig type t = private *** end
> =
> struct type t = *** end
Thanks for the correction. Also note I chose a *really bad name*
when I called it 'splice': the intent was to construct
a new list as stated, so I should have just called it 'concat'.
Of course you could make a list with an actual splice mutator,
but then it wouldn't be immutable.
> Second, the client cannot create values of the "private" type. This is
> not related at all with the mutability of the fields. It can only
> deconstruct values (with pattern matching).
Right. Well stated.
Hmm ..
module M : sig
?? type 'a t = private 'a list
val uniq_cons: 'a t -> 'a -> 'a list
val empty: unit -> 'a list
end = struct
type 'a t = 'a list
let uniq_cons lst a = if List.mem a lst then lst else a::lst
let empty () = []
end
;; ;;
Syntax error: 'end' expected, the highlighted 'sig' might be unmatched
Arggg.. what's wrong here? It has nothing to do with
either private or type variables, and the above sig
fails immediately in a module type statement too.
--
John Skaller, mailto:skaller@users.sf.net
voice: 061-2-9660-0850,
snail: PO BOX 401 Glebe NSW 2037 Australia
Checkout the Felix programming language http://felix.sf.net
-------------------
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:[~2004-05-01 20:40 UTC|newest]
Thread overview: 14+ messages / expand[flat|nested] mbox.gz Atom feed top
2004-04-28 15:28 André Luiz Moura
2004-04-28 16:28 ` Richard Jones
2004-05-01 14:03 ` Brian Hurt
2004-05-01 15:43 ` Rahul Siddharthan
2004-05-01 16:00 ` [Caml-list] [OcamlDoc] langage support sejourne kevin
2004-05-14 7:15 ` Maxence Guesdon
2004-05-01 18:05 ` [Caml-list] Reading a large text file Richard Jones
2004-05-01 18:25 ` Charles Forsyth
2004-05-01 19:25 ` skaller
2004-05-01 19:51 ` Alain.Frisch
2004-05-01 20:40 ` skaller [this message]
2004-05-01 21:11 ` [Caml-list] Private types skaller
2004-05-01 21:33 ` [Caml-list] Reading a large text file Alain.Frisch
2004-05-17 5:28 ` Eric Stokes
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=1083444008.20722.135.camel@pelican.wigram \
--to=skaller@users.sourceforge.net \
--cc=Alain.Frisch@ens.fr \
--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