Version française
Home     About     Download     Resources     Contact us    
Browse thread
[Caml-list] type issues with modules
[ Home ] [ Index: by date | by threads ]
[ Search: ]

[ Message by date: previous | next ] [ Message in thread: previous | next ] [ Thread: previous | next ]
Date: -- (:)
From: Chris GauthierDickey <chrisg@c...>
Subject: [Caml-list] type issues with modules
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