caml-list - the Caml user's mailing list
 help / color / mirror / Atom feed
* ocamlc throws exception
@ 2005-09-19 12:07 Michael Wohlwend
  2005-09-20  1:10 ` [Caml-list] " Jacques Garrigue
  0 siblings, 1 reply; 3+ messages in thread
From: Michael Wohlwend @ 2005-09-19 12:07 UTC (permalink / raw)
  To: caml-list

that code :

-----------------------------------------------
class ['a] nil = object(self:'a)
    method next = self
    method set_next n = ()
    method apply (f:'a -> unit) (upto:'a) = ()
end;;


class ['a] node = object(self:'a)
    constraint 'a = 'a #nil   (* line 10 *)
    inherit ['a] nil
    val mutable next = new nil
    method set_next n = next <- n
    method apply f upto =
        f self; if self <> upto then self#next#apply f upto
end;;
   
let a = new node;;
-----------------------------------------

causes this exception:
Fatal error: exception Ctype.Unify(_, 0)
(Program not linked with -g, cannot print stack backtrace)


without line 10 it compiles, allthough I get this error-message:
The type of this expression,
< apply : ('a -> unit) -> 'a -> unit; next : 'a;
  set_next : (< apply : ('b -> unit) -> 'b -> unit; next : 'b;
                set_next : '_c -> unit >
              as 'b) ->
             unit >
as 'a, contains type variables that cannot be generalized


is the exception o.k. ? I know now that the contstraint statement is wrong and 
sensless here...

 Michael


^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2005-09-20  4:24 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2005-09-19 12:07 ocamlc throws exception Michael Wohlwend
2005-09-20  1:10 ` [Caml-list] " Jacques Garrigue
2005-09-20  4:24   ` Jacques Garrigue

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).