author | haftmann |
Wed, 15 Sep 2010 15:11:40 +0200 | |
changeset 39399 | 267235a14938 |
parent 39305 | d4fa19eb0822 |
child 39478 | 8866d068791a |
permissions | -rw-r--r-- |
30394 | 1 |
(* Title: doc-src/more_antiquote.ML |
28440 | 2 |
Author: Florian Haftmann, TU Muenchen |
3 |
||
4 |
More antiquotations. |
|
5 |
*) |
|
6 |
||
7 |
signature MORE_ANTIQUOTE = |
|
8 |
sig |
|
28727 | 9 |
val typewriter: string -> string |
28440 | 10 |
end; |
11 |
||
12 |
structure More_Antiquote : MORE_ANTIQUOTE = |
|
13 |
struct |
|
14 |
||
28727 | 15 |
(* printing typewriter lines *) |
28440 | 16 |
|
28727 | 17 |
fun typewriter s = |
28714 | 18 |
let |
19 |
val parse = Scan.repeat |
|
20 |
(Scan.this_string "\n" |-- Scan.succeed "\\\\\n\\hspace*{0pt}" |
|
30394 | 21 |
|| (Scan.this_string " " |
28921
e60a41c21768
consider TeX spacing conventions for punctuation marks
haftmann
parents:
28727
diff
changeset
|
22 |
|| Scan.this_string "." |
e60a41c21768
consider TeX spacing conventions for punctuation marks
haftmann
parents:
28727
diff
changeset
|
23 |
|| Scan.this_string "," |
28714 | 24 |
|| Scan.this_string ":" |
28921
e60a41c21768
consider TeX spacing conventions for punctuation marks
haftmann
parents:
28727
diff
changeset
|
25 |
|| Scan.this_string ";" |
28714 | 26 |
|| Scan.this_string "\"" |-- Scan.succeed "{\\char34}" |
27 |
|| Scan.this_string "#" |-- Scan.succeed "{\\char35}" |
|
28 |
|| Scan.this_string "$" |-- Scan.succeed "{\\char36}" |
|
29 |
|| Scan.this_string "%" |-- Scan.succeed "{\\char37}" |
|
30 |
|| Scan.this_string "&" |-- Scan.succeed "{\\char38}" |
|
31 |
|| Scan.this_string "\\" |-- Scan.succeed "{\\char92}" |
|
32 |
|| Scan.this_string "^" |-- Scan.succeed "{\\char94}" |
|
33 |
|| Scan.this_string "_" |-- Scan.succeed "{\\char95}" |
|
34 |
|| Scan.this_string "{" |-- Scan.succeed "{\\char123}" |
|
35 |
|| Scan.this_string "}" |-- Scan.succeed "{\\char125}" |
|
36 |
|| Scan.this_string "~" |-- Scan.succeed "{\\char126}") |
|
37 |
-- Scan.repeat (Scan.this_string " ") |
|
38 |
>> (fn (x, xs) => x ^ replicate_string (length xs) "~") |
|
39 |
|| Scan.one Symbol.not_eof); |
|
40 |
fun is_newline s = (s = "\n"); |
|
41 |
val cs = explode s |> take_prefix is_newline |> snd |
|
42 |
|> take_suffix is_newline |> fst; |
|
43 |
val (texts, []) = Scan.finite Symbol.stopper parse cs |
|
44 |
in if null texts |
|
45 |
then "" |
|
28727 | 46 |
else implode ("\\isatypewriter%\n\\noindent%\n\\hspace*{0pt}" :: texts) |
28714 | 47 |
end |
28440 | 48 |
|
49 |
||
29397 | 50 |
(* code theorem antiquotation *) |
51 |
||
52 |
local |
|
53 |
||
54 |
fun pretty_term ctxt t = Syntax.pretty_term (Variable.auto_fixes t ctxt) t; |
|
55 |
||
56 |
fun pretty_thm ctxt = pretty_term ctxt o Thm.full_prop_of; |
|
57 |
||
58 |
fun no_vars ctxt thm = |
|
59 |
let |
|
60 |
val ctxt' = Variable.set_body false ctxt; |
|
31794
71af1fd6a5e4
renamed Variable.import_thms to Variable.import (back again cf. ed7aa5a350ef -- Alice is no longer supported);
wenzelm
parents:
31156
diff
changeset
|
61 |
val ((_, [thm]), _) = Variable.import true [thm] ctxt'; |
29397 | 62 |
in thm end; |
63 |
||
64 |
fun pretty_code_thm src ctxt raw_const = |
|
65 |
let |
|
66 |
val thy = ProofContext.theory_of ctxt; |
|
31156 | 67 |
val const = Code.check_const thy raw_const; |
34896
a22b09addd78
adjusted to changes in code equation administration
haftmann
parents:
34072
diff
changeset
|
68 |
val (_, eqngr) = Code_Preproc.obtain thy [const] []; |
29874 | 69 |
fun holize thm = @{thm meta_eq_to_obj_eq} OF [thm]; |
34896
a22b09addd78
adjusted to changes in code equation administration
haftmann
parents:
34072
diff
changeset
|
70 |
val thms = Code_Preproc.cert eqngr const |
35246 | 71 |
|> Code.equations_of_cert thy |
34896
a22b09addd78
adjusted to changes in code equation administration
haftmann
parents:
34072
diff
changeset
|
72 |
|> snd |
35246 | 73 |
|> map_filter (fn (_, (some_thm, proper)) => if proper then some_thm else NONE) |
29874 | 74 |
|> map (holize o no_vars ctxt o AxClass.overload thy); |
38767
d8da44a8dd25
proper context for various Thy_Output options, via official configuration options in ML and Isar;
wenzelm
parents:
37216
diff
changeset
|
75 |
in Thy_Output.output ctxt (Thy_Output.maybe_pretty_source pretty_thm ctxt src thms) end; |
29397 | 76 |
|
77 |
in |
|
78 |
||
37216
3165bc303f66
modernized some structure names, keeping a few legacy aliases;
wenzelm
parents:
36745
diff
changeset
|
79 |
val _ = Thy_Output.antiquotation "code_thms" Args.term |
30394 | 80 |
(fn {source, context, ...} => pretty_code_thm source context); |
29397 | 81 |
|
82 |
end; |
|
83 |
||
84 |
||
28440 | 85 |
(* code antiquotation *) |
86 |
||
87 |
local |
|
88 |
||
89 |
val parse_const_terms = Scan.repeat1 Args.term |
|
31156 | 90 |
>> (fn ts => fn thy => map (Code.check_const thy) ts); |
28440 | 91 |
val parse_consts = Scan.lift (Args.parens (Args.$$$ "consts")) |-- parse_const_terms |
29619 | 92 |
>> (fn mk_cs => fn thy => fn naming => map_filter (Code_Thingol.lookup_const naming) (mk_cs thy)); |
28440 | 93 |
val parse_types = Scan.lift (Args.parens (Args.$$$ "types") |-- Scan.repeat1 Args.name) |
29619 | 94 |
>> (fn tycos => fn thy => fn naming => map_filter (Code_Thingol.lookup_tyco naming o Sign.intern_type thy) tycos); |
28440 | 95 |
val parse_classes = Scan.lift (Args.parens (Args.$$$ "classes") |-- Scan.repeat1 Args.name) |
29619 | 96 |
>> (fn classes => fn thy => fn naming => map_filter (Code_Thingol.lookup_class naming o Sign.intern_class thy) classes); |
28440 | 97 |
val parse_instances = Scan.lift (Args.parens (Args.$$$ "instances") |-- Scan.repeat1 (Args.name --| Args.$$$ "::" -- Args.name)) |
29619 | 98 |
>> (fn insts => fn thy => fn naming => map_filter (Code_Thingol.lookup_instance naming o apsnd (Sign.intern_type thy) o apfst (Sign.intern_class thy) o swap) insts); |
30394 | 99 |
val parse_names = parse_consts || parse_types || parse_classes || parse_instances; |
28440 | 100 |
|
101 |
in |
|
102 |
||
37216
3165bc303f66
modernized some structure names, keeping a few legacy aliases;
wenzelm
parents:
36745
diff
changeset
|
103 |
val _ = Thy_Output.antiquotation "code_stmts" |
38932 | 104 |
(parse_const_terms -- Scan.repeat parse_names |
105 |
-- Scan.lift (Args.parens (Args.name -- Scan.option Parse.int))) |
|
106 |
(fn {context = ctxt, ...} => fn ((mk_cs, mk_stmtss), (target, some_width)) => |
|
30394 | 107 |
let val thy = ProofContext.theory_of ctxt in |
38929
d9ac9dee764d
distinguish code production and code presentation
haftmann
parents:
38921
diff
changeset
|
108 |
Code_Target.present_code thy (mk_cs thy) |
30394 | 109 |
(fn naming => maps (fn f => f thy naming) mk_stmtss) |
38932 | 110 |
target some_width "Example" [] |
30394 | 111 |
|> typewriter |
112 |
end); |
|
28440 | 113 |
|
114 |
end; |
|
30394 | 115 |
|
116 |
end; |