src/HOL/MicroJava/J/State.ML
author kleing
Wed, 30 Aug 2000 21:40:35 +0200
changeset 9755 6fefedeb3428
parent 9385 6e1ac1629ac7
child 9970 dfe4747c8318
permissions -rw-r--r--
tuned
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 obj_ty_def2 = prove_goalw thy [obj_ty_def] "obj_ty (C,fs) = Class C" 
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
     8
	(K [Simp_tac 1]);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
     9
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    10
Addsimps [obj_ty_def2];
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    11
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    12
val new_AddrD = prove_goalw thy [new_Addr_def] 
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    13
"\\<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
    14
	asm_full_simp_tac (simpset() addsimps [Pair_fst_snd_eq,select_split]) 1,
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    15
	rtac selectI 1,
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    16
	rtac disjI2 1,
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    17
	res_inst_tac [("r","snd (a,Some OutOfMemory)")] trans 1,
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    18
	 Auto_tac ]);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    19
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    20
val raise_if_True = prove_goalw thy [raise_if_def] 
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    21
	"raise_if True x y \\<noteq> None"
9385
6e1ac1629ac7 removed obsolete expand_if = split_if;
wenzelm
parents: 9348
diff changeset
    22
(K [split_tac [split_if] 1,Auto_tac]);
8011
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    23
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    24
val raise_if_False = prove_goalw thy [raise_if_def] 
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    25
	"raise_if False x y = y"
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    26
(K [Auto_tac]);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    27
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    28
val raise_if_Some = prove_goalw thy [raise_if_def] 
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    29
	"raise_if c x (Some y) \\<noteq> None" (K [Auto_tac]);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    30
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    31
val raise_if_Some2 = prove_goalw thy [raise_if_def] 
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    32
"raise_if c z (if x = None then Some y else x) \\<noteq> None" (K[
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    33
	induct_tac "x" 1,
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    34
	Auto_tac]);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    35
val if_None_eq = prove_goal thy 
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    36
"(if x = None then None else x) = x" (K[
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    37
	induct_tac "x" 1,
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    38
	Auto_tac]);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    39
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    40
Addsimps [raise_if_True,raise_if_False,raise_if_Some,raise_if_Some2,if_None_eq];
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    41
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    42
val raise_if_SomeD = prove_goalw thy [raise_if_def] 
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    43
	"raise_if c x y = Some z \\<longrightarrow> c \\<and>  Some z = Some x |  y = Some z" 
9385
6e1ac1629ac7 removed obsolete expand_if = split_if;
wenzelm
parents: 9348
diff changeset
    44
(K [split_tac [split_if] 1,Auto_tac]) RS mp;
8011
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    45
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    46
val raise_if_NoneD = prove_goalw thy [raise_if_def] 
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    47
	"raise_if c x y = None \\<longrightarrow> \\<not> c \\<and>  y = None"
9385
6e1ac1629ac7 removed obsolete expand_if = split_if;
wenzelm
parents: 9348
diff changeset
    48
(K [split_tac [split_if] 1,Auto_tac]) RS mp;
8011
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    49
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    50
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    51
val np_NoneD = (prove_goalw thy [np_def, raise_if_def] 
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    52
	"np a' x' = None \\<longrightarrow> x' = None \\<and>  a' \\<noteq> Null" (fn _ => [
9385
6e1ac1629ac7 removed obsolete expand_if = split_if;
wenzelm
parents: 9348
diff changeset
    53
	split_tac [split_if] 1,
8011
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    54
	Auto_tac ])) RS mp;
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    55
val np_None = (prove_goalw thy [np_def, raise_if_def] 
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    56
	"a' \\<noteq> Null \\<longrightarrow> np a' x' = x'" (fn _ => [
9385
6e1ac1629ac7 removed obsolete expand_if = split_if;
wenzelm
parents: 9348
diff changeset
    57
	split_tac [split_if] 1,
8011
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    58
	Auto_tac ])) RS mp;
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    59
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
    60
	(fn _ => [Auto_tac ]);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    61
val np_Null = prove_goalw thy [np_def, raise_if_def] 
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    62
	"np Null None = Some NullPointer" (fn _ => [
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    63
	Auto_tac ]);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    64
val np_Addr = prove_goalw thy [np_def, raise_if_def] "np (Addr a) None = None" 
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    65
	(fn _ => [Auto_tac ]);
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    66
Addsimps[np_None, np_Some,np_Null,np_Addr];
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    67
9348
f495dba0cb07 corrections (cast relation, Prog.ML -> Decl.ML)
oheimb
parents: 8875
diff changeset
    68
Goalw [raise_if_def] "(np Null (raise_if c xc None)) = \
f495dba0cb07 corrections (cast relation, Prog.ML -> Decl.ML)
oheimb
parents: 8875
diff changeset
    69
\ Some (if c then xc else NullPointer)";
f495dba0cb07 corrections (cast relation, Prog.ML -> Decl.ML)
oheimb
parents: 8875
diff changeset
    70
by (Simp_tac 1);
f495dba0cb07 corrections (cast relation, Prog.ML -> Decl.ML)
oheimb
parents: 8875
diff changeset
    71
qed "np_raise_if";
f495dba0cb07 corrections (cast relation, Prog.ML -> Decl.ML)
oheimb
parents: 8875
diff changeset
    72
Addsimps[np_raise_if];
8011
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