<?xml version="1.0" encoding="ISO-8859-1"?>

<!DOCTYPE message PUBLIC
  "-//MLarc//DTD MLarc output files//EN"
  "../../mlarc.dtd"[
  <!ATTLIST message
    listname CDATA #REQUIRED
    title CDATA #REQUIRED
  >
]>

  <?xml-stylesheet href="../../mlarc.xsl" type="text/xsl"?>


<message 
  url="2009/01/13994d2261e2703a410b2818687311b2"
  from="Martin Jambon &lt;martin.jambon@e...&gt;"
  author="Martin Jambon"
  date="2009-01-20T15:02:35"
  subject="Re: [Caml-list] Making a polymorphic type non-polymorphic to comply with original signature"
  prev="2009/01/eb1bb346ea9ac86f67b1c2011a41bdc8"
  next="2009/01/362d9a24596895194833ad9dc424ca61"
  prev-in-thread="2009/01/3faf1d84d33d7d63e5f417f0853743b6"
  next-in-thread="2009/01/bec8514bf8ec8e4b7403d82c8845ffa0"
  prev-thread="2009/01/6cfb5e559cd4bf982c4960d25352bc27"
  next-thread="2009/01/bdd60304d962e4e9ac5f3fc4516fce06"
  root="../../"
  period="month"
  listname="caml-list"
  title="Archives of the Caml mailing list">

<thread subject="Making a polymorphic type non-polymorphic to comply with original signature ">
<msg 
  url="2009/01/5086d82bd654331abd6d66fbfc5877f2"
  from="Hugo Ferreira &lt;hmf@i...&gt;"
  author="Hugo Ferreira"
  date="2009-01-20T10:59:50"
  subject="Making a polymorphic type non-polymorphic to comply with original signature ">
<msg 
  url="2009/01/03af28a51b1f263e4bce45395c2a24ee"
  from="Daniel_Bünzli &lt;daniel.buenzli@e...&gt;"
  author="Daniel_Bünzli"
  date="2009-01-20T11:25:04"
  subject="Re: [Caml-list] Making a polymorphic type non-polymorphic to comply with original signature">
<msg 
  url="2009/01/45ebef4fa64ce8ca6d0ab81460203417"
  from="David Teller &lt;David.Teller@u...&gt;"
  author="David Teller"
  date="2009-01-20T11:37:28"
  subject="Re: [Caml-list] Making a polymorphic type non-polymorphic to comply with original signature">
<msg 
  url="2009/01/8291b0da375a697d829347a7a18148e7"
  from="Hugo Ferreira &lt;hmf@i...&gt;"
  author="Hugo Ferreira"
  date="2009-01-20T11:46:45"
  subject="Re: [Caml-list] Making a polymorphic type non-polymorphic to	comply with original signature">
<msg 
  url="2009/01/da6cc2637b564bfd93a0b72007d53fe0"
  from="Thomas Gazagnaire &lt;ocaml@g...&gt;"
  author="Thomas Gazagnaire"
  date="2009-01-20T12:58:33"
  subject="Re: [Caml-list] Making a polymorphic type non-polymorphic to comply  with original signature">
<msg 
  url="2009/01/eb1bb346ea9ac86f67b1c2011a41bdc8"
  from="Hugo Ferreira &lt;hmf@i...&gt;"
  author="Hugo Ferreira"
  date="2009-01-20T13:25:52"
  subject="Re: [Caml-list] Making a polymorphic type non-polymorphic to comply with original signature">
</msg>
</msg>
</msg>
</msg>
<msg 
  url="2009/01/3faf1d84d33d7d63e5f417f0853743b6"
  from="Hugo Ferreira &lt;hmf@i...&gt;"
  author="Hugo Ferreira"
  date="2009-01-20T11:43:13"
  subject="Re: [Caml-list] Making a polymorphic type non-polymorphic to comply with original signature">
</msg>
</msg>
<msg 
  url="2009/01/13994d2261e2703a410b2818687311b2"
  from="Martin Jambon &lt;martin.jambon@e...&gt;"
  author="Martin Jambon"
  date="2009-01-20T15:02:35"
  subject="Re: [Caml-list] Making a polymorphic type non-polymorphic to comply with original signature">
