| author | wenzelm | 
| Thu, 21 Jan 2016 22:16:48 +0100 | |
| changeset 62230 | 949d2c9f6ff7 | 
| parent 61654 | 4a28eec739e9 | 
| child 62969 | 9f394a16c557 | 
| permissions | -rw-r--r-- | 
| 36952 
338c3f8229e4
renamed structure SpecParse to Parse_Spec, keeping the old name as alias for some time;
 wenzelm parents: 
36950diff
changeset | 1 | (* Title: Pure/Isar/parse_spec.ML | 
| 22104 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 2 | Author: Makarius | 
| 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 3 | |
| 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 4 | Parsers for complex specifications. | 
| 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 5 | *) | 
| 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 6 | |
| 36952 
338c3f8229e4
renamed structure SpecParse to Parse_Spec, keeping the old name as alias for some time;
 wenzelm parents: 
36950diff
changeset | 7 | signature PARSE_SPEC = | 
| 22104 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 8 | sig | 
| 29312 | 9 | val thm_name: string -> Attrib.binding parser | 
| 10 | val opt_thm_name: string -> Attrib.binding parser | |
| 30481 
de003023c302
removed old named_spec, spec_name, spec_opt_name;
 wenzelm parents: 
29601diff
changeset | 11 | val spec: (Attrib.binding * string) parser | 
| 
de003023c302
removed old named_spec, spec_name, spec_opt_name;
 wenzelm parents: 
29601diff
changeset | 12 | val specs: (Attrib.binding * string list) parser | 
| 
de003023c302
removed old named_spec, spec_name, spec_opt_name;
 wenzelm parents: 
29601diff
changeset | 13 | val alt_specs: (Attrib.binding * string) list parser | 
| 
de003023c302
removed old named_spec, spec_name, spec_opt_name;
 wenzelm parents: 
29601diff
changeset | 14 | val where_alt_specs: (Attrib.binding * string) list parser | 
| 58011 
bc6bced136e5
tuned signature -- moved type src to Token, without aliases;
 wenzelm parents: 
56945diff
changeset | 15 | val name_facts: (Attrib.binding * (Facts.ref * Token.src list) list) list parser | 
| 33287 
0f99569d23e1
provide SpecParse.constdecl/constdef, e.g. for quotient_definition;
 wenzelm parents: 
30726diff
changeset | 16 | val constdecl: (binding * string option * mixfix) parser | 
| 
0f99569d23e1
provide SpecParse.constdecl/constdef, e.g. for quotient_definition;
 wenzelm parents: 
30726diff
changeset | 17 | val constdef: ((binding * string option * mixfix) option * (Attrib.binding * string)) parser | 
| 47067 
4ef29b0c568f
optional 'includes' element for long theorem statements;
 wenzelm parents: 
46922diff
changeset | 18 | val includes: (xstring * Position.T) list parser | 
| 29581 | 19 | val locale_fixes: (binding * string option * mixfix) list parser | 
| 29312 | 20 | val locale_insts: (string option list * (Attrib.binding * string) list) parser | 
| 46922 
3717f3878714
source positions for locale and class expressions;
 wenzelm parents: 
45592diff
changeset | 21 | val class_expression: string list parser | 
| 61606 
6d5213bd9709
uniform mandatory qualifier for all locale expressions, including 'statespace' parent;
 wenzelm parents: 
61466diff
changeset | 22 | val locale_prefix: (string * bool) parser | 
| 49754 
acafcac41690
more explicit namespace prefix for 'statespace' -- duplicate facts;
 wenzelm parents: 
47067diff
changeset | 23 | val locale_keyword: string parser | 
| 61606 
6d5213bd9709
uniform mandatory qualifier for all locale expressions, including 'statespace' parent;
 wenzelm parents: 
61466diff
changeset | 24 | val locale_expression: Expression.expression parser | 
| 29312 | 25 | val context_element: Element.context parser | 
| 61654 
4a28eec739e9
support for structure statements in 'assume', 'presume';
 wenzelm parents: 
