From: John Max Skaller <skaller@ozemail.com.au>
To: Chris Hecker <checker@d6.com>
Cc: caml-list@inria.fr
Subject: Re: [Caml-list] recursive modules redux, & interface files
Date: Wed, 21 Mar 2001 04:43:54 +1100 [thread overview]
Message-ID: <3AB796DA.ABD786B1@ozemail.com.au> (raw)
In-Reply-To: <4.3.2.7.2.20010319034052.00d72ef0@shell16.ba.best.com>
Chris Hecker wrote:
>
> > Because types in a given implementation may or may not be present
> >in the interface.
>
> Right, that's fine, but I only want to have them once, whereever they are. So, if it's a private type, it's in the ml file, and if it's public it's in the mli file (assuming I want one, if I don't then everything's public). How does having them duplicated buy me anything but trouble?
>
> Chris
In C++, a function is either extern or static.
There are only two options. [And non-local classes are _always_ extern]
This is not so in Ocaml: you may wish to provide access to a component
such as a function with a type more constrained than the actual
implementation.
For example:
(* twoint.mli *)
val twoint: int -> int * int
(* twoint.ml *)
let twoint x = (x,x)
Here, the implementation is actually polymorphic, it will work
for more than ints, but clients of the module 'twoint' cannot
use this function to make a pair of floats.
Here is another example:
(* abstr.mli *)
type t
val get: t -> int
val make: int -> t
(* abstr.ml *)
type t = int * int
let get x = fst x
let make x = (x,x+1)
Here, the type t is implemented as a pair of ints.
But the implementation is hidden from the client of the module.
Note that the type 't' itself is not hidden.
--
John (Max) Skaller, mailto:skaller@maxtal.com.au
10/1 Toxteth Rd Glebe NSW 2037 Australia voice: 61-2-9660-0850
checkout Vyper http://Vyper.sourceforge.net
download Interscript http://Interscript.sourceforge.net
-------------------
To unsubscribe, mail caml-list-request@inria.fr. Archives: http://caml.inria.fr
next prev parent reply other threads:[~2001-03-20 18:18 UTC|newest]
Thread overview: 48+ messages / expand[flat|nested] mbox.gz Atom feed top
2001-03-18 23:05 Chris Hecker
2001-03-19 0:01 ` Brian Rogoff
2001-03-19 11:04 ` John Max Skaller
2001-03-19 11:41 ` Chris Hecker
2001-03-20 17:43 ` John Max Skaller [this message]
2001-03-21 4:03 ` Chris Hecker
2001-03-21 5:10 ` Patrick M Doane
2001-03-21 9:27 ` Chris Hecker
2001-03-21 18:20 ` John Max Skaller
2001-03-22 0:03 ` Patrick M Doane
2001-03-22 0:22 ` Brian Rogoff
2001-03-22 10:26 ` [Caml-list] duplication implementation/interface Judicael Courant
2001-03-22 11:16 ` [Caml-list] about typedefs... (was: duplication implementation/interface) Olivier Andrieu
2001-03-22 17:14 ` [Caml-list] duplication implementation/interface Brian Rogoff
2001-03-22 9:11 ` [Caml-list] recursive modules redux, & interface files Francois Pottier
2001-03-21 23:24 ` John Prevost
2001-03-22 0:00 ` Patrick M Doane
2001-03-21 18:18 ` John Max Skaller
2001-03-21 18:19 ` John Max Skaller
2001-03-22 11:40 ` Markus Mottl
2001-03-21 18:41 ` Xavier Leroy
2001-03-22 0:23 ` Patrick M Doane
2001-03-22 12:02 ` Hendrik Tews
2001-03-22 13:01 ` Markus Mottl
2001-03-22 16:56 ` Brian Rogoff
2001-03-22 17:13 ` Daniel de Rauglaudre
2001-03-23 17:30 ` Fergus Henderson
2001-03-23 18:04 ` Brian Rogoff
2001-03-23 20:35 ` [Caml-list] Why People Aren't Using OCAML? (was Haskell) Mattias Waldau
2001-03-26 2:29 ` [Caml-list] recursive modules redux, & interface files Fergus Henderson
2001-03-27 22:11 ` John Max Skaller
2001-03-28 4:30 ` Brian Rogoff
2001-04-05 17:07 ` John Max Skaller
2001-03-27 8:21 ` Hendrik Tews
2001-03-30 10:27 ` [Caml-list] parser combinators Kevin Backhouse
2001-04-08 18:28 ` Daniel de Rauglaudre
2001-03-22 11:55 [Caml-list] recursive modules redux, & interface files Dave Berry
2001-03-22 12:01 ` Markus Mottl
2001-03-27 6:29 ` John Max Skaller
2001-03-22 18:04 Dave Berry
2001-03-23 7:54 ` Tom Hirschowitz
2001-03-23 12:18 ` Fabrice Le Fessant
2001-03-27 8:49 ` Hendrik Tews
2001-03-23 10:33 Dave Berry
2001-03-23 20:33 Don Syme
2001-03-27 9:00 ` Xavier Leroy
2001-03-27 14:38 Don Syme
2001-03-27 17:05 Manuel Fahndrich
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=3AB796DA.ABD786B1@ozemail.com.au \
--to=skaller@ozemail.com.au \
--cc=caml-list@inria.fr \
--cc=checker@d6.com \
/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