]> matita.cs.unibo.it Git - helm.git/blob - helm/ocaml/cic_disambiguation/disambiguateTypes.ml
- factorized DisambiguateChoices module
[helm.git] / helm / ocaml / cic_disambiguation / disambiguateTypes.ml
1
2 type domain_item =
3  | Id of string               (* literal *)
4  | Symbol of string * int     (* literal, instance num *)
5  | Num of int                 (* instance num *)
6
7 module OrderedDomain =
8   struct
9     type t = domain_item
10     let compare = Pervasives.compare
11   end
12
13 module Domain = Set.Make (OrderedDomain)
14 module Environment = Map.Make (OrderedDomain)
15
16 type codomain_item =
17   string *  (* description *)
18   (environment -> string -> Cic.term list -> Cic.term)
19     (* environment, literal number, arguments as needed *)
20
21 and environment = codomain_item Environment.t
22
23 module type Callbacks =
24   sig
25     val output_html : ?append_NL:bool -> Ui_logger.html_msg -> unit
26     val interactive_user_uri_choice :
27       selection_mode:[`SINGLE | `MULTIPLE] ->
28       ?ok:string ->
29       ?enable_button_for_non_vars:bool ->
30       title:string -> msg:string -> id:string -> string list -> string list
31     val interactive_interpretation_choice :
32       (string * string) list list -> int
33     val input_or_locate_uri : title:string -> UriManager.uri
34   end
35
36 let string_of_domain_item = function
37   | Id s -> Printf.sprintf "ID(%s)" s
38   | Symbol (s, i) -> Printf.sprintf "SYMBOL(%s,%d)" s i
39   | Num i -> Printf.sprintf "NUM(instance %d)" i
40
41 let string_of_domain dom =
42   let buf = Buffer.create 1024 in
43   Domain.iter
44     (fun item -> Buffer.add_string buf (string_of_domain_item item ^ "; "))
45     dom;
46   Buffer.contents buf
47