Version française
Home     About     Download     Resources     Contact us    

This site is updated infrequently. For up-to-date information, please visit the new OCaml website at

Browse thread
RE: parametric types in simple functors?
[ Home ] [ Index: by date | by threads ]
[ Search: ]

[ Message by date: previous | next ] [ Message in thread: previous | next ] [ Thread: previous | next ]
Date: -- (:)
From: Don Syme <dsyme@m...>
Subject: RE: parametric types in simple functors?
Yes, I had the same problem just yesterday when wanting to generate the
natural, parametric version of "Map" using  In the end I
just copied to code in, substituting "Pervasives" for "Ord".  Is
there some trick we're overlooking?

-----Original Message-----
Sent: 05 July 1999 11:57
Subject: Q: parametric types in simple functors?

The subject title is poor. I have a concrete simple question.

(All CAML code is indented to the right here)

   type 'a symbol = { sy_name: string; sy_hash: int; mutable sy_prop: 'a
option };;

This is essentially a symbol, memoizing its hash code for fast
access. Some structures are naturally hashed map, whose key are
symbols (eg bindings). We make symbols with

  let get_symbol n =
    try Hashtbl.find symdict n 
    with Not_found ->
     let s = { sy_name=n; sy_hash=Hashtbl.hash n; sy_prop=None } in
      Hashtbl.add symdict n s;

The property field of symbols could be used the way you like it.

I want to define a binding as an hashtable mapping symbols to (say)
integers - or even any type 'b. But I can't code:

  module SymbolHash = Hashtbl.Make(
       type t = symbol
       let equal s1 s2 = s1 == s2
       let hash {sy_hash=h} = h

Because the type constructor t has no argument in the
Hashtbl.HashedType signature.

Any comments or suggestions (could define a class abstract_symbol
with a subclass symbol holding the properties. But I don't want
classes because I don't need inheritance).

The intent is that the symbol properties would be defined in another
module. I don't want to fix the 'a in symbol_t here, yet I want to
make an hashtable whose keys are symbols.

In other words, 

  why the stdlib doesn't give parametrized types for many modules
  (Hashtbl, Set...)

  when should I use a type constructor with an argument, or a functor?

Any comments?

N.B. Any opinions expressed here are only mine, and not of my organization.
N.B. Les opinions exprimees ici me sont personnelles et n engagent pas le

Basile STARYNKEVITCH   ----  Commissariat à l Energie Atomique 
DTA/LETI/DEIN/SLA * CEA/Saclay b.528 (p111f) * 91191 GIF/YVETTE CEDEX *
phone: 1,; fax: home: 1,
email: Basile point Starynkevitch at cea point fr