author | haftmann |
Mon, 13 Nov 2006 22:31:23 +0100 | |
changeset 21348 | 74c1da5d44be |
parent 20951 | 868120282837 |
child 21350 | 6e58289b6685 |
permissions | -rw-r--r-- |
12780 | 1 |
(* Title: Pure/proof_general.ML |
12778 | 2 |
ID: $Id$ |
14675 | 3 |
Author: David Aspinall and Markus Wenzel |
12778 | 4 |
|
17469 | 5 |
Isabelle configuration for Proof General (see |
6 |
http://proofgeneral.inf.ed.ac.uk). Also includes experimental support |
|
7 |
for PGIP control language for Isabelle/Isar (PGIP 2.X). |
|
12778 | 8 |
*) |
9 |
||
10 |
signature PROOF_GENERAL = |
|
11 |
sig |
|
12 |
val update_thy_only: string -> unit |
|
13 |
val try_update_thy_only: string -> unit |
|
13391 | 14 |
val inform_file_retracted: string -> unit |
12778 | 15 |
val inform_file_processed: string -> unit |
16534 | 16 |
val preferences: |
17 |
(string * |
|
18 |
(string * |
|
19 |
(string * |
|
20 |
(string * (string * (unit -> string)) * |
|
21 |
(string -> unit)))) list) list ref |
|
13728
8004e56204fd
Added some functions for processing PGIP (thanks to David Aspinall).
berghofe
parents:
13646
diff
changeset
|
22 |
val process_pgip: string -> unit |
12778 | 23 |
val thms_containing: string list -> unit |
24 |
val help: unit -> unit |
|
25 |
val show_context: unit -> theory |
|
26 |
val kill_goal: unit -> unit |
|
27 |
val repeat_undo: int -> unit |
|
28 |
val isa_restart: unit -> unit |
|
12833 | 29 |
val full_proofs: bool -> unit |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
30 |
val isarcmd: string -> unit |
12778 | 31 |
val init: bool -> unit |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
32 |
val init_pgip: bool -> unit |
12778 | 33 |
val write_keywords: string -> unit |
16534 | 34 |
val xmls_of_str: string -> string list (*temp for testing parser*) |
12778 | 35 |
end; |
36 |
||
16534 | 37 |
structure ProofGeneral: PROOF_GENERAL = |
12778 | 38 |
struct |
39 |
||
16534 | 40 |
structure P = OuterParse; |
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
41 |
|
15191
5ca1fd9dec83
Support parsing of -- {* comments *}. Add extra output channels.
aspinall
parents:
15173
diff
changeset
|
42 |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
43 |
(* PGIP messaging mode (independent of PGML output) *) |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
44 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
45 |
val pgip_active = ref false; |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
46 |
val pgip_emacs_compatibility_flag = ref false; |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
47 |
|
16534 | 48 |
fun pgip () = (! pgip_active); |
49 |
fun pgip_emacs_compatibility () = (! pgip_emacs_compatibility_flag); |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
50 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
51 |
|
12778 | 52 |
(* print modes *) |
53 |
||
16534 | 54 |
val proof_generalN = "ProofGeneral"; (*token markup (colouring vars, etc.)*) |
17217
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
55 |
val pgasciiN = "PGASCII"; (*plain 7-bit ASCII communication*) |
16534 | 56 |
val xsymbolsN = Symbol.xsymbolsN; (*X-Symbol symbols*) |
57 |
val pgmlN = "PGML"; (*XML escapes and PGML symbol elements*) |
|
58 |
val pgmlatomsN = "PGMLatoms"; (*variable kind decorations*) |
|
59 |
val thm_depsN = "thm_deps"; (*meta-information about theorem deps*) |
|
12778 | 60 |
|
16534 | 61 |
fun pgml () = Output.has_mode pgmlN; |
62 |
||
17217
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
63 |
fun special oct = |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
64 |
if Output.has_mode pgasciiN then chr 1 ^ chr (ord (oct_char oct) - 167) |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
65 |
else oct_char oct; |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
66 |
|
12778 | 67 |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
68 |
(* text output: print modes for xsymbol and PGML *) |
12778 | 69 |
|
70 |
local |
|
71 |
||
14827 | 72 |
fun xsym_output "\\" = "\\\\" |
73 |
| xsym_output s = if Symbol.is_raw s then Symbol.decode_raw s else s; |
|
74 |
||
12778 | 75 |
fun xsymbols_output s = |
16534 | 76 |
if Output.has_mode xsymbolsN andalso exists_string (equal "\\") s then |
12778 | 77 |
let val syms = Symbol.explode s |
14827 | 78 |
in (implode (map xsym_output syms), real (Symbol.length syms)) end |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
79 |
else Symbol.default_output s; |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
80 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
81 |
fun pgml_sym s = |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
82 |
(case Symbol.decode s of |
16534 | 83 |
(*NB: an alternative here would be to output the default print mode alternative |
84 |
in the element content, but unfortunately print modes are not that fine grained.*) |
|
15266 | 85 |
Symbol.Char s => XML.text s |
15403 | 86 |
| Symbol.Sym sn => XML.element "sym" [("name", sn)] [XML.text s] |
16534 | 87 |
| Symbol.Ctrl sn => XML.element "ctrl" [("name", sn)] [XML.text s] (* FIXME: no such PGML! *) |
15266 | 88 |
| Symbol.Raw s => s); |
12778 | 89 |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
90 |
fun pgml_output str = |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
91 |
let val syms = Symbol.explode str |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
92 |
in (implode (map pgml_sym syms), real (Symbol.length syms)) end; |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
93 |
|
16534 | 94 |
in |
12778 | 95 |
|
16534 | 96 |
fun setup_xsymbols_output () = |
97 |
Output.add_mode xsymbolsN |
|
19265 | 98 |
(xsymbols_output, K xsymbols_output, Symbol.default_indent, Symbol.encode_raw); |
12778 | 99 |
|
16534 | 100 |
fun setup_pgml_output () = |
101 |
Output.add_mode pgmlN |
|
19265 | 102 |
(pgml_output, K pgml_output, Symbol.default_indent, Symbol.encode_raw); |
12778 | 103 |
|
104 |
end; |
|
105 |
||
106 |
||
107 |
(* token translations *) |
|
108 |
||
109 |
local |
|
110 |
||
17217
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
111 |
fun end_tag () = special "350"; |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
112 |
val class_tag = ("class", fn () => special "351"); |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
113 |
val tfree_tag = ("tfree", fn () => special "352"); |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
114 |
val tvar_tag = ("tvar", fn () => special "353"); |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
115 |
val free_tag = ("free", fn () => special "354"); |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
116 |
val bound_tag = ("bound", fn () => special "355"); |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
117 |
val var_tag = ("var", fn () => special "356"); |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
118 |
val skolem_tag = ("skolem", fn () => special "357"); |
12778 | 119 |
|
120 |
fun xml_atom kind x = XML.element "atom" [("kind", kind)] [XML.text x]; |
|
121 |
||
122 |
fun tagit (kind, bg_tag) x = |
|
16534 | 123 |
(if Output.has_mode pgmlatomsN then xml_atom kind x |
17217
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
124 |
else bg_tag () ^ x ^ end_tag (), real (Symbol.length (Symbol.explode x))); |
12778 | 125 |
|
126 |
fun free_or_skolem x = |
|
20081 | 127 |
(case try Name.dest_skolem x of |
15531 | 128 |
NONE => tagit free_tag x |
129 |
| SOME x' => tagit skolem_tag x'); |
|
12778 | 130 |
|
131 |
fun var_or_skolem s = |
|
15985 | 132 |
(case Syntax.read_variable s of |
133 |
SOME (x, i) => |
|
20081 | 134 |
(case try Name.dest_skolem x of |
15531 | 135 |
NONE => tagit var_tag s |
15992
cb02d70a2040
var_or_skolem: always print question mark for vars stemming from skolems;
wenzelm
parents:
15985
diff
changeset
|
136 |
| SOME x' => tagit skolem_tag |
cb02d70a2040
var_or_skolem: always print question mark for vars stemming from skolems;
wenzelm
parents:
15985
diff
changeset
|
137 |
(setmp show_question_marks true Syntax.string_of_vname (x', i))) |
15985 | 138 |
| NONE => tagit var_tag s); |
12778 | 139 |
|
140 |
val proof_general_trans = |
|
141 |
Syntax.tokentrans_mode proof_generalN |
|
142 |
[("class", tagit class_tag), |
|
143 |
("tfree", tagit tfree_tag), |
|
144 |
("tvar", tagit tvar_tag), |
|
145 |
("free", free_or_skolem), |
|
146 |
("bound", tagit bound_tag), |
|
147 |
("var", var_or_skolem)]; |
|
148 |
||
15801 | 149 |
in |
150 |
||
18708 | 151 |
val _ = Context.add_setup (Theory.add_tokentrfuns proof_general_trans); |
15801 | 152 |
|
153 |
end; |
|
12778 | 154 |
|
155 |
||
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
156 |
(* assembling PGIP packets *) |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
157 |
|
17217
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
158 |
val pgip_refid = ref NONE: string option ref; |
16534 | 159 |
val pgip_refseq = ref NONE: string option ref; |
12778 | 160 |
|
161 |
local |
|
16821
ba1f6aba44ed
Update PGIP packet handling, fixing unique session identifier.
aspinall
parents:
16816
diff
changeset
|
162 |
val pgip_class = "pg" |
ba1f6aba44ed
Update PGIP packet handling, fixing unique session identifier.
aspinall
parents:
16816
diff
changeset
|
163 |
val pgip_tag = "Isabelle/Isar" |
ba1f6aba44ed
Update PGIP packet handling, fixing unique session identifier.
aspinall
parents:
16816
diff
changeset
|
164 |
val pgip_id = ref "" |
ba1f6aba44ed
Update PGIP packet handling, fixing unique session identifier.
aspinall
parents:
16816
diff
changeset
|
165 |
val pgip_seq = ref 0 |
ba1f6aba44ed
Update PGIP packet handling, fixing unique session identifier.
aspinall
parents:
16816
diff
changeset
|
166 |
fun pgip_serial () = inc pgip_seq |
12778 | 167 |
|
16534 | 168 |
fun assemble_pgips pgips = |
169 |
XML.element |
|
170 |
"pgip" |
|
16821
ba1f6aba44ed
Update PGIP packet handling, fixing unique session identifier.
aspinall
parents:
16816
diff
changeset
|
171 |
([("tag", pgip_tag), |
17407
38e0219ec022
Revert previous attribute name change, problem can be avoided in JAXB.
aspinall
parents:
17403
diff
changeset
|
172 |
("class", pgip_class), |
17217
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
173 |
("seq", string_of_int (pgip_serial())), |
16821
ba1f6aba44ed
Update PGIP packet handling, fixing unique session identifier.
aspinall
parents:
16816
diff
changeset
|
174 |
("id", !pgip_id)] @ |
19473 | 175 |
the_default [] (Option.map (single o (pair "destid")) (! pgip_refid)) @ |
16821
ba1f6aba44ed
Update PGIP packet handling, fixing unique session identifier.
aspinall
parents:
16816
diff
changeset
|
176 |
(* destid=refid since Isabelle only communicates back to sender, |
ba1f6aba44ed
Update PGIP packet handling, fixing unique session identifier.
aspinall
parents:
16816
diff
changeset
|
177 |
so we may omit refid from attributes. |
19473 | 178 |
the_default [] (Option.map (single o (pair "refid")) (! pgip_refid)) @ |
16821
ba1f6aba44ed
Update PGIP packet handling, fixing unique session identifier.
aspinall
parents:
16816
diff
changeset
|
179 |
*) |
19473 | 180 |
the_default [] (Option.map (single o (pair "refseq")) (! pgip_refseq))) |
16534 | 181 |
pgips; |
16821
ba1f6aba44ed
Update PGIP packet handling, fixing unique session identifier.
aspinall
parents:
16816
diff
changeset
|
182 |
|
13526 | 183 |
in |
12778 | 184 |
|
17217
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
185 |
fun init_pgip_session_id () = |
16821
ba1f6aba44ed
Update PGIP packet handling, fixing unique session identifier.
aspinall
parents:
16816
diff
changeset
|
186 |
pgip_id := getenv "HOSTNAME" ^ "/" ^ getenv "USER" ^ "/" ^ |
ba1f6aba44ed
Update PGIP packet handling, fixing unique session identifier.
aspinall
parents:
16816
diff
changeset
|
187 |
getenv "ISABELLE_PID" ^ "/" ^ Time.toString (Time.now ()) |
17217
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
188 |
|
16821
ba1f6aba44ed
Update PGIP packet handling, fixing unique session identifier.
aspinall
parents:
16816
diff
changeset
|
189 |
|
ba1f6aba44ed
Update PGIP packet handling, fixing unique session identifier.
aspinall
parents:
16816
diff
changeset
|
190 |
fun matching_pgip_id id = (id = !pgip_id) |
ba1f6aba44ed
Update PGIP packet handling, fixing unique session identifier.
aspinall
parents:
16816
diff
changeset
|
191 |
|
16534 | 192 |
fun decorated_output bg en prfx = |
193 |
writeln_default o enclose bg en o prefix_lines prfx; |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
194 |
|
16534 | 195 |
(* FIXME: see Rev 1.48 [PG CVS] for cleaner version of this which can be used |
196 |
for PG 4.0 which processes PGIP without needing special chars *) |
|
197 |
fun issue_pgips ps = |
|
198 |
if pgip_emacs_compatibility() then |
|
199 |
decorated_output (*add urgent message annotation*) |
|
17217
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
200 |
(special "360") (special "361") "" |
16534 | 201 |
(assemble_pgips ps) |
202 |
else |
|
203 |
writeln_default (assemble_pgips ps); |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
204 |
|
16534 | 205 |
fun assemble_pgip resp attrs s = assemble_pgips [XML.element resp attrs [s]]; |
206 |
fun assemble_pgipe resp attrs = assemble_pgips [XML.element resp attrs []]; |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
207 |
|
16534 | 208 |
(* FIXME: need to add stuff to gather PGIPs here *) |
209 |
fun issue_pgip resp attrs txt = |
|
210 |
if pgip_emacs_compatibility () then |
|
211 |
decorated_output (*add urgent message annotation*) |
|
17217
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
212 |
(special "360") (special "361") "" |
16534 | 213 |
(assemble_pgip resp attrs txt) |
214 |
else |
|
215 |
writeln_default (assemble_pgip resp attrs txt); |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
216 |
|
16534 | 217 |
(* FIXME: temporarily to support PG 3.4 *) |
218 |
fun issue_pgip_maybe_decorated bg en resp attrs s = |
|
219 |
if pgip_emacs_compatibility () then |
|
220 |
(*in PGIP mode, but using escape characters as well*) |
|
221 |
writeln_default (enclose bg en (assemble_pgip resp attrs s)) |
|
222 |
else |
|
223 |
issue_pgip resp attrs s; |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
224 |
|
16534 | 225 |
fun issue_pgipe resp attrs = writeln_default (assemble_pgipe resp attrs); |
226 |
||
227 |
end; |
|
228 |
||
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
229 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
230 |
(* messages and notification *) |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
231 |
|
15173
e1582a0d29b5
Comment about 3.6pre. Clean ups to XML, URL handling. Fix statedisplay double PGML quoting. Accumulate parse errors inside parseresult.
aspinall
parents:
15156
diff
changeset
|
232 |
local |
16534 | 233 |
val delay_msgs = ref false; (*true: accumulate messages*) |
234 |
val delayed_msgs = ref []; |
|
15173
e1582a0d29b5
Comment about 3.6pre. Clean ups to XML, URL handling. Fix statedisplay double PGML quoting. Accumulate parse errors inside parseresult.
aspinall
parents:
15156
diff
changeset
|
235 |
in |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
236 |
|
16534 | 237 |
fun message resp attrs bg en prfx s = |
238 |
if pgip () then |
|
239 |
(if (! delay_msgs) then |
|
240 |
delayed_msgs := (resp, attrs, prefix_lines prfx s) :: ! delayed_msgs (*NB: no decs*) |
|
241 |
else |
|
242 |
issue_pgip_maybe_decorated bg en resp attrs |
|
243 |
(XML.element "pgmltext" [] [prefix_lines prfx s])) |
|
244 |
else decorated_output bg en prfx s; |
|
15173
e1582a0d29b5
Comment about 3.6pre. Clean ups to XML, URL handling. Fix statedisplay double PGML quoting. Accumulate parse errors inside parseresult.
aspinall
parents:
15156
diff
changeset
|
245 |
|
16534 | 246 |
fun start_delay_msgs () = (set delay_msgs; delayed_msgs := []); |
15173
e1582a0d29b5
Comment about 3.6pre. Clean ups to XML, URL handling. Fix statedisplay double PGML quoting. Accumulate parse errors inside parseresult.
aspinall
parents:
15156
diff
changeset
|
247 |
|
16534 | 248 |
fun end_delayed_msgs () = (reset delay_msgs; |
249 |
(! delayed_msgs) |> map (fn (resp, attrs, s) => |
|
250 |
XML.element resp attrs [XML.element "pgmltext" [] [s]])); |
|
251 |
||
252 |
end; |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
253 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
254 |
local |
16534 | 255 |
val display_area = ("area", "display"); |
256 |
val message_area = ("area", "message"); |
|
257 |
val internal_category = ("messagecategory", "internal"); |
|
258 |
val info_category = ("messagecategory", "information"); |
|
259 |
val tracing_category = ("messagecategory", "tracing"); |
|
260 |
val urgent_indication = ("urgent", "y"); |
|
261 |
val nonfatal = ("fatality", "nonfatal"); |
|
262 |
val fatal = ("fatality", "fatal"); |
|
263 |
val panic = ("fatality", "panic"); |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
264 |
|
16534 | 265 |
val thyname_attr = pair "thyname"; |
266 |
val url_attr = pair "url"; |
|
267 |
fun localfile_url_attr path = url_attr ("file:///" ^ path); |
|
268 |
in |
|
12778 | 269 |
|
270 |
fun setup_messages () = |
|
17217
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
271 |
(writeln_fn := (fn s => message "normalresponse" [message_area] "" "" "" s); |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
272 |
priority_fn := (fn s => message "normalresponse" [message_area, urgent_indication] |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
273 |
(special "360") (special "361") "" s); |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
274 |
tracing_fn := (fn s => message "normalresponse" [message_area, tracing_category] |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
275 |
(special "360" ^ special "375") (special "361") "" s); |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
276 |
info_fn := (fn s => message "normalresponse" [message_area, info_category] |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
277 |
(special "362") (special "363") "+++ " s); |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
278 |
debug_fn := (fn s => message "normalresponse" [message_area, internal_category] |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
279 |
(special "362") (special "363") "+++ " s); |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
280 |
warning_fn := (fn s => message "errorresponse" [nonfatal] |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
281 |
(special "362") (special "363") "### " s); |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
282 |
error_fn := (fn s => message "errorresponse" [fatal] |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
283 |
(special "364") (special "365") "*** " s); |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
284 |
panic_fn := (fn s => message "errorresponse" [panic] |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
285 |
(special "364") (special "365") "!!! " s)); |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
286 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
287 |
|
15400
50bbdabd7326
Insert pgmltext element into responses in PGIP mode
aspinall
parents:
15289
diff
changeset
|
288 |
(* accumulate printed output in a single PGIP response (inside <pgmltext>) *) |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
289 |
|
16534 | 290 |
fun with_displaywrap (elt, attrs) dispfn = |
291 |
let |
|
292 |
val lines = ref ([]: string list); |
|
293 |
fun wlgrablines s = lines := s :: ! lines; |
|
294 |
in |
|
295 |
setmp writeln_fn wlgrablines dispfn (); |
|
16798 | 296 |
(* IMPORTANT FIXME: XML.element here too inefficient, should use stream output *) |
16534 | 297 |
issue_pgip elt attrs (XML.element "pgmltext" [] (! lines)) |
298 |
end; |
|
12778 | 299 |
|
17217
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
300 |
fun emacs_notify s = decorated_output (special "360") (special "361") "" s; |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
301 |
|
16534 | 302 |
fun tell_clear_goals () = |
303 |
if pgip () then |
|
304 |
issue_pgipe "cleardisplay" [display_area] |
|
305 |
else |
|
306 |
emacs_notify "Proof General, please clear the goals buffer."; |
|
307 |
||
308 |
fun tell_clear_response () = |
|
309 |
if pgip () then |
|
310 |
issue_pgipe "cleardisplay" [message_area] |
|
311 |
else |
|
312 |
emacs_notify "Proof General, please clear the response buffer."; |
|
12778 | 313 |
|
16534 | 314 |
fun tell_file_loaded path = |
315 |
if pgip () then |
|
16788
0c6f5fe30676
Fix informtheoryloaded/retracted -> informfileloaded/retracted to match pgip.rnc
aspinall
parents:
16534
diff
changeset
|
316 |
issue_pgipe "informfileloaded" |
0c6f5fe30676
Fix informtheoryloaded/retracted -> informfileloaded/retracted to match pgip.rnc
aspinall
parents:
16534
diff
changeset
|
317 |
[localfile_url_attr (XML.text (File.platform_path path))] |
16534 | 318 |
else |
319 |
emacs_notify ("Proof General, this file is loaded: " ^ quote (File.platform_path path)); |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
320 |
|
16534 | 321 |
fun tell_file_retracted path = |
322 |
if pgip() then |
|
16788
0c6f5fe30676
Fix informtheoryloaded/retracted -> informfileloaded/retracted to match pgip.rnc
aspinall
parents:
16534
diff
changeset
|
323 |
issue_pgipe "informfileretracted" |
0c6f5fe30676
Fix informtheoryloaded/retracted -> informfileloaded/retracted to match pgip.rnc
aspinall
parents:
16534
diff
changeset
|
324 |
[localfile_url_attr (XML.text (File.platform_path path))] |
16534 | 325 |
else |
326 |
emacs_notify ("Proof General, you can unlock the file " ^ quote (File.platform_path path)); |
|
12778 | 327 |
|
328 |
||
329 |
(* theory / proof state output *) |
|
330 |
||
331 |
local |
|
332 |
||
16534 | 333 |
fun tmp_markers f = |
17217
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
334 |
setmp Display.current_goals_markers (special "366", special "367", "") f (); |
12778 | 335 |
|
16534 | 336 |
fun statedisplay prts = |
337 |
issue_pgip "proofstate" [] |
|
338 |
(XML.element "pgml" [] |
|
339 |
[XML.element "statedisplay" [] [Pretty.output (Pretty.chunks prts)]]); |
|
17217
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
340 |
|
16534 | 341 |
fun print_current_goals n m st = |
342 |
if pgml () then statedisplay (Display.pretty_current_goals n m st) |
|
343 |
else tmp_markers (fn () => Display.print_current_goals_default n m st); |
|
13545 | 344 |
|
16534 | 345 |
fun print_state b st = |
346 |
if pgml () then statedisplay (Toplevel.pretty_state b st) |
|
347 |
else tmp_markers (fn () => Toplevel.print_state_default b st); |
|
348 |
||
13526 | 349 |
in |
350 |
||
16534 | 351 |
fun setup_state () = |
352 |
(Display.print_current_goals_fn := print_current_goals; |
|
353 |
Toplevel.print_state_fn := print_state; |
|
354 |
(* FIXME: check next octal char won't appear in pgip? *) |
|
17217
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
355 |
Toplevel.prompt_state_fn := (fn s => suffix (special "372") |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
356 |
(Toplevel.prompt_state_default s))); |
13728
8004e56204fd
Added some functions for processing PGIP (thanks to David Aspinall).
berghofe
parents:
13646
diff
changeset
|
357 |
|
16534 | 358 |
end; |
359 |
||
360 |
end; |
|
13728
8004e56204fd
Added some functions for processing PGIP (thanks to David Aspinall).
berghofe
parents:
13646
diff
changeset
|
361 |
|
16022 | 362 |
|
12778 | 363 |
(* misc commands for ProofGeneral/isa *) |
364 |
||
365 |
fun thms_containing ss = |
|
16534 | 366 |
FindTheorems.print_theorems (ProofContext.init (the_context ())) NONE NONE |
16022 | 367 |
(map (fn s => (true, FindTheorems.Pattern s)) ss); |
12778 | 368 |
|
369 |
val welcome = priority o Session.welcome; |
|
370 |
val help = welcome; |
|
371 |
val show_context = Context.the_context; |
|
372 |
||
17959 | 373 |
fun kill_goal () = (OldGoals.reset_goals (); tell_clear_goals ()); |
12778 | 374 |
|
375 |
fun no_print_goals f = setmp Display.print_current_goals_fn (fn _ => fn _ => fn _ => ()) f; |
|
376 |
||
377 |
fun repeat_undo 0 = () |
|
378 |
| repeat_undo 1 = undo () |
|
379 |
| repeat_undo n = (no_print_goals undo (); repeat_undo (n - 1)); |
|
380 |
||
381 |
||
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
382 |
(* theory loader actions *) |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
383 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
384 |
local |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
385 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
386 |
fun add_master_files name files = |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
387 |
let val masters = [ThyLoad.thy_path name, ThyLoad.ml_path name] |
20951
868120282837
gen_rem(s) abandoned in favour of remove / subtract
haftmann
parents:
20738
diff
changeset
|
388 |
in masters @ subtract (op = o pairself Path.base) masters files end; |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
389 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
390 |
fun trace_action action name = |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
391 |
if action = ThyInfo.Update then |
15570 | 392 |
List.app tell_file_loaded (ThyInfo.loaded_files name) |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
393 |
else if action = ThyInfo.Outdate orelse action = ThyInfo.Remove then |
15570 | 394 |
List.app tell_file_retracted (add_master_files name (ThyInfo.loaded_files name)) |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
395 |
else (); |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
396 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
397 |
in |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
398 |
fun setup_thy_loader () = ThyInfo.add_hook trace_action; |
15570 | 399 |
fun sync_thy_loader () = List.app (trace_action ThyInfo.Update) (ThyInfo.names ()); |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
400 |
end; |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
401 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
402 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
403 |
(* prepare theory context *) |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
404 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
405 |
val thy_name = Path.pack o #1 o Path.split_ext o Path.base o Path.unpack; |
16534 | 406 |
|
407 |
(* FIXME general treatment of tracing*) |
|
408 |
val update_thy_only = setmp MetaSimplifier.trace_simp false ThyInfo.update_thy_only; |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
409 |
|
16440 | 410 |
fun dynamic_context () = |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
411 |
(case Context.get_context () of |
16440 | 412 |
SOME thy => " Using current (dynamic!) one: " ^ quote (Context.theory_name thy) |
15531 | 413 |
| NONE => ""); |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
414 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
415 |
fun try_update_thy_only file = |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
416 |
ThyLoad.cond_add_path (Path.dir (Path.unpack file)) (fn () => |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
417 |
let val name = thy_name file in |
16534 | 418 |
if is_some (ThyLoad.check_file NONE (ThyLoad.thy_path name)) |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
419 |
then update_thy_only name |
16440 | 420 |
else warning ("Unkown theory context of ML file." ^ dynamic_context ()) |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
421 |
end) (); |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
422 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
423 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
424 |
(* get informed about files *) |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
425 |
|
16534 | 426 |
val inform_file_retracted = ThyInfo.if_known_thy ThyInfo.remove_thy o thy_name; |
427 |
val inform_file_processed = ThyInfo.if_known_thy ThyInfo.touch_child_thys o thy_name; |
|
428 |
val openfile_retract = Output.no_warnings (ThyInfo.if_known_thy ThyInfo.remove_thy) o thy_name; |
|
15629
4066f01f1beb
Add askguise/informguise as best as easily possible. Prevent warning in openfile when file doesn't exist in theory database.
aspinall
parents:
15626
diff
changeset
|
429 |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
430 |
fun proper_inform_file_processed file state = |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
431 |
let val name = thy_name file in |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
432 |
if Toplevel.is_toplevel state andalso ThyInfo.known_thy name then |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
433 |
(ThyInfo.touch_child_thys name; |
18678 | 434 |
ThyInfo.pretend_use_thy_only name handle ERROR msg => |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
435 |
(warning msg; warning ("Failed to register theory: " ^ quote name); |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
436 |
tell_file_retracted (Path.base (Path.unpack file)))) |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
437 |
else raise Toplevel.UNDEF |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
438 |
end; |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
439 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
440 |
fun vacuous_inform_file_processed file state = |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
441 |
(warning ("No theory " ^ quote (thy_name file)); |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
442 |
tell_file_retracted (Path.base (Path.unpack file))); |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
443 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
444 |
|
12778 | 445 |
(* restart top-level loop (keeps most state information) *) |
446 |
||
447 |
local |
|
448 |
||
449 |
fun restart isar = |
|
450 |
(if isar then tell_clear_goals () else kill_goal (); |
|
451 |
tell_clear_response (); |
|
452 |
welcome ()); |
|
453 |
||
454 |
in |
|
455 |
||
456 |
fun isa_restart () = restart false; |
|
457 |
fun isar_restart () = (sync_thy_loader (); restart true; raise Toplevel.RESTART); |
|
458 |
||
459 |
end; |
|
460 |
||
12833 | 461 |
fun full_proofs true = proofs := 2 |
462 |
| full_proofs false = proofs := 1; |
|
463 |
||
464 |
||
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
465 |
(* theorem dependency output *) |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
466 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
467 |
local |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
468 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
469 |
val spaces_quote = space_implode " " o map quote; |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
470 |
|
16789
e8f7a6ec92e5
Note about theorem dependencies including themselves.
aspinall
parents:
16788
diff
changeset
|
471 |
(* FIXME: investigate why dependencies at the moment include themselves! *) |
16534 | 472 |
fun thm_deps_message (thms, deps) = |
473 |
if pgip() then |
|
474 |
issue_pgips |
|
475 |
[XML.element |
|
476 |
"metainforesponse" (* FIXME: get thy name from info here? *) |
|
477 |
[("infotype", "isabelle_theorem_dependencies")] |
|
478 |
[XML.element "value" [("name", "thms")] [XML.text thms], |
|
479 |
XML.element "value" [("name", "deps")] [XML.text deps]]] |
|
480 |
else emacs_notify ("Proof General, theorem dependencies of " ^ thms ^ " are " ^ deps); |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
481 |
|
16534 | 482 |
fun tell_thm_deps ths = conditional (Output.has_mode thm_depsN) (fn () => |
483 |
let |
|
484 |
val names = filter_out (equal "") (map Thm.name_of_thm ths); |
|
485 |
val deps = filter_out (equal "") |
|
17018 | 486 |
(Symtab.keys (fold Proofterm.thms_of_proof |
487 |
(map Thm.proof_of ths) Symtab.empty)); |
|
16534 | 488 |
in |
489 |
if null names orelse null deps then () |
|
490 |
else thm_deps_message (spaces_quote names, spaces_quote deps) |
|
491 |
end); |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
492 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
493 |
in |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
494 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
495 |
fun setup_present_hook () = |
19482
9f11af8f7ef9
tuned basic list operators (flat, maps, map_filter);
wenzelm
parents:
19473
diff
changeset
|
496 |
Present.add_hook (fn _ => fn res => tell_thm_deps (maps #2 res)); |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
497 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
498 |
end; |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
499 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
500 |
|
16534 | 501 |
|
502 |
(** preferences **) |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
503 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
504 |
local |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
505 |
|
20364 | 506 |
fun signed_string_of_int i = |
507 |
if i < 0 then "-" ^ string_of_int (~ i) else string_of_int i; |
|
508 |
||
20299 | 509 |
val pgipint = XML.element "pgipint" [] []; |
16534 | 510 |
val pgipnat = XML.element "pgipint" [("min", "0")] []; |
511 |
fun pgipnatmax max = XML.element "pgipint" [("min", "0"), ("max", string_of_int max)] []; |
|
512 |
val pgipbool = XML.element "pgipbool" [] []; |
|
513 |
||
514 |
fun with_default f = (f (), f); |
|
515 |
||
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
516 |
in |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
517 |
|
20299 | 518 |
fun int_option r = (pgipint, |
20364 | 519 |
with_default (fn () => signed_string_of_int (! r)), |
20299 | 520 |
(fn s => (case Syntax.read_int s of |
521 |
NONE => error ("int_option: illegal value: " ^ s) |
|
522 |
| SOME i => r := i))); |
|
523 |
||
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
524 |
fun nat_option r = (pgipnat, |
16534 | 525 |
with_default (fn () => string_of_int (! r)), |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
526 |
(fn s => (case Syntax.read_nat s of |
16534 | 527 |
NONE => error ("nat_option: illegal value: " ^ s) |
528 |
| SOME i => r := i))); |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
529 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
530 |
fun bool_option r = (pgipbool, |
16534 | 531 |
with_default (fn () => Bool.toString (! r)), |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
532 |
(fn "false" => r := false | "true" => r := true |
16534 | 533 |
| x => error ("bool_option: illegal value: " ^ x))); |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
534 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
535 |
val proof_option = (pgipbool, |
16534 | 536 |
with_default (fn () => Bool.toString (! proofs >= 2)), |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
537 |
(fn "false" => proofs := 1 | "true" => proofs := 2 |
16534 | 538 |
| x => error ("proof_option: illegal value: " ^ x))); |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
539 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
540 |
val thm_deps_option = (pgipbool, |
16534 | 541 |
with_default (fn () => Bool.toString (Output.has_mode thm_depsN)), |
17217
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
542 |
(fn "false" => change print_mode (remove (op =) thm_depsN) |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
543 |
| "true" => change print_mode (insert (op =) thm_depsN) |
16534 | 544 |
| x => error ("thm_deps_option: illegal value: " ^ x))); |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
545 |
|
16534 | 546 |
local |
547 |
val pg_print_depth_val = ref 10; |
|
548 |
fun pg_print_depth n = (print_depth n; pg_print_depth_val := n) |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
549 |
in |
16534 | 550 |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
551 |
val print_depth_option = (pgipnat, |
16534 | 552 |
with_default (fn () => string_of_int (! pg_print_depth_val)), |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
553 |
(fn s => (case Syntax.read_nat s of |
16534 | 554 |
NONE => error ("print_depth_option: illegal value: " ^ s) |
555 |
| SOME i => pg_print_depth i))); |
|
556 |
end; |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
557 |
|
16534 | 558 |
val preferences = ref |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
559 |
[("Display", |
16534 | 560 |
[("show-types", |
561 |
("Include types in display of Isabelle terms", |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
562 |
bool_option show_types)), |
16534 | 563 |
("show-sorts", |
564 |
("Include sorts in display of Isabelle terms", |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
565 |
bool_option show_sorts)), |
16534 | 566 |
("show-consts", |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
567 |
("Show types of consts in Isabelle goal display", |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
568 |
bool_option show_consts)), |
16534 | 569 |
("long-names", |
570 |
("Show fully qualified names in Isabelle terms", |
|
571 |
bool_option long_names)), |
|
572 |
("show-brackets", |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
573 |
("Show full bracketing in Isabelle terms", |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
574 |
bool_option show_brackets)), |
16534 | 575 |
("show-main-goal", |
576 |
("Show main goal in proof state display", |
|
577 |
bool_option Proof.show_main_goal)), |
|
578 |
("eta-contract", |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
579 |
("Print terms eta-contracted", |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
580 |
bool_option Syntax.eta_contract))]), |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
581 |
("Advanced Display", |
16534 | 582 |
[("goals-limit", |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
583 |
("Setting for maximum number of goals printed", |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
584 |
nat_option goals_limit)), |
16534 | 585 |
("prems-limit", |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
586 |
("Setting for maximum number of premises printed", |
20299 | 587 |
int_option ProofContext.prems_limit)), |
16534 | 588 |
("print-depth", |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
589 |
("Setting for the ML print depth", |
15472 | 590 |
print_depth_option)), |
15985 | 591 |
("show-question-marks", |
15472 | 592 |
("Show leading question mark of variable name", |
15985 | 593 |
bool_option show_question_marks))]), |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
594 |
("Tracing", |
16534 | 595 |
[("trace-simplifier", |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
596 |
("Trace simplification rules.", |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
597 |
bool_option trace_simp)), |
17417 | 598 |
("trace-simplifier-depth", |
599 |
("Trace simplifier depth limit.", |
|
600 |
nat_option trace_simp_depth_limit)), |
|
16534 | 601 |
("trace-rules", |
602 |
("Trace application of the standard rules", |
|
603 |
bool_option trace_rules)), |
|
604 |
("trace-unification", |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
605 |
("Output error diagnostics during unification", |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
606 |
bool_option Pattern.trace_unify_fail)), |
16534 | 607 |
("global-timing", |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
608 |
("Whether to enable timing in Isabelle.", |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
609 |
bool_option Output.timing))]), |
16534 | 610 |
("Proof", |
611 |
[("quick-and-dirty", |
|
612 |
("Take a few short cuts", |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
613 |
bool_option quick_and_dirty)), |
16534 | 614 |
("full-proofs", |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
615 |
("Record full proof objects internally", |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
616 |
proof_option)), |
16534 | 617 |
("theorem-dependencies", |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
618 |
("Track theorem dependencies within Proof General", |
16534 | 619 |
thm_deps_option)), |
620 |
("skip-proofs", |
|
16816 | 621 |
("Ignore proof scripts (interactive-only)", |
15238
cb559bd0b03c
Added entry in Settings menu for Toplevel.skip_proofs flag.
berghofe
parents:
15225
diff
changeset
|
622 |
bool_option Toplevel.skip_proofs))]) |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
623 |
]; |
16534 | 624 |
end; |
625 |
||
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
626 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
627 |
(* Configuration: GUI config, proverinfo messages *) |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
628 |
|
17732
5b71bef7ad10
Initialise pgip id also for Emacs mode. Allow dynamic config file location for PGIP.
aspinall
parents:
17523
diff
changeset
|
629 |
|
5b71bef7ad10
Initialise pgip id also for Emacs mode. Allow dynamic config file location for PGIP.
aspinall
parents:
17523
diff
changeset
|
630 |
fun orenv v d = case (getenv v) of "" => d | s => s |
5b71bef7ad10
Initialise pgip id also for Emacs mode. Allow dynamic config file location for PGIP.
aspinall
parents:
17523
diff
changeset
|
631 |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
632 |
local |
17732
5b71bef7ad10
Initialise pgip id also for Emacs mode. Allow dynamic config file location for PGIP.
aspinall
parents:
17523
diff
changeset
|
633 |
fun config_file() = orenv "ISABELLE_PGIPCONFIG" "~~/lib/ProofGeneral/pgip_isar.xml" |
5b71bef7ad10
Initialise pgip id also for Emacs mode. Allow dynamic config file location for PGIP.
aspinall
parents:
17523
diff
changeset
|
634 |
fun isabelle_www() = orenv "ISABELLE_HOMEPAGE" "http://isabelle.in.tum.de/" |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
635 |
in |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
636 |
fun send_pgip_config () = |
16534 | 637 |
let |
17732
5b71bef7ad10
Initialise pgip id also for Emacs mode. Allow dynamic config file location for PGIP.
aspinall
parents:
17523
diff
changeset
|
638 |
val path = Path.unpack (config_file()) |
16534 | 639 |
val exists = File.exists path |
640 |
val proverinfo = |
|
641 |
XML.element "proverinfo" |
|
17732
5b71bef7ad10
Initialise pgip id also for Emacs mode. Allow dynamic config file location for PGIP.
aspinall
parents:
17523
diff
changeset
|
642 |
[("name", "Isabelle"), |
5b71bef7ad10
Initialise pgip id also for Emacs mode. Allow dynamic config file location for PGIP.
aspinall
parents:
17523
diff
changeset
|
643 |
("version", version), |
5b71bef7ad10
Initialise pgip id also for Emacs mode. Allow dynamic config file location for PGIP.
aspinall
parents:
17523
diff
changeset
|
644 |
("instance", Session.name()), |
17739 | 645 |
("descr", "The Isabelle/Isar theorem prover"), |
17732
5b71bef7ad10
Initialise pgip id also for Emacs mode. Allow dynamic config file location for PGIP.
aspinall
parents:
17523
diff
changeset
|
646 |
("url", isabelle_www()), |
5b71bef7ad10
Initialise pgip id also for Emacs mode. Allow dynamic config file location for PGIP.
aspinall
parents:
17523
diff
changeset
|
647 |
("filenameextns", ".thy;")] |
17739 | 648 |
[] |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
649 |
in |
16534 | 650 |
if exists then |
651 |
(issue_pgips [proverinfo]; issue_pgips [File.read path]) |
|
18678 | 652 |
else Output.panic ("PGIP configuration file \"" ^ config_file() ^ "\" not found") |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
653 |
end; |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
654 |
end |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
655 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
656 |
|
15629
4066f01f1beb
Add askguise/informguise as best as easily possible. Prevent warning in openfile when file doesn't exist in theory database.
aspinall
parents:
15626
diff
changeset
|
657 |
(* Reveal some information about prover state *) |
4066f01f1beb
Add askguise/informguise as best as easily possible. Prevent warning in openfile when file doesn't exist in theory database.
aspinall
parents:
15626
diff
changeset
|
658 |
fun send_informguise (openfile, opentheory, openproofpos) = |
16534 | 659 |
let val guisefile = |
660 |
case openfile of SOME f => [XML.element "guisefile" |
|
661 |
[("url",Url.pack (Url.File (Path.unpack f)))] []] |
|
662 |
| _ => [] |
|
663 |
val guisetheory = |
|
664 |
case opentheory of SOME t => [XML.element "guisetheory" [("thyname", t)] []] |
|
665 |
| _ => [] |
|
666 |
val guiseproof = |
|
667 |
case openproofpos of SOME i => [XML.element "guiseproof" [("proofpos", string_of_int i)] []] |
|
668 |
| _ => [] |
|
669 |
in |
|
670 |
issue_pgips [XML.element "informguise" [] (guisefile @ guisetheory @ guiseproof)] |
|
671 |
end |
|
15629
4066f01f1beb
Add askguise/informguise as best as easily possible. Prevent warning in openfile when file doesn't exist in theory database.
aspinall
parents:
15626
diff
changeset
|
672 |
|
4066f01f1beb
Add askguise/informguise as best as easily possible. Prevent warning in openfile when file doesn't exist in theory database.
aspinall
parents:
15626
diff
changeset
|
673 |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
674 |
(* PGIP identifier tables (prover objects). [incomplete] *) |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
675 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
676 |
local |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
677 |
val objtype_thy = "theory" |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
678 |
val objtype_thm = "theorem" |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
679 |
val objtype_term = "term" |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
680 |
val objtype_type = "type" |
16534 | 681 |
|
682 |
fun xml_idtable ty ctx ids = |
|
683 |
let |
|
15531 | 684 |
fun ctx_attr (SOME c)= [("context", c)] |
685 |
| ctx_attr NONE = [] |
|
16534 | 686 |
fun xmlid x = XML.element "identifier" [] [XML.text x]; |
687 |
in |
|
688 |
XML.element "idtable" (("objtype", ty)::ctx_attr ctx) |
|
689 |
(map xmlid ids) |
|
690 |
end |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
691 |
in |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
692 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
693 |
fun setids t = issue_pgip "setids" [] t |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
694 |
fun addids t = issue_pgip "addids" [] t |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
695 |
fun delids t = issue_pgip "delids" [] t |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
696 |
|
15531 | 697 |
fun delallids ty = setids (xml_idtable ty NONE []) |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
698 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
699 |
fun send_thy_idtable ctx thys = setids (xml_idtable objtype_thy ctx thys) |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
700 |
fun clear_thy_idtable () = delallids objtype_thy |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
701 |
|
16534 | 702 |
fun send_thm_idtable ctx thy = |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
703 |
addids (xml_idtable objtype_thm ctx (map fst (PureThy.thms_of thy))); |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
704 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
705 |
fun clear_thm_idtable () = delallids objtype_thm |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
706 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
707 |
(* fun send_type_idtable thy = TODO, it's a bit low-level messy |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
708 |
& maybe not so useful anyway *) |
16534 | 709 |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
710 |
end |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
711 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
712 |
(* Response to interface queries about known objects *) |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
713 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
714 |
local |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
715 |
val topthy = Toplevel.theory_of o Toplevel.get_state |
16486 | 716 |
fun pthm thy name = print_thm (get_thm thy (Name name)) |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
717 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
718 |
fun idvalue tp nm = ("idvalue",[("objtype",tp),("name",nm)]) |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
719 |
in |
16798 | 720 |
(* FIXME: add askids for "file" here, which returns single theory with same name *) |
15531 | 721 |
fun askids (NONE, SOME "theory") = send_thy_idtable NONE (ThyInfo.names()) |
722 |
| askids (NONE, NONE) = send_thy_idtable NONE (ThyInfo.names()) |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
723 |
(* only theories known in top context *) |
15531 | 724 |
| askids (SOME thy, SOME "theory") = send_thy_idtable (SOME thy) (ThyInfo.get_preds thy) |
725 |
| askids (SOME thy, SOME "theorem") = send_thm_idtable (SOME thy) (ThyInfo.get_theory thy) |
|
726 |
| askids (SOME thy, NONE) = (send_thy_idtable (SOME thy) (ThyInfo.get_preds thy); |
|
16534 | 727 |
send_thm_idtable (SOME thy) (ThyInfo.get_theory thy)) |
15531 | 728 |
| askids (_, SOME ot) = error ("No objects of type "^(quote ot)^" are available here.") |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
729 |
|
16534 | 730 |
fun showid (_, "theory", n) = |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
731 |
with_displaywrap (idvalue "theory" n) (fn ()=>(print_theory (ThyInfo.get_theory n))) |
16534 | 732 |
| showid (SOME thy, "theorem", t) = |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
733 |
with_displaywrap (idvalue "theorem" t) (fn ()=>(pthm (ThyInfo.get_theory thy) t)) |
16534 | 734 |
| showid (NONE, "theorem", t) = |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
735 |
with_displaywrap (idvalue "theorem" t) (fn ()=>pthm (topthy()) t) |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
736 |
| showid (_, ot, _) = error ("Cannot show objects of type "^ot) |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
737 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
738 |
end |
15629
4066f01f1beb
Add askguise/informguise as best as easily possible. Prevent warning in openfile when file doesn't exist in theory database.
aspinall
parents:
15626
diff
changeset
|
739 |
|
4066f01f1beb
Add askguise/informguise as best as easily possible. Prevent warning in openfile when file doesn't exist in theory database.
aspinall
parents:
15626
diff
changeset
|
740 |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
741 |
(** Parsing proof scripts without execution **) |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
742 |
|
15146
eab7de0d0a31
Parsing fixes: extra sync token; thmname attribute in opengoal; theory-end. Comments.
aspinall
parents:
15145
diff
changeset
|
743 |
(* Notes. |
eab7de0d0a31
Parsing fixes: extra sync token; thmname attribute in opengoal; theory-end. Comments.
aspinall
parents:
15145
diff
changeset
|
744 |
This is quite tricky, because 1) we need to put back whitespace which |
eab7de0d0a31
Parsing fixes: extra sync token; thmname attribute in opengoal; theory-end. Comments.
aspinall
parents:
15145
diff
changeset
|
745 |
was removed during parsing so we can provide markup around commands; |
eab7de0d0a31
Parsing fixes: extra sync token; thmname attribute in opengoal; theory-end. Comments.
aspinall
parents:
15145
diff
changeset
|
746 |
2) parsing is intertwined with execution in Isar so we have to repeat |
eab7de0d0a31
Parsing fixes: extra sync token; thmname attribute in opengoal; theory-end. Comments.
aspinall
parents:
15145
diff
changeset
|
747 |
the parsing to extract interesting parts of commands. The trace of |
15254
10cfd6a14682
Simplification to symbol processing; put quotes around theory name in message.
aspinall
parents:
15253
diff
changeset
|
748 |
tokens parsed which is now recorded in each transition (added by |
10cfd6a14682
Simplification to symbol processing; put quotes around theory name in message.
aspinall
parents:
15253
diff
changeset
|
749 |
Markus June '04) helps do this, but the mechanism is still a bad mess. |
16534 | 750 |
|
15254
10cfd6a14682
Simplification to symbol processing; put quotes around theory name in message.
aspinall
parents:
15253
diff
changeset
|
751 |
If we had proper parse trees it would be easy, although having a |
10cfd6a14682
Simplification to symbol processing; put quotes around theory name in message.
aspinall
parents:
15253
diff
changeset
|
752 |
fixed type of trees might be tricky with Isar's extensible parser. |
15146
eab7de0d0a31
Parsing fixes: extra sync token; thmname attribute in opengoal; theory-end. Comments.
aspinall
parents:
15145
diff
changeset
|
753 |
|
eab7de0d0a31
Parsing fixes: extra sync token; thmname attribute in opengoal; theory-end. Comments.
aspinall
parents:
15145
diff
changeset
|
754 |
Probably the best solution is to produce the meta-information at |
16534 | 755 |
the same time as the parse, for each command, e.g. by recording a |
756 |
list of (name,objtype) pairs which record the bindings created by |
|
757 |
a command. This would require changing the interfaces in |
|
758 |
outer_syntax.ML (or providing new ones), |
|
15146
eab7de0d0a31
Parsing fixes: extra sync token; thmname attribute in opengoal; theory-end. Comments.
aspinall
parents:
15145
diff
changeset
|
759 |
|
eab7de0d0a31
Parsing fixes: extra sync token; thmname attribute in opengoal; theory-end. Comments.
aspinall
parents:
15145
diff
changeset
|
760 |
datatype metainfo = Binding of string * string (* name, objtype *) |
eab7de0d0a31
Parsing fixes: extra sync token; thmname attribute in opengoal; theory-end. Comments.
aspinall
parents:
15145
diff
changeset
|
761 |
|
eab7de0d0a31
Parsing fixes: extra sync token; thmname attribute in opengoal; theory-end. Comments.
aspinall
parents:
15145
diff
changeset
|
762 |
val command_withmetainfo: string -> string -> string -> |
16534 | 763 |
(token list -> |
764 |
((Toplevel.transition -> Toplevel.transition) * metainfo list) * |
|
15146
eab7de0d0a31
Parsing fixes: extra sync token; thmname attribute in opengoal; theory-end. Comments.
aspinall
parents:
15145
diff
changeset
|
765 |
token list) -> parser |
15254
10cfd6a14682
Simplification to symbol processing; put quotes around theory name in message.
aspinall
parents:
15253
diff
changeset
|
766 |
|
10cfd6a14682
Simplification to symbol processing; put quotes around theory name in message.
aspinall
parents:
15253
diff
changeset
|
767 |
We'd also like to render terms as they appear in output, but this |
16534 | 768 |
will be difficult because inner syntax is extensible and we don't |
15254
10cfd6a14682
Simplification to symbol processing; put quotes around theory name in message.
aspinall
parents:
15253
diff
changeset
|
769 |
have the correct syntax to hand when just doing outer parsing |
16534 | 770 |
without execution. A reasonable approximation could |
15254
10cfd6a14682
Simplification to symbol processing; put quotes around theory name in message.
aspinall
parents:
15253
diff
changeset
|
771 |
perhaps be obtained by using the syntax of the current context. |
16534 | 772 |
However, this would mean more mess trying to pick out terms, |
15254
10cfd6a14682
Simplification to symbol processing; put quotes around theory name in message.
aspinall
parents:
15253
diff
changeset
|
773 |
so at this stage a more serious change to the Isar functions |
10cfd6a14682
Simplification to symbol processing; put quotes around theory name in message.
aspinall
parents:
15253
diff
changeset
|
774 |
seems necessary. |
15146
eab7de0d0a31
Parsing fixes: extra sync token; thmname attribute in opengoal; theory-end. Comments.
aspinall
parents:
15145
diff
changeset
|
775 |
*) |
eab7de0d0a31
Parsing fixes: extra sync token; thmname attribute in opengoal; theory-end. Comments.
aspinall
parents:
15145
diff
changeset
|
776 |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
777 |
local |
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
778 |
fun markup_text str elt = [XML.element elt [] [XML.text str]] |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
779 |
fun markup_text_attrs str elt attrs = [XML.element elt attrs [XML.text str]] |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
780 |
fun empty elt = [XML.element elt [] []] |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
781 |
|
15210
4ff917a91e16
Remove double escaping of backslash in PGML. Remove use of character refs in <whitespace>
aspinall
parents:
15208
diff
changeset
|
782 |
fun whitespace str = XML.element "whitespace" [] [XML.text str] |
15208
09271a87fbf0
Add filenamextns to prover info. Update doc location. Add whitespace element in parseresult
aspinall
parents:
15192
diff
changeset
|
783 |
|
15146
eab7de0d0a31
Parsing fixes: extra sync token; thmname attribute in opengoal; theory-end. Comments.
aspinall
parents:
15145
diff
changeset
|
784 |
(* an extra token is needed to terminate the command *) |
eab7de0d0a31
Parsing fixes: extra sync token; thmname attribute in opengoal; theory-end. Comments.
aspinall
parents:
15145
diff
changeset
|
785 |
val sync = OuterSyntax.scan "\\<^sync>"; |
eab7de0d0a31
Parsing fixes: extra sync token; thmname attribute in opengoal; theory-end. Comments.
aspinall
parents:
15145
diff
changeset
|
786 |
|
16534 | 787 |
fun named_item_elt_with nameattr toks str elt nameP objtyp = |
788 |
let |
|
789 |
val name = (fst (nameP (toks@sync))) |
|
790 |
handle _ => (error ("Error occurred in name parser for " ^ elt ^ |
|
791 |
"(objtype: " ^ objtyp ^ ")"); |
|
792 |
"") |
|
793 |
||
794 |
in |
|
795 |
[XML.element elt |
|
796 |
((if name="" then [] else [(nameattr, name)])@ |
|
797 |
(if objtyp="" then [] else [("objtype", objtyp)])) |
|
798 |
([XML.text str])] |
|
799 |
end |
|
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
800 |
|
15146
eab7de0d0a31
Parsing fixes: extra sync token; thmname attribute in opengoal; theory-end. Comments.
aspinall
parents:
15145
diff
changeset
|
801 |
val named_item_elt = named_item_elt_with "name" |
eab7de0d0a31
Parsing fixes: extra sync token; thmname attribute in opengoal; theory-end. Comments.
aspinall
parents:
15145
diff
changeset
|
802 |
val thmnamed_item_elt = named_item_elt_with "thmname" |
16534 | 803 |
|
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
804 |
fun parse_warning msg = warning ("script->PGIP markup parser: " ^ msg) |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
805 |
|
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
806 |
(* FIXME: allow dynamic extensions to language here: we need a hook in |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
807 |
outer_syntax.ML to reset this table. *) |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
808 |
|
16534 | 809 |
val keywords_classification_table = ref (NONE: string Symtab.table option) |
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
810 |
|
16534 | 811 |
fun get_keywords_classification_table () = |
812 |
case (!keywords_classification_table) of |
|
17221 | 813 |
SOME t => t |
814 |
| NONE => (let |
|
17417 | 815 |
val tab = fold (fn (c, _, k, _) => Symtab.update (c, k)) |
17221 | 816 |
(OuterSyntax.dest_parsers ()) Symtab.empty; |
817 |
in (keywords_classification_table := SOME tab; tab) end) |
|
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
818 |
|
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
819 |
|
16534 | 820 |
|
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
821 |
fun xmls_of_thy_begin (name,toks,str) = (* see isar_syn.ML/theoryP *) |
16534 | 822 |
let |
823 |
val ((thyname,imports,files),_) = ThyHeader.args (toks@sync) |
|
824 |
in |
|
825 |
markup_text_attrs str "opentheory" |
|
826 |
([("thyname",thyname)] @ |
|
827 |
(if imports=[] then [] else |
|
828 |
[("parentnames", (space_implode ";" imports) ^ ";")])) |
|
829 |
end |
|
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
830 |
|
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
831 |
fun xmls_of_thy_decl (name,toks,str) = (* see isar_syn.ML/thy_decl cases *) |
16534 | 832 |
let |
833 |
(* NB: PGIP only deals with single name bindings at the moment; |
|
834 |
potentially we could markup grouped definitions several times but |
|
835 |
that might suggest the wrong structure to the editor? |
|
836 |
Better alternative would be to put naming closer around text, |
|
837 |
but to do that we'd be much better off modifying the real parser |
|
838 |
instead of reconstructing it here. *) |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
839 |
|
16534 | 840 |
val plain_items = (* no names, unimportant names, or too difficult *) |
841 |
["defaultsort","arities","judgement","finalconsts", |
|
842 |
"syntax", "nonterminals", "translations", |
|
843 |
"global", "local", "hide", |
|
844 |
"ML_setup", "setup", "method_setup", |
|
845 |
"parse_ast_translation", "parse_translation", "print_translation", |
|
846 |
"typed_print_translation", "print_ast_translation", "token_translation", |
|
847 |
"oracle", |
|
848 |
"declare"] |
|
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
849 |
|
16534 | 850 |
val plain_item = markup_text str "theoryitem" |
851 |
val comment_item = markup_text str "litcomment" |
|
852 |
val named_item = named_item_elt toks str "theoryitem" |
|
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
853 |
|
16534 | 854 |
val opt_overloaded = P.opt_keyword "overloaded"; |
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
855 |
|
16534 | 856 |
val thmnameP = (* see isar_syn.ML/theoremsP *) |
857 |
let |
|
858 |
val name_facts = P.and_list1 ((P.opt_thm_name "=" --| P.xthms1) >> #1) |
|
16958 | 859 |
val theoremsP = P.opt_locale_target |-- name_facts >> (fn [] => "" | x::_ => x) |
16534 | 860 |
in |
861 |
theoremsP |
|
862 |
end |
|
863 |
in |
|
864 |
(* TODO: ideally we would like to render terms properly, just as they are |
|
865 |
in output. This implies using PGML for symbols and variables/atoms. |
|
866 |
BUT it's rather tricky without having the correct concrete syntax to hand, |
|
867 |
and even if we did, we'd have to mess around here a whole lot more first |
|
868 |
to pick out the terms from the syntax. *) |
|
15254
10cfd6a14682
Simplification to symbol processing; put quotes around theory name in message.
aspinall
parents:
15253
diff
changeset
|
869 |
|
20664 | 870 |
if member (op =) plain_items name then plain_item |
16534 | 871 |
else case name of |
872 |
"text" => comment_item |
|
873 |
| "text_raw" => comment_item |
|
874 |
| "typedecl" => named_item (P.type_args |-- P.name) "type" |
|
875 |
| "types" => named_item (P.type_args |-- P.name) "type" |
|
876 |
| "classes" => named_item P.name "class" |
|
877 |
| "classrel" => named_item P.name "class" |
|
878 |
| "consts" => named_item (P.const >> #1) "term" |
|
879 |
| "axioms" => named_item (P.spec_name >> (#1 o #1)) "theorem" |
|
880 |
| "defs" => named_item (opt_overloaded |-- P.spec_name >> (#1 o #1)) "theorem" |
|
881 |
| "constdefs" => named_item P.name (* FIXME: heavily simplified/wrong *) "term" |
|
882 |
| "theorems" => named_item thmnameP "thmset" |
|
883 |
| "lemmas" => named_item thmnameP "thmset" |
|
884 |
| "oracle" => named_item P.name "oracle" |
|
885 |
| "locale" => named_item ((P.opt_keyword "open" >> not) |-- P.name) "locale" |
|
886 |
| _ => (parse_warning ("Unrecognized thy-decl command: " ^ name); plain_item) |
|
887 |
end |
|
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
888 |
|
16534 | 889 |
fun xmls_of_thy_goal (name,toks,str) = |
890 |
let |
|
891 |
(* see isar_syn.ML/gen_theorem *) |
|
15146
eab7de0d0a31
Parsing fixes: extra sync token; thmname attribute in opengoal; theory-end. Comments.
aspinall
parents:
15145
diff
changeset
|
892 |
val statement = P.and_list1 (P.opt_thm_name ":" -- Scan.repeat1 P.propp); |
16534 | 893 |
val general_statement = |
18130 | 894 |
statement >> pair [] || Scan.repeat P.locale_element -- (P.$$$ "shows" |-- statement); |
16534 | 895 |
|
896 |
val gen_theoremP = |
|
16958 | 897 |
P.opt_locale_target -- Scan.optional (P.opt_thm_name ":" --| |
15146
eab7de0d0a31
Parsing fixes: extra sync token; thmname attribute in opengoal; theory-end. Comments.
aspinall
parents:
15145
diff
changeset
|
898 |
Scan.ahead (P.locale_keyword || P.$$$ "shows")) ("", []) -- |
16534 | 899 |
general_statement >> (fn ((locale, a), (elems, concl)) => |
900 |
fst a) (* a : (bstring * Args.src list) *) |
|
15146
eab7de0d0a31
Parsing fixes: extra sync token; thmname attribute in opengoal; theory-end. Comments.
aspinall
parents:
15145
diff
changeset
|
901 |
|
16958 | 902 |
val nameP = P.opt_locale_target |-- (Scan.optional ((P.opt_thm_name ":") >> #1) "") |
16534 | 903 |
(* TODO: add preference values for attributes |
904 |
val prefval = XML.element "prefval" [("name","thm-kind"),("value",name)] |
|
905 |
*) |
|
906 |
in |
|
907 |
(thmnamed_item_elt toks str "opengoal" nameP "") @ |
|
908 |
(empty "openblock") |
|
909 |
end |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
910 |
|
17217
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
911 |
fun xmls_of_qed (name,markup) = |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
912 |
let val qedmarkup = |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
913 |
(case name of |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
914 |
"sorry" => markup "postponegoal" |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
915 |
| "oops" => markup "giveupgoal" |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
916 |
| "done" => markup "closegoal" |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
917 |
| "by" => markup "closegoal" (* nested or toplevel *) |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
918 |
| "qed" => markup "closegoal" (* nested or toplevel *) |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
919 |
| "." => markup "closegoal" (* nested or toplevel *) |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
920 |
| ".." => markup "closegoal" (* nested or toplevel *) |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
921 |
| other => (* default to closegoal: may be wrong for extns *) |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
922 |
(parse_warning |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
923 |
("Unrecognized qed command: " ^ quote other); |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
924 |
markup "closegoal")) |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
925 |
in qedmarkup @ (empty "closeblock") end |
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
926 |
|
16534 | 927 |
fun xmls_of_kind kind (name,toks,str) = |
928 |
let val markup = markup_text str in |
|
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
929 |
case kind of |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
930 |
"control" => markup "badcmd" |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
931 |
| "diag" => markup "spuriouscmd" |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
932 |
(* theory/files *) |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
933 |
| "theory-begin" => xmls_of_thy_begin (name,toks,str) |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
934 |
| "theory-decl" => xmls_of_thy_decl (name,toks,str) |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
935 |
| "theory-heading" => markup "litcomment" |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
936 |
| "theory-script" => markup "theorystep" |
15146
eab7de0d0a31
Parsing fixes: extra sync token; thmname attribute in opengoal; theory-end. Comments.
aspinall
parents:
15145
diff
changeset
|
937 |
| "theory-end" => markup "closetheory" |
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
938 |
(* proof control *) |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
939 |
| "theory-goal" => xmls_of_thy_goal (name,toks,str) |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
940 |
| "proof-heading" => markup "litcomment" |
15225
68ab0f4eb457
Add openblock/closeblock to other opengoal/closegoal elements
aspinall
parents:
15220
diff
changeset
|
941 |
| "proof-goal" => (markup "opengoal") @ (empty "openblock") (* nested proof: have, show, ... *) |
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
942 |
| "proof-block" => markup "proofstep" (* context-shift: proof, next; really "newgoal" *) |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
943 |
| "proof-open" => (empty "openblock") @ (markup "proofstep") |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
944 |
| "proof-close" => (markup "proofstep") @ (empty "closeblock") |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
945 |
| "proof-script" => markup "proofstep" |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
946 |
| "proof-chain" => markup "proofstep" |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
947 |
| "proof-decl" => markup "proofstep" |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
948 |
| "proof-asm" => markup "proofstep" |
15289 | 949 |
| "proof-asm-goal" => (markup "opengoal") @ (empty "openblock") (* nested proof: obtain *) |
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
950 |
| "qed" => xmls_of_qed (name,markup) |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
951 |
| "qed-block" => xmls_of_qed (name,markup) |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
952 |
| "qed-global" => xmls_of_qed (name,markup) |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
953 |
| other => (* default for anything else is "spuriouscmd", ignored for undo. *) |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
954 |
(parse_warning ("Internal inconsistency, unrecognized keyword kind: " ^ quote other); |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
955 |
markup "spuriouscmd") |
16534 | 956 |
end |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
957 |
in |
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
958 |
|
16534 | 959 |
fun xmls_of_transition (name,str,toks) = |
960 |
let |
|
17417 | 961 |
val classification = Symtab.lookup (get_keywords_classification_table ()) name |
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
962 |
in case classification of |
16534 | 963 |
SOME k => (xmls_of_kind k (name,toks,str)) |
964 |
| NONE => (* an uncategorized keyword ignored for undo (maybe wrong) *) |
|
965 |
(parse_warning ("Uncategorized command found: " ^ name ^ " -- using spuriouscmd"); |
|
966 |
markup_text str "spuriouscmd") |
|
967 |
end |
|
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
968 |
|
15191
5ca1fd9dec83
Support parsing of -- {* comments *}. Add extra output channels.
aspinall
parents:
15173
diff
changeset
|
969 |
fun markup_toks [] _ = [] |
5ca1fd9dec83
Support parsing of -- {* comments *}. Add extra output channels.
aspinall
parents:
15173
diff
changeset
|
970 |
| markup_toks toks x = markup_text (implode (map OuterLex.unparse toks)) x |
5ca1fd9dec83
Support parsing of -- {* comments *}. Add extra output channels.
aspinall
parents:
15173
diff
changeset
|
971 |
|
5ca1fd9dec83
Support parsing of -- {* comments *}. Add extra output channels.
aspinall
parents:
15173
diff
changeset
|
972 |
fun markup_comment_whs [] = [] |
5ca1fd9dec83
Support parsing of -- {* comments *}. Add extra output channels.
aspinall
parents:
15173
diff
changeset
|
973 |
| markup_comment_whs (toks as t::ts) = (* this would be a lot neater if we could match on toks! *) |
16534 | 974 |
let |
975 |
val (prewhs,rest) = take_prefix (OuterLex.is_kind OuterLex.Space) toks |
|
976 |
in |
|
977 |
if (prewhs <> []) then |
|
978 |
whitespace (implode (map OuterLex.unparse prewhs)) |
|
979 |
:: (markup_comment_whs rest) |
|
980 |
else |
|
981 |
(markup_text (OuterLex.unparse t) "comment") @ |
|
982 |
(markup_comment_whs ts) |
|
15191
5ca1fd9dec83
Support parsing of -- {* comments *}. Add extra output channels.
aspinall
parents:
15173
diff
changeset
|
983 |
end |
5ca1fd9dec83
Support parsing of -- {* comments *}. Add extra output channels.
aspinall
parents:
15173
diff
changeset
|
984 |
|
5ca1fd9dec83
Support parsing of -- {* comments *}. Add extra output channels.
aspinall
parents:
15173
diff
changeset
|
985 |
fun xmls_pre_cmd [] = ([],[]) |
16534 | 986 |
| xmls_pre_cmd toks = |
987 |
let |
|
988 |
(* an extra token is needed to terminate the command *) |
|
989 |
val sync = OuterSyntax.scan "\\<^sync>"; |
|
990 |
val spaceP = Scan.bulk (Scan.one (fn t =>not (OuterLex.is_proper t)) >> OuterLex.val_of) >> implode |
|
991 |
val text_with_whs = |
|
992 |
((spaceP || Scan.succeed "") -- |
|
993 |
(P.short_ident || P.long_ident || P.sym_ident || P.string || P.number || P.verbatim) >> op^) |
|
994 |
-- (spaceP || Scan.succeed "") >> op^ |
|
995 |
val (prewhs,rest1) = take_prefix (not o OuterLex.is_proper) (toks@sync) |
|
15191
5ca1fd9dec83
Support parsing of -- {* comments *}. Add extra output channels.
aspinall
parents:
15173
diff
changeset
|
996 |
(* NB: this collapses litcomment,(litcomment|whitespace)* to a single litcomment *) |
16534 | 997 |
val (_,rest2) = (Scan.bulk (P.$$$ "--" |-- text_with_whs) >> implode || Scan.succeed "") rest1 |
998 |
val (postwhs,rest3) = take_prefix (not o OuterLex.is_proper) rest2 |
|
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
999 |
in |
16534 | 1000 |
((markup_comment_whs prewhs) @ |
1001 |
(if (length rest2 = length rest1) then [] |
|
1002 |
else markup_text (implode |
|
1003 |
(map OuterLex.unparse (Library.take (length rest1 - length rest2, rest1)))) |
|
1004 |
"litcomment") @ |
|
1005 |
(markup_comment_whs postwhs), |
|
1006 |
Library.take (length rest3 - 1,rest3)) |
|
15191
5ca1fd9dec83
Support parsing of -- {* comments *}. Add extra output channels.
aspinall
parents:
15173
diff
changeset
|
1007 |
end |
5ca1fd9dec83
Support parsing of -- {* comments *}. Add extra output channels.
aspinall
parents:
15173
diff
changeset
|
1008 |
|
16534 | 1009 |
fun xmls_of_impropers toks = |
1010 |
let |
|
1011 |
val (xmls,rest) = xmls_pre_cmd toks |
|
15191
5ca1fd9dec83
Support parsing of -- {* comments *}. Add extra output channels.
aspinall
parents:
15173
diff
changeset
|
1012 |
in |
16534 | 1013 |
xmls @ (markup_toks rest "unparseable") |
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1014 |
end |
16534 | 1015 |
|
1016 |
fun markup_unparseable str = markup_text str "unparseable" |
|
15173
e1582a0d29b5
Comment about 3.6pre. Clean ups to XML, URL handling. Fix statedisplay double PGML quoting. Accumulate parse errors inside parseresult.
aspinall
parents:
15156
diff
changeset
|
1017 |
|
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1018 |
end |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1019 |
|
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1020 |
|
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1021 |
local |
16534 | 1022 |
(* we have to weave together the whitespace/comments with proper tokens |
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1023 |
to reconstruct the input. *) |
15191
5ca1fd9dec83
Support parsing of -- {* comments *}. Add extra output channels.
aspinall
parents:
15173
diff
changeset
|
1024 |
(* TODO: see if duplicating isar_output/parse_thy can help here *) |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1025 |
|
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1026 |
fun match_tokens ([],us,vs) = (rev vs,us) (* used, unused *) |
16534 | 1027 |
| match_tokens (t::ts,w::ws,vs) = |
1028 |
if (t = w) then match_tokens (ts,ws,w::vs) |
|
1029 |
else match_tokens (t::ts,ws,w::vs) |
|
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1030 |
| match_tokens _ = error ("match_tokens: mismatched input parse") |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1031 |
in |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1032 |
fun xmls_of_str str = |
16534 | 1033 |
let |
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1034 |
(* parsing: See outer_syntax.ML/toplevel_source *) |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1035 |
fun parse_loop ([],[],xmls) = xmls |
16534 | 1036 |
| parse_loop ([],itoks,xmls) = xmls @ (xmls_of_impropers itoks) |
1037 |
| parse_loop ((nm,toks,_)::trs,itoks,xmls) = |
|
1038 |
let |
|
1039 |
(* first proper token after whitespace/litcomment/whitespace is command *) |
|
1040 |
val (xmls_pre_cmd,cmditoks') = xmls_pre_cmd itoks |
|
1041 |
val (cmdtok,itoks') = case cmditoks' of x::xs => (x,xs) |
|
1042 |
| _ => error("proof_general/parse_loop impossible") |
|
1043 |
val (utoks,itoks'') = match_tokens (toks,itoks',[]) |
|
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1044 |
(* FIXME: should take trailing [w/s+] semicolon too in utoks *) |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1045 |
|
16534 | 1046 |
val str = implode (map OuterLex.unparse (cmdtok::utoks)) |
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1047 |
|
16534 | 1048 |
val xmls_tr = xmls_of_transition (nm,str,toks) |
1049 |
in |
|
1050 |
parse_loop(trs,itoks'',xmls @ xmls_pre_cmd @ xmls_tr) |
|
1051 |
end |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1052 |
in |
16534 | 1053 |
(let val toks = OuterSyntax.scan str |
1054 |
in |
|
1055 |
parse_loop (OuterSyntax.read toks, toks, []) |
|
1056 |
end) |
|
1057 |
handle _ => markup_unparseable str |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1058 |
end |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1059 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1060 |
|
16534 | 1061 |
fun parsescript str attrs = |
1062 |
let |
|
1063 |
val _ = start_delay_msgs () (* accumulate error messages to put inside parseresult *) |
|
1064 |
val xmls = xmls_of_str str |
|
15173
e1582a0d29b5
Comment about 3.6pre. Clean ups to XML, URL handling. Fix statedisplay double PGML quoting. Accumulate parse errors inside parseresult.
aspinall
parents:
15156
diff
changeset
|
1065 |
val errs = end_delayed_msgs () |
16534 | 1066 |
in |
1067 |
issue_pgips [XML.element "parseresult" attrs (errs@xmls)] |
|
15173
e1582a0d29b5
Comment about 3.6pre. Clean ups to XML, URL handling. Fix statedisplay double PGML quoting. Accumulate parse errors inside parseresult.
aspinall
parents:
15156
diff
changeset
|
1068 |
end |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1069 |
end |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1070 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1071 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1072 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1073 |
(**** PGIP: Isabelle -> Interface ****) |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1074 |
|
16534 | 1075 |
val isabelle_pgml_version_supported = "1.0"; |
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1076 |
val isabelle_pgip_version_supported = "2.0" |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1077 |
|
16798 | 1078 |
(* TODO: would be cleaner to define a datatype here for the accepted elements, |
1079 |
and mapping functions to/from strings. At the moment this list must |
|
1080 |
coincide with the strings in the function process_pgip_element. *) |
|
17217
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
1081 |
val isabelle_acceptedpgipelems = |
16798 | 1082 |
["askpgip","askpgml","askprefs","getpref","setpref", |
1083 |
"proverinit","proverexit","startquiet","stopquiet", |
|
1084 |
"pgmlsymbolson", "pgmlsymbolsoff", |
|
1085 |
"dostep", "undostep", "redostep", "abortgoal", "forget", "restoregoal", |
|
1086 |
"askids", "showid", "askguise", |
|
1087 |
"parsescript", |
|
1088 |
"showproofstate", "showctxt", "searchtheorems", "setlinewidth", "viewdoc", |
|
1089 |
"doitem", "undoitem", "redoitem", "abortheory", |
|
1090 |
"retracttheory", "loadfile", "openfile", "closefile", |
|
1091 |
"abortfile", "changecwd", "systemcmd"]; |
|
1092 |
||
16534 | 1093 |
fun usespgip () = |
17217
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
1094 |
issue_pgip |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
1095 |
"usespgip" |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
1096 |
[("version", isabelle_pgip_version_supported)] |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
1097 |
(XML.element "acceptedpgipelems" [] |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
1098 |
(map (fn s=>XML.element "pgipelem" |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
1099 |
[] (* if threads: possibility to add async here *) |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
1100 |
[s]) |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
1101 |
isabelle_acceptedpgipelems)) |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1102 |
|
16534 | 1103 |
fun usespgml () = |
16798 | 1104 |
issue_pgipe "usespgml" [("version", isabelle_pgml_version_supported)] |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1105 |
|
16534 | 1106 |
fun hasprefs () = |
15570 | 1107 |
List.app (fn (prefcat, prefs) => |
16534 | 1108 |
issue_pgips [XML.element "hasprefs" [("prefcategory",prefcat)] |
1109 |
(map (fn (name, (descr, (ty, (default,_),_))) => |
|
1110 |
XML.element "haspref" [("name", name), |
|
1111 |
("descr", descr), |
|
1112 |
("default", default)] |
|
16798 | 1113 |
[ty]) prefs)]) (!preferences) |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1114 |
|
19473 | 1115 |
fun allprefs () = maps snd (!preferences) |
16534 | 1116 |
|
1117 |
fun setpref name value = |
|
17314 | 1118 |
(case AList.lookup (op =) (allprefs ()) name of |
16534 | 1119 |
NONE => warning ("Unknown pref: " ^ quote name) |
15531 | 1120 |
| SOME (_, (_, _, set)) => set value); |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1121 |
|
16534 | 1122 |
fun getpref name = |
17314 | 1123 |
(case AList.lookup (op =) (allprefs ()) name of |
16534 | 1124 |
NONE => warning ("Unknown pref: " ^ quote name) |
1125 |
| SOME (_, (_, (_,get), _)) => |
|
1126 |
issue_pgip "prefval" [("name", name)] (get ())); |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1127 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1128 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1129 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1130 |
(**** PGIP: Interface -> Isabelle/Isar ****) |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1131 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1132 |
exception PGIP of string; |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1133 |
exception PGIP_QUIT; |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1134 |
|
16534 | 1135 |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1136 |
(* Sending commands to Isar *) |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1137 |
|
16534 | 1138 |
fun isarcmd s = |
1139 |
s |> OuterSyntax.scan |> OuterSyntax.read |
|
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1140 |
|> map (Toplevel.position (Position.name "PGIP message") o #3) |> Toplevel.>>>; |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1141 |
|
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1142 |
fun xmltext ((XML.Text text)::ts) = text ^ (xmltext ts) |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1143 |
| xmltext [] = "" |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1144 |
| xmltext _ = raise PGIP "Expected text (PCDATA/CDATA)" |
16534 | 1145 |
|
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1146 |
fun isarscript xmls = isarcmd (xmltext xmls) (* send a script command *) |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1147 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1148 |
|
16791 | 1149 |
(* load an arbitrary file (must be .thy or .ML) *) |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1150 |
|
16534 | 1151 |
fun use_thy_or_ml_file file = |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1152 |
let |
16534 | 1153 |
val (path,extn) = Path.split_ext (Path.unpack file) |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1154 |
in |
16534 | 1155 |
case extn of |
1156 |
"" => isarcmd ("use_thy " ^ (quote (Path.pack path))) |
|
1157 |
| "thy" => isarcmd ("use_thy " ^ (quote (Path.pack path))) |
|
1158 |
| "ML" => isarcmd ("use " ^ quote file) |
|
1159 |
| other => error ("Don't know how to read a file with extension " ^ other) |
|
1160 |
end |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1161 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1162 |
|
15173
e1582a0d29b5
Comment about 3.6pre. Clean ups to XML, URL handling. Fix statedisplay double PGML quoting. Accumulate parse errors inside parseresult.
aspinall
parents:
15156
diff
changeset
|
1163 |
(* Proof control commands *) |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1164 |
|
15173
e1582a0d29b5
Comment about 3.6pre. Clean ups to XML, URL handling. Fix statedisplay double PGML quoting. Accumulate parse errors inside parseresult.
aspinall
parents:
15156
diff
changeset
|
1165 |
local |
17314 | 1166 |
fun xmlattro attr attrs = AList.lookup (op =) attrs attr |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1167 |
|
16534 | 1168 |
fun xmlattr attr attrs = |
1169 |
(case xmlattro attr attrs of |
|
1170 |
SOME value => value |
|
1171 |
| NONE => raise PGIP ("Missing attribute: " ^ attr)) |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1172 |
|
15173
e1582a0d29b5
Comment about 3.6pre. Clean ups to XML, URL handling. Fix statedisplay double PGML quoting. Accumulate parse errors inside parseresult.
aspinall
parents:
15156
diff
changeset
|
1173 |
val thyname_attro = xmlattro "thyname" |
e1582a0d29b5
Comment about 3.6pre. Clean ups to XML, URL handling. Fix statedisplay double PGML quoting. Accumulate parse errors inside parseresult.
aspinall
parents:
15156
diff
changeset
|
1174 |
val thyname_attr = xmlattr "thyname" |
e1582a0d29b5
Comment about 3.6pre. Clean ups to XML, URL handling. Fix statedisplay double PGML quoting. Accumulate parse errors inside parseresult.
aspinall
parents:
15156
diff
changeset
|
1175 |
val objtype_attro = xmlattro "objtype" |
e1582a0d29b5
Comment about 3.6pre. Clean ups to XML, URL handling. Fix statedisplay double PGML quoting. Accumulate parse errors inside parseresult.
aspinall
parents:
15156
diff
changeset
|
1176 |
val objtype_attr = xmlattr "objtype" |
e1582a0d29b5
Comment about 3.6pre. Clean ups to XML, URL handling. Fix statedisplay double PGML quoting. Accumulate parse errors inside parseresult.
aspinall
parents:
15156
diff
changeset
|
1177 |
val name_attr = xmlattr "name" |
e1582a0d29b5
Comment about 3.6pre. Clean ups to XML, URL handling. Fix statedisplay double PGML quoting. Accumulate parse errors inside parseresult.
aspinall
parents:
15156
diff
changeset
|
1178 |
val dirname_attr = xmlattr "dir" |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1179 |
fun comment x = "(* " ^ x ^ " *)" |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1180 |
|
15173
e1582a0d29b5
Comment about 3.6pre. Clean ups to XML, URL handling. Fix statedisplay double PGML quoting. Accumulate parse errors inside parseresult.
aspinall
parents:
15156
diff
changeset
|
1181 |
fun localfile_of_url url = (* only handle file:/// or file://localhost/ *) |
e1582a0d29b5
Comment about 3.6pre. Clean ups to XML, URL handling. Fix statedisplay double PGML quoting. Accumulate parse errors inside parseresult.
aspinall
parents:
15156
diff
changeset
|
1182 |
case Url.unpack url of |
16534 | 1183 |
(Url.File path) => File.platform_path path |
1184 |
| _ => error ("Cannot access non-local URL " ^ url) |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1185 |
|
15173
e1582a0d29b5
Comment about 3.6pre. Clean ups to XML, URL handling. Fix statedisplay double PGML quoting. Accumulate parse errors inside parseresult.
aspinall
parents:
15156
diff
changeset
|
1186 |
val fileurl_of = localfile_of_url o (xmlattr "url") |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1187 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1188 |
val topthy = Toplevel.theory_of o Toplevel.get_state |
16440 | 1189 |
val topthy_name = Context.theory_name o topthy |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1190 |
|
15531 | 1191 |
val currently_open_file = ref (NONE : string option) |
15629
4066f01f1beb
Add askguise/informguise as best as easily possible. Prevent warning in openfile when file doesn't exist in theory database.
aspinall
parents:
15626
diff
changeset
|
1192 |
|
16791 | 1193 |
(* Path management: we allow theory files to have dependencies |
1194 |
in their own directory, but when we change directory for a new |
|
1195 |
file we remove the path. Leaving it there can cause confusion |
|
1196 |
with difference in batch mode.a NB: PGIP does not assume |
|
1197 |
that the prover has a load path. *) |
|
17217
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
1198 |
local |
16791 | 1199 |
val current_working_dir = ref (NONE : string option) |
1200 |
in |
|
17217
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
1201 |
fun changecwd dir = |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
1202 |
(case (!current_working_dir) of |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
1203 |
NONE => () |
16791 | 1204 |
| SOME dir => ThyLoad.del_path dir; |
17217
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
1205 |
ThyLoad.add_path dir; |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
1206 |
current_working_dir := SOME dir) |
16791 | 1207 |
end |
1208 |
||
18587 | 1209 |
fun topproofpos () = try Toplevel.proof_position_of (Isar.state ()); |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1210 |
in |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1211 |
|
16534 | 1212 |
fun process_pgip_element pgipxml = (case pgipxml of |
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1213 |
(XML.Text t) => warning ("Ignored text in PGIP packet: \n" ^ t) |
16534 | 1214 |
| (xml as (XML.Elem (elem, attrs, data))) => |
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1215 |
(case elem of |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1216 |
(* protocol config *) |
16534 | 1217 |
"askpgip" => (pgip_emacs_compatibility_flag:=false; (* PG>=3.6 or other PGIP interface *) |
1218 |
usespgip (); send_pgip_config ()) |
|
1219 |
| "askpgml" => usespgml () |
|
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1220 |
(* proverconfig *) |
16534 | 1221 |
| "askprefs" => hasprefs () |
1222 |
| "getpref" => getpref (name_attr attrs) |
|
1223 |
| "setpref" => setpref (name_attr attrs) (xmltext data) |
|
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1224 |
(* provercontrol *) |
16534 | 1225 |
| "proverinit" => isar_restart () |
1226 |
| "proverexit" => isarcmd "quit" |
|
1227 |
| "startquiet" => isarcmd "disable_pr" |
|
1228 |
| "stopquiet" => isarcmd "enable_pr" |
|
18174 | 1229 |
| "pgmlsymbolson" => change print_mode (fn mode => |
1230 |
remove (op =) Symbol.xsymbolsN mode @ [Symbol.xsymbolsN]) |
|
17217
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
1231 |
| "pgmlsymbolsoff" => change print_mode (remove (op =) Symbol.xsymbolsN) |
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1232 |
(* properproofcmd: proper commands which belong in script *) |
15401
ba28d103bada
Support PGIP <whitespace>, <dostep>, <doitem> elements as input
aspinall
parents:
15400
diff
changeset
|
1233 |
(* FIXME: next ten are by Eclipse interface, can be removed in favour of dostep *) |
15629
4066f01f1beb
Add askguise/informguise as best as easily possible. Prevent warning in openfile when file doesn't exist in theory database.
aspinall
parents:
15626
diff
changeset
|
1234 |
(* NB: Isar doesn't make lemma name of goal accessible during proof *) |
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1235 |
| "opengoal" => isarscript data |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1236 |
| "proofstep" => isarscript data |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1237 |
| "closegoal" => isarscript data |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1238 |
| "giveupgoal" => isarscript data |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1239 |
| "postponegoal" => isarscript data |
16534 | 1240 |
| "comment" => isarscript data (* NB: should be ignored, but process anyway *) |
1241 |
| "whitespace" => isarscript data (* NB: should be ignored, but process anyway *) |
|
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1242 |
| "litcomment" => isarscript data |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1243 |
| "spuriouscmd" => isarscript data |
16534 | 1244 |
| "badcmd" => isarscript data |
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1245 |
(* improperproofcmd: improper commands which *do not* belong in script *) |
15401
ba28d103bada
Support PGIP <whitespace>, <dostep>, <doitem> elements as input
aspinall
parents:
15400
diff
changeset
|
1246 |
| "dostep" => isarscript data |
15286 | 1247 |
| "undostep" => isarcmd "undos_proof 1" |
15626 | 1248 |
| "redostep" => isarcmd "redo" |
16534 | 1249 |
| "abortgoal" => isarcmd "ProofGeneral.kill_proof" |
1250 |
| "forget" => error "Not implemented" |
|
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1251 |
| "restoregoal" => error "Not implemented" (* could just treat as forget? *) |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1252 |
(* proofctxt: improper commands *) |
15173
e1582a0d29b5
Comment about 3.6pre. Clean ups to XML, URL handling. Fix statedisplay double PGML quoting. Accumulate parse errors inside parseresult.
aspinall
parents:
15156
diff
changeset
|
1253 |
| "askids" => askids (thyname_attro attrs, objtype_attro attrs) |
16534 | 1254 |
| "showid" => showid (thyname_attro attrs, objtype_attr attrs, name_attr attrs) |
1255 |
| "askguise" => send_informguise (!currently_open_file, |
|
1256 |
SOME (topthy_name()) handle Toplevel.UNDEF => NONE, |
|
1257 |
topproofpos()) |
|
15173
e1582a0d29b5
Comment about 3.6pre. Clean ups to XML, URL handling. Fix statedisplay double PGML quoting. Accumulate parse errors inside parseresult.
aspinall
parents:
15156
diff
changeset
|
1258 |
| "parsescript" => parsescript (xmltext data) attrs (* just pass back attrs unchanged *) |
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1259 |
| "showproofstate" => isarcmd "pr" |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1260 |
| "showctxt" => isarcmd "print_theory" (* more useful than print_context *) |
17217
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
1261 |
| "searchtheorems" => isarcmd ("thms_containing " ^ xmltext data) |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
1262 |
| "setlinewidth" => isarcmd ("pretty_setmargin " ^ xmltext data) |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
1263 |
| "viewdoc" => isarcmd ("print_" ^ xmltext data) (* FIXME: isatool doc? *) |
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1264 |
(* properfilecmd: proper theory-level script commands *) |
15401
ba28d103bada
Support PGIP <whitespace>, <dostep>, <doitem> elements as input
aspinall
parents:
15400
diff
changeset
|
1265 |
(* FIXME: next three are sent by Eclipse, can be removed in favour of doitem *) |
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1266 |
| "opentheory" => isarscript data |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1267 |
| "theoryitem" => isarscript data |
16534 | 1268 |
| "closetheory" => let |
1269 |
val thyname = topthy_name() |
|
1270 |
in (isarscript data; |
|
17217
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
1271 |
writeln ("Theory " ^ quote thyname ^ " completed.")) |
16534 | 1272 |
end |
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1273 |
(* improperfilecmd: theory-level commands not in script *) |
15401
ba28d103bada
Support PGIP <whitespace>, <dostep>, <doitem> elements as input
aspinall
parents:
15400
diff
changeset
|
1274 |
| "doitem" => isarscript data |
15286 | 1275 |
| "undoitem" => isarcmd "ProofGeneral.undo" |
15626 | 1276 |
| "redoitem" => isarcmd "ProofGeneral.redo" |
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1277 |
| "aborttheory" => isarcmd ("init_toplevel") |
17217
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
1278 |
| "retracttheory" => isarcmd ("kill_thy " ^ quote (thyname_attr attrs)) |
15173
e1582a0d29b5
Comment about 3.6pre. Clean ups to XML, URL handling. Fix statedisplay double PGML quoting. Accumulate parse errors inside parseresult.
aspinall
parents:
15156
diff
changeset
|
1279 |
| "loadfile" => use_thy_or_ml_file (fileurl_of attrs) |
15629
4066f01f1beb
Add askguise/informguise as best as easily possible. Prevent warning in openfile when file doesn't exist in theory database.
aspinall
parents:
15626
diff
changeset
|
1280 |
| "openfile" => (openfile_retract (fileurl_of attrs); |
16534 | 1281 |
currently_open_file := SOME (fileurl_of attrs)) |
1282 |
| "closefile" => (case !currently_open_file of |
|
1283 |
SOME f => (inform_file_processed f; |
|
1284 |
currently_open_file := NONE) |
|
1285 |
| NONE => raise PGIP ("closefile when no file is open!")) |
|
15531 | 1286 |
| "abortfile" => (currently_open_file := NONE) (* perhaps error for no file open *) |
16791 | 1287 |
| "changecwd" => changecwd (dirname_attr attrs) |
16534 | 1288 |
| "systemcmd" => isarscript data |
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1289 |
(* unofficial command for debugging *) |
16534 | 1290 |
| "quitpgip" => raise PGIP_QUIT |
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1291 |
| _ => raise PGIP ("Unrecognized PGIP element: " ^ elem))) |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1292 |
|
16534 | 1293 |
fun process_pgip_tree xml = |
16821
ba1f6aba44ed
Update PGIP packet handling, fixing unique session identifier.
aspinall
parents:
16816
diff
changeset
|
1294 |
(pgip_refid := NONE; |
ba1f6aba44ed
Update PGIP packet handling, fixing unique session identifier.
aspinall
parents:
16816
diff
changeset
|
1295 |
pgip_refseq := NONE; |
15173
e1582a0d29b5
Comment about 3.6pre. Clean ups to XML, URL handling. Fix statedisplay double PGML quoting. Accumulate parse errors inside parseresult.
aspinall
parents:
15156
diff
changeset
|
1296 |
(case xml of |
16534 | 1297 |
XML.Elem ("pgip", attrs, pgips) => |
1298 |
(let |
|
17407
38e0219ec022
Revert previous attribute name change, problem can be avoided in JAXB.
aspinall
parents:
17403
diff
changeset
|
1299 |
val class = xmlattr "class" attrs |
17217
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
1300 |
val dest = xmlattro "destid" attrs |
16821
ba1f6aba44ed
Update PGIP packet handling, fixing unique session identifier.
aspinall
parents:
16816
diff
changeset
|
1301 |
val _ = (pgip_refid := xmlattro "id" attrs; |
17217
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
1302 |
pgip_refseq := xmlattro "seq" attrs) |
16534 | 1303 |
in |
17217
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
1304 |
(* We respond to broadcast messages to provers, or |
16821
ba1f6aba44ed
Update PGIP packet handling, fixing unique session identifier.
aspinall
parents:
16816
diff
changeset
|
1305 |
messages intended uniquely for us. Silently ignore rest. *) |
ba1f6aba44ed
Update PGIP packet handling, fixing unique session identifier.
aspinall
parents:
16816
diff
changeset
|
1306 |
case dest of |
17217
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
1307 |
NONE => if (class = "pa") then |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
1308 |
(List.app process_pgip_element pgips; true) |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
1309 |
else false |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
1310 |
| SOME id => if (matching_pgip_id id) then |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
1311 |
(List.app process_pgip_element pgips; true) |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
1312 |
else false |
16534 | 1313 |
end) |
1314 |
| _ => raise PGIP "Invalid PGIP packet received") |
|
18678 | 1315 |
handle PGIP msg => |
1316 |
error (msg ^ "\nPGIP error occured in XML text below:\n" ^ |
|
1317 |
(XML.string_of_tree xml))) |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1318 |
|
16821
ba1f6aba44ed
Update PGIP packet handling, fixing unique session identifier.
aspinall
parents:
16816
diff
changeset
|
1319 |
val process_pgip = K () o process_pgip_tree o XML.tree_of_string |
15191
5ca1fd9dec83
Support parsing of -- {* comments *}. Add extra output channels.
aspinall
parents:
15173
diff
changeset
|
1320 |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1321 |
end |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1322 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1323 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1324 |
(* PGIP loop: process PGIP input only *) |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1325 |
|
16534 | 1326 |
local |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1327 |
|
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1328 |
exception XML_PARSE |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1329 |
|
16821
ba1f6aba44ed
Update PGIP packet handling, fixing unique session identifier.
aspinall
parents:
16816
diff
changeset
|
1330 |
fun loop ready src = |
16534 | 1331 |
let |
16821
ba1f6aba44ed
Update PGIP packet handling, fixing unique session identifier.
aspinall
parents:
16816
diff
changeset
|
1332 |
val _ = if ready then (issue_pgipe "ready" []) else () |
16534 | 1333 |
val pgipo = (Source.get_single src) |
1334 |
handle e => raise XML_PARSE |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1335 |
in |
16534 | 1336 |
case pgipo of |
1337 |
NONE => () |
|
1338 |
| SOME (pgip,src') => |
|
17217
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
1339 |
let |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
1340 |
val ready' = (process_pgip_tree pgip) handle e => (handler (e,SOME src'); true) |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
1341 |
in |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
1342 |
loop ready' src' |
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
1343 |
end |
15531 | 1344 |
end handle e => handler (e,SOME src) (* i.e. error in ready/XML parse *) |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1345 |
|
16534 | 1346 |
and handler (e,srco) = |
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1347 |
case (e,srco) of |
16534 | 1348 |
(XML_PARSE,SOME src) => |
18678 | 1349 |
Output.panic "Invalid XML input, aborting" (* NB: loop OK for tty, but want exit on EOF *) |
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1350 |
| (PGIP_QUIT,_) => () |
16821
ba1f6aba44ed
Update PGIP packet handling, fixing unique session identifier.
aspinall
parents:
16816
diff
changeset
|
1351 |
| (Interrupt,SOME src) => (!error_fn "Interrupt during PGIP processing"; loop true src) |
ba1f6aba44ed
Update PGIP packet handling, fixing unique session identifier.
aspinall
parents:
16816
diff
changeset
|
1352 |
| (Toplevel.UNDEF,SOME src) => (error "No working context defined"; loop true src) (* usually *) |
ba1f6aba44ed
Update PGIP packet handling, fixing unique session identifier.
aspinall
parents:
16816
diff
changeset
|
1353 |
| (e,SOME src) => (error (Toplevel.exn_message e); loop true src) |
15531 | 1354 |
| (_,NONE) => () |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1355 |
in |
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1356 |
(* NB: simple tty for now; later might read from other tty-style sources (e.g. sockets). *) |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1357 |
|
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1358 |
val xmlP = XML.scan_comment_whspc |-- XML.parse_elem >> single |
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1359 |
|
20738 | 1360 |
val tty_src = Source.set_prompt "" (Source.source Symbol.stopper xmlP NONE Source.tty) |
15145
07360eef9f4f
Version for PGIP 2.X, with greatly improved parsing and XML handling.
aspinall
parents:
15134
diff
changeset
|
1361 |
|
16824 | 1362 |
fun pgip_toplevel x = loop true x |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1363 |
end |
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1364 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1365 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1366 |
(* additional outer syntax for Isar *) |
12778 | 1367 |
|
17057 | 1368 |
local structure P = OuterParse and K = OuterKeyword in |
12778 | 1369 |
|
16534 | 1370 |
val undoP = (*undo without output*) |
12778 | 1371 |
OuterSyntax.improper_command "ProofGeneral.undo" "(internal)" K.control |
1372 |
(Scan.succeed (Toplevel.no_timing o IsarCmd.undo)); |
|
1373 |
||
16534 | 1374 |
val redoP = (*redo without output*) |
15626 | 1375 |
OuterSyntax.improper_command "ProofGeneral.redo" "(internal)" K.control |
1376 |
(Scan.succeed (Toplevel.no_timing o IsarCmd.redo)); |
|
1377 |
||
12778 | 1378 |
val context_thy_onlyP = |
1379 |
OuterSyntax.improper_command "ProofGeneral.context_thy_only" "(internal)" K.control |
|
1380 |
(P.name >> (Toplevel.no_timing oo IsarThy.init_context update_thy_only)); |
|
1381 |
||
1382 |
val try_context_thy_onlyP = |
|
1383 |
OuterSyntax.improper_command "ProofGeneral.try_context_thy_only" "(internal)" K.control |
|
1384 |
(P.name >> (Toplevel.no_timing oo |
|
1385 |
(Toplevel.imperative (K ()) oo IsarThy.init_context try_update_thy_only))); |
|
1386 |
||
1387 |
val restartP = |
|
1388 |
OuterSyntax.improper_command "ProofGeneral.restart" "(internal)" K.control |
|
1389 |
(P.opt_unit >> (Toplevel.no_timing oo K (Toplevel.imperative isar_restart))); |
|
1390 |
||
1391 |
val kill_proofP = |
|
1392 |
OuterSyntax.improper_command "ProofGeneral.kill_proof" "(internal)" K.control |
|
1393 |
(Scan.succeed (Toplevel.no_timing o IsarCmd.kill_proof_notify tell_clear_goals)); |
|
1394 |
||
1395 |
val inform_file_processedP = |
|
1396 |
OuterSyntax.improper_command "ProofGeneral.inform_file_processed" "(internal)" K.control |
|
14902
bef0dc694c48
Path.split_ext; more robust inform_file_processed;
wenzelm
parents:
14880
diff
changeset
|
1397 |
(P.name >> (fn file => Toplevel.no_timing o |
bef0dc694c48
Path.split_ext; more robust inform_file_processed;
wenzelm
parents:
14880
diff
changeset
|
1398 |
Toplevel.keep (vacuous_inform_file_processed file) o |
bef0dc694c48
Path.split_ext; more robust inform_file_processed;
wenzelm
parents:
14880
diff
changeset
|
1399 |
Toplevel.kill o |
bef0dc694c48
Path.split_ext; more robust inform_file_processed;
wenzelm
parents:
14880
diff
changeset
|
1400 |
Toplevel.keep (proper_inform_file_processed file))); |
12778 | 1401 |
|
1402 |
val inform_file_retractedP = |
|
1403 |
OuterSyntax.improper_command "ProofGeneral.inform_file_retracted" "(internal)" K.control |
|
1404 |
(P.name >> (Toplevel.no_timing oo |
|
14902
bef0dc694c48
Path.split_ext; more robust inform_file_processed;
wenzelm
parents:
14880
diff
changeset
|
1405 |
(fn file => Toplevel.imperative (fn () => inform_file_retracted file)))); |
12778 | 1406 |
|
14725 | 1407 |
val process_pgipP = |
1408 |
OuterSyntax.improper_command "ProofGeneral.process_pgip" "(internal)" K.control |
|
1409 |
(P.text >> (Toplevel.no_timing oo |
|
1410 |
(fn txt => Toplevel.imperative (fn () => process_pgip txt)))); |
|
1411 |
||
12778 | 1412 |
fun init_outer_syntax () = OuterSyntax.add_parsers |
15626 | 1413 |
[undoP, redoP, restartP, kill_proofP, context_thy_onlyP, try_context_thy_onlyP, |
14725 | 1414 |
inform_file_processedP, inform_file_retractedP, process_pgipP]; |
12778 | 1415 |
|
1416 |
end; |
|
1417 |
||
1418 |
||
1419 |
(* init *) |
|
1420 |
||
1421 |
val initialized = ref false; |
|
1422 |
||
16534 | 1423 |
fun set_prompts true _ = ml_prompts "ML> " "ML# " |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1424 |
| set_prompts false true = ml_prompts "PGIP-ML>" "PGIP-ML# " |
17217
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
1425 |
| set_prompts false false = ml_prompts ("> " ^ special "372") ("- " ^ special "373"); |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1426 |
|
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1427 |
fun init_setup isar pgip = |
16534 | 1428 |
(conditional (not (! initialized)) (fn () => |
12778 | 1429 |
(if isar then setmp warning_fn (K ()) init_outer_syntax () else (); |
1430 |
setup_xsymbols_output (); |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1431 |
setup_pgml_output (); |
12778 | 1432 |
setup_messages (); |
1433 |
setup_state (); |
|
1434 |
setup_thy_loader (); |
|
13526 | 1435 |
setup_present_hook (); |
12778 | 1436 |
set initialized; ())); |
1437 |
sync_thy_loader (); |
|
17217
954c0f265203
added PGASCII print_mode, which represents special chars as ASCII 1 + A ... Z;
wenzelm
parents:
17057
diff
changeset
|
1438 |
change print_mode (cons proof_generalN o remove (op =) proof_generalN); |
18993
f055b4fe381e
removed set quick_and_dirty and ThmDeps.enable -- no effect here;
wenzelm
parents:
18708
diff
changeset
|
1439 |
init_pgip_session_id (); |
16534 | 1440 |
if pgip then |
19300 | 1441 |
change print_mode (append [pgmlN, pgmlatomsN] o subtract (op =) [pgmlN, pgmlatomsN]) |
16534 | 1442 |
else |
1443 |
pgip_emacs_compatibility_flag := true; (* assume this for PG <3.6 compatibility *) |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1444 |
set_prompts isar pgip; |
16534 | 1445 |
pgip_active := pgip); |
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1446 |
|
16534 | 1447 |
fun init isar = |
1448 |
(init_setup isar false; |
|
1449 |
if isar then Isar.sync_main () else isa_restart ()); |
|
15134
d3fa5e1d6e4d
Experimental version supporting PGIP, merged with main branch with help from Makarius.
aspinall
parents:
15010
diff
changeset
|
1450 |
|
18678 | 1451 |
fun init_pgip false = Output.panic "PGIP not supported for Isabelle/classic mode." |
16534 | 1452 |
| init_pgip true = (init_setup true true; pgip_toplevel tty_src); |
12778 | 1453 |
|
1454 |
||
1455 |
||
16534 | 1456 |
(** generate elisp file for keyword classification **) |
12778 | 1457 |
|
1458 |
local |
|
1459 |
||
20664 | 1460 |
val regexp_meta = member (op =) (explode ".*+?[]^$"); |
16534 | 1461 |
val regexp_quote = |
20664 | 1462 |
implode o map (fn c => if regexp_meta c then "\\\\" ^ c else c) o explode; |
12778 | 1463 |
|
1464 |
fun defconst name strs = |
|
1465 |
"\n(defconst isar-keywords-" ^ name ^ |
|
1466 |
"\n '(" ^ space_implode "\n " (map (quote o regexp_quote) strs) ^ "))\n"; |
|
1467 |
||
16534 | 1468 |
fun make_elisp_commands commands kind = defconst kind |
19482
9f11af8f7ef9
tuned basic list operators (flat, maps, map_filter);
wenzelm
parents:
19473
diff
changeset
|
1469 |
(commands |> map_filter (fn (c, _, k, _) => if k = kind then SOME c else NONE)); |
12778 | 1470 |
|
1471 |
fun make_elisp_syntax (keywords, commands) = |
|
1472 |
";;\n\ |
|
1473 |
\;; Keyword classification tables for Isabelle/Isar.\n\ |
|
1474 |
\;; This file was generated by " ^ Session.name () ^ " -- DO NOT EDIT!\n\ |
|
1475 |
\;;\n\ |
|
1476 |
\;; $" ^ "Id$\n\ |
|
1477 |
\;;\n" ^ |
|
1478 |
defconst "major" (map #1 commands) ^ |
|
15570 | 1479 |
defconst "minor" (List.filter Syntax.is_identifier keywords) ^ |
17057 | 1480 |
implode (map (make_elisp_commands commands) OuterKeyword.kinds) ^ |
12778 | 1481 |
"\n(provide 'isar-keywords)\n"; |
1482 |
||
1483 |
in |
|
1484 |
||
1485 |
fun write_keywords s = |
|
16534 | 1486 |
(init_outer_syntax (); |
1487 |
File.write (Path.unpack ("isar-keywords" ^ (if s = "" then "" else "-" ^ s) ^".el")) |
|
1488 |
(make_elisp_syntax (OuterSyntax.dest_keywords (), OuterSyntax.dest_parsers ()))); |
|
12778 | 1489 |
|
1490 |
end; |
|
1491 |
||
16534 | 1492 |
end; |