src/HOL/Bali/State.thy
author kleing
Mon Jun 21 10:25:57 2004 +0200 (2004-06-21)
changeset 14981 e73f8140af78
parent 14766 c0401da7726d
child 16417 9bc16273c2d4
permissions -rw-r--r--
Merged in license change from Isabelle2004
wenzelm@12857
     1
(*  Title:      HOL/Bali/State.thy
schirmer@12854
     2
    ID:         $Id$
schirmer@12854
     3
    Author:     David von Oheimb
schirmer@12854
     4
*)
schirmer@12854
     5
header {* State for evaluation of Java expressions and statements *}
schirmer@12854
     6
schirmer@12854
     7
theory State = DeclConcepts:
schirmer@12854
     8
schirmer@12854
     9
text {*
schirmer@12854
    10
design issues:
schirmer@12854
    11
\begin{itemize}
schirmer@12854
    12
\item all kinds of objects (class instances, arrays, and class objects)
schirmer@12854
    13
  are handeled via a general object abstraction
schirmer@12854
    14
\item the heap and the map for class objects are combined into a single table
schirmer@12854
    15
  @{text "(recall (loc, obj) table \<times> (qtname, obj) table  ~=  (loc + qtname, obj) table)"}
schirmer@12854
    16
\end{itemize}
schirmer@12854
    17
*}
schirmer@12854
    18
schirmer@12854
    19
section "objects"
schirmer@12854
    20
schirmer@13688
    21
datatype  obj_tag =     --{* tag for generic object   *}
schirmer@13688
    22
	  CInst qtname  --{* class instance           *}
schirmer@13688
    23
	| Arr  ty int   --{* array with component type and length *}
schirmer@13688
    24
    --{* | CStat qtname   the tag is irrelevant for a class object,
schirmer@12925
    25
			   i.e. the static fields of a class,
schirmer@12925
    26
                           since its type is given already by the reference to 
schirmer@13688
    27
                           it (see below) *}
schirmer@12854
    28
schirmer@13688
    29
types	vn   = "fspec + int"                    --{* variable name      *}
schirmer@12854
    30
record	obj  = 
schirmer@13688
    31
          tag :: "obj_tag"                      --{* generalized object *}
schirmer@12854
    32
          values :: "(vn, val) table"      
schirmer@12854
    33
schirmer@12854
    34
translations 
schirmer@12854
    35
  "fspec" <= (type) "vname \<times> qtname" 
schirmer@12854
    36
  "vn"    <= (type) "fspec + int"
schirmer@12854
    37
  "obj"   <= (type) "\<lparr>tag::obj_tag, values::vn \<Rightarrow> val option\<rparr>"
schirmer@12854
    38
  "obj"   <= (type) "\<lparr>tag::obj_tag, values::vn \<Rightarrow> val option,\<dots>::'a\<rparr>"
schirmer@12854
    39
schirmer@12854
    40
constdefs
schirmer@12854
    41
  
schirmer@12854
    42
  the_Arr :: "obj option \<Rightarrow> ty \<times> int \<times> (vn, val) table"
wenzelm@14766
    43
 "the_Arr obj \<equiv> SOME (T,k,t). obj = Some \<lparr>tag=Arr T k,values=t\<rparr>"
schirmer@12854
    44
schirmer@12854
    45
lemma the_Arr_Arr [simp]: "the_Arr (Some \<lparr>tag=Arr T k,values=cs\<rparr>) = (T,k,cs)"
schirmer@12854
    46
apply (auto simp: the_Arr_def)
schirmer@12854
    47
done
schirmer@12854
    48
schirmer@12854
    49
lemma the_Arr_Arr1 [simp,intro,dest]:
schirmer@12854
    50
 "\<lbrakk>tag obj = Arr T k\<rbrakk> \<Longrightarrow> the_Arr (Some obj) = (T,k,values obj)"
schirmer@12854
    51
apply (auto simp add: the_Arr_def)
schirmer@12854
    52
done
schirmer@12854
    53
schirmer@12854
    54
constdefs
schirmer@12854
    55
schirmer@12854
    56
  upd_obj       :: "vn \<Rightarrow> val \<Rightarrow> obj \<Rightarrow> obj" 
schirmer@12854
    57
 "upd_obj n v \<equiv> \<lambda> obj . obj \<lparr>values:=(values obj)(n\<mapsto>v)\<rparr>"
schirmer@12854
    58
schirmer@12854
    59
lemma upd_obj_def2 [simp]: 
schirmer@12854
    60
  "upd_obj n v obj = obj \<lparr>values:=(values obj)(n\<mapsto>v)\<rparr>" 
schirmer@12854
    61
apply (auto simp: upd_obj_def)
schirmer@12854
    62
done
schirmer@12854
    63
schirmer@12854
    64
constdefs
schirmer@12854
    65
  obj_ty        :: "obj \<Rightarrow> ty"
schirmer@12854
    66
 "obj_ty obj    \<equiv> case tag obj of 
schirmer@12854
    67
                    CInst C \<Rightarrow> Class C 
schirmer@12854
    68
                  | Arr T k \<Rightarrow> T.[]"
schirmer@12854
    69
schirmer@12854
    70
lemma obj_ty_eq [intro!]: "obj_ty \<lparr>tag=oi,values=x\<rparr> = obj_ty \<lparr>tag=oi,values=y\<rparr>" 
schirmer@12854
    71
by (simp add: obj_ty_def)
schirmer@12854
    72
schirmer@12854
    73
schirmer@12854
    74
lemma obj_ty_eq1 [intro!,dest]: 
schirmer@12854
    75
  "tag obj = tag obj' \<Longrightarrow> obj_ty obj = obj_ty obj'" 
schirmer@12854
    76
by (simp add: obj_ty_def)
schirmer@12854
    77
schirmer@12854
    78
lemma obj_ty_cong [simp]: 
schirmer@12854
    79
  "obj_ty (obj \<lparr>values:=vs\<rparr>) = obj_ty obj" 
schirmer@12854
    80
by auto
schirmer@13688
    81
schirmer@12854
    82
lemma obj_ty_CInst [simp]: 
schirmer@12854
    83
 "obj_ty \<lparr>tag=CInst C,values=vs\<rparr> = Class C" 
schirmer@12854
    84
by (simp add: obj_ty_def)
schirmer@12854
    85
schirmer@12854
    86
lemma obj_ty_CInst1 [simp,intro!,dest]: 
schirmer@12854
    87
 "\<lbrakk>tag obj = CInst C\<rbrakk> \<Longrightarrow> obj_ty obj = Class C" 
schirmer@12854
    88
by (simp add: obj_ty_def)
schirmer@12854
    89
schirmer@12854
    90
lemma obj_ty_Arr [simp]: 
schirmer@12854
    91
 "obj_ty \<lparr>tag=Arr T i,values=vs\<rparr> = T.[]"
schirmer@12854
    92
by (simp add: obj_ty_def)
schirmer@12854
    93
schirmer@12854
    94
lemma obj_ty_Arr1 [simp,intro!,dest]: 
schirmer@12854
    95
 "\<lbrakk>tag obj = Arr T i\<rbrakk> \<Longrightarrow> obj_ty obj = T.[]"
