author | blanchet |
Tue, 27 Jul 2010 17:58:30 +0200 | |
changeset 38022 | d9c4d87838f3 |
parent 33384 | 1b5ba4e6a953 |
child 42279 | 6da43a5018e2 |
permissions | -rw-r--r-- |
24236
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
1 |
(* Title: Pure/Syntax/simple_syntax.ML |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
2 |
Author: Makarius |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
3 |
|
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
4 |
Simple syntax for types and terms --- for bootstrapping Pure. |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
5 |
*) |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
6 |
|
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
7 |
signature SIMPLE_SYNTAX = |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
8 |
sig |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
9 |
val read_typ: string -> typ |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
10 |
val read_term: string -> term |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
11 |
val read_prop: string -> term |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
12 |
end; |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
13 |
|
33384 | 14 |
structure Simple_Syntax: SIMPLE_SYNTAX = |
24236
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
15 |
struct |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
16 |
|
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
17 |
(* scanning tokens *) |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
18 |
|
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
19 |
val lexicon = Scan.make_lexicon |
28856
5e009a80fe6d
Pure syntax: more coherent treatment of aprop, permanent TERM and &&&;
wenzelm
parents:
27888
diff
changeset
|
20 |
(map Symbol.explode ["!!", "%", "(", ")", ".", "::", "==", "==>", "=?=", "=>", "&&&", "CONST"]); |
24236
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
21 |
|
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
22 |
fun read scan s = |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
23 |
(case |
30573 | 24 |
Symbol_Pos.explode (s, Position.none) |> |
24246 | 25 |
Lexicon.tokenize lexicon false |> |
27888
7ed38f1d11de
filter Lexicon.is_proper -- Lexicon.tokenize now includes improper tokens;
wenzelm
parents:
27802
diff
changeset
|
26 |
filter Lexicon.is_proper |> |
27802
1eddcd7dda2d
datatype token: maintain range, tuned representation;
wenzelm
parents:
27774
diff
changeset
|
27 |
Scan.read Lexicon.stopper scan of |
24236
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
28 |
SOME x => x |
24246 | 29 |
| NONE => error ("Malformed input: " ^ quote s)); |
24236
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
30 |
|
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
31 |
|
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
32 |
(* basic scanners *) |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
33 |
|
27802
1eddcd7dda2d
datatype token: maintain range, tuned representation;
wenzelm
parents:
27774
diff
changeset
|
34 |
fun $$ s = Scan.some (fn Lexicon.Token (Lexicon.Literal, s', _) => |
1eddcd7dda2d
datatype token: maintain range, tuned representation;
wenzelm
parents:
27774
diff
changeset
|
35 |
if s = s' then SOME s else NONE | _ => NONE); |
1eddcd7dda2d
datatype token: maintain range, tuned representation;
wenzelm
parents:
27774
diff
changeset
|
36 |
|
25999 | 37 |
fun enum1 s scan = scan ::: Scan.repeat ($$ s |-- scan); |
38 |
fun enum2 s scan = scan ::: Scan.repeat1 ($$ s |-- scan); |
|
24236
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
39 |
|
27802
1eddcd7dda2d
datatype token: maintain range, tuned representation;
wenzelm
parents:
27774
diff
changeset
|
40 |
val tfree = Scan.some (fn Lexicon.Token (Lexicon.TFreeSy, s, _) => SOME s | _ => NONE); |
1eddcd7dda2d
datatype token: maintain range, tuned representation;
wenzelm
parents:
27774
diff
changeset
|
41 |
val ident = Scan.some (fn Lexicon.Token (Lexicon.IdentSy, s, _) => SOME s | _ => NONE); |
1eddcd7dda2d
datatype token: maintain range, tuned representation;
wenzelm
parents:
27774
diff
changeset
|
42 |
|
1eddcd7dda2d
datatype token: maintain range, tuned representation;
wenzelm
parents:
27774
diff
changeset
|
43 |
val var = Scan.some (fn Lexicon.Token (Lexicon.VarSy, s, _) => |
1eddcd7dda2d
datatype token: maintain range, tuned representation;
wenzelm
parents:
27774
diff
changeset
|
44 |
SOME (Lexicon.read_indexname (unprefix "?" s)) | _ => NONE); |
1eddcd7dda2d
datatype token: maintain range, tuned representation;
wenzelm
parents:
27774
diff
changeset
|
45 |
|
1eddcd7dda2d
datatype token: maintain range, tuned representation;
wenzelm
parents:
27774
diff
changeset
|
46 |
val long_ident = Scan.some (fn Lexicon.Token (Lexicon.LongIdentSy, s, _) => SOME s | _ => NONE); |
24236
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
47 |
val const = long_ident || ident; |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
48 |
|
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
49 |
|
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
50 |
(* types *) |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
51 |
|
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
52 |
(* |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
53 |
typ = typ1 => ... => typ1 |
24237 | 54 |
| typ1 |
24236
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
55 |
typ1 = typ2 const ... const |
24237 | 56 |
| typ2 |
57 |
typ2 = tfree |
|
58 |
| const |
|
59 |
| ( typ ) |
|
24236
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
60 |
*) |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
61 |
|
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
62 |
fun typ x = |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
63 |
(enum1 "=>" typ1 >> (op ---> o split_last)) x |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
64 |
and typ1 x = |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
65 |
(typ2 -- Scan.repeat const >> (fn (T, cs) => fold (fn c => fn U => Type (c, [U])) cs T)) x |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
66 |
and typ2 x = |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
67 |
(tfree >> (fn a => TFree (a, [])) || |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
68 |
const >> (fn c => Type (c, [])) || |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
69 |
$$ "(" |-- typ --| $$ ")") x; |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
70 |
|
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
71 |
val read_typ = read typ; |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
72 |
|
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
73 |
|
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
74 |
(* terms *) |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
75 |
|
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
76 |
(* |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
77 |
term = !!ident :: typ. term |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
78 |
| term1 |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
79 |
term1 = term2 ==> ... ==> term2 |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
80 |
| term2 |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
81 |
term2 = term3 == term2 |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
82 |
| term3 =?= term2 |
28856
5e009a80fe6d
Pure syntax: more coherent treatment of aprop, permanent TERM and &&&;
wenzelm
parents:
27888
diff
changeset
|
83 |
| term3 &&& term2 |
24236
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
84 |
| term3 |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
85 |
term3 = ident :: typ |
24246 | 86 |
| var :: typ |
24236
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
87 |
| CONST const :: typ |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
88 |
| %ident :: typ. term3 |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
89 |
| term4 |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
90 |
term4 = term5 ... term5 |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
91 |
| term5 |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
92 |
term5 = ident |
24246 | 93 |
| var |
24236
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
94 |
| CONST const |
24237 | 95 |
| ( term ) |
24236
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
96 |
*) |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
97 |
|
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
98 |
local |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
99 |
|
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
100 |
val constraint = $$ "::" |-- typ; |
24246 | 101 |
val idt = ident -- constraint; |
102 |
val bind = idt --| $$ "."; |
|
24236
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
103 |
|
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
104 |
fun term env T x = |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
105 |
($$ "!!" |-- bind :|-- (fn v => |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
106 |
term (v :: env) propT >> (fn B => Term.all (#2 v) $ lambda (Free v) B)) || |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
107 |
term1 env T) x |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
108 |
and term1 env T x = |
24262 | 109 |
(enum2 "==>" (term2 env propT) >> foldr1 Logic.mk_implies || |
24236
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
110 |
term2 env T) x |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
111 |
and term2 env T x = |
24246 | 112 |
(equal env "==" || equal env "=?=" || |
28856
5e009a80fe6d
Pure syntax: more coherent treatment of aprop, permanent TERM and &&&;
wenzelm
parents:
27888
diff
changeset
|
113 |
term3 env propT -- ($$ "&&&" |-- term2 env propT) >> Logic.mk_conjunction || |
24246 | 114 |
term3 env T) x |
24236
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
115 |
and equal env eq x = |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
116 |
(term3 env dummyT -- ($$ eq |-- term2 env dummyT) >> (fn (t, u) => |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
117 |
Const (eq, Term.fastype_of t --> Term.fastype_of u --> propT) $ t $ u)) x |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
118 |
and term3 env T x = |
24246 | 119 |
(idt >> Free || |
120 |
var -- constraint >> Var || |
|
24236
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
121 |
$$ "CONST" |-- const -- constraint >> Const || |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
122 |
$$ "%" |-- bind :|-- (fn v => term3 (v :: env) dummyT >> lambda (Free v)) || |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
123 |
term4 env T) x |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
124 |
and term4 env T x = |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
125 |
(term5 env dummyT -- Scan.repeat1 (term5 env dummyT) >> Term.list_comb || |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
126 |
term5 env T) x |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
127 |
and term5 env T x = |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
128 |
(ident >> (fn a => Free (a, the_default T (AList.lookup (op =) env a))) || |
24246 | 129 |
var >> (fn xi => Var (xi, T)) || |
24236
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
130 |
$$ "CONST" |-- const >> (fn c => Const (c, T)) || |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
131 |
$$ "(" |-- term env T --| $$ ")") x; |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
132 |
|
24246 | 133 |
fun read_tm T s = |
134 |
let val t = read (term [] T) s in |
|
135 |
if can (Term.map_types Term.no_dummyT) t then t |
|
136 |
else error ("Unspecified types in input: " ^ quote s) |
|
137 |
end; |
|
138 |
||
24487 | 139 |
in |
140 |
||
24246 | 141 |
val read_term = read_tm dummyT; |
142 |
val read_prop = read_tm propT; |
|
24236
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
143 |
|
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
144 |
end; |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
145 |
|
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
146 |
end; |
d8b05073edc7
Simple syntax for types and terms --- for bootstrapping Pure.
wenzelm
parents:
diff
changeset
|
147 |