61606diff
changeset | 26 | val statement': (string * string list) list list parser | 
| 
4a28eec739e9
support for structure statements in 'assume', 'presume';
 wenzelm parents: 
61606diff
changeset | 27 | val if_statement': (string * string list) list list parser | 
| 29312 | 28 | val statement: (Attrib.binding * (string * string list) list) list parser | 
| 60449 | 29 | val if_statement: (Attrib.binding * (string * string list) list) list parser | 
| 60555 
51a6997b1384
support 'when' statement, which corresponds to 'presume';
 wenzelm parents: 
60449diff
changeset | 30 | val cond_statement: (bool * (Attrib.binding * (string * string list) list) list) parser | 
| 60448 | 31 | val obtains: Element.obtains parser | 
| 29312 | 32 | val general_statement: (Element.context list * Element.statement) parser | 
| 33 | val statement_keyword: string parser | |
| 61260 | 34 | val overloaded: bool parser | 
| 22104 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 35 | end; | 
| 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 36 | |
| 36952 
338c3f8229e4
renamed structure SpecParse to Parse_Spec, keeping the old name as alias for some time;
 wenzelm parents: 
36950diff
changeset | 37 | structure Parse_Spec: PARSE_SPEC = | 
| 22104 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 38 | struct | 
| 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 39 | |
| 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 40 | (* theorem specifications *) | 
| 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 41 | |
| 58028 
e4250d370657
tuned signature -- define some elementary operations earlier;
 wenzelm parents: 
58011diff
changeset | 42 | fun thm_name s = Parse.binding -- Parse.opt_attribs --| Parse.$$$ s; | 
| 28083 
103d9282a946
explicit type Name.binding for higher-specification elements;
 wenzelm parents: 
27816diff
changeset | 43 | |
| 22104 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 44 | fun opt_thm_name s = | 
| 58028 
e4250d370657
tuned signature -- define some elementary operations earlier;
 wenzelm parents: 
58011diff
changeset | 45 | Scan.optional | 
| 
e4250d370657
tuned signature -- define some elementary operations earlier;
 wenzelm parents: 
58011diff
changeset | 46 | ((Parse.binding -- Parse.opt_attribs || Parse.attribs >> pair Binding.empty) --| Parse.$$$ s) | 
| 28965 | 47 | Attrib.empty_binding; | 
| 22104 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 48 | |
| 36950 | 49 | val spec = opt_thm_name ":" -- Parse.prop; | 
| 50 | val specs = opt_thm_name ":" -- Scan.repeat1 Parse.prop; | |
| 22104 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 51 | |
| 30481 
de003023c302
removed old named_spec, spec_name, spec_opt_name;
 wenzelm parents: 
29601diff
changeset | 52 | val alt_specs = | 
| 36950 | 53 | Parse.enum1 "|" | 
| 54 | (spec --| Scan.option (Scan.ahead (Parse.name || Parse.$$$ "[") -- Parse.!!! (Parse.$$$ "|"))); | |
| 30481 
de003023c302
removed old named_spec, spec_name, spec_opt_name;
 wenzelm parents: 
29601diff
changeset | 55 | |
| 36950 | 56 | val where_alt_specs = Parse.where_ |-- Parse.!!! alt_specs; | 
| 22104 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 57 | |
| 58028 
e4250d370657
tuned signature -- define some elementary operations earlier;
 wenzelm parents: 
58011diff
changeset | 58 | val name_facts = Parse.and_list1 (opt_thm_name "=" -- Parse.xthms1); | 
| 22104 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 59 | |
| 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 60 | |
| 33287 
0f99569d23e1
provide SpecParse.constdecl/constdef, e.g. for quotient_definition;
 wenzelm parents: 
30726diff
changeset | 61 | (* basic constant specifications *) | 
| 
0f99569d23e1
provide SpecParse.constdecl/constdef, e.g. for quotient_definition;
 wenzelm parents: 