schirmer@12854
    96
by (simp add: obj_ty_def)
schirmer@12854
    97
schirmer@12854
    98
lemma obj_ty_widenD: 
schirmer@12854
    99
 "G\<turnstile>obj_ty obj\<preceq>RefT t \<Longrightarrow> (\<exists>C. tag obj = CInst C) \<or> (\<exists>T k. tag obj = Arr T k)"
schirmer@12854
   100
apply (unfold obj_ty_def)
schirmer@12854
   101
apply (auto split add: obj_tag.split_asm)
schirmer@12854
   102
done
schirmer@12854
   103
schirmer@12854
   104
constdefs
schirmer@12854
   105
schirmer@12854
   106
  obj_class :: "obj \<Rightarrow> qtname"
schirmer@12854
   107
 "obj_class obj \<equiv> case tag obj of 
schirmer@12854
   108
                    CInst C \<Rightarrow> C 
schirmer@12854
   109
                  | Arr T k \<Rightarrow> Object"
schirmer@12854
   110
schirmer@12854
   111
schirmer@12854
   112
lemma obj_class_CInst [simp]: "obj_class \<lparr>tag=CInst C,values=vs\<rparr> = C" 
schirmer@12854
   113
by (auto simp: obj_class_def)
schirmer@12854
   114
schirmer@12854
   115
lemma obj_class_CInst1 [simp,intro!,dest]: 
schirmer@12854
   116
  "tag obj = CInst C \<Longrightarrow> obj_class obj = C" 
schirmer@12854
   117
by (auto simp: obj_class_def)
schirmer@12854
   118
schirmer@12854
   119
lemma obj_class_Arr [simp]: "obj_class \<lparr>tag=Arr T k,values=vs\<rparr> = Object" 
schirmer@12854
   120
by (auto simp: obj_class_def)
schirmer@12854
   121
schirmer@12854
   122
lemma obj_class_Arr1 [simp,intro!,dest]: 
schirmer@12854
   123
 "tag obj = Arr T k \<Longrightarrow> obj_class obj = Object" 
schirmer@12854
   124
by (auto simp: obj_class_def)
schirmer@12854
   125
schirmer@12854
   126
lemma obj_ty_obj_class: "G\<turnstile>obj_ty obj\<preceq> Class statC = G\<turnstile>obj_class obj \<preceq>\<^sub>C statC"
schirmer@12854
   127
apply (case_tac "tag obj")
schirmer@12854
   128
apply (auto simp add: obj_ty_def obj_class_def)
schirmer@12854
   129
apply (case_tac "statC = Object")
schirmer@12854
   130
apply (auto dest: widen_Array_Class)
schirmer@12854
   131
done
schirmer@12854
   132
schirmer@12854
   133
section "object references"
schirmer@12854
   134
schirmer@13688
   135
types oref = "loc + qtname"         --{* generalized object reference *}
schirmer@12854
   136
syntax
schirmer@12854
   137
  Heap  :: "loc   \<Rightarrow> oref"
schirmer@12854
   138
  Stat  :: "qtname \<Rightarrow> oref"
schirmer@12854
   139
schirmer@12854
   140
translations
schirmer@12854
   141
  "Heap" => "Inl"
schirmer@12854
   142
  "Stat" => "Inr"
schirmer@12854
   143
  "oref" <= (type) "loc + qtname"
schirmer@12854
   144
schirmer@12854
   145
constdefs
schirmer@12854
   146
  fields_table::
schirmer@12854
   147
    "prog \<Rightarrow> qtname \<Rightarrow> (fspec \<Rightarrow> field \<Rightarrow> bool)  \<Rightarrow> (fspec, ty) table"
schirmer@12854
   148
 "fields_table G C P 
schirmer@12854
   149
    \<equiv> option_map type \<circ> table_of (filter (split P) (DeclConcepts.fields G C))"
schirmer@12854
   150
schirmer@12854
   151
lemma fields_table_SomeI: 
schirmer@12854
   152
"\<lbrakk>table_of (DeclConcepts.fields G C) n = Some f; P n f\<rbrakk> 
schirmer@12854
   153
 \<Longrightarrow> fields_table G C P n = Some (type f)"
schirmer@12854
   154
apply (unfold fields_table_def)
schirmer@12854
   155
apply clarsimp
schirmer@12854
   156
apply (rule exI)
schirmer@12854
   157
apply (rule conjI)
schirmer@12854
   158
apply (erule map_of_filter_in)
schirmer@12854
   159
apply assumption
schirmer@12854
   160
apply simp
schirmer@12854
   161
done
schirmer@12854
   162
schirmer@12854
   163
(* unused *)
schirmer@12854
   164
lemma fields_table_SomeD': "fields_table G C P fn = Some T \<Longrightarrow>  
schirmer@12854
   165
  \<exists>f. (fn,f)\<in>set(DeclConcepts.fields G C) \<and> type f = T"
schirmer@12854
   166
apply (unfold fields_table_def)
schirmer@12854
   167
apply clarsimp
schirmer@12854
   168
apply (drule map_of_SomeD)
schirmer@12854
   169
apply auto
schirmer@12854
   170
done
schirmer@12854
   171
schirmer@12854
   172
lemma fields_table_SomeD: 
schirmer@12854
   173
"\<lbrakk>fields_table G C P fn = Some T; unique (DeclConcepts.fields G C)\<rbrakk> \<Longrightarrow>  
schirmer@12854
   174
  \<exists>f. table_of (DeclConcepts.fields G C) fn = Some f \<and> type f = T"
schirmer@12854
   175
apply (unfold fields_table_def)
schirmer@12854
   176
apply clarsimp
schirmer@12854
   177
apply (rule exI)
schirmer@12854
   178
apply (rule conjI)
schirmer@12854
   179
apply (erule table_of_filter_unique_SomeD)
schirmer@12854
   180
apply assumption
schirmer@12854
   181
apply simp
schirmer@12854
   182
done
schirmer@12854
   183
schirmer@12854
   184
constdefs
schirmer@12854
   185
  in_bounds :: "int \<Rightarrow> int \<Rightarrow> bool"            ("(_/ in'_bounds _)" [50, 51] 50)
schirmer@12854
   186
 "i in_bounds k \<equiv> 0 \<le> i \<and> i < k"
schirmer@12854
   187
schirmer@12854
   188
  arr_comps :: "'a \<Rightarrow> int \<Rightarrow> int \<Rightarrow> 'a option"
schirmer@12854
   189
 "arr_comps T k \<equiv> \<lambda>i. if i in_bounds k then Some T else None"
schirmer@12854
   190
  
schirmer@12854
   191
  var_tys       :: "prog \<Rightarrow> obj_tag \<Rightarrow> oref \<Rightarrow> (vn, ty) table"
schirmer@12854
   192
"var_tys G oi r 
schirmer@12854
   193
  \<equiv> case r of 
schirmer@12854
   194
      Heap a \<Rightarrow> (case oi of 
schirmer@12854
   195
                   CInst C \<Rightarrow> fields_table G C (\<lambda>n f. \<not>static f) (+) empty
schirmer@12854
   196
                 | Arr T k \<Rightarrow> empty (+) arr_comps T k)
