src/HOL/MicroJava/J/JTypeSafe.ML
author oheimb
Mon, 03 Jan 2000 14:07:08 +0100
changeset 8082 381716a86fcb
parent 8034 6fc37b5c5e98
child 8085 dce06445aafd
permissions -rw-r--r--
removed inj_eq from the default simpset again
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
8011
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
     1
(*  Title:      HOL/MicroJava/J/JTypeSafe.ML
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
     2
    ID:         $Id$
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
     3
    Author:     David von Oheimb
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
     4
    Copyright   1999 Technische Universitaet Muenchen
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
     5
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
     6
Type safety proof
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
     7
*)
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
     8
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
     9
Addsimps [split_beta];
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    10
8082
381716a86fcb removed inj_eq from the default simpset again
oheimb
parents: 8034
diff changeset
    11
Goal "\\<lbrakk>h a = None; (h, l)\\<Colon>\\<preceq>(G, lT); wf_prog wf_mb G; is_class G C\\<rbrakk> \\<Longrightarrow> \
8011
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    12
\ (h(a\\<mapsto>(C,(init_vars (fields (G,C))))), l)\\<Colon>\\<preceq>(G, lT)";
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    13
by( etac conforms_upd_obj 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    14
by(  rewtac oconf_def);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    15
by(  auto_tac (claset() addSDs [is_type_fields, map_of_SomeD], simpset()));
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    16
qed "NewC_conforms";
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    17
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    18
Goalw [cast_ok_def]
8082
381716a86fcb removed inj_eq from the default simpset again
oheimb
parents: 8034
diff changeset
    19
 "\\<lbrakk> wf_prog wf_mb G; G,h\\<turnstile>v\\<Colon>\\<preceq>Tb; G\\<turnstile>Tb\\<Rightarrow>? T'; cast_ok G T' h v\\<rbrakk> \
8011
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    20
\ \\<Longrightarrow> G,h\\<turnstile>v\\<Colon>\\<preceq>T'";
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    21
by( case_tac1 "v = Null" 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    22
by(  Asm_full_simp_tac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    23
by(  dtac widen_RefT 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    24
by(  Clarify_tac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    25
by(  forward_tac [cast_RefT] 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    26
by(  Clarify_tac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    27
by(  rtac widen.null 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    28
by( case_tac1 "\\<exists>pt. T' = PrimT pt" 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    29
by(  strip_tac1 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    30
by(  dtac cast_PrimT2 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    31
by(  etac conf_widen 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    32
by(   atac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    33
by(  atac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    34
by( Asm_full_simp_tac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    35
by( dtac (non_PrimT RS iffD1) 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    36
by( strip_tac1 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    37
by( forward_tac [cast_RefT2] 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    38
by( strip_tac1 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    39
by( dtac non_npD 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    40
by(  atac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    41
by( rewrite_goals_tac [the_Addr_def,obj_ty_def]);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    42
by Auto_tac ;
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    43
by(  ALLGOALS (rtac conf_AddrI));
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    44
by     Auto_tac;
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    45
qed "Cast_conf";
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    46
8082
381716a86fcb removed inj_eq from the default simpset again
oheimb
parents: 8034
diff changeset
    47
Goal "\\<lbrakk> wf_prog wf_mb G; field (G,C) fn = Some (fd, ft); (h,l)\\<Colon>\\<preceq>(G,lT); \
8011
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    48
\    x' = None \\<longrightarrow> G,h\\<turnstile>a'\\<Colon>\\<preceq>Class C; np a' x' = None \\<rbrakk> \\<Longrightarrow> \
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    49
\ G,h\\<turnstile>the (snd (the (h (the_Addr a'))) (fn, fd))\\<Colon>\\<preceq>ft";
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    50
by( dtac np_NoneD 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    51
by( etac conjE 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    52
by( mp_tac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    53
by( dtac non_np_objD 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    54
by   Auto_tac;
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    55
by( dtac (conforms_heapD RS hconfD) 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    56
by(  atac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    57
by( dtac widen_cfs_fields 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    58
by(   atac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    59
by(  atac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    60
by( dtac oconf_objD 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    61
by(  atac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    62
by Auto_tac;
8082
381716a86fcb removed inj_eq from the default simpset again
oheimb
parents: 8034
diff changeset
    63
qed "FAcc_type_sound";
8011
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    64
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    65
Goal
8082
381716a86fcb removed inj_eq from the default simpset again
oheimb
parents: 8034
diff changeset
    66
 "\\<lbrakk> wf_prog wf_mb G; a = the_Addr a'; (c, fs) = the (h a); \
8011
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    67
\   (G, lT)\\<turnstile>v\\<Colon>T'; G\\<turnstile>T'\\<preceq>ft; \
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    68
\   (G, lT)\\<turnstile>aa\\<Colon>Class C; \
8034
6fc37b5c5e98 Various little changes like cmethd -> method and cfield -> field.
nipkow
parents: 8011
diff changeset
    69
\   field (G,C) fn = Some (fd, ft); h''\\<le>|h'; \
8011
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    70
\   x' = None \\<longrightarrow> G,h'\\<turnstile>a'\\<Colon>\\<preceq>Class C; h'\\<le>|h; \
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    71
\   (h, l)\\<Colon>\\<preceq>(G, lT); G,h\\<turnstile>x\\<Colon>\\<preceq>T'; np a' x' = None\\<rbrakk> \\<Longrightarrow> \
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    72
\ h''\\<le>|h(a\\<mapsto>(c,(fs((fn,fd)\\<mapsto>x)))) \\<and>  \
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    73
\ (h(a\\<mapsto>(c,(fs((fn,fd)\\<mapsto>x)))), l)\\<Colon>\\<preceq>(G, lT) \\<and>  \
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    74
\ G,h(a\\<mapsto>(c,(fs((fn,fd)\\<mapsto>x))))\\<turnstile>x\\<Colon>\\<preceq>T'";
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    75
by( dtac np_NoneD 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    76
by( etac conjE 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    77
by( Asm_full_simp_tac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    78
by( dtac non_np_objD 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    79
by(   atac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    80
by(  SELECT_GOAL Auto_tac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    81
by( strip_tac1 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    82
by( Full_simp_tac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    83
by( EVERY [forward_tac [hext_objD] 1, atac 1]);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    84
by( etac exE 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    85
by( Asm_full_simp_tac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    86
by( strip_tac1 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    87
by( rtac conjI 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    88
by(  fast_tac (HOL_cs addEs [hext_trans, hext_upd_obj]) 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    89
by( rtac conjI 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    90
by(  fast_tac (HOL_cs addEs [conf_upd_obj RS iffD2]) 2);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    91
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    92
by( rtac conforms_upd_obj 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    93
by   Auto_tac;
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    94
by(  rtac hextI 2);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    95
by(  Force_tac 2);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    96
by( rtac oconf_hext 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    97
by(  etac hext_upd_obj 2);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    98
by( dtac widen_cfs_fields 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    99
by(   atac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   100
by(  atac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   101
by( rtac (oconf_obj RS iffD2) 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   102
by( Simp_tac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   103
by( strip_tac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   104
by( case_tac1 "(aaa, b) = (fn, fd)" 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   105
by(  Asm_full_simp_tac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   106
by(  fast_tac (HOL_cs addIs [conf_widen]) 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   107
by( fast_tac (HOL_cs addDs [conforms_heapD RS hconfD, oconf_objD]) 1);
8082
381716a86fcb removed inj_eq from the default simpset again
oheimb
parents: 8034
diff changeset
   108
qed "FAss_type_sound";
8011
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   109
8082
381716a86fcb removed inj_eq from the default simpset again
oheimb
parents: 8034
diff changeset
   110
Goalw [wf_mhead_def] "\\<lbrakk> wf_prog wf_mb G; list_all2 (conf G h) pvs pTs; \
8011
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   111
 \ list_all2 (\\<lambda>T T'. G\\<turnstile>T\\<preceq>T') pTs pTs'; wf_mhead G (mn,pTs') rT; \
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   112
\ length pTs' = length pns; nodups pns; \
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   113
\ Ball (set lvars) (split (\\<lambda>vn. is_type G)) \
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   114
\ \\<rbrakk> \\<Longrightarrow> G,h\\<turnstile>init_vars lvars(pns[\\<mapsto>]pvs)[\\<Colon>\\<preceq>]map_of lvars(pns[\\<mapsto>]pTs')";
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   115
by( Clarsimp_tac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   116
by( rtac lconf_ext_list 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   117
by(    rtac (Ball_set_table RS lconf_init_vars) 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   118
by(    Force_tac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   119
by(   atac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   120
by(  atac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   121
by( (etac conf_list_gext_widen THEN_ALL_NEW atac) 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   122
qed "Call_lemma2";
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   123
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   124
Goalw [wf_java_prog_def]
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   125
 "\\<lbrakk> wf_java_prog G; a' \\<noteq> Null; (h, l)\\<Colon>\\<preceq>(G, lT); \
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   126
\    max_spec G T (mn,pTsa) = {((mda,rTa),pTs')}; xc\\<le>|xh; xh\\<le>|h; \
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   127
\    list_all2 (conf G h) pvs pTsa;\
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   128
\    (md, rT, pns, lvars, blk, res) = \
8034
6fc37b5c5e98 Various little changes like cmethd -> method and cfield -> field.
nipkow
parents: 8011
diff changeset
   129
\              the (method (G,fst (the (h (the_Addr a')))) (mn, pTs'));\
8011
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   130
\ \\<forall>lT. (h, init_vars lvars(pns[\\<mapsto>]pvs)(This\\<mapsto>a'))\\<Colon>\\<preceq>(G, lT) \\<longrightarrow> \
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   131
\ (G, lT)\\<turnstile>blk\\<surd> \\<longrightarrow>  h\\<le>|xi \\<and>  (xi, xl)\\<Colon>\\<preceq>(G, lT); \
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   132
\ \\<forall>lT. (xi, xl)\\<Colon>\\<preceq>(G, lT) \\<longrightarrow> (\\<forall>T. (G, lT)\\<turnstile>res\\<Colon>T \\<longrightarrow> \
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   133
\         xi\\<le>|h' \\<and> (h', xj)\\<Colon>\\<preceq>(G, lT) \\<and> (x' = None \\<longrightarrow> G,h'\\<turnstile>v\\<Colon>\\<preceq>T)); \
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   134
\ G,xh\\<turnstile>a'\\<Colon>\\<preceq>RefT T \\<rbrakk> \\<Longrightarrow> \
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   135
\ xc\\<le>|h' \\<and> (h', l)\\<Colon>\\<preceq>(G, lT) \\<and>  (x' = None \\<longrightarrow> G,h'\\<turnstile>v\\<Colon>\\<preceq>rTa)";
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   136
by( dtac (insertI1 RSN (2,(equalityD2 RS subsetD))) 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   137
by( dtac (max_spec2appl_meths RS appl_methsD) 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   138
by( etac conjE 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   139
by( dtac non_np_objD' 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   140
by(    atac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   141
by(   atac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   142
by(  strip_tac1 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   143
by(  Asm_full_simp_tac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   144
by( Clarsimp_tac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   145
by( EVERY'[forward_tac [hext_objD], atac] 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   146
by( Clarsimp_tac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   147
by( EVERY'[dtac Call_lemma, atac, atac] 1);
8082
381716a86fcb removed inj_eq from the default simpset again
oheimb
parents: 8034
diff changeset
   148
by( clarsimp_tac (claset(),simpset() addsimps [wf_java_mdecl_def])1);
8034
6fc37b5c5e98 Various little changes like cmethd -> method and cfield -> field.
nipkow
parents: 8011
diff changeset
   149
by( thin_tac "method ?sig ?x = ?y" 1);
8011
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   150
by( EVERY'[dtac spec, etac impE] 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   151
by(  mp_tac 2);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   152
by(  rtac conformsI 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   153
by(   etac conforms_heapD 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   154
by(  rtac lconf_ext 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   155
by(   force_tac (claset() addSEs [Call_lemma2],simpset()) 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   156
by(  EVERY'[etac conf_hext, etac conf_obj_AddrI, atac] 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   157
by( thin_tac "?E\\<turnstile>?blk\\<surd>" 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   158
by( etac conjE 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   159
by( EVERY'[dtac spec, mp_tac] 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   160
(*by( thin_tac "?E\\<Colon>\\<preceq>(G, pT')" 1);*)
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   161
by( EVERY'[dtac spec, mp_tac] 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   162
by( thin_tac "?E\\<turnstile>res\\<Colon>?rT" 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   163
by( strip_tac1 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   164
by( rtac conjI 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   165
by(  fast_tac (HOL_cs addIs [hext_trans]) 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   166
by( rtac conjI 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   167
by(  rtac impI 2);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   168
by(  mp_tac 2);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   169
by(  forward_tac [conf_widen] 2);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   170
by(    atac 4);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   171
by(   atac 2);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   172
by(  fast_tac (HOL_cs addSEs [widen_trans]) 2);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   173
by( etac conforms_hext 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   174
by(  etac hext_trans 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   175
by(  atac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   176
by( etac conforms_heapD 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   177
qed "Call_type_sound";
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   178
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   179
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   180
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   181
Unify.search_bound := 40;
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   182
Unify.trace_bound  := 40;
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   183
Delsplits[split_if];
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   184
Delsimps[fun_upd_apply];(*###*)
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   185
Goal
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   186
"wf_java_prog G \\<Longrightarrow> \
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   187
\ (G\\<turnstile>(x,(h,l)) -e  \\<succ>v  \\<rightarrow> (x', (h',l')) \\<longrightarrow> \
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   188
\     (\\<forall>lT.    (h ,l )\\<Colon>\\<preceq>(G,lT) \\<longrightarrow> (\\<forall>T . (G,lT)\\<turnstile>e  \\<Colon> T \\<longrightarrow> \
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   189
\     h\\<le>|h' \\<and> (h',l')\\<Colon>\\<preceq>(G,lT) \\<and> (x'=None \\<longrightarrow> G,h'\\<turnstile>v  \\<Colon>\\<preceq> T )))) \\<and> \
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   190
\ (G\\<turnstile>(x,(h,l)) -es[\\<succ>]vs\\<rightarrow> (x', (h',l')) \\<longrightarrow> \
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   191
\     (\\<forall>lT.    (h ,l )\\<Colon>\\<preceq>(G,lT) \\<longrightarrow> (\\<forall>Ts. (G,lT)\\<turnstile>es[\\<Colon>]Ts \\<longrightarrow> \
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   192
\     h\\<le>|h' \\<and> (h',l')\\<Colon>\\<preceq>(G,lT) \\<and> (x'=None \\<longrightarrow> list_all2 (\\<lambda>v T. G,h'\\<turnstile>v\\<Colon>\\<preceq>T) vs Ts)))) \\<and> \
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   193
\ (G\\<turnstile>(x,(h,l)) -c       \\<rightarrow> (x', (h',l')) \\<longrightarrow> \
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   194
\     (\\<forall>lT.    (h ,l )\\<Colon>\\<preceq>(G,lT) \\<longrightarrow>       (G,lT)\\<turnstile>c  \\<surd> \\<longrightarrow> \
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   195
\     h\\<le>|h' \\<and> (h',l')\\<Colon>\\<preceq>(G,lT)))";
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   196
by( rtac eval_evals_exec.induct 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   197
by( rewtac c_hupd_def);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   198
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   199
(* several simplifications, XcptE, XcptEs, XcptS, Skip *)
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   200
by( ALLGOALS Asm_full_simp_tac);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   201
by( ALLGOALS strip_tac);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   202
by( ALLGOALS (eresolve_tac ty_expr_ty_exprs_wt_stmt.elims 
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   203
		THEN_ALL_NEW Full_simp_tac));
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   204
by( ALLGOALS (EVERY' [REPEAT o (etac conjE), REPEAT o hyp_subst_tac]));
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   205
by( rewtac wf_java_prog_def);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   206
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   207
(* Level 7 *)
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   208
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   209
(* 14 NewC *)
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   210
by( dtac new_AddrD 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   211
by( etac disjE 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   212
by(  Asm_simp_tac 2);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   213
by( etac conjE 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   214
by( Asm_simp_tac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   215
by( rtac conjI 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   216
by(  fast_tac (HOL_cs addSEs [NewC_conforms]) 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   217
by( rtac conf_obj_AddrI 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   218
by(  rtac widen.refl 2);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   219
by(  Asm_simp_tac 2);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   220
by( Simp_tac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   221
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   222
(* for Cast *)
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   223
by( defer_tac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   224
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   225
(* 13 Lit *)
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   226
by( etac conf_litval 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   227
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   228
(* 12 LAcc *)
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   229
by( fast_tac (claset() addEs [conforms_localD RS lconfD]) 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   230
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   231
(* 11 Nil *)
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   232
by( Simp_tac 5);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   233
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   234
(* for FAss *)
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   235
by( EVERY'[eresolve_tac ty_expr_ty_exprs_wt_stmt.elims THEN_ALL_NEW Full_simp_tac, 
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   236
			REPEAT o (etac conjE), hyp_subst_tac] 3);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   237
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   238
(* for if *)
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   239
by( (case_tac1 "the_Bool v" THEN_ALL_NEW Asm_full_simp_tac) 8);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   240
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   241
val forward_hyp_tac = ALLGOALS (TRY o (EVERY' [dtac spec, mp_tac,
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   242
	(mp_tac ORELSE' (dtac spec THEN' mp_tac)), REPEAT o (etac conjE)]));
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   243
by forward_hyp_tac;
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   244
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   245
(* 10+1 if *)
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   246
by(  fast_tac (HOL_cs addIs [hext_trans]) 8);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   247
by( fast_tac (HOL_cs addIs [hext_trans]) 8);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   248
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   249
(* 9 Expr *)
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   250
by( Fast_tac 6);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   251
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   252
by( ALLGOALS Asm_full_simp_tac);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   253
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   254
(* 8 Cast *)
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   255
by( EVERY'[rtac impI, dtac raise_if_NoneD, Clarsimp_tac, 
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   256
           fast_tac (claset() addEs [Cast_conf])] 8);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   257
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   258
(* 7 LAss *)
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   259
by( asm_simp_tac (simpset() addsplits [expand_if]) 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   260
by( EVERY'[eresolve_tac ty_expr_ty_exprs_wt_stmt.elims THEN_ALL_NEW Full_simp_tac] 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   261
by( blast_tac (claset() addIs [conforms_upd_local, conf_widen]) 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   262
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   263
(* 6 FAcc *)
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   264
by( fast_tac (claset() addSEs [FAcc_type_sound]) 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   265
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   266
(* 5 While *)
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   267
by( fast_tac (claset() addIs [ty_expr_ty_exprs_wt_stmt.Cond, ty_expr_ty_exprs_wt_stmt.Comp, ty_expr_ty_exprs_wt_stmt.Skip]
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   268
		       addEs [ty_expr_ty_exprs_wt_stmt.Loop]) 5);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   269
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   270
by forward_hyp_tac;
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   271
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   272
(* 4 Cons *)
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   273
by( fast_tac (claset() addDs [evals_no_xcpt] addIs [conf_hext,hext_trans]) 3);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   274
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   275
(* 3 ;; *)
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   276
by( fast_tac (claset() addIs [hext_trans]) 3);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   277
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   278
(* 2 FAss *)
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   279
by( case_tac1 "x2 = None" 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   280
by(  Asm_simp_tac 2);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   281
by(  fast_tac (claset() addIs [hext_trans]) 2);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   282
by( Asm_full_simp_tac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   283
by( dtac eval_no_xcpt 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   284
by( SELECT_GOAL (etac FAss_type_sound 1 THEN rtac refl 1 THEN ALLGOALS atac) 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   285
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   286
by prune_params_tac;
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   287
(* Level 45 *)
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   288
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   289
(* 1 Call *)
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   290
by( case_tac1 "x = None" 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   291
by(  dtac (not_None_eq RS iffD1) 2);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   292
by(  Clarsimp_tac 2);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   293
by(  dtac exec_xcpt 2);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   294
by(  Asm_full_simp_tac 2);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   295
by(  dtac eval_xcpt 2);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   296
by(  Asm_full_simp_tac 2);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   297
by(  fast_tac (HOL_cs addEs [hext_trans]) 2);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   298
by( Clarify_tac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   299
by( dtac evals_no_xcpt 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   300
by( Asm_full_simp_tac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   301
by( case_tac1 "a' = Null" 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   302
by(  Asm_full_simp_tac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   303
by(  dtac exec_xcpt 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   304
by(  Asm_full_simp_tac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   305
by(  dtac eval_xcpt 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   306
by(  Asm_full_simp_tac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   307
by(  fast_tac (HOL_cs addEs [hext_trans]) 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   308
by( (rtac (rewrite_rule[wf_java_prog_def]Call_type_sound) THEN_ALL_NEW Asm_simp_tac) 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   309
qed "eval_evals_exec_type_sound";
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   310
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   311
Goal "\\<And>E s s'. \
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   312
\ \\<lbrakk> G=prg E; wf_java_prog G; G\\<turnstile>(x,s) -e\\<succ>v \\<rightarrow> (x',s'); s\\<Colon>\\<preceq>E; E\\<turnstile>e\\<Colon>T \\<rbrakk> \
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   313
\ \\<Longrightarrow> s'\\<Colon>\\<preceq>E \\<and> (x'=None \\<longrightarrow> G,heap s'\\<turnstile>v\\<Colon>\\<preceq>T)";
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   314
by( split_all_tac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   315
bd (eval_evals_exec_type_sound RS conjunct1 RS mp RS spec RS mp) 1;
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   316
by Auto_tac;
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   317
qed "eval_type_sound";
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   318
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   319
Goal "\\<And>E s s'. \
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   320
\ \\<lbrakk> G=prg E; wf_java_prog G; G\\<turnstile>(x,s) -s0\\<rightarrow> (x',s'); s\\<Colon>\\<preceq>E; E\\<turnstile>s0\\<surd> \\<rbrakk> \
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   321
\ \\<Longrightarrow> s'\\<Colon>\\<preceq>E";
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   322
by( split_all_tac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   323
bd (eval_evals_exec_type_sound RS conjunct2 RS conjunct2 RS mp RS spec RS mp) 1;
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   324
by   Auto_tac;
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   325
qed "exec_type_sound";
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   326
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   327
Goal "\\<lbrakk>G=prg E; wf_java_prog G; G\\<turnstile>(x,s) -e\\<succ>a'\\<rightarrow> Norm s'; a' \\<noteq> Null;\
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   328
\         s\\<Colon>\\<preceq>E; E\\<turnstile>e\\<Colon>RefT T; m_head G T sig \\<noteq> None\\<rbrakk> \\<Longrightarrow> \
8034
6fc37b5c5e98 Various little changes like cmethd -> method and cfield -> field.
nipkow
parents: 8011
diff changeset
   329
\ method (G,fst (the (heap s' (the_Addr a')))) sig \\<noteq> None";
8011
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   330
by( dtac eval_type_sound 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   331
by(     atac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   332
by(    atac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   333
by(   atac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   334
by(  atac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   335
by( not_None_tac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   336
by( split_all_tac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   337
by(rewtac wf_java_prog_def);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   338
by( forward_tac [widen_methd] 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   339
by(   atac 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   340
by(  rtac (not_None_eq RS iffD1) 2);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   341
by(  Fast_tac 2);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   342
by( etac conjE 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   343
by( dtac non_npD 1);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   344
by Auto_tac;
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   345
qed "all_methods_understood";
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   346
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   347
Delsimps [split_beta];
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   348
Addsimps[fun_upd_apply];(*###*)
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
   349