uCharTbl.ml1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80# 1 "Camomile/public/uCharTbl.ml" (** Fast lookup tables for Unicode. Accessible by constant time. *) (* Copyright (C) 2002, 2003 Yamagata Yoriyuki. distributed with LGPL *) (* This library is free software; you can redistribute it and/or *) (* modify it under the terms of the GNU Lesser General Public License *) (* as published by the Free Software Foundation; either version 2 of *) (* the License, or (at your option) any later version. *) (* As a special exception to the GNU Library General Public License, you *) (* may link, statically or dynamically, a "work that uses this library" *) (* with a publicly distributed version of this library to produce an *) (* executable file containing portions of this library, and distribute *) (* that executable file under terms of your choice, without any of the *) (* additional requirements listed in clause 6 of the GNU Library General *) (* Public License. By "a publicly distributed version of this library", *) (* we mean either the unmodified Library as distributed by the authors, *) (* or a modified version of this library that is distributed under the *) (* conditions defined in clause 3 of the GNU Library General Public *) (* License. This exception does not however invalidate any other reasons *) (* why the executable file might be covered by the GNU Library General *) (* Public License . *) (* This library is distributed in the hope that it will be useful, *) (* but WITHOUT ANY WARRANTY; without even the implied warranty of *) (* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU *) (* Lesser General Public License for more details. *) (* You should have received a copy of the GNU Lesser General Public *) (* License along with this library; if not, write to the Free Software *) (* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 *) (* USA *) (* You can contact the authour by sending email to *) (* yori@users.sourceforge.net *) type 'a tbl = 'a Tbl31.tbl type 'a t = 'a tbl let get tbl u = Tbl31.get tbl (UChar.uint_code u) module type Type = sig type elt type t = elt tbl val get : elt tbl -> UChar.t -> elt val of_map : elt -> elt UMap.t -> t end module Make (H : Hashtbl.HashedType) = struct module T31 = Tbl31.Make (H) type elt = T31.elt type t = H.t tbl let get = get let of_map v m = T31.of_map v (UMap.imap_of_umap m) end module Bool = struct type t = Tbl31.Bool.t let get tbl u = Tbl31.Bool.get tbl (UChar.uint_code u) let of_set s = Tbl31.Bool.of_set (USet.iset_of_uset s) end module Bits = struct type t = Tbl31.Bits.t let get tbl u = Tbl31.Bits.get tbl (UChar.uint_code u) let of_map v m = Tbl31.Bits.of_map v (UMap.imap_of_umap m) end module Bytes = struct type t = Tbl31.Bytes.t let get tbl u = Tbl31.Bytes.get tbl (UChar.uint_code u) let of_map v m = Tbl31.Bytes.of_map v (UMap.imap_of_umap m) end module Char = struct type t = Tbl31.Char.t let get tbl u = Tbl31.Char.get tbl (UChar.uint_code u) let of_map v m = Tbl31.Char.of_map v (UMap.imap_of_umap m) end