schirmer@12854
   197
    | Stat C \<Rightarrow> fields_table G C (\<lambda>fn f. declclassf fn = C \<and> static f) 
schirmer@12854
   198
                (+) empty"
schirmer@12854
   199
schirmer@12854
   200
lemma var_tys_Some_eq: 
schirmer@12854
   201
 "var_tys G oi r n = Some T 
schirmer@12854
   202
  = (case r of 
schirmer@12854
   203
       Inl a \<Rightarrow> (case oi of  
schirmer@12854
   204
                   CInst C \<Rightarrow> (\<exists>nt. n = Inl nt \<and> fields_table G C (\<lambda>n f. 
schirmer@12854
   205
                               \<not>static f) nt = Some T)  
schirmer@12854
   206
                 | Arr t k \<Rightarrow> (\<exists> i. n = Inr i  \<and> i in_bounds k \<and> t = T))  
schirmer@12854
   207
     | Inr C \<Rightarrow> (\<exists>nt. n = Inl nt \<and> 
schirmer@12854
   208
                 fields_table G C (\<lambda>fn f. declclassf fn = C \<and> static f) nt 
schirmer@12854
   209
                  = Some T))"
schirmer@12854
   210
apply (unfold var_tys_def arr_comps_def)
schirmer@12854
   211
apply (force split add: sum.split_asm sum.split obj_tag.split)
schirmer@12854
   212
done
schirmer@12854
   213
schirmer@12854
   214
schirmer@12854
   215
section "stores"
schirmer@12854
   216
schirmer@13688
   217
types	globs               --{* global variables: heap and static variables *}
schirmer@12854
   218
	= "(oref , obj) table"
schirmer@12854
   219
	heap
schirmer@12854
   220
	= "(loc  , obj) table"
schirmer@13337
   221
(*	locals                   
schirmer@13337
   222
	= "(lname, val) table" *) (* defined in Value.thy local variables *)
schirmer@12854
   223
schirmer@12854
   224
translations
schirmer@12854
   225
 "globs"  <= (type) "(oref , obj) table"
schirmer@12854
   226
 "heap"   <= (type) "(loc  , obj) table"
schirmer@13337
   227
(*  "locals" <= (type) "(lname, val) table" *)
schirmer@12854
   228
schirmer@12854
   229
datatype st = (* pure state, i.e. contents of all variables *)
schirmer@12854
   230
	 st globs locals
schirmer@12854
   231
schirmer@12854
   232
subsection "access"
schirmer@12854
   233
schirmer@12854
   234
constdefs
schirmer@12854
   235
schirmer@12854
   236
  globs  :: "st \<Rightarrow> globs"
schirmer@12854
   237
 "globs  \<equiv> st_case (\<lambda>g l. g)"
schirmer@12854
   238
  
schirmer@12854
   239
  locals :: "st \<Rightarrow> locals"
schirmer@12854
   240
 "locals \<equiv> st_case (\<lambda>g l. l)"
schirmer@12854
   241
schirmer@12854
   242
  heap   :: "st \<Rightarrow> heap"
schirmer@12854
   243
 "heap s \<equiv> globs s \<circ> Heap"
schirmer@12854
   244
schirmer@12854
   245
schirmer@12854
   246
lemma globs_def2 [simp]: " globs (st g l) = g"
schirmer@12854
   247
by (simp add: globs_def)
schirmer@12854
   248
schirmer@12854
   249
lemma locals_def2 [simp]: "locals (st g l) = l"
schirmer@12854
   250
by (simp add: locals_def)
schirmer@12854
   251
schirmer@12854
   252
lemma heap_def2 [simp]:  "heap s a=globs s (Heap a)"
schirmer@12854
   253
by (simp add: heap_def)
schirmer@12854
   254
schirmer@12854
   255
schirmer@12854
   256
syntax
schirmer@12854
   257
  val_this     :: "st \<Rightarrow> val"
schirmer@12854
   258
  lookup_obj   :: "st \<Rightarrow> val \<Rightarrow> obj"
schirmer@12854
   259
schirmer@12854
   260
translations
schirmer@12854
   261
 "val_this s"       == "the (locals s This)" 
schirmer@12854
   262
 "lookup_obj s a'"  == "the (heap s (the_Addr a'))"
schirmer@12854
   263
schirmer@12854
   264
subsection "memory allocation"
schirmer@12854
   265
schirmer@12854
   266
constdefs
schirmer@12854
   267
  new_Addr     :: "heap \<Rightarrow> loc option"
wenzelm@14766
   268
 "new_Addr h   \<equiv> if (\<forall>a. h a \<noteq> None) then None else Some (SOME a. h a = None)"
schirmer@12854
   269
schirmer@12854
   270
lemma new_AddrD: "new_Addr h = Some a \<Longrightarrow> h a = None"
schirmer@12854
   271
apply (unfold new_Addr_def)
schirmer@12854
   272
apply auto
schirmer@12854
   273
apply (case_tac "h (SOME a\<Colon>loc. h a = None)")
schirmer@12854
   274
apply simp
schirmer@12854
   275
apply (fast intro: someI2)
schirmer@12854
   276
done
schirmer@12854
   277
schirmer@12854
   278
lemma new_AddrD2: "new_Addr h = Some a \<Longrightarrow> \<forall>b. h b \<noteq> None \<longrightarrow> b \<noteq> a"
schirmer@12854
   279
apply (drule new_AddrD)
schirmer@12854
   280
apply auto
schirmer@12854
   281
done
schirmer@12854
   282
schirmer@12854
   283
lemma new_Addr_SomeI: "h a = None \<Longrightarrow> \<exists>b. new_Addr h = Some b \<and> h b = None"
schirmer@12854
   284
apply (unfold new_Addr_def)
schirmer@12854
   285
apply (frule not_Some_eq [THEN iffD2])
schirmer@12854
   286
apply auto
schirmer@12854
   287
apply  (drule not_Some_eq [THEN iffD2])
schirmer@12854
   288
apply  auto
schirmer@12854
   289
apply (fast intro!: someI2)
schirmer@12854
   290
done
schirmer@12854
   291
schirmer@12854
   292
schirmer@12854
   293
subsection "initialization"
schirmer@12854
   294
schirmer@12854
   295
syntax
schirmer@12854
   296
schirmer@12854
   297
  init_vals     :: "('a, ty) table \<Rightarrow> ('a, val) table"
schirmer@12854
   298
schirmer@12854
   299
translations
schirmer@12854
   300
 "init_vals vs"    == "option_map default_val \<circ> vs"
schirmer@12854
   301
schirmer@12854
   302
lemma init_arr_comps_base [simp]: "init_vals (arr_comps T 0) = empty"
schirmer@12854
   303
apply (unfold arr_comps_def in_bounds_def)
schirmer@12854
   304
apply (rule ext)
schirmer@12854
   305
apply auto
schirmer@12854
   306
done
schirmer@12854
   307
schirmer@12854
   308
lemma init_arr_comps_step [simp]: 
schirmer@12854
   309
