1 (* Copyright (C) 2000-2002, HELM Team.
3 * This file is part of HELM, an Hypertextual, Electronic
4 * Library of Mathematics, developed at the Computer Science
5 * Department, University of Bologna, Italy.
7 * HELM is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU General Public License
9 * as published by the Free Software Foundation; either version 2
10 * of the License, or (at your option) any later version.
12 * HELM is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
17 * You should have received a copy of the GNU General Public License
18 * along with HELM; if not, write to the Free Software
19 * Foundation, Inc., 59 Temple Place - Suite 330, Boston,
22 * For details, see the HELM World-Wide-Web page,
23 * http://cs.unibo.it/helm/.
26 (***************************************************************************)
30 (* Andrea Asperti <asperti@cs.unibo.it> *)
34 (***************************************************************************)
36 val mml_of_cic_sequent:
37 Cic.metasenv -> (* metasenv *)
38 Cic.conjecture -> (* sequent *)
39 Gdome.document * (* Math ML *)
40 Cic.conjecture * (* unshared sequent *)
41 (Cic.annconjecture * (* annsequent *)
42 ((Cic.id, Cic.term) Hashtbl.t * (* id -> term *)
43 (Cic.id, Cic.id option) Hashtbl.t * (* id -> father id *)
44 (Cic.id, Cic.hypothesis) Hashtbl.t * (* id -> hypothesis *)
45 (Cic.id, Cic2acic.sort_kind) Hashtbl.t)) (* ids_to_inner_sorts *)
47 val nmml_of_cic_sequent:
48 #NCicCoercion.status ->
49 NCic.metasenv -> NCic.substitution -> (* metasenv, substitution *)
50 int * NCic.conjecture -> (* sequent *)
51 Gdome.document (* Math ML *)
53 val ntxt_of_cic_sequent:
54 map_unicode_to_tex:bool -> int ->
55 #NCicCoercion.status ->
56 NCic.metasenv -> NCic.substitution -> (* metasenv, substitution *)
57 int * NCic.conjecture -> (* sequent *)
60 val mml_of_cic_object:
61 Cic.obj -> (* object *)
62 Gdome.document * (* Math ML *)
63 (Cic.annobj * (* annobj *)
64 ((Cic.id, Cic.term) Hashtbl.t * (* id -> term *)
65 (Cic.id, Cic.id option) Hashtbl.t * (* id -> father id *)
66 (Cic.id, Cic.conjecture) Hashtbl.t * (* id -> conjecture *)
67 (Cic.id, Cic.hypothesis) Hashtbl.t * (* id -> hypothesis *)
68 (Cic.id, Cic2acic.sort_kind) Hashtbl.t * (* ids_to_inner_sorts *)
69 (Cic.id, Cic2acic.anntypes) Hashtbl.t)) (* ids_to_inner_types *)
71 val nmml_of_cic_object: #NCicCoercion.status -> NCic.obj -> Gdome.document
73 val ntxt_of_cic_object:
74 map_unicode_to_tex:bool -> int -> #NCicCoercion.status -> NCic.obj -> string
76 val txt_of_cic_sequent_all:
77 map_unicode_to_tex:bool -> int ->
78 Cic.metasenv -> (* metasenv *)
79 Cic.conjecture -> (* sequent *)
81 Cic.conjecture * (* unshared sequent *)
82 (Cic.annconjecture * (* annsequent *)
83 ((Cic.id, Cic.term) Hashtbl.t * (* id -> term *)
84 (Cic.id, Cic.id option) Hashtbl.t * (* id -> father id *)
85 (Cic.id, Cic.hypothesis) Hashtbl.t * (* id -> hypothesis *)
86 (Cic.id, Cic2acic.sort_kind) Hashtbl.t)) (* ids_to_inner_sorts *)
89 map_unicode_to_tex:bool -> int -> Cic.metasenv -> Cic.context -> Cic.term ->
91 val txt_of_cic_sequent:
92 map_unicode_to_tex:bool -> int -> Cic.metasenv -> Cic.conjecture -> string
93 val txt_of_cic_sequent_conclusion:
94 map_unicode_to_tex:bool -> output_type:[`Pattern | `Term] -> int ->
95 Cic.metasenv -> Cic.conjecture -> string
97 (* columns, params, object *)
98 val txt_of_cic_object:
99 map_unicode_to_tex:bool ->
100 ?skip_thm_and_qed:bool -> ?skip_initial_lambdas:int ->
101 int -> GrafiteAst.inline_param list -> Cic.obj ->
104 val txt_of_cic_object_all:
105 map_unicode_to_tex:bool ->
106 ?skip_thm_and_qed:bool -> ?skip_initial_lambdas:int ->
107 int -> GrafiteAst.inline_param list -> Cic.obj ->
109 (Cic.annobj * (* annobj *)
110 ((Cic.id, Cic.term) Hashtbl.t * (* id -> term *)
111 (Cic.id, Cic.id option) Hashtbl.t * (* id -> father id *)
112 (Cic.id, Cic.conjecture) Hashtbl.t * (* id -> conjecture *)
113 (Cic.id, Cic.hypothesis) Hashtbl.t * (* id -> hypothesis *)
114 (Cic.id, Cic2acic.sort_kind) Hashtbl.t * (* ids_to_inner_sorts *)
115 (Cic.id, Cic2acic.anntypes) Hashtbl.t)) (* ids_to_inner_types *)
117 (* params, uri or baseuri *)
118 val txt_of_inline_macro:
119 map_unicode_to_tex:bool -> GrafiteAst.inline_param list -> string ->
123 map_unicode_to_tex:bool ->
126 (Cic.term, Cic.lazy_term) GrafiteAst.macro -> string