ident.mli 3.68 KB
Newer Older
1 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
(**************************************************************************)
(*                                                                        *)
(*  Copyright (C) 2010-                                                   *)
(*    Francois Bobot                                                      *)
(*    Jean-Christophe Filliatre                                           *)
(*    Johannes Kanig                                                      *)
(*    Andrei Paskevich                                                    *)
(*                                                                        *)
(*  This software is free software; you can redistribute it and/or        *)
(*  modify it under the terms of the GNU Library General Public           *)
(*  License version 2.1, with the special exception on linking            *)
(*  described in file LICENSE.                                            *)
(*                                                                        *)
(*  This software 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.                  *)
(*                                                                        *)
(**************************************************************************)

(** Identifiers *)

type ident = private {
  id_short : string;    (* non-unique name for string-based lookup *)
  id_long : string;     (* non-unique name for pretty printing *)
  id_origin : origin;   (* origin of the ident *)
  id_tag : int;         (* unique numeric tag *)
}

and origin =
  | User of Loc.position
  | Derived of ident
  | Fresh

module Sid : Set.S with type elt = ident
module Mid : Map.S with type key = ident
module Hid : Hashtbl.S with type key = ident

38 39
(* a user-created type of unregistered identifiers *)
type preid
40

41 42
(* register a pre-ident (never use this function) *)
val id_register : preid -> ident
43

44 45 46
(* create a fresh pre-ident *)
val id_fresh : string -> preid
val id_fresh_long : string -> string -> preid
47

48 49 50 51 52 53 54 55 56 57 58 59 60
(* create a localized pre-ident *)
val id_user : string -> Loc.position -> preid
val id_user_long : string -> string -> Loc.position -> preid

(* create a derived pre-ident *)
val id_derive : string -> ident -> preid
val id_derive_long : string -> string -> ident -> preid

(* create a derived pre-ident with the same name *)
val id_clone : ident -> preid

(* create a duplicate pre-ident *)
val id_dup : ident -> preid
61

62 63
(* id_derived_from i1 i2 <=> i1 is derived from i2 *)
val id_derived_from : ident -> ident -> bool
64

Francois Bobot's avatar
Francois Bobot committed
65 66 67
(* id_derived_from i1 i2 <=> i1 is derived from i2 *)
val id_from_user : ident -> Loc.position option

68 69
(** Unique persistent names for pretty printing *)

70
type ident_printer
71

72 73 74
(* start a new printer with a sanitizing function and a blacklist *)
val create_ident_printer :
  ?sanitizer : (string -> string) -> string list -> ident_printer
75

76
(* use ident_printer to generate a unique name for ident *)
77
(* an optional sanitizer is applied over the printer's sanitizer *)
78 79
val id_unique :
  ident_printer -> ?sanitizer : (string -> string) -> ident -> string
80

81 82 83
(* Uniquify string *)
val string_unique : ident_printer -> string -> string

84
(* forget an ident *)
85
val forget_id : ident_printer -> ident -> unit
86 87

(* forget all idents *)
88
val forget_all : ident_printer -> unit
89 90 91 92 93 94 95 96 97 98

(* generic sanitizer taking a separate encoder for the first letter *)
val sanitizer : (char -> string) -> (char -> string) -> string -> string

(* various character encoders *)
val char_to_alpha : char -> string
val char_to_lalpha : char -> string
val char_to_ualpha : char -> string
val char_to_alnum : char -> string
val char_to_alnumus : char -> string
99