"0 < j \<Longrightarrow> init_vals (arr_comps T  j    ) =  
schirmer@12854
   310
           init_vals (arr_comps T (j - 1))(j - 1\<mapsto>default_val T)"
schirmer@12854
   311
apply (unfold arr_comps_def in_bounds_def)
schirmer@12854
   312
apply (rule ext)
schirmer@12854
   313
apply auto
schirmer@12854
   314
done
schirmer@12854
   315
schirmer@12854
   316
subsection "update"
schirmer@12854
   317
schirmer@12854
   318
constdefs
schirmer@12854
   319
  gupd       :: "oref  \<Rightarrow> obj \<Rightarrow> st \<Rightarrow> st"        ("gupd'(_\<mapsto>_')"[10,10]1000)
schirmer@12854
   320
 "gupd r obj  \<equiv> st_case (\<lambda>g l. st (g(r\<mapsto>obj)) l)"
schirmer@12854
   321
schirmer@12854
   322
  lupd       :: "lname \<Rightarrow> val \<Rightarrow> st \<Rightarrow> st"        ("lupd'(_\<mapsto>_')"[10,10]1000)
schirmer@12854
   323
 "lupd vn v   \<equiv> st_case (\<lambda>g l. st g (l(vn\<mapsto>v)))"
schirmer@12854
   324
schirmer@12854
   325
  upd_gobj   :: "oref \<Rightarrow> vn \<Rightarrow> val \<Rightarrow> st \<Rightarrow> st" 
schirmer@12854
   326
 "upd_gobj r n v \<equiv> st_case (\<lambda>g l. st (chg_map (upd_obj n v) r g) l)"
schirmer@12854
   327
schirmer@12854
   328
  set_locals  :: "locals \<Rightarrow> st \<Rightarrow> st"
schirmer@12854
   329
 "set_locals l \<equiv> st_case (\<lambda>g l'. st g l)"
schirmer@12854
   330
  
schirmer@12854
   331
  init_obj    :: "prog \<Rightarrow> obj_tag \<Rightarrow> oref \<Rightarrow> st \<Rightarrow> st"
schirmer@12854
   332
 "init_obj G oi r \<equiv> gupd(r\<mapsto>\<lparr>tag=oi, values=init_vals (var_tys G oi r)\<rparr>)"
schirmer@12854
   333
schirmer@12854
   334
syntax
schirmer@12854
   335
  init_class_obj :: "prog \<Rightarrow> qtname \<Rightarrow> st \<Rightarrow> st"
schirmer@12854
   336
schirmer@12854
   337
translations
schirmer@12854
   338
 "init_class_obj G C" == "init_obj G arbitrary (Inr C)"
schirmer@12854
   339
schirmer@12854
   340
lemma gupd_def2 [simp]: "gupd(r\<mapsto>obj) (st g l) = st (g(r\<mapsto>obj)) l"
schirmer@12854
   341
apply (unfold gupd_def)
schirmer@12854
   342
apply (simp (no_asm))
schirmer@12854
   343
done
schirmer@12854
   344
schirmer@12854
   345
lemma lupd_def2 [simp]: "lupd(vn\<mapsto>v) (st g l) = st g (l(vn\<mapsto>v))"
schirmer@12854
   346
apply (unfold lupd_def)
schirmer@12854
   347
apply (simp (no_asm))
schirmer@12854
   348
done
schirmer@12854
   349
schirmer@12854
   350
lemma globs_gupd [simp]: "globs  (gupd(r\<mapsto>obj) s) = globs s(r\<mapsto>obj)"
schirmer@12854
   351
apply (induct "s")
schirmer@12854
   352
by (simp add: gupd_def)
schirmer@12854
   353
schirmer@12854
   354
lemma globs_lupd [simp]: "globs  (lupd(vn\<mapsto>v ) s) = globs  s"
schirmer@12854
   355
apply (induct "s")
schirmer@12854
   356
by (simp add: lupd_def)
schirmer@12854
   357
schirmer@12854
   358
lemma locals_gupd [simp]: "locals (gupd(r\<mapsto>obj) s) = locals s"
schirmer@12854
   359
apply (induct "s")
schirmer@12854
   360
by (simp add: gupd_def)
schirmer@12854
   361
schirmer@12854
   362
lemma locals_lupd [simp]: "locals (lupd(vn\<mapsto>v ) s) = locals s(vn\<mapsto>v )"
schirmer@12854
   363
apply (induct "s")
schirmer@12854
   364
by (simp add: lupd_def)
schirmer@12854
   365
schirmer@12854
   366
lemma globs_upd_gobj_new [rule_format (no_asm), simp]: 
schirmer@12854
   367
  "globs s r = None \<longrightarrow> globs (upd_gobj r n v s) = globs s"
schirmer@12854
   368
apply (unfold upd_gobj_def)
schirmer@12854
   369
apply (induct "s")
schirmer@12854
   370
apply auto
schirmer@12854
   371
done
schirmer@12854
   372
schirmer@12854
   373
lemma globs_upd_gobj_upd [rule_format (no_asm), simp]: 
schirmer@12854
   374
"globs s r=Some obj\<longrightarrow> globs (upd_gobj r n v s) = globs s(r\<mapsto>upd_obj n v obj)"
schirmer@12854
   375
apply (unfold upd_gobj_def)
schirmer@12854
   376
apply (induct "s")
schirmer@12854
   377
apply auto
schirmer@12854
   378
done
schirmer@12854
   379
schirmer@12854
   380
lemma locals_upd_gobj [simp]: "locals (upd_gobj r n v s) = locals s"
schirmer@12854
   381
apply (induct "s")
schirmer@12854
   382
by (simp add: upd_gobj_def) 
schirmer@12854
   383
schirmer@12854
   384
schirmer@12854
   385
lemma globs_init_obj [simp]: "globs (init_obj G oi r s) t =  
schirmer@12854
   386
  (if t=r then Some \<lparr>tag=oi,values=init_vals (var_tys G oi r)\<rparr> else globs s t)"
schirmer@12854
   387
apply (unfold init_obj_def)
schirmer@12854
   388
apply (simp (no_asm))
schirmer@12854
   389
done
schirmer@12854
   390
schirmer@12854
   391
lemma locals_init_obj [simp]: "locals (init_obj G oi r s) = locals s"
schirmer@12854
   392
by (simp add: init_obj_def)
schirmer@12854
   393
  
schirmer@12854
   394
lemma surjective_st [simp]: "st (globs s) (locals s) = s"
schirmer@12854
   395
apply (induct "s")
schirmer@12854
   396
by auto
schirmer@12854
   397
schirmer@12854
   398
lemma surjective_st_init_obj: 
schirmer@12854
   399
 "st (globs (init_obj G oi r s)) (locals s) = init_obj G oi r s"
schirmer@12854
   400
apply (subst locals_init_obj [THEN sym])
schirmer@12854
   401
apply (rule surjective_st)
schirmer@12854
   402
done
schirmer@12854
   403
schirmer@12854
   404
lemma heap_heap_upd [simp]: 
schirmer@12854
   405
  "heap (st (g(Inl a\<mapsto>obj)) l) = heap (st g l)(a\<mapsto>obj)"
