src/HOL/MicroJava/J/State.ML
author kleing
Thu, 09 Mar 2000 13:50:58 +0100
changeset 8386 3e56677d3b98
parent 8011 d14c4e9e9c8e
child 8875 ac86b3d44730
permissions -rw-r--r--
minor adjustments in branch and method invocation for completeness of LBV
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
8011
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
     1
(*  Title:      HOL/MicroJava/J/State.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
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
     7
val the_Addr_Addr = prove_goalw thy [the_Addr_def] 
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
     8
	"the_Addr (Addr a) = a" (K [Auto_tac]);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
     9
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    10
Addsimps [the_Addr_Addr];
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    11
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    12
val obj_ty_def2 = prove_goalw thy [obj_ty_def] "obj_ty (C,fs) = Class C" 
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    13
	(K [Simp_tac 1]);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    14
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    15
Addsimps [obj_ty_def2];
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    16
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    17
val new_AddrD = prove_goalw thy [new_Addr_def] 
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    18
"\\<And>X. (a,x) = new_Addr h \\<Longrightarrow> h a = None \\<and>  x = None |  x = Some OutOfMemory" (K[
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    19
	asm_full_simp_tac (simpset() addsimps [Pair_fst_snd_eq,select_split]) 1,
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    20
	rtac selectI 1,
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    21
	rtac disjI2 1,
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    22
	res_inst_tac [("r","snd (a,Some OutOfMemory)")] trans 1,
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    23
	 Auto_tac ]);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    24
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    25
val raise_if_True = prove_goalw thy [raise_if_def] 
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    26
	"raise_if True x y \\<noteq> None"
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    27
(K [split_tac [expand_if] 1,Auto_tac]);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    28
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    29
val raise_if_False = prove_goalw thy [raise_if_def] 
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    30
	"raise_if False x y = y"
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    31
(K [Auto_tac]);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    32
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    33
val raise_if_Some = prove_goalw thy [raise_if_def] 
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    34
	"raise_if c x (Some y) \\<noteq> None" (K [Auto_tac]);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    35
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    36
val raise_if_Some2 = prove_goalw thy [raise_if_def] 
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    37
"raise_if c z (if x = None then Some y else x) \\<noteq> None" (K[
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    38
	induct_tac "x" 1,
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    39
	Auto_tac]);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    40
val if_None_eq = prove_goal thy 
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    41
"(if x = None then None else x) = x" (K[
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    42
	induct_tac "x" 1,
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    43
	Auto_tac]);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    44
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    45
Addsimps [raise_if_True,raise_if_False,raise_if_Some,raise_if_Some2,if_None_eq];
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    46
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    47
val raise_if_SomeD = prove_goalw thy [raise_if_def] 
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    48
	"raise_if c x y = Some z \\<longrightarrow> c \\<and>  Some z = Some x |  y = Some z" 
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    49
(K [split_tac [expand_if] 1,Auto_tac]) RS mp;
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    50
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    51
val raise_if_NoneD = prove_goalw thy [raise_if_def] 
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    52
	"raise_if c x y = None \\<longrightarrow> \\<not> c \\<and>  y = None"
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    53
(K [split_tac [expand_if] 1,Auto_tac]) RS mp;
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    54
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    55
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    56
val np_NoneD = (prove_goalw thy [np_def, raise_if_def] 
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    57
	"np a' x' = None \\<longrightarrow> x' = None \\<and>  a' \\<noteq> Null" (fn _ => [
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    58
	split_tac [expand_if] 1,
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    59
	Auto_tac ])) RS mp;
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    60
val np_None = (prove_goalw thy [np_def, raise_if_def] 
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    61
	"a' \\<noteq> Null \\<longrightarrow> np a' x' = x'" (fn _ => [
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    62
	split_tac [expand_if] 1,
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    63
	Auto_tac ])) RS mp;
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    64
val np_Some = prove_goalw thy [np_def, raise_if_def] "np a' (Some xc) = Some xc"
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    65
	(fn _ => [Auto_tac ]);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    66
val np_Null = prove_goalw thy [np_def, raise_if_def] 
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    67
	"np Null None = Some NullPointer" (fn _ => [
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    68
	Auto_tac ]);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    69
val np_Addr = prove_goalw thy [np_def, raise_if_def] "np (Addr a) None = None" 
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    70
	(fn _ => [Auto_tac ]);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    71
Addsimps[np_None, np_Some,np_Null,np_Addr];
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    72
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    73
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    74
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    75
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    76
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    77