<msg 
  url="2009/01/bec8514bf8ec8e4b7403d82c8845ffa0"
  from="Hugo Ferreira &lt;hmf@i...&gt;"
  author="Hugo Ferreira"
  date="2009-01-20T17:05:16"
  subject="Re: [Caml-list] Making a polymorphic type non-polymorphic to comply with original signature">
</msg>
</msg>
</msg>
</thread>

<contents>
Hugo Ferreira wrote:
&gt; Hello,
&gt; 
&gt; I have the following definition:
&gt; 
&gt; module rec H :
&gt;   sig
&gt;       type 'a node =
&gt;           | Node of 'a node J.t
&gt;           | Leaf of 'a
&gt; 
&gt;      type 'a t = 'a node
&gt;      val equal : 'a t -&gt; 'a t -&gt; bool
&gt;     val hash : 'a t -&gt; int
&gt;   end =
&gt; struct
&gt;     type 'a node =
&gt;         | Node of 'a node J.t
&gt;         | Leaf of 'a
&gt; 
&gt;     type 'a t = 'a node
&gt;     let equa = (==)
&gt;     let hash = Hashtbl.hash
&gt; end
&gt; 
&gt; and J : Hashtbl.S with type 'a key = 'a H.node = Hashtbl.Make( H )
&gt; ;;
&gt; 
&gt; The data type 'a node is polymorphic. It is also a key used by the
&gt; hash-table. Note that H now does not comply with Hashtbl.HashedType
&gt; (because Hashtbl.HashedType is not polymorphic). By adding the
&gt; constraint "with type" also does not help.
&gt; 
&gt; Is it possible to make H comply with Hashtbl.HashedType i.e: make
&gt; J.Key = 'a H.node ?


I just posted an implementation of polymorphic hash tables with physical
comparison, using the Obj module:

  http://martin.jambon.free.fr/phys.html

It is the following code:

(***** phys.mli *****)

type ('a, 'b) t

val add : ('a, 'b) t -&gt; 'a -&gt; 'b -&gt; unit
val clear : ('a, 'b) t -&gt; unit
val copy : ('a, 'b) t -&gt; ('a, 'b) t
val create : int -&gt; ('a, 'b) t
val find : ('a, 'b) t -&gt; 'a -&gt; 'b
val find_all : ('a, 'b) t -&gt; 'a -&gt; 'b list
val fold : ('a -&gt; 'b -&gt; 'c -&gt; 'c) -&gt; ('a, 'b) t -&gt; 'c -&gt; 'c
val iter : ('a -&gt; 'b -&gt; unit) -&gt; ('a, 'b) t -&gt; unit
val length : ('a, 'b) t -&gt; int
val mem : ('a, 'b) t -&gt; 'a -&gt; bool
val remove : ('a, 'b) t -&gt; 'a -&gt; unit
val replace : ('a, 'b) t -&gt; 'a -&gt; 'b -&gt; unit



(***** phys.ml *****)

(*
  This implementation uses the Obj module which allows to transgress
  the type system. It is not regular OCaml.
*)

module Magic_key =
struct
  type t = Obj.t
  let equal = ( == )
  let hash = Hashtbl.hash
end

module Magic_table = Hashtbl.Make (Magic_key)


type ('a, 'b) t = 'b Magic_table.t

let add tbl k v = Magic_table.add tbl (Obj.repr k) v
let clear tbl = Magic_table.clear tbl
let copy tbl = Magic_table.copy tbl
let create n = Magic_table.create n
let find tbl k = Magic_table.find tbl (Obj.repr k)
let find_all tbl k = Magic_table.find_all tbl (Obj.repr k)
let fold f tbl accu = Magic_table.fold (Obj.magic f) (Obj.magic tbl) accu
let iter f tbl = Magic_table.iter (Obj.magic f) (Obj.magic tbl)
let length tbl = Magic_table.length tbl
let mem tbl k = Magic_table.mem tbl (Obj.repr k)
let remove tbl k = Magic_table.remove tbl (Obj.repr k)
let replace tbl k v = Magic_table.replace tbl (Obj.repr k) v


(*****************)



Martin

-- 
http://mjambon.com/

</contents>

</message>