schirmer@12854
   406
apply (rule ext)
schirmer@12854
   407
apply (simp (no_asm))
schirmer@12854
   408
done
schirmer@12854
   409
lemma heap_stat_upd [simp]: "heap (st (g(Inr C\<mapsto>obj)) l) = heap (st g l)"
schirmer@12854
   410
apply (rule ext)
schirmer@12854
   411
apply (simp (no_asm))
schirmer@12854
   412
done
schirmer@12854
   413
lemma heap_local_upd [simp]: "heap (st g (l(vn\<mapsto>v))) = heap (st g l)"
schirmer@12854
   414
apply (rule ext)
schirmer@12854
   415
apply (simp (no_asm))
schirmer@12854
   416
done
schirmer@12854
   417
schirmer@12854
   418
lemma heap_gupd_Heap [simp]: "heap (gupd(Heap a\<mapsto>obj) s) = heap s(a\<mapsto>obj)"
schirmer@12854
   419
apply (rule ext)
schirmer@12854
   420
apply (simp (no_asm))
schirmer@12854
   421
done
schirmer@12854
   422
lemma heap_gupd_Stat [simp]: "heap (gupd(Stat C\<mapsto>obj) s) = heap s"
schirmer@12854
   423
apply (rule ext)
schirmer@12854
   424
apply (simp (no_asm))
schirmer@12854
   425
done
schirmer@12854
   426
lemma heap_lupd [simp]: "heap (lupd(vn\<mapsto>v) s) = heap s"
schirmer@12854
   427
apply (rule ext)
schirmer@12854
   428
apply (simp (no_asm))
schirmer@12854
   429
done
schirmer@12854
   430
schirmer@12854
   431
lemma heap_upd_gobj_Stat [simp]: "heap (upd_gobj (Stat C) n v s) = heap s"
schirmer@12854
   432
apply (rule ext)
schirmer@12854
   433
apply (simp (no_asm))
schirmer@12854
   434
apply (case_tac "globs s (Stat C)")
schirmer@12854
   435
apply  auto
schirmer@12854
   436
done
schirmer@12854
   437
schirmer@12854
   438
lemma set_locals_def2 [simp]: "set_locals l (st g l') = st g l"
schirmer@12854
   439
apply (unfold set_locals_def)
schirmer@12854
   440
apply (simp (no_asm))
schirmer@12854
   441
done
schirmer@12854
   442
schirmer@12854
   443
lemma set_locals_id [simp]: "set_locals (locals s) s = s"
schirmer@12854
   444
apply (unfold set_locals_def)
schirmer@12854
   445
apply (induct_tac "s")
schirmer@12854
   446
apply (simp (no_asm))
schirmer@12854
   447
done
schirmer@12854
   448
schirmer@12854
   449
lemma set_set_locals [simp]: "set_locals l (set_locals l' s) = set_locals l s"
schirmer@12854
   450
apply (unfold set_locals_def)
schirmer@12854
   451
apply (induct_tac "s")
schirmer@12854
   452
apply (simp (no_asm))
schirmer@12854
   453
done
schirmer@12854
   454
schirmer@12854
   455
lemma locals_set_locals [simp]: "locals (set_locals l s) = l"
schirmer@12854
   456
apply (unfold set_locals_def)
schirmer@12854
   457
apply (induct_tac "s")
schirmer@12854
   458
apply (simp (no_asm))
schirmer@12854
   459
done
schirmer@12854
   460
schirmer@12854
   461
lemma globs_set_locals [simp]: "globs (set_locals l s) = globs s"
schirmer@12854
   462
apply (unfold set_locals_def)
schirmer@12854
   463
apply (induct_tac "s")
schirmer@12854
   464
apply (simp (no_asm))
schirmer@12854
   465
done
schirmer@12854
   466
schirmer@12854
   467
lemma heap_set_locals [simp]: "heap (set_locals l s) = heap s"
schirmer@12854
   468
apply (unfold heap_def)
schirmer@12854
   469
apply (induct_tac "s")
schirmer@12854
   470
apply (simp (no_asm))
schirmer@12854
   471
done
schirmer@12854
   472
schirmer@12854
   473
schirmer@12854
   474
section "abrupt completion"
schirmer@12854
   475
schirmer@12854
   476
schirmer@12854
   477
schirmer@12854
   478
consts
schirmer@12854
   479
schirmer@12854
   480
  the_Xcpt :: "abrupt \<Rightarrow> xcpt"
schirmer@12854
   481
  the_Jump :: "abrupt => jump"
schirmer@12854
   482
  the_Loc  :: "xcpt \<Rightarrow> loc"
schirmer@12854
   483
  the_Std  :: "xcpt \<Rightarrow> xname"
schirmer@12854
   484
schirmer@12854
   485
primrec "the_Xcpt (Xcpt x) = x"
schirmer@12854
   486
primrec "the_Jump (Jump j) = j"
schirmer@12854
   487
primrec "the_Loc (Loc a) = a"
schirmer@12854
   488
primrec "the_Std (Std x) = x"
schirmer@12854
   489
schirmer@13337
   490
schirmer@12854
   491
	
schirmer@12854
   492
schirmer@12854
   493
constdefs
schirmer@12854
   494
  abrupt_if    :: "bool \<Rightarrow> abopt \<Rightarrow> abopt \<Rightarrow> abopt"
schirmer@12854
   495
 "abrupt_if c x' x \<equiv> if c \<and> (x = None) then x' else x"
schirmer@12854
   496
schirmer@12854
   497
lemma abrupt_if_True_None [simp]: "abrupt_if True x None = x"
schirmer@12854
   498
by (simp add: abrupt_if_def)
schirmer@12854
   499
schirmer@12854
   500
lemma abrupt_if_True_not_None [simp]: "x \<noteq> None \<Longrightarrow> abrupt_if True x y \<noteq> None"
schirmer@12854
   501
by (simp add: abrupt_if_def)
schirmer@12854
   502
schirmer@12854
   503
lemma abrupt_if_False [simp]: "abrupt_if False x y = y"
schirmer@12854
   504
by (simp add: abrupt_if_def)
schirmer@12854
   505
schirmer@12854
   506
lemma abrupt_if_Some [simp]: "abrupt_if c x (Some y) = Some y"
schirmer@12854
   507
by (simp add: abrupt_if_def)
schirmer@12854
   508
schirmer@12854
   509
lemma abrupt_if_not_None [simp]: "y \<noteq> None \<Longrightarrow> abrupt_if c x y = y"
schirmer@12854
   510
apply (simp add: abrupt_if_def)
schirmer@12854
   511
by auto
schirmer@12854
   512
schirmer@12854
   513
schirmer@12854
   514
lemma split_abrupt_if: 
schirmer@12854
   515
