5368
|
1 |
(* Title: HOL/ex/Antiquote.thy
|
|
2 |
ID: $Id$
|
|
3 |
Author: Markus Wenzel, TU Muenchen
|
|
4 |
|
|
5 |
Simple quote / antiquote example.
|
|
6 |
*)
|
|
7 |
|
8559
|
8 |
theory Antiquote = Main:;
|
5368
|
9 |
|
|
10 |
syntax
|
8559
|
11 |
"_Expr" :: "'a => 'a" ("EXPR _" [1000] 999);
|
5368
|
12 |
|
|
13 |
constdefs
|
|
14 |
var :: "'a => ('a => nat) => nat" ("VAR _" [1000] 999)
|
|
15 |
"var x env == env x"
|
|
16 |
|
8559
|
17 |
Expr :: "(('a => nat) => nat) => ('a => nat) => nat"
|
|
18 |
"Expr exp env == exp env";
|
5368
|
19 |
|
8559
|
20 |
parse_translation {* [Syntax.quote_antiquote_tr "_Expr" "var" "Expr"] *};
|
|
21 |
print_translation {* [Syntax.quote_antiquote_tr' "_Expr" "var" "Expr"] *};
|
|
22 |
|
|
23 |
term "EXPR (a + b + c)";
|
|
24 |
term "EXPR (a + b + c + VAR x + VAR y + 1)";
|
|
25 |
term "EXPR (VAR (f w) + VAR x)";
|
5368
|
26 |
|
8559
|
27 |
term "Expr (%env. env x)"; (*improper*)
|
|
28 |
term "Expr (%env. f env)";
|
|
29 |
term "Expr (%env. f env + env x)"; (*improper*)
|
|
30 |
term "Expr (%env. f env y z)";
|
|
31 |
term "Expr (%env. f env + g y env)";
|
|
32 |
term "Expr (%env. f env + g env y + h a env z)";
|
5368
|
33 |
|
8559
|
34 |
end;
|
|
35 |
|