added get_cs/map_cs;
authorwenzelm
Sat, 28 Jul 2007 20:40:26 +0200 (2007-07-28)
changeset 24021 491c68f40bc4
parent 24020 ed4d7abffee7
child 24022 ab76c73b3b58
added get_cs/map_cs;
src/Provers/classical.ML
--- a/src/Provers/classical.ML	Sat Jul 28 20:40:24 2007 +0200
+++ b/src/Provers/classical.ML	Sat Jul 28 20:40:26 2007 +0200
@@ -143,6 +143,8 @@
   val get_local_claset: Proof.context -> claset
   val put_local_claset: claset -> Proof.context -> Proof.context
   val print_local_claset: Proof.context -> unit
+  val get_cs: Context.generic -> claset
+  val map_cs: (claset -> claset) -> Context.generic -> Context.generic
   val safe_dest: int option -> attribute
   val safe_elim: int option -> attribute
   val safe_intro: int option -> attribute
@@ -860,7 +862,7 @@
 
 (** claset data **)
 
-(* global claset *)
+(* global clasets *)
 
 structure GlobalClaset = TheoryDataFun
 (
@@ -912,7 +914,7 @@
   (AList.delete (op =) name);
 
 
-(* local claset *)
+(* local clasets *)
 
 structure LocalClaset = ProofDataFun
 (
@@ -929,6 +931,15 @@
 val print_local_claset = print_cs o local_claset_of;
 
 
+(* generic clasets *)
+
+fun get_cs (Context.Theory thy) = claset_of thy
+  | get_cs (Context.Proof ctxt) = local_claset_of ctxt;
+
+fun map_cs f (Context.Theory thy) = (change_claset_of thy f; Context.Theory thy)
+  | map_cs f (Context.Proof ctxt) = Context.Proof (LocalClaset.map f ctxt);
+
+
 (* attributes *)
 
 fun attrib f = Thm.declaration_attribute (fn th =>