30726diff
changeset | 62 | |
| 
0f99569d23e1
provide SpecParse.constdecl/constdef, e.g. for quotient_definition;
 wenzelm parents: 
30726diff
changeset | 63 | val constdecl = | 
| 36950 | 64 | Parse.binding -- | 
| 65 | (Parse.where_ >> K (NONE, NoSyn) || | |
| 66 | Parse.$$$ "::" |-- Parse.!!! ((Parse.typ >> SOME) -- Parse.opt_mixfix' --| Parse.where_) || | |
| 67 |       Scan.ahead (Parse.$$$ "(") |-- Parse.!!! (Parse.mixfix' --| Parse.where_ >> pair NONE))
 | |
| 61466 | 68 | >> Scan.triple2; | 
| 33287 
0f99569d23e1
provide SpecParse.constdecl/constdef, e.g. for quotient_definition;
 wenzelm parents: 
30726diff
changeset | 69 | |
| 36950 | 70 | val constdef = Scan.option constdecl -- (opt_thm_name ":" -- Parse.prop); | 
| 33287 
0f99569d23e1
provide SpecParse.constdecl/constdef, e.g. for quotient_definition;
 wenzelm parents: 
30726diff
changeset | 71 | |
| 
0f99569d23e1
provide SpecParse.constdecl/constdef, e.g. for quotient_definition;
 wenzelm parents: 
30726diff
changeset | 72 | |
| 22104 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 73 | (* locale and context elements *) | 
| 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 74 | |
| 47067 
4ef29b0c568f
optional 'includes' element for long theorem statements;
 wenzelm parents: 
46922diff
changeset | 75 | val includes = Parse.$$$ "includes" |-- Parse.!!! (Scan.repeat1 (Parse.position Parse.xname)); | 
| 
4ef29b0c568f
optional 'includes' element for long theorem statements;
 wenzelm parents: 
46922diff
changeset | 76 | |
| 22104 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 77 | val locale_fixes = | 
| 51654 
8450b944e58a
just one syntax category "mixfix" -- check structure annotation semantically;
 wenzelm parents: 
49754diff
changeset | 78 | Parse.and_list1 (Parse.binding -- Scan.option (Parse.$$$ "::" |-- Parse.typ) -- Parse.mixfix | 
| 61466 | 79 | >> (single o Scan.triple1) || | 
| 60448 | 80 | Parse.params) >> flat; | 
| 22104 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 81 | |
| 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 82 | val locale_insts = | 
| 36950 | 83 | Scan.optional | 
| 84 | (Parse.$$$ "[" |-- Parse.!!! (Scan.repeat1 (Parse.maybe Parse.term) --| Parse.$$$ "]")) [] -- | |
| 85 | Scan.optional (Parse.where_ |-- Parse.and_list1 (opt_thm_name ":" -- Parse.prop)) []; | |
| 22104 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 86 | |
| 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 87 | local | 
| 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 88 | |
| 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 89 | val loc_element = | 
| 36950 | 90 | Parse.$$$ "fixes" |-- Parse.!!! locale_fixes >> Element.Fixes || | 
| 91 | Parse.$$$ "constrains" |-- | |
| 92 | Parse.!!! (Parse.and_list1 (Parse.name -- (Parse.$$$ "::" |-- Parse.typ))) | |
| 22104 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 93 | >> Element.Constrains || | 
| 36950 | 94 | Parse.$$$ "assumes" |-- Parse.!!! (Parse.and_list1 (opt_thm_name ":" -- Scan.repeat1 Parse.propp)) | 
| 22104 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 95 | >> Element.Assumes || | 
| 36950 | 96 | Parse.$$$ "defines" |-- Parse.!!! (Parse.and_list1 (opt_thm_name ":" -- Parse.propp)) | 
| 22104 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 97 | >> Element.Defines || | 
| 58028 
e4250d370657
tuned signature -- define some elementary operations earlier;
 wenzelm parents: 
58011diff
changeset | 98 | Parse.$$$ "notes" |-- Parse.!!! (Parse.and_list1 (opt_thm_name "=" -- Parse.xthms1)) | 
| 22104 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 99 | >> (curry Element.Notes ""); | 
| 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 100 | |
| 24869 | 101 | fun plus1_unless test scan = | 
| 36950 | 102 | scan ::: Scan.repeat (Parse.$$$ "+" |-- Scan.unless test (Parse.!!! scan)); | 
| 22104 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 103 | |
| 36950 | 104 | val instance = Parse.where_ |-- | 
| 105 | Parse.and_list1 (Parse.name -- (Parse.$$$ "=" |-- Parse.term)) >> Expression.Named || | |
| 106 | Scan.repeat1 (Parse.maybe Parse.term) >> Expression.Positional; | |
| 29033 
721529248e31
Enable keyword 'structure' in for clause of locale expression.
 ballarin parents: 
28965diff
changeset | 107 | |
| 24869 | 108 | in | 
| 109 | ||
| 61606 
6d5213bd9709
uniform mandatory qualifier for all locale expressions, including 'statespace' parent;
 wenzelm parents: 
61466diff
changeset | 110 | val locale_prefix = | 
| 49754 
acafcac41690
more explicit namespace prefix for 'statespace' -- duplicate facts;
 wenzelm parents: 
47067diff
changeset | 111 | Scan.optional | 
| 61606 
6d5213bd9709
uniform mandatory qualifier for all locale expressions, including 'statespace' parent;
 wenzelm parents: 
61466diff
changeset | 112 | (Parse.name -- (Scan.option (Parse.$$$ "?") >> is_none) --| Parse.$$$ ":") | 
| 49754 
acafcac41690
more explicit namespace prefix for 'statespace' -- duplicate facts;
 wenzelm parents: 
47067diff
changeset | 113 |     ("", false);
 | 
| 
acafcac41690
more explicit namespace prefix for 'statespace' -- duplicate facts;
 wenzelm parents: 
47067diff
changeset | 114 | |
| 36950 | 115 | val locale_keyword = | 
| 116 | Parse.$$$ "fixes" || Parse.$$$ "constrains" || Parse.$$$ "assumes" || | |
| 117 | Parse.$$$ "defines" || Parse.$$$ "notes"; | |
| 28722 | 118 | |
| 46922 
3717f3878714
source positions for locale and class expressions;
 wenzelm parents: 
45592diff
changeset | 119 | val class_expression = plus1_unless locale_keyword Parse.class; | 
| 24869 | 120 | |
| 61606 
6d5213bd9709
uniform mandatory qualifier for all locale expressions, including 'statespace' parent;
 wenzelm parents: 
61466diff
changeset | 121 | val locale_expression = | 
| 29033 
721529248e31
Enable keyword 'structure' in for clause of locale expression.
 ballarin parents: 
28965diff
changeset | 122 | let | 
| 46922 
3717f3878714
source positions for locale and class expressions;
 wenzelm parents: 
45592diff
changeset | 123 | val expr2 = Parse.position Parse.xname; | 
| 61606 
6d5213bd9709
uniform mandatory qualifier for all locale expressions, including 'statespace' parent;
 wenzelm parents: 
61466diff
changeset | 124 | val expr1 = | 
| 
6d5213bd9709
uniform mandatory qualifier for all locale expressions, including 'statespace' parent;
 wenzelm parents: 
61466diff
changeset | 125 | locale_prefix -- expr2 -- | 
| 30720 | 126 | Scan.optional instance (Expression.Named []) >> (fn ((p, l), i) => (l, (p, i))); | 
| 127 | val expr0 = plus1_unless locale_keyword expr1; | |
| 36950 | 128 | in expr0 -- Scan.optional (Parse.$$$ "for" |-- Parse.!!! locale_fixes) [] end; | 
| 29033 
721529248e31
Enable keyword 'structure' in for clause of locale expression.
 ballarin parents: 
28965diff
changeset | 129 | |
| 44357 | 130 | val context_element = Parse.group (fn () => "context element") loc_element; | 
| 22104 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 131 | |
| 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 132 | end; | 
| 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 133 | |
| 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 134 | |
| 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 135 | (* statements *) | 
| 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 136 | |
| 61654 
4a28eec739e9
support for structure statements in 'assume', 'presume';
 wenzelm parents: 
61606diff
changeset | 137 | val statement' = Parse.and_list1 (Scan.repeat1 Parse.propp); | 
| 
4a28eec739e9
support for structure statements in 'assume', 'presume';
 wenzelm parents: 
61606diff
changeset | 138 | val if_statement' = Scan.optional (Parse.$$$ "if" |-- Parse.!!! statement') []; | 
| 
4a28eec739e9
support for structure statements in 'assume', 'presume';
 wenzelm parents: 
61606diff
changeset | 139 | |
| 36950 | 140 | val statement = Parse.and_list1 (opt_thm_name ":" -- Scan.repeat1 Parse.propp); | 
| 60449 | 141 | val if_statement = Scan.optional (Parse.$$$ "if" |-- Parse.!!! statement) []; | 
| 60414 | 142 | |
| 60555 
51a6997b1384
support 'when' statement, which corresponds to 'presume';
 wenzelm parents: 
60449diff
changeset | 143 | val cond_statement = | 
| 
51a6997b1384
support 'when' statement, which corresponds to 'presume';
 wenzelm parents: 
60449diff
changeset | 144 | Parse.$$$ "if" |-- Parse.!!! statement >> pair true || | 
| 
51a6997b1384
support 'when' statement, which corresponds to 'presume';
 wenzelm parents: 
60449diff
changeset | 145 | Parse.$$$ "when" |-- Parse.!!! statement >> pair false || | 
| 
51a6997b1384
support 'when' statement, which corresponds to 'presume';
 wenzelm parents: 
60449diff
changeset | 146 | Scan.succeed (true, []); | 
| 
51a6997b1384
support 'when' statement, which corresponds to 'presume';
 wenzelm parents: 
60449diff
changeset | 147 | |
| 22104 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 148 | val obtain_case = | 
| 59784 | 149 | Parse.parbinding -- | 
| 60448 | 150 | (Scan.optional (Parse.and_list1 Parse.fixes --| Parse.where_ >> flat) [] -- | 
| 59784 | 151 | (Parse.and_list1 (Scan.repeat1 Parse.prop) >> flat)); | 
| 22104 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 152 | |
| 60448 | 153 | val obtains = Parse.enum1 "|" obtain_case; | 
| 154 | ||
| 22104 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 155 | val general_statement = | 
| 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 156 | statement >> (fn x => ([], Element.Shows x)) || | 
| 28722 | 157 | Scan.repeat context_element -- | 
| 60448 | 158 | (Parse.$$$ "obtains" |-- Parse.!!! obtains >> Element.Obtains || | 
| 36950 | 159 | Parse.$$$ "shows" |-- Parse.!!! statement >> Element.Shows); | 
| 22104 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 160 | |
| 36950 | 161 | val statement_keyword = Parse.$$$ "obtains" || Parse.$$$ "shows"; | 
| 22104 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 162 | |
| 61260 | 163 | |
| 164 | (* options *) | |
| 165 | ||
| 166 | val overloaded = | |
| 167 |   Scan.optional (Parse.$$$ "(" -- Parse.$$$ "overloaded" -- Parse.$$$ ")" >> K true) false;
 | |
| 168 | ||
| 22104 
e8a1c88be824
Parsers for complex specifications (material from outer_parse.ML);
 wenzelm parents: diff
changeset | 169 | end; |