author | eberlm <eberlm@in.tum.de> |
Thu, 18 May 2017 15:43:14 +0200 | |
changeset 65870 | 81574a7e7c38 |
parent 64994 | 6e4c05e8edbb |
child 66190 | a41435469559 |
permissions | -rw-r--r-- |
31051
4d9b52e0a48c
refined HOL string theories and corresponding ML fragments
haftmann
parents:
diff
changeset
|
1 |
(* Author: Tobias Nipkow, Florian Haftmann, TU Muenchen *) |
4d9b52e0a48c
refined HOL string theories and corresponding ML fragments
haftmann
parents:
diff
changeset
|
2 |
|
60758 | 3 |
section \<open>Character and string types\<close> |
31051
4d9b52e0a48c
refined HOL string theories and corresponding ML fragments
haftmann
parents:
diff
changeset
|
4 |
|
4d9b52e0a48c
refined HOL string theories and corresponding ML fragments
haftmann
parents:
diff
changeset
|
5 |
theory String |
55969 | 6 |
imports Enum |
31051
4d9b52e0a48c
refined HOL string theories and corresponding ML fragments
haftmann
parents:
diff
changeset
|
7 |
begin |
4d9b52e0a48c
refined HOL string theories and corresponding ML fragments
haftmann
parents:
diff
changeset
|
8 |
|
60758 | 9 |
subsection \<open>Characters and strings\<close> |
31051
4d9b52e0a48c
refined HOL string theories and corresponding ML fragments
haftmann
parents:
diff
changeset
|
10 |
|
62364
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
11 |
subsubsection \<open>Characters as finite algebraic type\<close> |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
12 |
|
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
13 |
typedef char = "{n::nat. n < 256}" |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
14 |
morphisms nat_of_char Abs_char |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
15 |
proof |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
16 |
show "Suc 0 \<in> {n. n < 256}" by simp |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
17 |
qed |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
18 |
|
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
19 |
definition char_of_nat :: "nat \<Rightarrow> char" |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
20 |
where |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
21 |
"char_of_nat n = Abs_char (n mod 256)" |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
22 |
|
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
23 |
lemma char_cases [case_names char_of_nat, cases type: char]: |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
24 |
"(\<And>n. c = char_of_nat n \<Longrightarrow> n < 256 \<Longrightarrow> P) \<Longrightarrow> P" |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
25 |
by (cases c) (simp add: char_of_nat_def) |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
26 |
|
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
27 |
lemma char_of_nat_of_char [simp]: |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
28 |
"char_of_nat (nat_of_char c) = c" |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
29 |
by (cases c) (simp add: char_of_nat_def Abs_char_inject Abs_char_inverse) |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
30 |
|
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
31 |
lemma inj_nat_of_char: |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
32 |
"inj nat_of_char" |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
33 |
proof (rule injI) |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
34 |
fix c d |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
35 |
assume "nat_of_char c = nat_of_char d" |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
36 |
then have "char_of_nat (nat_of_char c) = char_of_nat (nat_of_char d)" |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
37 |
by simp |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
38 |
then show "c = d" |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
39 |
by simp |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
40 |
qed |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
41 |
|
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
42 |
lemma nat_of_char_eq_iff [simp]: |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
43 |
"nat_of_char c = nat_of_char d \<longleftrightarrow> c = d" |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
44 |
by (fact nat_of_char_inject) |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
45 |
|
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
46 |
lemma nat_of_char_of_nat [simp]: |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
47 |
"nat_of_char (char_of_nat n) = n mod 256" |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
48 |
by (cases "char_of_nat n") (simp add: char_of_nat_def Abs_char_inject Abs_char_inverse) |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
49 |
|
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
50 |
lemma char_of_nat_mod_256 [simp]: |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
51 |
"char_of_nat (n mod 256) = char_of_nat n" |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
52 |
by (cases "char_of_nat (n mod 256)") (simp add: char_of_nat_def) |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
53 |
|
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
54 |
lemma char_of_nat_quasi_inj [simp]: |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
55 |
"char_of_nat m = char_of_nat n \<longleftrightarrow> m mod 256 = n mod 256" |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
56 |
by (simp add: char_of_nat_def Abs_char_inject) |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
57 |
|
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
58 |
lemma inj_on_char_of_nat [simp]: |
62597 | 59 |
"inj_on char_of_nat {..<256}" |
62364
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
60 |
by (rule inj_onI) simp |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
61 |
|
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
62 |
lemma nat_of_char_mod_256 [simp]: |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
63 |
"nat_of_char c mod 256 = nat_of_char c" |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
64 |
by (cases c) simp |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
65 |
|
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
66 |
lemma nat_of_char_less_256 [simp]: |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
67 |
"nat_of_char c < 256" |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
68 |
proof - |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
69 |
have "nat_of_char c mod 256 < 256" |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
70 |
by arith |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
71 |
then show ?thesis by simp |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
72 |
qed |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
73 |
|
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
74 |
lemma UNIV_char_of_nat: |
62597 | 75 |
"UNIV = char_of_nat ` {..<256}" |
62364
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
76 |
proof - |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
77 |
{ fix c |
62597 | 78 |
have "c \<in> char_of_nat ` {..<256}" |
62364
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
79 |
by (cases c) auto |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
80 |
} then show ?thesis by auto |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
81 |
qed |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
82 |
|
62597 | 83 |
lemma card_UNIV_char: |
84 |
"card (UNIV :: char set) = 256" |
|
85 |
by (auto simp add: UNIV_char_of_nat card_image) |
|
31051
4d9b52e0a48c
refined HOL string theories and corresponding ML fragments
haftmann
parents:
diff
changeset
|
86 |
|
62597 | 87 |
lemma range_nat_of_char: |
88 |
"range nat_of_char = {..<256}" |
|
89 |
by (auto simp add: UNIV_char_of_nat image_image image_def) |
|
31051
4d9b52e0a48c
refined HOL string theories and corresponding ML fragments
haftmann
parents:
diff
changeset
|
90 |
|
49972
f11f8905d9fd
incorporated constant chars into instantiation proof for enum;
haftmann
parents:
49948
diff
changeset
|
91 |
|
62597 | 92 |
subsubsection \<open>Character literals as variant of numerals\<close> |
93 |
||
94 |
instantiation char :: zero |
|
49972
f11f8905d9fd
incorporated constant chars into instantiation proof for enum;
haftmann
parents:
49948
diff
changeset
|
95 |
begin |
f11f8905d9fd
incorporated constant chars into instantiation proof for enum;
haftmann
parents:
49948
diff
changeset
|
96 |
|
62597 | 97 |
definition zero_char :: char |
98 |
where "0 = char_of_nat 0" |
|
49972
f11f8905d9fd
incorporated constant chars into instantiation proof for enum;
haftmann
parents:
49948
diff
changeset
|
99 |
|
62597 | 100 |
instance .. |
49972
f11f8905d9fd
incorporated constant chars into instantiation proof for enum;
haftmann
parents:
49948
diff
changeset
|
101 |
|
f11f8905d9fd
incorporated constant chars into instantiation proof for enum;
haftmann
parents:
49948
diff
changeset
|
102 |
end |
f11f8905d9fd
incorporated constant chars into instantiation proof for enum;
haftmann
parents:
49948
diff
changeset
|
103 |
|
62597 | 104 |
definition Char :: "num \<Rightarrow> char" |
105 |
where "Char k = char_of_nat (numeral k)" |
|
106 |
||
107 |
code_datatype "0 :: char" Char |
|
108 |
||
109 |
lemma nat_of_char_zero [simp]: |
|
110 |
"nat_of_char 0 = 0" |
|
111 |
by (simp add: zero_char_def) |
|
112 |
||
113 |
lemma nat_of_char_Char [simp]: |
|
114 |
"nat_of_char (Char k) = numeral k mod 256" |
|
115 |
by (simp add: Char_def) |
|
31051
4d9b52e0a48c
refined HOL string theories and corresponding ML fragments
haftmann
parents:
diff
changeset
|
116 |
|
64630
96015aecfeba
emphasize dedicated rewrite rules for congruences
haftmann
parents:
63950
diff
changeset
|
117 |
lemma Char_eq_Char_iff: |
62597 | 118 |
"Char k = Char l \<longleftrightarrow> numeral k mod (256 :: nat) = numeral l mod 256" (is "?P \<longleftrightarrow> ?Q") |
119 |
proof - |
|
120 |
have "?P \<longleftrightarrow> nat_of_char (Char k) = nat_of_char (Char l)" |
|
121 |
by (rule sym, rule inj_eq) (fact inj_nat_of_char) |
|
122 |
also have "nat_of_char (Char k) = nat_of_char (Char l) \<longleftrightarrow> ?Q" |
|
123 |
by (simp only: Char_def nat_of_char_of_nat) |
|
124 |
finally show ?thesis . |
|
125 |
qed |
|
126 |
||
64630
96015aecfeba
emphasize dedicated rewrite rules for congruences
haftmann
parents:
63950
diff
changeset
|
127 |
lemma zero_eq_Char_iff: |
62597 | 128 |
"0 = Char k \<longleftrightarrow> numeral k mod (256 :: nat) = 0" |
129 |
by (auto simp add: zero_char_def Char_def) |
|
130 |
||
64630
96015aecfeba
emphasize dedicated rewrite rules for congruences
haftmann
parents:
63950
diff
changeset
|
131 |
lemma Char_eq_zero_iff: |
62597 | 132 |
"Char k = 0 \<longleftrightarrow> numeral k mod (256 :: nat) = 0" |
133 |
by (auto simp add: zero_char_def Char_def) |
|
134 |
||
64630
96015aecfeba
emphasize dedicated rewrite rules for congruences
haftmann
parents:
63950
diff
changeset
|
135 |
simproc_setup char_eq |
96015aecfeba
emphasize dedicated rewrite rules for congruences
haftmann
parents:
63950
diff
changeset
|
136 |
("Char m = Char n" | "Char m = 0" | "0 = Char n") = \<open> |
96015aecfeba
emphasize dedicated rewrite rules for congruences
haftmann
parents:
63950
diff
changeset
|
137 |
let |
96015aecfeba
emphasize dedicated rewrite rules for congruences
haftmann
parents:
63950
diff
changeset
|
138 |
val ss = put_simpset HOL_ss @{context} |
96015aecfeba
emphasize dedicated rewrite rules for congruences
haftmann
parents:
63950
diff
changeset
|
139 |
|> fold Simplifier.add_simp @{thms Char_eq_Char_iff zero_eq_Char_iff Char_eq_zero_iff cong_exp_iff_simps} |
96015aecfeba
emphasize dedicated rewrite rules for congruences
haftmann
parents:
63950
diff
changeset
|
140 |
|> simpset_of |
96015aecfeba
emphasize dedicated rewrite rules for congruences
haftmann
parents:
63950
diff
changeset
|
141 |
in |
96015aecfeba
emphasize dedicated rewrite rules for congruences
haftmann
parents:
63950
diff
changeset
|
142 |
fn _ => fn ctxt => SOME o Simplifier.rewrite (put_simpset ss ctxt) |
96015aecfeba
emphasize dedicated rewrite rules for congruences
haftmann
parents:
63950
diff
changeset
|
143 |
end |
96015aecfeba
emphasize dedicated rewrite rules for congruences
haftmann
parents:
63950
diff
changeset
|
144 |
\<close> |
96015aecfeba
emphasize dedicated rewrite rules for congruences
haftmann
parents:
63950
diff
changeset
|
145 |
|
62597 | 146 |
definition integer_of_char :: "char \<Rightarrow> integer" |
51160
599ff65b85e2
systematic conversions between nat and nibble/char;
haftmann
parents:
49972
diff
changeset
|
147 |
where |
62597 | 148 |
"integer_of_char = integer_of_nat \<circ> nat_of_char" |
51160
599ff65b85e2
systematic conversions between nat and nibble/char;
haftmann
parents:
49972
diff
changeset
|
149 |
|
62597 | 150 |
definition char_of_integer :: "integer \<Rightarrow> char" |
151 |
where |
|
152 |
"char_of_integer = char_of_nat \<circ> nat_of_integer" |
|
153 |
||
154 |
lemma integer_of_char_zero [simp, code]: |
|
155 |
"integer_of_char 0 = 0" |
|
156 |
by (simp add: integer_of_char_def integer_of_nat_def) |
|
51160
599ff65b85e2
systematic conversions between nat and nibble/char;
haftmann
parents:
49972
diff
changeset
|
157 |
|
62597 | 158 |
lemma integer_of_char_Char [simp]: |
159 |
"integer_of_char (Char k) = numeral k mod 256" |
|
160 |
by (simp only: integer_of_char_def integer_of_nat_def comp_apply nat_of_char_Char map_fun_def |
|
63950
cdc1e59aa513
syntactic type class for operation mod named after mod;
haftmann
parents:
62678
diff
changeset
|
161 |
id_apply zmod_int modulo_integer.abs_eq [symmetric]) simp |
51160
599ff65b85e2
systematic conversions between nat and nibble/char;
haftmann
parents:
49972
diff
changeset
|
162 |
|
62597 | 163 |
lemma less_256_integer_of_char_Char: |
164 |
assumes "numeral k < (256 :: integer)" |
|
165 |
shows "integer_of_char (Char k) = numeral k" |
|
166 |
proof - |
|
167 |
have "numeral k mod 256 = (numeral k :: integer)" |
|
168 |
by (rule semiring_numeral_div_class.mod_less) (insert assms, simp_all) |
|
169 |
then show ?thesis using integer_of_char_Char [of k] |
|
170 |
by (simp only:) |
|
171 |
qed |
|
51160
599ff65b85e2
systematic conversions between nat and nibble/char;
haftmann
parents:
49972
diff
changeset
|
172 |
|
62597 | 173 |
setup \<open> |
174 |
let |
|
175 |
val chars = map_range (Thm.cterm_of @{context} o HOLogic.mk_numeral o curry (op +) 1) 255; |
|
176 |
val simpset = |
|
177 |
put_simpset HOL_ss @{context} |
|
178 |
addsimps @{thms numeral_less_iff less_num_simps}; |
|
179 |
fun mk_code_eqn ct = |
|
180 |
Thm.instantiate' [] [SOME ct] @{thm less_256_integer_of_char_Char} |
|
181 |
|> full_simplify simpset; |
|
182 |
val code_eqns = map mk_code_eqn chars; |
|
183 |
in |
|
184 |
Global_Theory.note_thmss "" |
|
185 |
[((@{binding integer_of_char_simps}, []), [(code_eqns, [])])] |
|
186 |
#> snd |
|
187 |
end |
|
188 |
\<close> |
|
51160
599ff65b85e2
systematic conversions between nat and nibble/char;
haftmann
parents:
49972
diff
changeset
|
189 |
|
62597 | 190 |
declare integer_of_char_simps [code] |
191 |
||
192 |
lemma nat_of_char_code [code]: |
|
193 |
"nat_of_char = nat_of_integer \<circ> integer_of_char" |
|
194 |
by (simp add: integer_of_char_def fun_eq_iff) |
|
51160
599ff65b85e2
systematic conversions between nat and nibble/char;
haftmann
parents:
49972
diff
changeset
|
195 |
|
62597 | 196 |
lemma char_of_nat_code [code]: |
197 |
"char_of_nat = char_of_integer \<circ> integer_of_nat" |
|
198 |
by (simp add: char_of_integer_def fun_eq_iff) |
|
51160
599ff65b85e2
systematic conversions between nat and nibble/char;
haftmann
parents:
49972
diff
changeset
|
199 |
|
62597 | 200 |
instantiation char :: equal |
62364
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
201 |
begin |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
202 |
|
62597 | 203 |
definition equal_char |
204 |
where "equal_char (c :: char) d \<longleftrightarrow> c = d" |
|
62364
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
205 |
|
62597 | 206 |
instance |
207 |
by standard (simp add: equal_char_def) |
|
31051
4d9b52e0a48c
refined HOL string theories and corresponding ML fragments
haftmann
parents:
diff
changeset
|
208 |
|
62364
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
209 |
end |
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
210 |
|
62597 | 211 |
lemma equal_char_simps [code]: |
212 |
"HOL.equal (0::char) 0 \<longleftrightarrow> True" |
|
213 |
"HOL.equal (Char k) (Char l) \<longleftrightarrow> HOL.equal (numeral k mod 256 :: nat) (numeral l mod 256)" |
|
214 |
"HOL.equal 0 (Char k) \<longleftrightarrow> HOL.equal (numeral k mod 256 :: nat) 0" |
|
215 |
"HOL.equal (Char k) 0 \<longleftrightarrow> HOL.equal (numeral k mod 256 :: nat) 0" |
|
216 |
by (simp_all only: equal refl Char_eq_Char_iff zero_eq_Char_iff Char_eq_zero_iff) |
|
62364
9209770bdcdf
more direct bootstrap of char type, still retaining the nibble representation for syntax
haftmann
parents:
61799
diff
changeset
|
217 |
|
31051
4d9b52e0a48c
refined HOL string theories and corresponding ML fragments
haftmann
parents:
diff
changeset
|
218 |
syntax |
62597 | 219 |
"_Char" :: "str_position \<Rightarrow> char" ("CHR _") |
62678 | 220 |
"_Char_ord" :: "num_const \<Rightarrow> char" ("CHR _") |
31051
4d9b52e0a48c
refined HOL string theories and corresponding ML fragments
haftmann
parents:
diff
changeset
|
221 |
|
42163
392fd6c4669c
renewing specifications in HOL: replacing types by type_synonym
bulwahn
parents:
41750
diff
changeset
|
222 |
type_synonym string = "char list" |
31051
4d9b52e0a48c
refined HOL string theories and corresponding ML fragments
haftmann
parents:
diff
changeset
|
223 |
|
4d9b52e0a48c
refined HOL string theories and corresponding ML fragments
haftmann
parents:
diff
changeset
|
224 |
syntax |
46483 | 225 |
"_String" :: "str_position => string" ("_") |
31051
4d9b52e0a48c
refined HOL string theories and corresponding ML fragments
haftmann
parents:
diff
changeset
|
226 |
|
48891 | 227 |
ML_file "Tools/string_syntax.ML" |
31051
4d9b52e0a48c
refined HOL string theories and corresponding ML fragments
haftmann
parents:
diff
changeset
|
228 |
|
49972
f11f8905d9fd
incorporated constant chars into instantiation proof for enum;
haftmann
parents:
49948
diff
changeset
|
229 |
instantiation char :: enum |
f11f8905d9fd
incorporated constant chars into instantiation proof for enum;
haftmann
parents:
49948
diff
changeset
|
230 |
begin |
f11f8905d9fd
incorporated constant chars into instantiation proof for enum;
haftmann
parents:
49948
diff
changeset
|
231 |
|
f11f8905d9fd
incorporated constant chars into instantiation proof for enum;
haftmann
parents:
49948
diff
changeset
|
232 |
definition |
62678 | 233 |
"Enum.enum = [0, CHR 0x01, CHR 0x02, CHR 0x03, |
234 |
CHR 0x04, CHR 0x05, CHR 0x06, CHR 0x07, |
|
235 |
CHR 0x08, CHR 0x09, CHR ''\<newline>'', CHR 0x0B, |
|
236 |
CHR 0x0C, CHR 0x0D, CHR 0x0E, CHR 0x0F, |
|
237 |
CHR 0x10, CHR 0x11, CHR 0x12, CHR 0x13, |
|
238 |
CHR 0x14, CHR 0x15, CHR 0x16, CHR 0x17, |
|
239 |
CHR 0x18, CHR 0x19, CHR 0x1A, CHR 0x1B, |
|
240 |
CHR 0x1C, CHR 0x1D, CHR 0x1E, CHR 0x1F, |
|
241 |
CHR '' '', CHR ''!'', CHR 0x22, CHR ''#'', |
|
242 |
CHR ''$'', CHR ''%'', CHR ''&'', CHR 0x27, |
|
62597 | 243 |
CHR ''('', CHR '')'', CHR ''*'', CHR ''+'', |
244 |
CHR '','', CHR ''-'', CHR ''.'', CHR ''/'', |
|
245 |
CHR ''0'', CHR ''1'', CHR ''2'', CHR ''3'', |
|
246 |
CHR ''4'', CHR ''5'', CHR ''6'', CHR ''7'', |
|
247 |
CHR ''8'', CHR ''9'', CHR '':'', CHR '';'', |
|
248 |
CHR ''<'', CHR ''='', CHR ''>'', CHR ''?'', |
|
249 |
CHR ''@'', CHR ''A'', CHR ''B'', CHR ''C'', |
|
250 |
CHR ''D'', CHR ''E'', CHR ''F'', CHR ''G'', |
|
251 |
CHR ''H'', CHR ''I'', CHR ''J'', CHR ''K'', |
|
252 |
CHR ''L'', CHR ''M'', CHR ''N'', CHR ''O'', |
|
253 |
CHR ''P'', CHR ''Q'', CHR ''R'', CHR ''S'', |
|
254 |
CHR ''T'', CHR ''U'', CHR ''V'', CHR ''W'', |
|
255 |
CHR ''X'', CHR ''Y'', CHR ''Z'', CHR ''['', |
|
62678 | 256 |
CHR 0x5C, CHR '']'', CHR ''^'', CHR ''_'', |
257 |
CHR 0x60, CHR ''a'', CHR ''b'', CHR ''c'', |
|
62597 | 258 |
CHR ''d'', CHR ''e'', CHR ''f'', CHR ''g'', |
259 |
CHR ''h'', CHR ''i'', CHR ''j'', CHR ''k'', |
|
260 |
CHR ''l'', CHR ''m'', CHR ''n'', CHR ''o'', |
|
261 |
CHR ''p'', CHR ''q'', CHR ''r'', CHR ''s'', |
|
262 |
CHR ''t'', CHR ''u'', CHR ''v'', CHR ''w'', |
|
263 |
CHR ''x'', CHR ''y'', CHR ''z'', CHR ''{'', |
|
62678 | 264 |
CHR ''|'', CHR ''}'', CHR ''~'', CHR 0x7F, |
265 |
CHR 0x80, CHR 0x81, CHR 0x82, CHR 0x83, |
|
266 |
CHR 0x84, CHR 0x85, CHR 0x86, CHR 0x87, |
|
267 |
CHR 0x88, CHR 0x89, CHR 0x8A, CHR 0x8B, |
|
268 |
CHR 0x8C, CHR 0x8D, CHR 0x8E, CHR 0x8F, |
|
269 |
CHR 0x90, CHR 0x91, CHR 0x92, CHR 0x93, |
|
270 |
CHR 0x94, CHR 0x95, CHR 0x96, CHR 0x97, |
|
271 |
CHR 0x98, CHR 0x99, CHR 0x9A, CHR 0x9B, |
|
272 |
CHR 0x9C, CHR 0x9D, CHR 0x9E, CHR 0x9F, |
|
273 |
CHR 0xA0, CHR 0xA1, CHR 0xA2, CHR 0xA3, |
|
274 |
CHR 0xA4, CHR 0xA5, CHR 0xA6, CHR 0xA7, |
|
275 |
CHR 0xA8, CHR 0xA9, CHR 0xAA, CHR 0xAB, |
|
276 |
CHR 0xAC, CHR 0xAD, CHR 0xAE, CHR 0xAF, |
|
277 |
CHR 0xB0, CHR 0xB1, CHR 0xB2, CHR 0xB3, |
|
278 |
CHR 0xB4, CHR 0xB5, CHR 0xB6, CHR 0xB7, |
|
279 |
CHR 0xB8, CHR 0xB9, CHR 0xBA, CHR 0xBB, |
|
280 |
CHR 0xBC, CHR 0xBD, CHR 0xBE, CHR 0xBF, |
|
281 |
CHR 0xC0, CHR 0xC1, CHR 0xC2, CHR 0xC3, |
|
282 |
CHR 0xC4, CHR 0xC5, CHR 0xC6, CHR 0xC7, |
|
283 |
CHR 0xC8, CHR 0xC9, CHR 0xCA, CHR 0xCB, |
|
284 |
CHR 0xCC, CHR 0xCD, CHR 0xCE, CHR 0xCF, |
|
285 |
CHR 0xD0, CHR 0xD1, CHR 0xD2, CHR 0xD3, |
|
286 |
CHR 0xD4, CHR 0xD5, CHR 0xD6, CHR 0xD7, |
|
287 |
CHR 0xD8, CHR 0xD9, CHR 0xDA, CHR 0xDB, |
|
288 |
CHR 0xDC, CHR 0xDD, CHR 0xDE, CHR 0xDF, |
|
289 |
CHR 0xE0, CHR 0xE1, CHR 0xE2, CHR 0xE3, |
|
290 |
CHR 0xE4, CHR 0xE5, CHR 0xE6, CHR 0xE7, |
|
291 |
CHR 0xE8, CHR 0xE9, CHR 0xEA, CHR 0xEB, |
|
292 |
CHR 0xEC, CHR 0xED, CHR 0xEE, CHR 0xEF, |
|
293 |
CHR 0xF0, CHR 0xF1, CHR 0xF2, CHR 0xF3, |
|
294 |
CHR 0xF4, CHR 0xF5, CHR 0xF6, CHR 0xF7, |
|
295 |
CHR 0xF8, CHR 0xF9, CHR 0xFA, CHR 0xFB, |
|
296 |
CHR 0xFC, CHR 0xFD, CHR 0xFE, CHR 0xFF]" |
|
31484 | 297 |
|
49972
f11f8905d9fd
incorporated constant chars into instantiation proof for enum;
haftmann
parents:
49948
diff
changeset
|
298 |
definition |
f11f8905d9fd
incorporated constant chars into instantiation proof for enum;
haftmann
parents:
49948
diff
changeset
|
299 |
"Enum.enum_all P \<longleftrightarrow> list_all P (Enum.enum :: char list)" |
f11f8905d9fd
incorporated constant chars into instantiation proof for enum;
haftmann
parents:
49948
diff
changeset
|
300 |
|
f11f8905d9fd
incorporated constant chars into instantiation proof for enum;
haftmann
parents:
49948
diff
changeset
|
301 |
definition |
f11f8905d9fd
incorporated constant chars into instantiation proof for enum;
haftmann
parents:
49948
diff
changeset
|
302 |
"Enum.enum_ex P \<longleftrightarrow> list_ex P (Enum.enum :: char list)" |
f11f8905d9fd
incorporated constant chars into instantiation proof for enum;
haftmann
parents:
49948
diff
changeset
|
303 |
|
62597 | 304 |
lemma enum_char_unfold: |
305 |
"Enum.enum = map char_of_nat [0..<256]" |
|
306 |
proof - |
|
307 |
have *: "Suc (Suc 0) = 2" by simp |
|
308 |
have "map nat_of_char Enum.enum = [0..<256]" |
|
309 |
by (simp add: enum_char_def upt_conv_Cons_Cons *) |
|
310 |
then have "map char_of_nat (map nat_of_char Enum.enum) = |
|
311 |
map char_of_nat [0..<256]" by simp |
|
312 |
then show ?thesis by (simp add: comp_def) |
|
313 |
qed |
|
51160
599ff65b85e2
systematic conversions between nat and nibble/char;
haftmann
parents:
49972
diff
changeset
|
314 |
|
49972
f11f8905d9fd
incorporated constant chars into instantiation proof for enum;
haftmann
parents:
49948
diff
changeset
|
315 |
instance proof |
f11f8905d9fd
incorporated constant chars into instantiation proof for enum;
haftmann
parents:
49948
diff
changeset
|
316 |
show UNIV: "UNIV = set (Enum.enum :: char list)" |
62597 | 317 |
by (simp add: enum_char_unfold UNIV_char_of_nat atLeast0LessThan) |
49972
f11f8905d9fd
incorporated constant chars into instantiation proof for enum;
haftmann
parents:
49948
diff
changeset
|
318 |
show "distinct (Enum.enum :: char list)" |
62597 | 319 |
by (auto simp add: enum_char_unfold distinct_map intro: inj_onI) |
49972
f11f8905d9fd
incorporated constant chars into instantiation proof for enum;
haftmann
parents:
49948
diff
changeset
|
320 |
show "\<And>P. Enum.enum_all P \<longleftrightarrow> Ball (UNIV :: char set) P" |
f11f8905d9fd
incorporated constant chars into instantiation proof for enum;
haftmann
parents:
49948
diff
changeset
|
321 |
by (simp add: UNIV enum_all_char_def list_all_iff) |
f11f8905d9fd
incorporated constant chars into instantiation proof for enum;
haftmann
parents:
49948
diff
changeset
|
322 |
show "\<And>P. Enum.enum_ex P \<longleftrightarrow> Bex (UNIV :: char set) P" |
f11f8905d9fd
incorporated constant chars into instantiation proof for enum;
haftmann
parents:
49948
diff
changeset
|
323 |
by (simp add: UNIV enum_ex_char_def list_ex_iff) |
f11f8905d9fd
incorporated constant chars into instantiation proof for enum;
haftmann
parents:
49948
diff
changeset
|
324 |
qed |
f11f8905d9fd
incorporated constant chars into instantiation proof for enum;
haftmann
parents:
49948
diff
changeset
|
325 |
|
f11f8905d9fd
incorporated constant chars into instantiation proof for enum;
haftmann
parents:
49948
diff
changeset
|
326 |
end |
f11f8905d9fd
incorporated constant chars into instantiation proof for enum;
haftmann
parents:
49948
diff
changeset
|
327 |
|
62597 | 328 |
lemma char_of_integer_code [code]: |
329 |
"char_of_integer n = Enum.enum ! (nat_of_integer n mod 256)" |
|
330 |
by (simp add: char_of_integer_def enum_char_unfold) |
|
49948
744934b818c7
moved quite generic material from theory Enum to more appropriate places
haftmann
parents:
49834
diff
changeset
|
331 |
|
31051
4d9b52e0a48c
refined HOL string theories and corresponding ML fragments
haftmann
parents:
diff
changeset
|
332 |
|
60758 | 333 |
subsection \<open>Strings as dedicated type\<close> |
39250
548a3e5521ab
changing String.literal to a type instead of a datatype
bulwahn
parents:
39198
diff
changeset
|
334 |
|
49834 | 335 |
typedef literal = "UNIV :: string set" |
39250
548a3e5521ab
changing String.literal to a type instead of a datatype
bulwahn
parents:
39198
diff
changeset
|
336 |
morphisms explode STR .. |
548a3e5521ab
changing String.literal to a type instead of a datatype
bulwahn
parents:
39198
diff
changeset
|
337 |
|
59484
a130ae7a9398
slightly more standard code setup for String.literal, with explicit special case in predicate compiler
haftmann
parents:
59483
diff
changeset
|
338 |
setup_lifting type_definition_literal |
a130ae7a9398
slightly more standard code setup for String.literal, with explicit special case in predicate compiler
haftmann
parents:
59483
diff
changeset
|
339 |
|
a130ae7a9398
slightly more standard code setup for String.literal, with explicit special case in predicate compiler
haftmann
parents:
59483
diff
changeset
|
340 |
lemma STR_inject' [simp]: |
a130ae7a9398
slightly more standard code setup for String.literal, with explicit special case in predicate compiler
haftmann
parents:
59483
diff
changeset
|
341 |
"STR s = STR t \<longleftrightarrow> s = t" |
a130ae7a9398
slightly more standard code setup for String.literal, with explicit special case in predicate compiler
haftmann
parents:
59483
diff
changeset
|
342 |
by transfer rule |
54594
a2d1522cdd54
setup lifting/transfer for String.literal
Andreas Lochbihler
parents:
54317
diff
changeset
|
343 |
|
57437 | 344 |
definition implode :: "string \<Rightarrow> String.literal" |
345 |
where |
|
59484
a130ae7a9398
slightly more standard code setup for String.literal, with explicit special case in predicate compiler
haftmann
parents:
59483
diff
changeset
|
346 |
[code del]: "implode = STR" |
a130ae7a9398
slightly more standard code setup for String.literal, with explicit special case in predicate compiler
haftmann
parents:
59483
diff
changeset
|
347 |
|
39250
548a3e5521ab
changing String.literal to a type instead of a datatype
bulwahn
parents:
39198
diff
changeset
|
348 |
instantiation literal :: size |
548a3e5521ab
changing String.literal to a type instead of a datatype
bulwahn
parents:
39198
diff
changeset
|
349 |
begin |
31051
4d9b52e0a48c
refined HOL string theories and corresponding ML fragments
haftmann
parents:
diff
changeset
|
350 |
|
39250
548a3e5521ab
changing String.literal to a type instead of a datatype
bulwahn
parents:
39198
diff
changeset
|
351 |
definition size_literal :: "literal \<Rightarrow> nat" |
548a3e5521ab
changing String.literal to a type instead of a datatype
bulwahn
parents:
39198
diff
changeset
|
352 |
where |
61076 | 353 |
[code]: "size_literal (s::literal) = 0" |
31051
4d9b52e0a48c
refined HOL string theories and corresponding ML fragments
haftmann
parents:
diff
changeset
|
354 |
|
39250
548a3e5521ab
changing String.literal to a type instead of a datatype
bulwahn
parents:
39198
diff
changeset
|
355 |
instance .. |
548a3e5521ab
changing String.literal to a type instead of a datatype
bulwahn
parents:
39198
diff
changeset
|
356 |
|
548a3e5521ab
changing String.literal to a type instead of a datatype
bulwahn
parents:
39198
diff
changeset
|
357 |
end |
548a3e5521ab
changing String.literal to a type instead of a datatype
bulwahn
parents:
39198
diff
changeset
|
358 |
|
548a3e5521ab
changing String.literal to a type instead of a datatype
bulwahn
parents:
39198
diff
changeset
|
359 |
instantiation literal :: equal |
548a3e5521ab
changing String.literal to a type instead of a datatype
bulwahn
parents:
39198
diff
changeset
|
360 |
begin |
31051
4d9b52e0a48c
refined HOL string theories and corresponding ML fragments
haftmann
parents:
diff
changeset
|
361 |
|
54594
a2d1522cdd54
setup lifting/transfer for String.literal
Andreas Lochbihler
parents:
54317
diff
changeset
|
362 |
lift_definition equal_literal :: "literal \<Rightarrow> literal \<Rightarrow> bool" is "op =" . |
31051
4d9b52e0a48c
refined HOL string theories and corresponding ML fragments
haftmann
parents:
diff
changeset
|
363 |
|
54594
a2d1522cdd54
setup lifting/transfer for String.literal
Andreas Lochbihler
parents:
54317
diff
changeset
|
364 |
instance by intro_classes (transfer, simp) |
39250
548a3e5521ab
changing String.literal to a type instead of a datatype
bulwahn
parents:
39198
diff
changeset
|
365 |
|
548a3e5521ab
changing String.literal to a type instead of a datatype
bulwahn
parents:
39198
diff
changeset
|
366 |
end |
31051
4d9b52e0a48c
refined HOL string theories and corresponding ML fragments
haftmann
parents:
diff
changeset
|
367 |
|
54594
a2d1522cdd54
setup lifting/transfer for String.literal
Andreas Lochbihler
parents:
54317
diff
changeset
|
368 |
declare equal_literal.rep_eq[code] |
a2d1522cdd54
setup lifting/transfer for String.literal
Andreas Lochbihler
parents:
54317
diff
changeset
|
369 |
|
52365
95186e6e4bf4
reflexive nbe equation for equality on String.literal
haftmann
parents:
51717
diff
changeset
|
370 |
lemma [code nbe]: |
95186e6e4bf4
reflexive nbe equation for equality on String.literal
haftmann
parents:
51717
diff
changeset
|
371 |
fixes s :: "String.literal" |
95186e6e4bf4
reflexive nbe equation for equality on String.literal
haftmann
parents:
51717
diff
changeset
|
372 |
shows "HOL.equal s s \<longleftrightarrow> True" |
95186e6e4bf4
reflexive nbe equation for equality on String.literal
haftmann
parents:
51717
diff
changeset
|
373 |
by (simp add: equal) |
95186e6e4bf4
reflexive nbe equation for equality on String.literal
haftmann
parents:
51717
diff
changeset
|
374 |
|
55426
90f2ceed2828
make lifting setup for String.literal local to prevent transfer from replacing STR ''...'' literals
Andreas Lochbihler
parents:
55015
diff
changeset
|
375 |
lifting_update literal.lifting |
90f2ceed2828
make lifting setup for String.literal local to prevent transfer from replacing STR ''...'' literals
Andreas Lochbihler
parents:
55015
diff
changeset
|
376 |
lifting_forget literal.lifting |
90f2ceed2828
make lifting setup for String.literal local to prevent transfer from replacing STR ''...'' literals
Andreas Lochbihler
parents:
55015
diff
changeset
|
377 |
|
64994
6e4c05e8edbb
computation preprocessing rules to allow literals as input for computations
haftmann
parents:
64630
diff
changeset
|
378 |
|
6e4c05e8edbb
computation preprocessing rules to allow literals as input for computations
haftmann
parents:
64630
diff
changeset
|
379 |
subsection \<open>Dedicated conversion for generated computations\<close> |
6e4c05e8edbb
computation preprocessing rules to allow literals as input for computations
haftmann
parents:
64630
diff
changeset
|
380 |
|
6e4c05e8edbb
computation preprocessing rules to allow literals as input for computations
haftmann
parents:
64630
diff
changeset
|
381 |
definition char_of_num :: "num \<Rightarrow> char" |
6e4c05e8edbb
computation preprocessing rules to allow literals as input for computations
haftmann
parents:
64630
diff
changeset
|
382 |
where "char_of_num = char_of_nat o nat_of_num" |
6e4c05e8edbb
computation preprocessing rules to allow literals as input for computations
haftmann
parents:
64630
diff
changeset
|
383 |
|
6e4c05e8edbb
computation preprocessing rules to allow literals as input for computations
haftmann
parents:
64630
diff
changeset
|
384 |
lemma [code_computation_unfold]: |
6e4c05e8edbb
computation preprocessing rules to allow literals as input for computations
haftmann
parents:
64630
diff
changeset
|
385 |
"Char = char_of_num" |
6e4c05e8edbb
computation preprocessing rules to allow literals as input for computations
haftmann
parents:
64630
diff
changeset
|
386 |
by (simp add: fun_eq_iff char_of_num_def nat_of_num_numeral Char_def) |
6e4c05e8edbb
computation preprocessing rules to allow literals as input for computations
haftmann
parents:
64630
diff
changeset
|
387 |
|
6e4c05e8edbb
computation preprocessing rules to allow literals as input for computations
haftmann
parents:
64630
diff
changeset
|
388 |
|
60758 | 389 |
subsection \<open>Code generator\<close> |
31051
4d9b52e0a48c
refined HOL string theories and corresponding ML fragments
haftmann
parents:
diff
changeset
|
390 |
|
48891 | 391 |
ML_file "Tools/string_code.ML" |
31051
4d9b52e0a48c
refined HOL string theories and corresponding ML fragments
haftmann
parents:
diff
changeset
|
392 |
|
33237 | 393 |
code_reserved SML string |
394 |
code_reserved OCaml string |
|
34886 | 395 |
code_reserved Scala string |
33237 | 396 |
|
52435
6646bb548c6b
migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents:
52365
diff
changeset
|
397 |
code_printing |
6646bb548c6b
migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents:
52365
diff
changeset
|
398 |
type_constructor literal \<rightharpoonup> |
6646bb548c6b
migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents:
52365
diff
changeset
|
399 |
(SML) "string" |
6646bb548c6b
migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents:
52365
diff
changeset
|
400 |
and (OCaml) "string" |
6646bb548c6b
migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents:
52365
diff
changeset
|
401 |
and (Haskell) "String" |
6646bb548c6b
migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents:
52365
diff
changeset
|
402 |
and (Scala) "String" |
31051
4d9b52e0a48c
refined HOL string theories and corresponding ML fragments
haftmann
parents:
diff
changeset
|
403 |
|
60758 | 404 |
setup \<open> |
34886 | 405 |
fold String_Code.add_literal_string ["SML", "OCaml", "Haskell", "Scala"] |
60758 | 406 |
\<close> |
31051
4d9b52e0a48c
refined HOL string theories and corresponding ML fragments
haftmann
parents:
diff
changeset
|
407 |
|
52435
6646bb548c6b
migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents:
52365
diff
changeset
|
408 |
code_printing |
6646bb548c6b
migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents:
52365
diff
changeset
|
409 |
class_instance literal :: equal \<rightharpoonup> |
6646bb548c6b
migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents:
52365
diff
changeset
|
410 |
(Haskell) - |
6646bb548c6b
migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents:
52365
diff
changeset
|
411 |
| constant "HOL.equal :: literal \<Rightarrow> literal \<Rightarrow> bool" \<rightharpoonup> |
6646bb548c6b
migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents:
52365
diff
changeset
|
412 |
(SML) "!((_ : string) = _)" |
6646bb548c6b
migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents:
52365
diff
changeset
|
413 |
and (OCaml) "!((_ : string) = _)" |
6646bb548c6b
migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents:
52365
diff
changeset
|
414 |
and (Haskell) infix 4 "==" |
6646bb548c6b
migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
haftmann
parents:
52365
diff
changeset
|
415 |
and (Scala) infixl 5 "==" |
31051
4d9b52e0a48c
refined HOL string theories and corresponding ML fragments
haftmann
parents:
diff
changeset
|
416 |
|
60758 | 417 |
setup \<open>Sign.map_naming (Name_Space.mandatory_path "Code")\<close> |
52910
7bfe0df532a9
abort execution of generated code with explicit exception message
Andreas Lochbihler
parents:
52435
diff
changeset
|
418 |
|
7bfe0df532a9
abort execution of generated code with explicit exception message
Andreas Lochbihler
parents:
52435
diff
changeset
|
419 |
definition abort :: "literal \<Rightarrow> (unit \<Rightarrow> 'a) \<Rightarrow> 'a" |
7bfe0df532a9
abort execution of generated code with explicit exception message
Andreas Lochbihler
parents:
52435
diff
changeset
|
420 |
where [simp, code del]: "abort _ f = f ()" |
7bfe0df532a9
abort execution of generated code with explicit exception message
Andreas Lochbihler
parents:
52435
diff
changeset
|
421 |
|
54317
da932f511746
add congruence rule to prevent code_simp from looping
Andreas Lochbihler
parents:
52910
diff
changeset
|
422 |
lemma abort_cong: "msg = msg' ==> Code.abort msg f = Code.abort msg' f" |
da932f511746
add congruence rule to prevent code_simp from looping
Andreas Lochbihler
parents:
52910
diff
changeset
|
423 |
by simp |
da932f511746
add congruence rule to prevent code_simp from looping
Andreas Lochbihler
parents:
52910
diff
changeset
|
424 |
|
60758 | 425 |
setup \<open>Sign.map_naming Name_Space.parent_path\<close> |
52910
7bfe0df532a9
abort execution of generated code with explicit exception message
Andreas Lochbihler
parents:
52435
diff
changeset
|
426 |
|
60758 | 427 |
setup \<open>Code_Simp.map_ss (Simplifier.add_cong @{thm Code.abort_cong})\<close> |
54317
da932f511746
add congruence rule to prevent code_simp from looping
Andreas Lochbihler
parents:
52910
diff
changeset
|
428 |
|
52910
7bfe0df532a9
abort execution of generated code with explicit exception message
Andreas Lochbihler
parents:
52435
diff
changeset
|
429 |
code_printing constant Code.abort \<rightharpoonup> |
7bfe0df532a9
abort execution of generated code with explicit exception message
Andreas Lochbihler
parents:
52435
diff
changeset
|
430 |
(SML) "!(raise/ Fail/ _)" |
7bfe0df532a9
abort execution of generated code with explicit exception message
Andreas Lochbihler
parents:
52435
diff
changeset
|
431 |
and (OCaml) "failwith" |
59483
ddb73392356e
explicit type annotation avoids problems with Haskell type inference
haftmann
parents:
58889
diff
changeset
|
432 |
and (Haskell) "!(error/ ::/ forall a./ String -> (() -> a) -> a)" |
52910
7bfe0df532a9
abort execution of generated code with explicit exception message
Andreas Lochbihler
parents:
52435
diff
changeset
|
433 |
and (Scala) "!{/ sys.error((_));/ ((_)).apply(())/ }" |
7bfe0df532a9
abort execution of generated code with explicit exception message
Andreas Lochbihler
parents:
52435
diff
changeset
|
434 |
|
36176
3fe7e97ccca8
replaced generic 'hide' command by more conventional 'hide_class', 'hide_type', 'hide_const', 'hide_fact' -- frees some popular keywords;
wenzelm
parents:
35123
diff
changeset
|
435 |
hide_type (open) literal |
31205
98370b26c2ce
String.literal replaces message_string, code_numeral replaces (code_)index
haftmann
parents:
31176
diff
changeset
|
436 |
|
57437 | 437 |
hide_const (open) implode explode |
438 |
||
39250
548a3e5521ab
changing String.literal to a type instead of a datatype
bulwahn
parents:
39198
diff
changeset
|
439 |
end |