]> matita.cs.unibo.it Git - helm.git/blob - helm/software/helena/src/common/options.ml
we are optimizing the code by conditional compilation.
[helm.git] / helm / software / helena / src / common / options.ml
1 (*
2     ||M||  This file is part of HELM, an Hypertextual, Electronic        
3     ||A||  Library of Mathematics, developed at the Computer Science     
4     ||T||  Department, University of Bologna, Italy.                     
5     ||I||                                                                
6     ||T||  HELM is free software; you can redistribute it and/or         
7     ||A||  modify it under the terms of the GNU General Public License   
8     \   /  version 2 or (at your option) any later version.              
9      \ /   This software is distributed as is, NO WARRANTY.              
10       V_______________________________________________________________ *)
11
12 module KF = Filename
13
14 module C = Cps
15
16 type uri_generator = string -> string
17
18 type kernel = V4 | V3 | V0
19
20 type manager = Quiet
21              | Coq
22              | Matita
23              | LP1    (* newelpi *)
24              | LP2    (* newelpi *)
25              | TJ2    (* teyjus  *)
26              | TJ3    (* teyjus  *)
27
28 (* interface functions ******************************************************)
29
30 let version_string = "Helena 0.8.3 M (June 2015)"
31
32 let stage = ref 3            (* stage *)
33
34 let trace = ref 0            (* trace level *)
35
36 let ct = ref 0               (* current trace level *)
37
38 let summary = ref false      (* log summary information *)
39
40 let export = ref false       (* export entities to XML *)
41
42 let xdir = ref ""            (* directory for XML output *)
43
44 let kernel = ref V3          (* kernel type *)
45
46 let si = ref false           (* use sort inclusion *)
47
48 let cover = ref ""           (* initial uri segment *)
49
50 let cc = ref false           (* activate conversion constraints *)
51
52 let indexes = ref false      (* show de Bruijn indexes *)
53
54 let icm = ref 0              (* complexity measure of relocated terms *)
55
56 let unquote = ref false      (* do not quote identifiers when lexing *)
57
58 let debug_parser = ref false (* output parser debug information *)
59
60 let debug_lexer = ref false  (* output lexer debug information *)
61
62 let alpha = ref ""           (* prefix of numeric identifiers *)
63
64 let first = ref 0            (* begin trace here *)
65
66 let last = ref max_int       (* end trace here *) 
67
68 let extended = ref false     (* extended applications *) 
69
70 let infinity = ref false     (* use ∞-abstractions in contexts *) 
71
72 let short = ref false        (* short global constants *) 
73
74 IFDEF EXPAND THEN
75 let expand = ref false       (* always expand global definitions *)
76 END
77
78 IFDEF PREPROCESS THEN
79 let preprocess = ref false   (* preprocess source *)
80 END
81
82 IFDEF MANAGER THEN
83 let manager_dir = ref ""     (* output directory for manager *)
84 let manager = ref Quiet      (* manager *)
85 let preamble = ref ""        (* preamble file for manager *)
86 END
87
88 let set_current_trace n =
89    ct := if !first <= n && n <= !last then !trace else 0
90
91 let kernel_id () = 
92    let id = match !kernel with
93       | V4 -> "Environment"
94       | V3 -> "Environment_V3"
95       | V0 -> "Environment_V0"
96    in
97    let si = if !si then "_si" else "" in
98    let ext = if !extended then "_x" else "" in
99    id ^ si ^ ext
100
101 let get_baseuri () =
102    String.concat "/" ["ld:"; kernel_id (); !cover; "" ]
103
104 let get_mk_uri () =
105    let bu = get_baseuri () in
106    fun s -> KF.concat bu (s ^ ".ld")
107
108 let clear () =
109    stage := 3; trace := 0; summary := false; export := false; first := 0; last := max_int;
110    xdir := ""; kernel := V3; si := false; extended := false; infinity := false; cover := ""; 
111    indexes := false; icm := 0; unquote := false; short := false;
112    debug_parser := false; debug_lexer := false;
113    IFDEF EXPAND THEN expand := false ELSE () END;
114    IFDEF MANAGER THEN manager_dir := ""; manager := Quiet; preamble := "" ELSE () END;
115    IFDEF PREPROCESS THEN preprocess := false ELSE () END