"P (abrupt_if c x' x) = 
schirmer@12854
   516
      ((c \<and> x = None \<longrightarrow> P x') \<and> (\<not> (c \<and> x = None) \<longrightarrow> P x))"
schirmer@12854
   517
apply (unfold abrupt_if_def)
schirmer@12854
   518
apply (split split_if)
schirmer@12854
   519
apply auto
schirmer@12854
   520
done
schirmer@12854
   521
schirmer@12854
   522
syntax
schirmer@12854
   523
schirmer@12854
   524
  raise_if :: "bool \<Rightarrow> xname \<Rightarrow> abopt \<Rightarrow> abopt"
schirmer@12854
   525
  np       :: "val  \<spacespace>        \<Rightarrow> abopt \<Rightarrow> abopt"
schirmer@12854
   526
  check_neg:: "val  \<spacespace>        \<Rightarrow> abopt \<Rightarrow> abopt"
schirmer@12925
   527
  error_if :: "bool \<Rightarrow> error \<Rightarrow> abopt \<Rightarrow> abopt"
schirmer@12854
   528
  
schirmer@12854
   529
translations
schirmer@12854
   530
schirmer@12854
   531
 "raise_if c xn" == "abrupt_if c (Some (Xcpt (Std xn)))"
schirmer@12854
   532
 "np v"          == "raise_if (v = Null)      NullPointer"
schirmer@12854
   533
 "check_neg i'"  == "raise_if (the_Intg i'<0) NegArrSize"
schirmer@12925
   534
 "error_if c e"  == "abrupt_if c (Some (Error e))"
schirmer@12854
   535
schirmer@12854
   536
lemma raise_if_None [simp]: "(raise_if c x y = None) = (\<not>c \<and> y = None)"
schirmer@12854
   537
apply (simp add: abrupt_if_def)
schirmer@12854
   538
by auto
schirmer@12854
   539
declare raise_if_None [THEN iffD1, dest!]
schirmer@12854
   540
schirmer@12854
   541
lemma if_raise_if_None [simp]: 
schirmer@12854
   542
  "((if b then y else raise_if c x y) = None) = ((c \<longrightarrow> b) \<and> y = None)"
schirmer@12854
   543
apply (simp add: abrupt_if_def)
schirmer@12854
   544
apply auto
schirmer@12854
   545
done
schirmer@12854
   546
schirmer@12854
   547
lemma raise_if_SomeD [dest!]:
schirmer@12854
   548
  "raise_if c x y = Some z \<Longrightarrow> c \<and> z=(Xcpt (Std x)) \<and> y=None \<or> (y=Some z)"
schirmer@12854
   549
apply (case_tac y)
schirmer@12854
   550
apply (case_tac c)
schirmer@12854
   551
apply (simp add: abrupt_if_def)
schirmer@12854
   552
apply (simp add: abrupt_if_def)
schirmer@12854
   553
apply auto
schirmer@12854
   554
done
schirmer@12854
   555
schirmer@12925
   556
lemma error_if_None [simp]: "(error_if c e y = None) = (\<not>c \<and> y = None)"
schirmer@12925
   557
apply (simp add: abrupt_if_def)
schirmer@12925
   558
by auto
schirmer@12925
   559
declare error_if_None [THEN iffD1, dest!]
schirmer@12925
   560
schirmer@12925
   561
lemma if_error_if_None [simp]: 
schirmer@12925
   562
  "((if b then y else error_if c e y) = None) = ((c \<longrightarrow> b) \<and> y = None)"
schirmer@12925
   563
apply (simp add: abrupt_if_def)
schirmer@12925
   564
apply auto
schirmer@12925
   565
done
schirmer@12925
   566
wenzelm@13524
   567
lemma error_if_SomeD [dest!]:
schirmer@12925
   568
  "error_if c e y = Some z \<Longrightarrow> c \<and> z=(Error e) \<and> y=None \<or> (y=Some z)"
schirmer@12925
   569
apply (case_tac y)
schirmer@12925
   570
apply (case_tac c)
schirmer@12925
   571
apply (simp add: abrupt_if_def)
schirmer@12925
   572
apply (simp add: abrupt_if_def)
schirmer@12925
   573
apply auto
schirmer@12925
   574
done
schirmer@12925
   575
schirmer@12854
   576
constdefs
schirmer@12854
   577
   absorb :: "jump \<Rightarrow> abopt \<Rightarrow> abopt"
schirmer@12854
   578
  "absorb j a \<equiv> if a=Some (Jump j) then None else a"
schirmer@12854
   579
schirmer@12854
   580
lemma absorb_SomeD [dest!]: "absorb j a = Some x \<Longrightarrow> a = Some x"
schirmer@12854
   581
by (auto simp add: absorb_def)
schirmer@12854
   582
schirmer@12854
   583
lemma absorb_same [simp]: "absorb j (Some (Jump j)) = None"
schirmer@12854
   584
by (auto simp add: absorb_def)
schirmer@12854
   585
schirmer@12854
   586
lemma absorb_other [simp]: "a \<noteq> Some (Jump j) \<Longrightarrow> absorb j a = a"
schirmer@12854
   587
by (auto simp add: absorb_def)
schirmer@12854
   588
schirmer@13688
   589
lemma absorb_Some_NoneD: "absorb j (Some abr) = None \<Longrightarrow> abr = Jump j"
schirmer@13688
   590
  by (simp add: absorb_def)
schirmer@13688
   591
schirmer@13688
   592
lemma absorb_Some_JumpD: "absorb j s = Some (Jump j') \<Longrightarrow> j'\<noteq>j"
schirmer@13688
   593
  by (simp add: absorb_def)
schirmer@13688
   594
schirmer@12854
   595
schirmer@12854
   596
section "full program state"
schirmer@12854
   597
schirmer@12854
   598
types
schirmer@13688
   599
  state = "abopt \<times> st"          --{* state including abruption information *}
schirmer@12854
   600
schirmer@12854
   601
syntax 
schirmer@12854
   602
  Norm   :: "st \<Rightarrow> state"
schirmer@12854
   603
  abrupt :: "state \<Rightarrow> abopt"
schirmer@12854
   604
  store  :: "state \<Rightarrow> st"
schirmer@12854
   605
schirmer@12854
   606
translations
schirmer@12854
   607
   
schirmer@12854
   608
  "Norm s"     == "(None,s)" 
schirmer@12854
   609
  "abrupt"     => "fst"
schirmer@12854
   610
  "store"      => "snd"
schirmer@12854
   611
  "abopt"       <= (type) "State.abrupt option"
schirmer@12854
   612
  "abopt"       <= (type) "abrupt option"
schirmer@12854
   613
  "state"      <= (type) "abopt \<times> State.st"
schirmer@12854
   614
  "state"      <= (type) "abopt \<times> st"
schirmer@12854
   615
schirmer@12854
   616
schirmer@12854
   617
schirmer@12854
   618
lemma single_stateE: "\<forall>Z. Z = (s::state) \<Longrightarrow> False"
schirmer@12854
   619
apply (erule_tac x = "(Some k,y)" in all_dupE)
schirmer@12854
   620
apply (erule_tac x = "(None,y)" in allE)
schirmer@12854
   621
apply clarify
schirmer@12854
   622
done
schirmer@12854
   623
schirmer@12854
   624
lemma state_not_single: "All (op = (x::state)) \<Longrightarrow> R"
schirmer@12854
   625
apply (drule_tac x = "(if abrupt x = None then Some ?x else None,?y)" in spec)
schirmer@12854
   626
apply clarsimp
schirmer@12854
   627
done
schirmer@12854
   628
schirmer@12854
   629
constdefs
schirmer@12854
   630
schirmer@12854
   631
  normal     :: "state \<Rightarrow> bool"
schirmer@12854
   632
 "normal \<equiv> \<lambda>s. abrupt s = None"
schirmer@12854
   633
schirmer@12854
   634
lemma normal_def2 [simp]: "normal s = (abrupt s = None)"
schirmer@12854
   635
apply (unfold normal_def)
schirmer@12854
   636
apply (simp (no_asm))
schirmer@12854
   637
done
schirmer@12854
   638
schirmer@12854
   639
constdefs
schirmer@12854
   640
  heap_free :: "nat \<Rightarrow> state \<Rightarrow> bool"
schirmer@12854
   641
 "heap_free n \<equiv> \<lambda>s. atleast_free (heap (store s)) n"
schirmer@12854
   642
schirmer@12854
   643
lemma heap_free_def2 [simp]: "heap_free n s = atleast_free (heap (store s)) n"
schirmer@12854
   644
apply (unfold heap_free_def)
schirmer@12854
   645
apply simp
schirmer@12854
   646
done
schirmer@12854
   647
schirmer@12854
   648
subsection "update"
schirmer@12854
   649
schirmer@12854
   650
constdefs
schirmer@12854
   651
 
schirmer@12854
   652
  abupd     :: "(abopt \<Rightarrow> abopt) \<Rightarrow> state \<Rightarrow> state"
schirmer@12854
   653
 "abupd f \<equiv> prod_fun f id"
schirmer@12854
   654
schirmer@12854
   655
  supd     :: "(st \<Rightarrow> st) \<Rightarrow> state \<Rightarrow> state" 
schirmer@12854
   656
 "supd \<equiv> prod_fun id"
schirmer@12854
   657
  
schirmer@12854
   658
lemma abupd_def2 [simp]: "abupd f (x,s) = (f x,s)"
schirmer@12854
   659
by (simp add: abupd_def)
schirmer@12854
   660
schirmer@12854
   661
lemma abupd_abrupt_if_False [simp]: "\<And> s. abupd (abrupt_if False xo) s = s"
schirmer@12854
   662
by simp
schirmer@12854
   663
schirmer@12854
   664
lemma supd_def2 [simp]: "supd f (x,s) = (x,f s)"
schirmer@12854
   665
by (simp add: supd_def)
schirmer@12854
   666
schirmer@12854
   667
lemma supd_lupd [simp]: 
schirmer@12854
   668
 "\<And> s. supd (lupd vn v ) s = (abrupt s,lupd vn v (store s))"
schirmer@12854
   669
apply (simp (no_asm_simp) only: split_tupled_all)
schirmer@12854
   670
apply (simp (no_asm))
schirmer@12854
   671
done
schirmer@12854
   672
schirmer@12854
   673
schirmer@12854
   674
lemma supd_gupd [simp]: 
schirmer@12854
   675
 "\<And> s. supd (gupd r obj) s = (abrupt s,gupd r obj (store s))"
schirmer@12854
   676
apply (simp (no_asm_simp) only: split_tupled_all)
schirmer@12854
   677
apply (simp (no_asm))
schirmer@12854
   678
done
schirmer@12854
   679
schirmer@12854
   680
lemma supd_init_obj [simp]: 
schirmer@12854
   681
 "supd (init_obj G oi r) s = (abrupt s,init_obj G oi r (store s))"
schirmer@12854
   682
apply (unfold init_obj_def)
schirmer@12854
   683
apply (simp (no_asm))
schirmer@12854
   684
done
schirmer@12854
   685
schirmer@13688
   686
lemma abupd_store_invariant [simp]: "store (abupd f s) = store s"
schirmer@13688
   687
  by (cases s) simp
schirmer@13688
   688
schirmer@13688
   689
lemma supd_abrupt_invariant [simp]: "abrupt (supd f s) = abrupt s"
schirmer@13688
   690
  by (cases s) simp
schirmer@13688
   691
schirmer@12854
   692
syntax
schirmer@12854
   693
schirmer@12854
   694
  set_lvars     :: "locals \<Rightarrow> state \<Rightarrow> state"
schirmer@12854
   695
  restore_lvars :: "state  \<Rightarrow> state \<Rightarrow> state"
schirmer@12854
   696
  
schirmer@12854
   697
translations
schirmer@12854
   698
schirmer@12854
   699
 "set_lvars l" == "supd (set_locals l)"
schirmer@12854
   700
 "restore_lvars s' s" == "set_lvars (locals (store s')) s"
schirmer@12854
   701
schirmer@12854
   702
lemma set_set_lvars [simp]: "\<And> s. set_lvars l (set_lvars l' s) = set_lvars l s"
schirmer@12854
   703
apply (simp (no_asm_simp) only: split_tupled_all)
schirmer@12854
   704
apply (simp (no_asm))
schirmer@12854
   705
done
schirmer@12854
   706
schirmer@12854
   707
lemma set_lvars_id [simp]: "\<And> s. set_lvars (locals (store s)) s = s"
schirmer@12854
   708
apply (simp (no_asm_simp) only: split_tupled_all)
schirmer@12854
   709
apply (simp (no_asm))
schirmer@12854
   710
done
schirmer@12854
   711
schirmer@12854
   712
section "initialisation test"
schirmer@12854
   713
schirmer@12854
   714
constdefs
schirmer@12854
   715
schirmer@12854
   716
  inited   :: "qtname \<Rightarrow> globs \<Rightarrow> bool"
schirmer@12854
   717
 "inited C g \<equiv> g (Stat C) \<noteq> None"
schirmer@12854
   718
schirmer@12854
   719
  initd    :: "qtname \<Rightarrow> state \<Rightarrow> bool"
schirmer@12854
   720
 "initd C \<equiv> inited C \<circ> globs \<circ> store"
schirmer@12854
   721
schirmer@12854
   722
lemma not_inited_empty [simp]: "\<not>inited C empty"
schirmer@12854
   723
apply (unfold inited_def)
schirmer@12854
   724
apply (simp (no_asm))
schirmer@12854
   725
done
schirmer@12854
   726
schirmer@12854
   727
lemma inited_gupdate [simp]: "inited C (g(r\<mapsto>obj)) = (inited C g \<or> r = Stat C)"
schirmer@12854
   728
apply (unfold inited_def)
schirmer@12854
   729
apply (auto split add: st.split)
schirmer@12854
   730
done
schirmer@12854
   731
schirmer@12854
   732
lemma inited_init_class_obj [intro!]: "inited C (globs (init_class_obj G C s))"
schirmer@12854
   733
apply (unfold inited_def)
schirmer@12854
   734
apply (simp (no_asm))
schirmer@12854
   735
done
schirmer@12854
   736
schirmer@12854
   737
lemma not_initedD: "\<not> inited C g \<Longrightarrow> g (Stat C) = None"
schirmer@12854
   738
apply (unfold inited_def)
schirmer@12854
   739
apply (erule notnotD)
schirmer@12854
   740
done
schirmer@12854
   741
schirmer@12854
   742
lemma initedD: "inited C g \<Longrightarrow> \<exists> obj. g (Stat C) = Some obj"
schirmer@12854
   743
apply (unfold inited_def)
schirmer@12854
   744
apply auto
schirmer@12854
   745
done
schirmer@12854
   746
schirmer@12854
   747
lemma initd_def2 [simp]: "initd C s = inited C (globs (store s))"
schirmer@12854
   748
apply (unfold initd_def)
schirmer@12854
   749
apply (simp (no_asm))
schirmer@12854
   750
done
schirmer@12854
   751
schirmer@12925
   752
section {* @{text error_free} *}
schirmer@12925
   753
constdefs error_free:: "state \<Rightarrow> bool"
schirmer@12925
   754
"error_free s \<equiv> \<not> (\<exists> err. abrupt s = Some (Error err))"
schirmer@12854
   755
schirmer@12925
   756
lemma error_free_Norm [simp,intro]: "error_free (Norm s)"
schirmer@12925
   757
by (simp add: error_free_def)
schirmer@12925
   758
schirmer@12925
   759
lemma error_free_normal [simp,intro]: "normal s \<Longrightarrow> error_free s"
schirmer@12925
   760
by (simp add: error_free_def)
schirmer@12925
   761
schirmer@12925
   762
lemma error_free_Xcpt [simp]: "error_free (Some (Xcpt x),s)"
schirmer@12925
   763
by (simp add: error_free_def)
schirmer@12925
   764
schirmer@12925
   765
lemma error_free_Jump [simp,intro]: "error_free (Some (Jump j),s)"
schirmer@12925
   766
by (simp add: error_free_def)
schirmer@12925
   767
schirmer@12925
   768
lemma error_free_Error [simp]: "error_free (Some (Error e),s) = False"
schirmer@12925
   769
by (simp add: error_free_def)  
schirmer@12925
   770
schirmer@12925
   771
lemma error_free_Some [simp,intro]: 
schirmer@12925
   772
 "\<not> (\<exists> err. x=Error err) \<Longrightarrow> error_free ((Some x),s)"
schirmer@12925
   773
by (auto simp add: error_free_def)
schirmer@12925
   774
wenzelm@13524
   775
lemma error_free_abupd_absorb [simp,intro]: 
schirmer@12925
   776
 "error_free s \<Longrightarrow> error_free (abupd (absorb j) s)"
schirmer@12925
   777
by (cases s) 
schirmer@12925
   778
   (auto simp add: error_free_def absorb_def
schirmer@12925
   779
         split: split_if_asm)
schirmer@12925
   780
schirmer@12925
   781
lemma error_free_absorb [simp,intro]: 
schirmer@12925
   782
 "error_free (a,s) \<Longrightarrow> error_free (absorb j a, s)"
schirmer@12925
   783
by (auto simp add: error_free_def absorb_def
schirmer@12925
   784
            split: split_if_asm)
schirmer@12925
   785
schirmer@12925
   786
lemma error_free_abrupt_if [simp,intro]:
schirmer@12925
   787
"\<lbrakk>error_free s; \<not> (\<exists> err. x=Error err)\<rbrakk>
schirmer@12925
   788
 \<Longrightarrow> error_free (abupd (abrupt_if p (Some x)) s)"
schirmer@12925
   789
by (cases s)
schirmer@12925
   790
   (auto simp add: abrupt_if_def
schirmer@12925
   791
            split: split_if)
schirmer@12925
   792
schirmer@12925
   793
lemma error_free_abrupt_if1 [simp,intro]:
schirmer@12925
   794
"\<lbrakk>error_free (a,s); \<not> (\<exists> err. x=Error err)\<rbrakk>
schirmer@12925
   795
 \<Longrightarrow> error_free (abrupt_if p (Some x) a, s)"
schirmer@12925
   796
by  (auto simp add: abrupt_if_def
schirmer@12925
   797
            split: split_if)
schirmer@12925
   798
schirmer@12925
   799
lemma error_free_abrupt_if_Xcpt [simp,intro]:
schirmer@12925
   800
 "error_free s 
schirmer@12925
   801
  \<Longrightarrow> error_free (abupd (abrupt_if p (Some (Xcpt x))) s)"
schirmer@12925
   802
by simp 
schirmer@12925
   803
schirmer@12925
   804
lemma error_free_abrupt_if_Xcpt1 [simp,intro]:
schirmer@12925
   805
 "error_free (a,s) 
schirmer@12925
   806
  \<Longrightarrow> error_free (abrupt_if p (Some (Xcpt x)) a, s)" 
schirmer@12925
   807
by simp 
schirmer@12925
   808
schirmer@12925
   809
lemma error_free_abrupt_if_Jump [simp,intro]:
schirmer@12925
   810
 "error_free s 
schirmer@12925
   811
  \<Longrightarrow> error_free (abupd (abrupt_if p (Some (Jump j))) s)" 
schirmer@12925
   812
by simp
schirmer@12925
   813
schirmer@12925
   814
lemma error_free_abrupt_if_Jump1 [simp,intro]:
schirmer@12925
   815
 "error_free (a,s) 
schirmer@12925
   816
  \<Longrightarrow> error_free (abrupt_if p (Some (Jump j)) a, s)" 
schirmer@12925
   817
by simp
schirmer@12925
   818
schirmer@12925
   819
lemma error_free_raise_if [simp,intro]:
schirmer@12925
   820
 "error_free s \<Longrightarrow> error_free (abupd (raise_if p x) s)"
schirmer@12925
   821
by simp 
schirmer@12925
   822
schirmer@12925
   823
lemma error_free_raise_if1 [simp,intro]:
schirmer@12925
   824
 "error_free (a,s) \<Longrightarrow> error_free ((raise_if p x a), s)"
schirmer@12925
   825
by simp 
schirmer@12925
   826
schirmer@12925
   827
lemma error_free_supd [simp,intro]:
schirmer@12925
   828
 "error_free s \<Longrightarrow> error_free (supd f s)"
schirmer@12925
   829
by (cases s) (simp add: error_free_def)
schirmer@12925
   830
schirmer@12925
   831
lemma error_free_supd1 [simp,intro]:
schirmer@12925
   832
 "error_free (a,s) \<Longrightarrow> error_free (a,f s)"
schirmer@12925
   833
by (simp add: error_free_def)
schirmer@12925
   834
schirmer@12925
   835
lemma error_free_set_lvars [simp,intro]:
schirmer@12925
   836
"error_free s \<Longrightarrow> error_free ((set_lvars l) s)"
schirmer@12925
   837
by (cases s) simp
schirmer@12925
   838
schirmer@12925
   839
lemma error_free_set_locals [simp,intro]: 
schirmer@12925
   840
"error_free (x, s)
schirmer@12925
   841
       \<Longrightarrow> error_free (x, set_locals l s')"
schirmer@12925
   842
by (simp add: error_free_def)
schirmer@12854
   843
schirmer@13688
   844
schirmer@12854
   845
end
schirmer@12854
   846