caml-list - the Caml user's mailing list
 help / color / mirror / Atom feed
From: Chris GauthierDickey <chrisg@cs.uoregon.edu>
To: caml-list@inria.fr
Subject: [Caml-list] type issues with modules
Date: Mon, 10 Nov 2003 21:33:16 -0800	[thread overview]
Message-ID: <3FB0749C.80103@cs.uoregon.edu> (raw)

I have a weird issue, but I'm not sure if it's related to the type
system or what's really going on.  I've boiled the problem down to the
simple case below. I have 4 files, two that are interfaces for the modules.

file: mod1.mli
type t1 = T1
val v: t1

file mod1.ml
type t1 = T1
let v = Mod2.f2 ()

file mod2.mli
val f2: unit -> Mod1.t1

file mod2.ml
let f2 ()  = Mod1.T1


I compile the files as such:

ocamlc -g mod1.mli
ocamlc -g mod2.mli
ocamlc -g mod1.ml

at which point I get the error:
The implementation mod1.ml does not match the interface mod1.cmi:
Values do not match: val v : Mod1.t1 is not included in val v: t1

which seems a little odd since t1 is certainly contained in Mod1.t1. I
feel like the types at this point are known, defined in the interface
file and that we know that the types in the ml file belong to the same
module as the interface. Am I wrong?

If I had the type expressions and change mod1.ml to:
type t1 = T1
let v:(Mod1.t1)

and then mod1.mli to
type t1 = T1
let v:(Mod1.t1)

I get the error: Unbound type constructor Mod1.t1, which makes some
sense. But again I'd argue that at this point, we know the name of the
module, so Mod1.t1 is the same thing as t1.

Maybe I'm totally missing something obvious?

Thanks in advance,
Chris

P.S. I know I can move t1 into another module, but for software
engineering reasons, I don't want to do that.


-------------------
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:[~2003-11-11  5:34 UTC|newest]

Thread overview: 6+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2003-11-11  5:33 Chris GauthierDickey [this message]
2003-11-11  8:21 ` Jacques Garrigue
2003-11-11 17:25   ` Damien
2003-11-12  1:12     ` Jacques Garrigue
2003-11-12 12:51       ` Remi Vanicat
2003-11-13 21:31       ` Issac Trotts

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=3FB0749C.80103@cs.uoregon.edu \
    --to=chrisg@cs.uoregon.edu \
    --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;
as well as URLs for NNTP newsgroup(s).