Merge
authorpaulson <lp15@cam.ac.uk>
Wed, 11 Feb 2015 12:01:56 +0000
changeset 59507 b468e0f8da2a
parent 59506 4af607652318 (current diff)
parent 59503 9937bc07202b (diff)
child 59508 49ca7836ae81
child 59512 9bf568cc71a4
Merge
src/HOL/Fun.thy
src/HOL/HOL.thy
src/HOL/Set.thy
--- a/NEWS	Tue Feb 10 17:37:06 2015 +0000
+++ b/NEWS	Wed Feb 11 12:01:56 2015 +0000
@@ -248,8 +248,8 @@
 Input.source (with formal position information).
 
 * Proper context for various elementary tactics: assume_tac,
-match_tac, compose_tac, Splitter.split_tac etc.  Minor
-INCOMPATIBILITY.
+resolve_tac, eresolve_tac, dresolve_tac, forward_tac, match_tac,
+compose_tac, Splitter.split_tac etc. INCOMPATIBILITY.
 
 * Tactical PARALLEL_ALLGOALS is the most common way to refer to
 PARALLEL_GOALS.
--- a/src/CCL/CCL.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/CCL/CCL.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -204,8 +204,9 @@
       fun mk_inj_lemmas r = [@{thm arg_cong}] RL [r RS (r RS @{thm eq_lemma})]
       val inj_lemmas = maps mk_inj_lemmas rews
     in
-      CHANGED (REPEAT (ares_tac [@{thm iffI}, @{thm allI}, @{thm conjI}] i ORELSE
-        eresolve_tac inj_lemmas i ORELSE
+      CHANGED (REPEAT (assume_tac ctxt i ORELSE
+        resolve_tac ctxt @{thms iffI allI conjI} i ORELSE
+        eresolve_tac ctxt inj_lemmas i ORELSE
         asm_simp_tac (ctxt addsimps rews) i))
     end;
 *}
@@ -267,7 +268,7 @@
   let
     fun mk_raw_dstnct_thm rls s =
       Goal.prove_global @{theory} [] [] (Syntax.read_prop_global @{theory} s)
-        (fn _ => rtac @{thm notI} 1 THEN eresolve_tac rls 1)
+        (fn {context = ctxt, ...} => rtac @{thm notI} 1 THEN eresolve_tac ctxt rls 1)
   in map (mk_raw_dstnct_thm caseB_lemmas)
     (mk_dstnct_rls @{theory} ["bot","true","false","pair","lambda"]) end
 
--- a/src/CCL/Term.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/CCL/Term.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -203,7 +203,7 @@
 method_setup beta_rl = {*
   Scan.succeed (fn ctxt =>
     SIMPLE_METHOD' (CHANGED o
-      simp_tac (ctxt addsimps @{thms rawBs} setloop (fn _ => stac @{thm letrecB}))))
+      simp_tac (ctxt addsimps @{thms rawBs} setloop (fn _ => stac ctxt @{thm letrecB}))))
 *}
 
 lemma ifBtrue: "if true then t else u = t"
--- a/src/CCL/Type.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/CCL/Type.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -126,10 +126,11 @@
 ML {*
 fun mk_ncanT_tac top_crls crls =
   SUBPROOF (fn {context = ctxt, prems = major :: prems, ...} =>
-    resolve_tac ([major] RL top_crls) 1 THEN
-    REPEAT_SOME (eresolve_tac (crls @ [@{thm exE}, @{thm bexE}, @{thm conjE}, @{thm disjE}])) THEN
+    resolve_tac ctxt ([major] RL top_crls) 1 THEN
+    REPEAT_SOME (eresolve_tac ctxt (crls @ @{thms exE bexE conjE disjE})) THEN
     ALLGOALS (asm_simp_tac ctxt) THEN
-    ALLGOALS (ares_tac (prems RL [@{thm lem}]) ORELSE' etac @{thm bspec}) THEN
+    ALLGOALS (assume_tac ctxt ORELSE' resolve_tac ctxt (prems RL [@{thm lem}])
+      ORELSE' eresolve_tac ctxt @{thms bspec}) THEN
     safe_tac (ctxt addSIs prems))
 *}
 
@@ -436,7 +437,7 @@
 fun POgen_tac ctxt (rla, rlb) i =
   SELECT_GOAL (safe_tac ctxt) i THEN
   rtac (rlb RS (rla RS @{thm ssubst_pair})) i THEN
-  (REPEAT (resolve_tac
+  (REPEAT (resolve_tac ctxt
       (@{thms POgenIs} @ [@{thm PO_refl} RS (@{thm POgen_mono} RS @{thm ci3_AI})] @
         (@{thms POgenIs} RL [@{thm POgen_mono} RS @{thm ci3_AgenI}]) @
         [@{thm POgen_mono} RS @{thm ci3_RI}]) i))
@@ -467,8 +468,8 @@
   unfolding data_defs by (genIs EQgenXH EQgen_mono)+
 
 ML {*
-fun EQgen_raw_tac i =
-  (REPEAT (resolve_tac (@{thms EQgenIs} @
+fun EQgen_raw_tac ctxt i =
+  (REPEAT (resolve_tac ctxt (@{thms EQgenIs} @
         [@{thm EQ_refl} RS (@{thm EQgen_mono} RS @{thm ci3_AI})] @
         (@{thms EQgenIs} RL [@{thm EQgen_mono} RS @{thm ci3_AgenI}]) @
         [@{thm EQgen_mono} RS @{thm ci3_RI}]) i))
@@ -480,9 +481,9 @@
 fun EQgen_tac ctxt rews i =
  SELECT_GOAL
    (TRY (safe_tac ctxt) THEN
-    resolve_tac ((rews @ [@{thm refl}]) RL ((rews @ [@{thm refl}]) RL [@{thm ssubst_pair}])) i THEN
+    resolve_tac ctxt ((rews @ [@{thm refl}]) RL ((rews @ [@{thm refl}]) RL [@{thm ssubst_pair}])) i THEN
     ALLGOALS (simp_tac ctxt) THEN
-    ALLGOALS EQgen_raw_tac) i
+    ALLGOALS (EQgen_raw_tac ctxt)) i
 *}
 
 method_setup EQgen = {*
--- a/src/CCL/Wfd.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/CCL/Wfd.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -448,13 +448,14 @@
 fun rcall_tac ctxt i =
   let fun tac ps rl i = res_inst_tac ctxt ps rl i THEN atac i
   in IHinst tac @{thms rcallTs} i end
-  THEN eresolve_tac @{thms rcall_lemmas} i
+  THEN eresolve_tac ctxt @{thms rcall_lemmas} i
 
 fun raw_step_tac ctxt prems i =
-  ares_tac (prems@type_rls) i ORELSE
+  assume_tac ctxt i ORELSE
+  resolve_tac ctxt (prems @ type_rls) i ORELSE
   rcall_tac ctxt i ORELSE
-  ematch_tac ctxt [@{thm SubtypeE}] i ORELSE
-  match_tac ctxt [@{thm SubtypeI}] i
+  ematch_tac ctxt @{thms SubtypeE} i ORELSE
+  match_tac ctxt @{thms SubtypeI} i
 
 fun tc_step_tac ctxt prems = SUBGOAL (fn (Bi,i) =>
     if is_rigid_prog Bi then raw_step_tac ctxt prems i else no_tac)
@@ -467,7 +468,7 @@
 fun clean_ccs_tac ctxt =
   let fun tac ps rl i = eres_inst_tac ctxt ps rl i THEN atac i in
     TRY (REPEAT_FIRST (IHinst tac @{thms hyprcallTs} ORELSE'
-      eresolve_tac ([asm_rl, @{thm SubtypeE}] @ @{thms rmIHs}) ORELSE'
+      eresolve_tac ctxt ([asm_rl, @{thm SubtypeE}] @ @{thms rmIHs}) ORELSE'
       hyp_subst_tac ctxt))
   end
 
@@ -498,7 +499,7 @@
 fun eval_tac ths =
   Subgoal.FOCUS_PREMS (fn {context = ctxt, prems, ...} =>
     let val eval_rules = Named_Theorems.get ctxt @{named_theorems eval}
-    in DEPTH_SOLVE_1 (resolve_tac (ths @ prems @ rev eval_rules) 1) end)
+    in DEPTH_SOLVE_1 (resolve_tac ctxt (ths @ prems @ rev eval_rules) 1) end)
 *}
 
 method_setup eval = {*
@@ -521,7 +522,7 @@
   apply (unfold let_def)
   apply (rule 1 [THEN canonical])
   apply (tactic {*
-    REPEAT (DEPTH_SOLVE_1 (resolve_tac (@{thms assms} @ @{thms eval_rls}) 1 ORELSE
+    REPEAT (DEPTH_SOLVE_1 (resolve_tac @{context} (@{thms assms} @ @{thms eval_rls}) 1 ORELSE
       etac @{thm substitute} 1)) *})
   done
 
--- a/src/CTT/Arith.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/CTT/Arith.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -177,7 +177,7 @@
   (Arith_simp.norm_tac ctxt (congr_rls, prems))
 
 fun hyp_arith_rew_tac ctxt prems = make_rew_tac ctxt
-  (Arith_simp.cond_norm_tac ctxt (prove_cond_tac, congr_rls, prems))
+  (Arith_simp.cond_norm_tac ctxt (prove_cond_tac ctxt, congr_rls, prems))
 
 end
 *}
--- a/src/CTT/CTT.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/CTT/CTT.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -453,13 +453,13 @@
 
 fun safestep_tac ctxt thms i =
     form_tac ctxt ORELSE
-    resolve_tac thms i  ORELSE
-    biresolve_tac safe0_brls i  ORELSE  mp_tac ctxt i  ORELSE
-    DETERM (biresolve_tac safep_brls i)
+    resolve_tac ctxt thms i  ORELSE
+    biresolve_tac ctxt safe0_brls i  ORELSE  mp_tac ctxt i  ORELSE
+    DETERM (biresolve_tac ctxt safep_brls i)
 
 fun safe_tac ctxt thms i = DEPTH_SOLVE_1 (safestep_tac ctxt thms i)
 
-fun step_tac ctxt thms = safestep_tac ctxt thms  ORELSE'  biresolve_tac unsafe_brls
+fun step_tac ctxt thms = safestep_tac ctxt thms  ORELSE'  biresolve_tac ctxt unsafe_brls
 
 (*Fails unless it solves the goal!*)
 fun pc_tac ctxt thms = DEPTH_SOLVE_1 o (step_tac ctxt thms)
--- a/src/CTT/ex/Elimination.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/CTT/ex/Elimination.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -182,7 +182,7 @@
     and "\<And>z. z:A*B \<Longrightarrow> C(z) type"
   shows "?a : (SUM z:A*B. C(z)) --> (SUM u:A. SUM v:B. C(<u,v>))"
 apply (rule intr_rls)
-apply (tactic {* biresolve_tac safe_brls 2 *})
+apply (tactic {* biresolve_tac @{context} safe_brls 2 *})
 (*Now must convert assumption C(z) into antecedent C(<kd,ke>) *)
 apply (rule_tac [2] a = "y" in ProdE)
 apply (typechk assms)
--- a/src/CTT/ex/Synthesis.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/CTT/ex/Synthesis.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -92,12 +92,12 @@
                 *  (PROD y:N. Eq(N, plus`succ(y)`x, succ(plus`y`x)))"
 apply intr
 apply eqintr
-apply (tactic "resolve_tac [TSimp.split_eqn] 3")
+apply (tactic "resolve_tac @{context} [TSimp.split_eqn] 3")
 apply (tactic "SELECT_GOAL (rew_tac @{context} []) 4")
-apply (tactic "resolve_tac [TSimp.split_eqn] 3")
+apply (tactic "resolve_tac @{context} [TSimp.split_eqn] 3")
 apply (tactic "SELECT_GOAL (rew_tac @{context} []) 4")
 apply (rule_tac [3] p = "y" in NC_succ)
-  (**  by (resolve_tac comp_rls 3);  caused excessive branching  **)
+  (**  by (resolve_tac @{context} comp_rls 3);  caused excessive branching  **)
 apply rew
 done
 
--- a/src/CTT/ex/Typechecking.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/CTT/ex/Typechecking.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -66,7 +66,8 @@
 
 (*Proofs involving arbitrary types.
   For concreteness, every type variable left over is forced to be N*)
-method_setup N = {* Scan.succeed (fn _ => SIMPLE_METHOD (TRYALL (resolve_tac @{thms NF}))) *}
+method_setup N =
+  {* Scan.succeed (fn ctxt => SIMPLE_METHOD (TRYALL (resolve_tac ctxt @{thms NF}))) *}
 
 schematic_lemma "lam w. <w,w> : ?A"
 apply typechk
--- a/src/CTT/rew.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/CTT/rew.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -11,7 +11,7 @@
   | peEs n = @{thm EqE} :: map (curry (op RS) @{thm ProdE}) (peEs (n-1));
 
 (*Tactic used for proving conditions for the cond_rls*)
-val prove_cond_tac = eresolve_tac (peEs 5);
+fun prove_cond_tac ctxt = eresolve_tac ctxt (peEs 5);
 
 
 structure TSimp_data: TSIMP_DATA =
@@ -32,11 +32,11 @@
 
 (*Make a rewriting tactic from a normalization tactic*)
 fun make_rew_tac ctxt ntac =
-    TRY (eqintr_tac ctxt)  THEN  TRYALL (resolve_tac [TSimp.split_eqn])  THEN  
+    TRY (eqintr_tac ctxt)  THEN  TRYALL (resolve_tac ctxt [TSimp.split_eqn])  THEN  
     ntac;
 
 fun rew_tac ctxt thms = make_rew_tac ctxt
     (TSimp.norm_tac ctxt (standard_congr_rls, thms));
 
 fun hyp_rew_tac ctxt thms = make_rew_tac ctxt
-    (TSimp.cond_norm_tac ctxt (prove_cond_tac, standard_congr_rls, thms));
+    (TSimp.cond_norm_tac ctxt (prove_cond_tac ctxt, standard_congr_rls, thms));
--- a/src/Cube/Example.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Cube/Example.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -10,17 +10,17 @@
   J. Functional Programming.\<close>
 
 method_setup depth_solve =
-  \<open>Attrib.thms >> (fn thms => K (METHOD (fn facts =>
-    (DEPTH_SOLVE (HEADGOAL (ares_tac (facts @ thms)))))))\<close>
+  \<open>Attrib.thms >> (fn thms => fn ctxt => METHOD (fn facts =>
+    (DEPTH_SOLVE (HEADGOAL (assume_tac ctxt ORELSE' resolve_tac ctxt (facts @ thms))))))\<close>
 
 method_setup depth_solve1 =
-  \<open>Attrib.thms >> (fn thms => K (METHOD (fn facts =>
-    (DEPTH_SOLVE_1 (HEADGOAL (ares_tac (facts @ thms)))))))\<close>
+  \<open>Attrib.thms >> (fn thms => fn ctxt => METHOD (fn facts =>
+    (DEPTH_SOLVE_1 (HEADGOAL (assume_tac ctxt ORELSE' resolve_tac ctxt (facts @ thms))))))\<close>
 
 method_setup strip_asms =
-  \<open>Attrib.thms >> (fn thms => K (METHOD (fn facts =>
-    REPEAT (resolve_tac [@{thm strip_b}, @{thm strip_s}] 1 THEN
-    DEPTH_SOLVE_1 (ares_tac (facts @ thms) 1)))))\<close>
+  \<open>Attrib.thms >> (fn thms => fn ctxt => METHOD (fn facts =>
+    REPEAT (resolve_tac ctxt [@{thm strip_b}, @{thm strip_s}] 1 THEN
+    DEPTH_SOLVE_1 (assume_tac ctxt 1 ORELSE resolve_tac ctxt (facts @ thms) 1))))\<close>
 
 
 subsection \<open>Simple types\<close>
--- a/src/Doc/Implementation/Isar.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Doc/Implementation/Isar.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -366,8 +366,8 @@
 
   have "A \<and> B"
     apply (tactic \<open>rtac @{thm conjI} 1\<close>)
-    using a apply (tactic \<open>resolve_tac facts 1\<close>)
-    using b apply (tactic \<open>resolve_tac facts 1\<close>)
+    using a apply (tactic \<open>resolve_tac @{context} facts 1\<close>)
+    using b apply (tactic \<open>resolve_tac @{context} facts 1\<close>)
     done
 
   have "A \<and> B"
--- a/src/Doc/Implementation/Tactic.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Doc/Implementation/Tactic.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -277,11 +277,11 @@
 
 text %mlref \<open>
   \begin{mldecls}
-  @{index_ML resolve_tac: "thm list -> int -> tactic"} \\
-  @{index_ML eresolve_tac: "thm list -> int -> tactic"} \\
-  @{index_ML dresolve_tac: "thm list -> int -> tactic"} \\
-  @{index_ML forward_tac: "thm list -> int -> tactic"} \\
-  @{index_ML biresolve_tac: "(bool * thm) list -> int -> tactic"} \\[1ex]
+  @{index_ML resolve_tac: "Proof.context -> thm list -> int -> tactic"} \\
+  @{index_ML eresolve_tac: "Proof.context -> thm list -> int -> tactic"} \\
+  @{index_ML dresolve_tac: "Proof.context -> thm list -> int -> tactic"} \\
+  @{index_ML forward_tac: "Proof.context -> thm list -> int -> tactic"} \\
+  @{index_ML biresolve_tac: "Proof.context -> (bool * thm) list -> int -> tactic"} \\[1ex]
   @{index_ML assume_tac: "Proof.context -> int -> tactic"} \\
   @{index_ML eq_assume_tac: "int -> tactic"} \\[1ex]
   @{index_ML match_tac: "Proof.context -> thm list -> int -> tactic"} \\
@@ -292,20 +292,20 @@
 
   \begin{description}
 
-  \item @{ML resolve_tac}~@{text "thms i"} refines the goal state
+  \item @{ML resolve_tac}~@{text "ctxt thms i"} refines the goal state
   using the given theorems, which should normally be introduction
   rules.  The tactic resolves a rule's conclusion with subgoal @{text
   i}, replacing it by the corresponding versions of the rule's
   premises.
 
-  \item @{ML eresolve_tac}~@{text "thms i"} performs elim-resolution
+  \item @{ML eresolve_tac}~@{text "ctxt thms i"} performs elim-resolution
   with the given theorems, which are normally be elimination rules.
 
-  Note that @{ML "eresolve_tac [asm_rl]"} is equivalent to @{ML
-  assume_tac}, which facilitates mixing of assumption steps with
+  Note that @{ML_text "eresolve_tac ctxt [asm_rl]"} is equivalent to @{ML_text
+  "assume_tac ctxt"}, which facilitates mixing of assumption steps with
   genuine eliminations.
 
-  \item @{ML dresolve_tac}~@{text "thms i"} performs
+  \item @{ML dresolve_tac}~@{text "ctxt thms i"} performs
   destruct-resolution with the given theorems, which should normally
   be destruction rules.  This replaces an assumption by the result of
   applying one of the rules.
@@ -314,7 +314,7 @@
   selected assumption is not deleted.  It applies a rule to an
   assumption, adding the result as a new assumption.
 
-  \item @{ML biresolve_tac}~@{text "brls i"} refines the proof state
+  \item @{ML biresolve_tac}~@{text "ctxt brls i"} refines the proof state
   by resolution or elim-resolution on each rule, as indicated by its
   flag.  It affects subgoal @{text "i"} of the proof state.
 
--- a/src/Doc/Isar_Ref/Generic.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Doc/Isar_Ref/Generic.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -1054,7 +1054,7 @@
 ML \<open>
   fun subgoaler_tac ctxt =
     assume_tac ctxt ORELSE'
-    resolve_tac (Simplifier.prems_of ctxt) ORELSE'
+    resolve_tac ctxt (Simplifier.prems_of ctxt) ORELSE'
     asm_simp_tac ctxt
 \<close>
 
--- a/src/Doc/Isar_Ref/ML_Tactic.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Doc/Isar_Ref/ML_Tactic.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -62,11 +62,11 @@
   \medskip
   \begin{tabular}{lll}
     @{ML rtac}~@{text "a 1"} & & @{text "rule a"} \\
-    @{ML resolve_tac}~@{text "[a\<^sub>1, \<dots>] 1"} & & @{text "rule a\<^sub>1 \<dots>"} \\
+    @{ML resolve_tac}~@{text "ctxt [a\<^sub>1, \<dots>] 1"} & & @{text "rule a\<^sub>1 \<dots>"} \\
     @{ML res_inst_tac}~@{text "ctxt [(x\<^sub>1, t\<^sub>1), \<dots>] a 1"} & &
     @{text "rule_tac x\<^sub>1 = t\<^sub>1 \<AND> \<dots> \<IN> a"} \\[0.5ex]
     @{ML rtac}~@{text "a i"} & & @{text "rule_tac [i] a"} \\
-    @{ML resolve_tac}~@{text "[a\<^sub>1, \<dots>] i"} & & @{text "rule_tac [i] a\<^sub>1 \<dots>"} \\
+    @{ML resolve_tac}~@{text "ctxt [a\<^sub>1, \<dots>] i"} & & @{text "rule_tac [i] a\<^sub>1 \<dots>"} \\
     @{ML res_inst_tac}~@{text "ctxt [(x\<^sub>1, t\<^sub>1), \<dots>] a i"} & &
     @{text "rule_tac [i] x\<^sub>1 = t\<^sub>1 \<AND> \<dots> \<IN> a"} \\
   \end{tabular}
--- a/src/Doc/Tutorial/Protocol/Event.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Doc/Tutorial/Protocol/Event.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -262,7 +262,7 @@
 {*
 fun analz_mono_contra_tac ctxt =
   rtac @{thm analz_impI} THEN' 
-  REPEAT1 o (dresolve_tac @{thms analz_mono_contra})
+  REPEAT1 o (dresolve_tac ctxt @{thms analz_mono_contra})
   THEN' mp_tac ctxt
 *}
 
@@ -333,7 +333,7 @@
 fun synth_analz_mono_contra_tac ctxt = 
   rtac @{thm syan_impI} THEN'
   REPEAT1 o 
-    (dresolve_tac 
+    (dresolve_tac ctxt
      [@{thm knows_Spy_subset_knows_Spy_Says} RS @{thm synth_analz_mono} RS @{thm contra_subsetD},
       @{thm knows_Spy_subset_knows_Spy_Notes} RS @{thm synth_analz_mono} RS @{thm contra_subsetD},
       @{thm knows_Spy_subset_knows_Spy_Gets} RS @{thm synth_analz_mono} RS @{thm contra_subsetD}])
--- a/src/Doc/Tutorial/Protocol/Message.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Doc/Tutorial/Protocol/Message.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -837,13 +837,13 @@
 *)
 fun impOfSubs th = th RSN (2, @{thm rev_subsetD})
 
-val Fake_insert_tac = 
-    dresolve_tac [impOfSubs Fake_analz_insert,
+fun Fake_insert_tac ctxt =
+    dresolve_tac ctxt [impOfSubs Fake_analz_insert,
                   impOfSubs Fake_parts_insert] THEN'
-    eresolve_tac [asm_rl, @{thm synth.Inj}];
+    eresolve_tac ctxt [asm_rl, @{thm synth.Inj}];
 
 fun Fake_insert_simp_tac ctxt i = 
-  REPEAT (Fake_insert_tac i) THEN asm_full_simp_tac ctxt i;
+  REPEAT (Fake_insert_tac ctxt i) THEN asm_full_simp_tac ctxt i;
 
 fun atomic_spy_analz_tac ctxt =
   SELECT_GOAL
@@ -859,7 +859,7 @@
            (res_inst_tac ctxt [(("x", 1), "X")] (insert_commute RS ssubst) 1),
        (*...allowing further simplifications*)
        simp_tac ctxt 1,
-       REPEAT (FIRSTGOAL (resolve_tac [allI,impI,notI,conjI,iffI])),
+       REPEAT (FIRSTGOAL (resolve_tac ctxt [allI,impI,notI,conjI,iffI])),
        DEPTH_SOLVE (atomic_spy_analz_tac ctxt 1)]) i);
 *}
 
--- a/src/Doc/Tutorial/Protocol/Public.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Doc/Tutorial/Protocol/Public.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -162,7 +162,7 @@
     (ALLGOALS (simp_tac (ctxt delsimps [used_Says]))
      THEN
      REPEAT_FIRST (eq_assume_tac ORELSE' 
-                   resolve_tac [refl, conjI, @{thm Nonce_supply}]));
+                   resolve_tac ctxt [refl, conjI, @{thm Nonce_supply}]));
 *}
 
 method_setup possibility = {* Scan.succeed (SIMPLE_METHOD o possibility_tac) *}
--- a/src/FOL/IFOL.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/FOL/IFOL.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -208,8 +208,8 @@
 
 (*Finds P-->Q and P in the assumptions, replaces implication by Q *)
 ML {*
-  fun mp_tac i = eresolve_tac [@{thm notE}, @{thm impE}] i  THEN  atac i
-  fun eq_mp_tac i = eresolve_tac [@{thm notE}, @{thm impE}] i  THEN  eq_assume_tac i
+  fun mp_tac i = eresolve0_tac [@{thm notE}, @{thm impE}] i  THEN  atac i
+  fun eq_mp_tac i = eresolve0_tac [@{thm notE}, @{thm impE}] i  THEN  eq_assume_tac i
 *}
 
 
@@ -305,8 +305,8 @@
 (*Use iffE on a premise.  For conj_cong, imp_cong, all_cong, ex_cong*)
 ML {*
   fun iff_tac prems i =
-    resolve_tac (prems RL @{thms iffE}) i THEN
-    REPEAT1 (eresolve_tac [@{thm asm_rl}, @{thm mp}] i)
+    resolve0_tac (prems RL @{thms iffE}) i THEN
+    REPEAT1 (eresolve0_tac [@{thm asm_rl}, @{thm mp}] i)
 *}
 
 lemma conj_cong:
--- a/src/FOL/ex/Miniscope.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/FOL/ex/Miniscope.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -65,7 +65,8 @@
 
 ML {*
 val mini_ss = simpset_of (@{context} addsimps @{thms mini_simps});
-fun mini_tac ctxt = resolve_tac @{thms ccontr} THEN' asm_full_simp_tac (put_simpset mini_ss ctxt);
+fun mini_tac ctxt =
+  resolve_tac ctxt @{thms ccontr} THEN' asm_full_simp_tac (put_simpset mini_ss ctxt);
 *}
 
 end
--- a/src/FOL/ex/Prolog.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/FOL/ex/Prolog.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -63,26 +63,29 @@
 
 (*backtracking version*)
 ML {*
-val prolog_tac = DEPTH_FIRST (has_fewer_prems 1) (resolve_tac (@{thms rules}) 1)
+fun prolog_tac ctxt =
+  DEPTH_FIRST (has_fewer_prems 1) (resolve_tac ctxt @{thms rules} 1)
 *}
 
 schematic_lemma "rev(?x, a:b:c:Nil)"
-apply (tactic prolog_tac)
+apply (tactic \<open>prolog_tac @{context}\<close>)
 done
 
 schematic_lemma "rev(a:?x:c:?y:Nil, d:?z:b:?u)"
-apply (tactic prolog_tac)
+apply (tactic \<open>prolog_tac @{context}\<close>)
 done
 
 (*rev([a..p], ?w) requires 153 inferences *)
 schematic_lemma "rev(a:b:c:d:e:f:g:h:i:j:k:l:m:n:o:p:Nil, ?w)"
-apply (tactic {* DEPTH_SOLVE (resolve_tac ([@{thm refl}, @{thm conjI}] @ @{thms rules}) 1) *})
+apply (tactic {*
+  DEPTH_SOLVE (resolve_tac @{context} ([@{thm refl}, @{thm conjI}] @ @{thms rules}) 1) *})
 done
 
 (*?x has 16, ?y has 32;  rev(?y,?w) requires 561 (rather large) inferences
   total inferences = 2 + 1 + 17 + 561 = 581*)
 schematic_lemma "a:b:c:d:e:f:g:h:i:j:k:l:m:n:o:p:Nil = ?x & app(?x,?x,?y) & rev(?y,?w)"
-apply (tactic {* DEPTH_SOLVE (resolve_tac ([@{thm refl}, @{thm conjI}] @ @{thms rules}) 1) *})
+apply (tactic {*
+  DEPTH_SOLVE (resolve_tac @{context} ([@{thm refl}, @{thm conjI}] @ @{thms rules}) 1) *})
 done
 
 end
--- a/src/FOL/intprover.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/FOL/intprover.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -76,12 +76,14 @@
 (*These steps could instantiate variables and are therefore unsafe.*)
 fun inst_step_tac ctxt =
   assume_tac ctxt APPEND' mp_tac APPEND' 
-  biresolve_tac (safe0_brls @ safep_brls);
+  biresolve_tac ctxt (safe0_brls @ safep_brls);
 
 (*One safe or unsafe step. *)
-fun step_tac ctxt i = FIRST [safe_tac ctxt, inst_step_tac ctxt i, biresolve_tac haz_brls i];
+fun step_tac ctxt i =
+  FIRST [safe_tac ctxt, inst_step_tac ctxt i, biresolve_tac ctxt haz_brls i];
 
-fun step_dup_tac ctxt i = FIRST [safe_tac ctxt, inst_step_tac ctxt i, biresolve_tac haz_dup_brls i];
+fun step_dup_tac ctxt i =
+  FIRST [safe_tac ctxt, inst_step_tac ctxt i, biresolve_tac ctxt haz_dup_brls i];
 
 (*Dumb but fast*)
 fun fast_tac ctxt = SELECT_GOAL (DEPTH_SOLVE (step_tac ctxt 1));
--- a/src/FOL/simpdata.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/FOL/simpdata.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -23,7 +23,7 @@
 (*Replace premises x=y, X<->Y by X==Y*)
 fun mk_meta_prems ctxt =
     rule_by_tactic ctxt
-      (REPEAT_FIRST (resolve_tac [@{thm meta_eq_to_obj_eq}, @{thm def_imp_iff}]));
+      (REPEAT_FIRST (resolve_tac ctxt [@{thm meta_eq_to_obj_eq}, @{thm def_imp_iff}]));
 
 (*Congruence rules for = or <-> (instead of ==)*)
 fun mk_meta_cong ctxt rl =
@@ -107,9 +107,9 @@
 val triv_rls = [@{thm TrueI}, @{thm refl}, reflexive_thm, @{thm iff_refl}, @{thm notFalseI}];
 
 fun unsafe_solver ctxt =
-  FIRST' [resolve_tac (triv_rls @ Simplifier.prems_of ctxt),
+  FIRST' [resolve_tac ctxt (triv_rls @ Simplifier.prems_of ctxt),
     assume_tac ctxt,
-    eresolve_tac @{thms FalseE}];
+    eresolve_tac ctxt @{thms FalseE}];
 
 (*No premature instantiation of variables during simplification*)
 fun safe_solver ctxt =
--- a/src/FOLP/FOLP.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/FOLP/FOLP.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -57,7 +57,7 @@
   shows "?p : R"
   apply (rule excluded_middle [THEN disjE])
    apply (tactic {* DEPTH_SOLVE (atac 1 ORELSE
-       resolve_tac [@{thm r1}, @{thm r2}, @{thm major} RS @{thm mp}] 1) *})
+       resolve_tac @{context} [@{thm r1}, @{thm r2}, @{thm major} RS @{thm mp}] 1) *})
   done
 
 (*Double negation law*)
@@ -81,8 +81,8 @@
   apply (unfold iff_def)
   apply (rule conjE)
   apply (tactic {* DEPTH_SOLVE_1 (etac @{thm impCE} 1 ORELSE
-      eresolve_tac [@{thm notE}, @{thm impE}] 1 THEN atac 1 ORELSE atac 1 ORELSE
-      resolve_tac [@{thm r1}, @{thm r2}] 1) *})+
+      eresolve_tac @{context} [@{thm notE}, @{thm impE}] 1 THEN atac 1 ORELSE atac 1 ORELSE
+      resolve_tac @{context} [@{thm r1}, @{thm r2}] 1) *})+
   done
 
 
--- a/src/FOLP/IFOLP.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/FOLP/IFOLP.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -273,13 +273,13 @@
 (*Finds P-->Q and P in the assumptions, replaces implication by Q *)
 ML {*
   fun mp_tac ctxt i =
-    eresolve_tac [@{thm notE}, make_elim @{thm mp}] i  THEN  assume_tac ctxt i
+    eresolve_tac ctxt [@{thm notE}, make_elim @{thm mp}] i  THEN  assume_tac ctxt i
 *}
 
 (*Like mp_tac but instantiates no variables*)
 ML {*
   fun int_uniq_mp_tac ctxt i =
-    eresolve_tac [@{thm notE}, @{thm impE}] i  THEN  uniq_assume_tac ctxt i
+    eresolve_tac ctxt [@{thm notE}, @{thm impE}] i  THEN  uniq_assume_tac ctxt i
 *}
 
 
@@ -361,8 +361,8 @@
 (*Use iffE on a premise.  For conj_cong, imp_cong, all_cong, ex_cong*)
 ML {*
 fun iff_tac prems i =
-    resolve_tac (prems RL [@{thm iffE}]) i THEN
-    REPEAT1 (eresolve_tac [asm_rl, @{thm mp}] i)
+    resolve0_tac (prems RL [@{thm iffE}]) i THEN
+    REPEAT1 (eresolve0_tac [asm_rl, @{thm mp}] i)
 *}
 
 schematic_lemma conj_cong:
@@ -503,17 +503,20 @@
 
 schematic_lemma pred1_cong: "p:a=a' ==> ?p:P(a) <-> P(a')"
   apply (rule iffI)
-   apply (tactic {* DEPTH_SOLVE (atac 1 ORELSE eresolve_tac [@{thm subst}, @{thm ssubst}] 1) *})
+   apply (tactic {*
+     DEPTH_SOLVE (atac 1 ORELSE eresolve_tac @{context} [@{thm subst}, @{thm ssubst}] 1) *})
   done
 
 schematic_lemma pred2_cong: "[| p:a=a';  q:b=b' |] ==> ?p:P(a,b) <-> P(a',b')"
   apply (rule iffI)
-   apply (tactic {* DEPTH_SOLVE (atac 1 ORELSE eresolve_tac [@{thm subst}, @{thm ssubst}] 1) *})
+   apply (tactic {*
+     DEPTH_SOLVE (atac 1 ORELSE eresolve_tac @{context} [@{thm subst}, @{thm ssubst}] 1) *})
   done
 
 schematic_lemma pred3_cong: "[| p:a=a';  q:b=b';  r:c=c' |] ==> ?p:P(a,b,c) <-> P(a',b',c')"
   apply (rule iffI)
-   apply (tactic {* DEPTH_SOLVE (atac 1 ORELSE eresolve_tac [@{thm subst}, @{thm ssubst}] 1) *})
+   apply (tactic {*
+     DEPTH_SOLVE (atac 1 ORELSE eresolve_tac @{context} [@{thm subst}, @{thm ssubst}] 1) *})
   done
 
 lemmas pred_congs = pred1_cong pred2_cong pred3_cong
@@ -541,7 +544,7 @@
     and minor: "!!x y.[| x:P-->S; y:Q-->S |] ==> q(x,y):R"
   shows "?p:R"
   apply (tactic {* DEPTH_SOLVE (atac 1 ORELSE
-      resolve_tac [@{thm disjI1}, @{thm disjI2}, @{thm impI},
+      resolve_tac @{context} [@{thm disjI1}, @{thm disjI2}, @{thm impI},
         @{thm major} RS @{thm mp}, @{thm minor}] 1) *})
   done
 
--- a/src/FOLP/classical.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/FOLP/classical.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -73,7 +73,7 @@
 fun contr_tac ctxt = etac not_elim THEN'  assume_tac ctxt;
 
 (*Finds P-->Q and P in the assumptions, replaces implication by Q *)
-fun mp_tac ctxt i = eresolve_tac ([not_elim,imp_elim]) i  THEN  assume_tac ctxt i;
+fun mp_tac ctxt i = eresolve_tac ctxt ([not_elim,imp_elim]) i  THEN  assume_tac ctxt i;
 
 (*Like mp_tac but instantiates no variables*)
 fun uniq_mp_tac ctxt i = ematch_tac ctxt ([not_elim,imp_elim]) i  THEN  uniq_assume_tac ctxt i;
@@ -151,9 +151,9 @@
 fun safe_step_tac ctxt (CS{safe0_brls,safep_brls,...}) = 
   FIRST' [uniq_assume_tac ctxt,
           uniq_mp_tac ctxt,
-          biresolve_tac safe0_brls,
+          biresolve_tac ctxt safe0_brls,
           FIRST' hyp_subst_tacs,
-          biresolve_tac safep_brls] ;
+          biresolve_tac ctxt safep_brls] ;
 
 (*Repeatedly attack subgoals using safe inferences*)
 fun safe_tac ctxt cs = DETERM (REPEAT_FIRST (safe_step_tac ctxt cs));
@@ -165,7 +165,7 @@
 fun step_tac ctxt (cs as (CS{haz_brls,...})) i = 
   FIRST [safe_tac ctxt cs,
          inst_step_tac ctxt i,
-         biresolve_tac haz_brls i];
+         biresolve_tac ctxt haz_brls i];
 
 (*** The following tactics all fail unless they solve one goal ***)
 
@@ -179,7 +179,7 @@
 (*Using a "safe" rule to instantiate variables is unsafe.  This tactic
   allows backtracking from "safe" rules to "unsafe" rules here.*)
 fun slow_step_tac ctxt (cs as (CS{haz_brls,...})) i = 
-    safe_tac ctxt cs ORELSE (assume_tac ctxt i APPEND biresolve_tac haz_brls i);
+    safe_tac ctxt cs ORELSE (assume_tac ctxt i APPEND biresolve_tac ctxt haz_brls i);
 
 end; 
 end;
--- a/src/FOLP/intprover.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/FOLP/intprover.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -54,9 +54,9 @@
 (*Attack subgoals using safe inferences*)
 fun safe_step_tac ctxt = FIRST' [uniq_assume_tac ctxt,
                             int_uniq_mp_tac ctxt,
-                            biresolve_tac safe0_brls,
+                            biresolve_tac ctxt safe0_brls,
                             hyp_subst_tac,
-                            biresolve_tac safep_brls] ;
+                            biresolve_tac ctxt safep_brls] ;
 
 (*Repeatedly attack subgoals using safe inferences*)
 fun safe_tac ctxt = DETERM (REPEAT_FIRST (safe_step_tac ctxt));
@@ -65,7 +65,7 @@
 fun inst_step_tac ctxt = assume_tac ctxt APPEND' mp_tac ctxt;
 
 (*One safe or unsafe step. *)
-fun step_tac ctxt i = FIRST [safe_tac ctxt, inst_step_tac ctxt i, biresolve_tac haz_brls i];
+fun step_tac ctxt i = FIRST [safe_tac ctxt, inst_step_tac ctxt i, biresolve_tac ctxt haz_brls i];
 
 (*Dumb but fast*)
 fun fast_tac ctxt = SELECT_GOAL (DEPTH_SOLVE (step_tac ctxt 1));
--- a/src/FOLP/simp.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/FOLP/simp.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -75,12 +75,12 @@
   rewrite rules are not ordered.*)
 fun net_tac net =
   SUBGOAL(fn (prem,i) =>
-          resolve_tac (Net.unify_term net (Logic.strip_assums_concl prem)) i);
+          resolve0_tac (Net.unify_term net (Logic.strip_assums_concl prem)) i);
 
 (*match subgoal i against possible theorems indexed by lhs in the net*)
 fun lhs_net_tac net =
   SUBGOAL(fn (prem,i) =>
-          biresolve_tac (Net.unify_term net
+          biresolve0_tac (Net.unify_term net
                        (lhs_of (Logic.strip_assums_concl prem))) i);
 
 fun nth_subgoal i thm = nth (prems_of thm) (i - 1);
@@ -119,7 +119,7 @@
 fun lhs_is_NORM(thm,i) = case lhs_of_eq i thm of
         Const(s,_)$_ => member (op =) norms s | _ => false;
 
-val refl_tac = resolve_tac refl_thms;
+val refl_tac = resolve0_tac refl_thms;
 
 fun find_res thms thm =
     let fun find [] = error "Check Simp_Data"
@@ -138,7 +138,7 @@
         SOME(thm',_) => thm'
       | NONE => raise THM("Simplifier: could not continue", 0, [thm]);
 
-fun res1(thm,thms,i) = one_result(resolve_tac thms i,thm);
+fun res1(thm,thms,i) = one_result(resolve0_tac thms i,thm);
 
 
 (**** Adding "NORM" tags ****)
@@ -204,10 +204,10 @@
     fun norm_step_tac st = st |>
          (case head_of(rhs_of_eq 1 st) of
             Var(ixn,_) => if member (op =) hvs ixn then refl1_tac
-                          else resolve_tac normI_thms 1 ORELSE refl1_tac
-          | Const _ => resolve_tac normI_thms 1 ORELSE
-                       resolve_tac congs 1 ORELSE refl1_tac
-          | Free _ => resolve_tac congs 1 ORELSE refl1_tac
+                          else resolve0_tac normI_thms 1 ORELSE refl1_tac
+          | Const _ => resolve0_tac normI_thms 1 ORELSE
+                       resolve0_tac congs 1 ORELSE refl1_tac
+          | Free _ => resolve0_tac congs 1 ORELSE refl1_tac
           | _ => refl1_tac)
     val add_norm_tac = DEPTH_FIRST (has_fewer_prems nops) norm_step_tac
     val SOME(thm'',_) = Seq.pull(add_norm_tac thm')
--- a/src/HOL/Auth/Event.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Auth/Event.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -272,7 +272,7 @@
 {*
 fun analz_mono_contra_tac ctxt = 
   rtac @{thm analz_impI} THEN' 
-  REPEAT1 o (dresolve_tac @{thms analz_mono_contra})
+  REPEAT1 o (dresolve_tac ctxt @{thms analz_mono_contra})
   THEN' (mp_tac ctxt)
 *}
 
@@ -289,7 +289,7 @@
 fun synth_analz_mono_contra_tac ctxt = 
   rtac @{thm syan_impI} THEN'
   REPEAT1 o 
-    (dresolve_tac 
+    (dresolve_tac ctxt
      [@{thm knows_Spy_subset_knows_Spy_Says} RS @{thm synth_analz_mono} RS @{thm contra_subsetD},
       @{thm knows_Spy_subset_knows_Spy_Notes} RS @{thm synth_analz_mono} RS @{thm contra_subsetD},
       @{thm knows_Spy_subset_knows_Spy_Gets} RS @{thm synth_analz_mono} RS @{thm contra_subsetD}])
--- a/src/HOL/Auth/Message.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Auth/Message.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -845,13 +845,13 @@
 (*Apply rules to break down assumptions of the form
   Y \<in> parts(insert X H)  and  Y \<in> analz(insert X H)
 *)
-val Fake_insert_tac = 
-    dresolve_tac [impOfSubs @{thm Fake_analz_insert},
+fun Fake_insert_tac ctxt = 
+    dresolve_tac ctxt [impOfSubs @{thm Fake_analz_insert},
                   impOfSubs @{thm Fake_parts_insert}] THEN'
-    eresolve_tac [asm_rl, @{thm synth.Inj}];
+    eresolve_tac ctxt [asm_rl, @{thm synth.Inj}];
 
 fun Fake_insert_simp_tac ctxt i = 
-  REPEAT (Fake_insert_tac i) THEN asm_full_simp_tac ctxt i;
+  REPEAT (Fake_insert_tac ctxt i) THEN asm_full_simp_tac ctxt i;
 
 fun atomic_spy_analz_tac ctxt =
   SELECT_GOAL
@@ -869,7 +869,7 @@
            (res_inst_tac ctxt [(("x", 1), "X")] (insert_commute RS ssubst) 1),
        (*...allowing further simplifications*)
        simp_tac ctxt 1,
-       REPEAT (FIRSTGOAL (resolve_tac [allI,impI,notI,conjI,iffI])),
+       REPEAT (FIRSTGOAL (resolve_tac ctxt [allI,impI,notI,conjI,iffI])),
        DEPTH_SOLVE (atomic_spy_analz_tac ctxt 1)]) i);
 *}
 
--- a/src/HOL/Auth/OtwayReesBella.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Auth/OtwayReesBella.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -126,14 +126,14 @@
 
 ML
 {*
-fun parts_explicit_tac i = 
-    forward_tac [@{thm Oops_parts_knows_Spy}] (i+7) THEN
-    forward_tac [@{thm OR4_parts_knows_Spy}]  (i+6) THEN
-    forward_tac [@{thm OR2_parts_knows_Spy}]  (i+4)
+fun parts_explicit_tac ctxt i =
+    forward_tac ctxt [@{thm Oops_parts_knows_Spy}] (i+7) THEN
+    forward_tac ctxt [@{thm OR4_parts_knows_Spy}]  (i+6) THEN
+    forward_tac ctxt [@{thm OR2_parts_knows_Spy}]  (i+4)
 *}
  
 method_setup parts_explicit = {*
-    Scan.succeed (K (SIMPLE_METHOD' parts_explicit_tac)) *}
+    Scan.succeed (SIMPLE_METHOD' o parts_explicit_tac) *}
   "to explicitly state that some message components belong to parts knows Spy"
 
 
@@ -249,7 +249,7 @@
 method_setup analz_freshCryptK = {*
     Scan.succeed (fn ctxt =>
      (SIMPLE_METHOD
-      (EVERY [REPEAT_FIRST (resolve_tac [allI, ballI, impI]),
+      (EVERY [REPEAT_FIRST (resolve_tac ctxt [allI, ballI, impI]),
           REPEAT_FIRST (rtac @{thm analz_image_freshCryptK_lemma}),
           ALLGOALS (asm_simp_tac
             (put_simpset OtwayReesBella.analz_image_freshK_ss ctxt))]))) *}
@@ -259,7 +259,7 @@
 method_setup disentangle = {*
     Scan.succeed
      (fn ctxt => SIMPLE_METHOD
-      (REPEAT_FIRST (eresolve_tac [asm_rl, conjE, disjE] 
+      (REPEAT_FIRST (eresolve_tac ctxt [asm_rl, conjE, disjE] 
                    ORELSE' hyp_subst_tac ctxt))) *}
   "for eliminating conjunctions, disjunctions and the like"
 
--- a/src/HOL/Auth/Public.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Auth/Public.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -417,7 +417,7 @@
     (ALLGOALS (simp_tac (ctxt setSolver safe_solver delsimps [@{thm used_Says}]))
      THEN
      REPEAT_FIRST (eq_assume_tac ORELSE' 
-                   resolve_tac [refl, conjI, @{thm Nonce_supply}]))
+                   resolve_tac ctxt [refl, conjI, @{thm Nonce_supply}]))
 
 (*For harder protocols (such as Recur) where we have to set up some
   nonces and keys initially*)
@@ -425,7 +425,7 @@
     REPEAT 
     (ALLGOALS (asm_simp_tac (ctxt setSolver safe_solver))
      THEN
-     REPEAT_FIRST (resolve_tac [refl, conjI]))
+     REPEAT_FIRST (resolve_tac ctxt [refl, conjI]))
 
 end
 *}
@@ -433,7 +433,7 @@
 method_setup analz_freshK = {*
     Scan.succeed (fn ctxt =>
      (SIMPLE_METHOD
-      (EVERY [REPEAT_FIRST (resolve_tac [allI, ballI, impI]),
+      (EVERY [REPEAT_FIRST (resolve_tac ctxt [allI, ballI, impI]),
           REPEAT_FIRST (rtac @{thm analz_image_freshK_lemma}),
           ALLGOALS (asm_simp_tac (put_simpset Public.analz_image_freshK_ss ctxt))]))) *}
     "for proving the Session Key Compromise theorem"
--- a/src/HOL/Auth/Shared.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Auth/Shared.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -205,7 +205,7 @@
           setSolver safe_solver))
      THEN
      REPEAT_FIRST (eq_assume_tac ORELSE' 
-                   resolve_tac [refl, conjI, @{thm Nonce_supply}])))
+                   resolve_tac ctxt [refl, conjI, @{thm Nonce_supply}])))
 
 (*For harder protocols (such as Recur) where we have to set up some
   nonces and keys initially*)
@@ -213,7 +213,7 @@
     REPEAT 
     (ALLGOALS (asm_simp_tac (ctxt setSolver safe_solver))
      THEN
-     REPEAT_FIRST (resolve_tac [refl, conjI]))
+     REPEAT_FIRST (resolve_tac ctxt [refl, conjI]))
 
 
 val analz_image_freshK_ss =
@@ -237,7 +237,7 @@
 method_setup analz_freshK = {*
     Scan.succeed (fn ctxt =>
      (SIMPLE_METHOD
-      (EVERY [REPEAT_FIRST (resolve_tac [allI, ballI, impI]),
+      (EVERY [REPEAT_FIRST (resolve_tac ctxt [allI, ballI, impI]),
           REPEAT_FIRST (rtac @{thm analz_image_freshK_lemma}),
           ALLGOALS (asm_simp_tac (put_simpset Shared.analz_image_freshK_ss ctxt))]))) *}
     "for proving the Session Key Compromise theorem"
--- a/src/HOL/Auth/Smartcard/ShoupRubin.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Auth/Smartcard/ShoupRubin.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -736,32 +736,32 @@
 structure ShoupRubin =
 struct
 
-val prepare_tac = 
- (*SR8*)   forward_tac [@{thm Outpts_B_Card_form_7}] 14 THEN
-           eresolve_tac [exE] 15 THEN eresolve_tac [exE] 15 THEN 
- (*SR9*)   forward_tac [@{thm Outpts_A_Card_form_4}] 16 THEN 
- (*SR11*)  forward_tac [@{thm Outpts_A_Card_form_10}] 21 THEN
-           eresolve_tac [exE] 22 THEN eresolve_tac [exE] 22
+fun prepare_tac ctxt = 
+ (*SR8*)   forward_tac ctxt [@{thm Outpts_B_Card_form_7}] 14 THEN
+           eresolve_tac ctxt [exE] 15 THEN eresolve_tac ctxt [exE] 15 THEN 
+ (*SR9*)   forward_tac ctxt [@{thm Outpts_A_Card_form_4}] 16 THEN 
+ (*SR11*)  forward_tac ctxt [@{thm Outpts_A_Card_form_10}] 21 THEN
+           eresolve_tac ctxt [exE] 22 THEN eresolve_tac ctxt [exE] 22
 
 fun parts_prepare_tac ctxt = 
-           prepare_tac THEN
- (*SR9*)   dresolve_tac [@{thm Gets_imp_knows_Spy_parts_Snd}] 18 THEN 
- (*SR9*)   dresolve_tac [@{thm Gets_imp_knows_Spy_parts_Snd}] 19 THEN 
- (*Oops1*) dresolve_tac [@{thm Outpts_B_Card_form_7}] 25    THEN               
- (*Oops2*) dresolve_tac [@{thm Outpts_A_Card_form_10}] 27 THEN                
+           prepare_tac ctxt THEN
+ (*SR9*)   dresolve_tac ctxt [@{thm Gets_imp_knows_Spy_parts_Snd}] 18 THEN 
+ (*SR9*)   dresolve_tac ctxt [@{thm Gets_imp_knows_Spy_parts_Snd}] 19 THEN 
+ (*Oops1*) dresolve_tac ctxt [@{thm Outpts_B_Card_form_7}] 25    THEN               
+ (*Oops2*) dresolve_tac ctxt [@{thm Outpts_A_Card_form_10}] 27 THEN                
  (*Base*)  (force_tac ctxt) 1
 
 fun analz_prepare_tac ctxt =
-         prepare_tac THEN
+         prepare_tac ctxt THEN
          dtac @{thm Gets_imp_knows_Spy_analz_Snd} 18 THEN 
  (*SR9*) dtac @{thm Gets_imp_knows_Spy_analz_Snd} 19 THEN 
-         REPEAT_FIRST (eresolve_tac [asm_rl, conjE] ORELSE' hyp_subst_tac ctxt)
+         REPEAT_FIRST (eresolve_tac ctxt [asm_rl, conjE] ORELSE' hyp_subst_tac ctxt)
 
 end
 *}
 
 method_setup prepare = {*
-    Scan.succeed (K (SIMPLE_METHOD ShoupRubin.prepare_tac)) *}
+    Scan.succeed (SIMPLE_METHOD o ShoupRubin.prepare_tac) *}
   "to launch a few simple facts that will help the simplifier"
 
 method_setup parts_prepare = {*
@@ -817,7 +817,7 @@
     Scan.succeed (fn ctxt =>
      (SIMPLE_METHOD
       (EVERY [REPEAT_FIRST
-       (resolve_tac [allI, ballI, impI]),
+       (resolve_tac ctxt [allI, ballI, impI]),
         REPEAT_FIRST (rtac @{thm analz_image_freshK_lemma}),
         ALLGOALS (asm_simp_tac (put_simpset Smartcard.analz_image_freshK_ss ctxt
           addsimps [@{thm knows_Spy_Inputs_secureM_sr_Spy},
--- a/src/HOL/Auth/Smartcard/ShoupRubinBella.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Auth/Smartcard/ShoupRubinBella.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -747,24 +747,24 @@
 struct
 
 fun prepare_tac ctxt = 
- (*SR_U8*)   forward_tac [@{thm Outpts_B_Card_form_7}] 14 THEN
+ (*SR_U8*)   forward_tac ctxt [@{thm Outpts_B_Card_form_7}] 14 THEN
  (*SR_U8*)   clarify_tac ctxt 15 THEN
- (*SR_U9*)   forward_tac [@{thm Outpts_A_Card_form_4}] 16 THEN 
- (*SR_U11*)  forward_tac [@{thm Outpts_A_Card_form_10}] 21 
+ (*SR_U9*)   forward_tac ctxt [@{thm Outpts_A_Card_form_4}] 16 THEN 
+ (*SR_U11*)  forward_tac ctxt [@{thm Outpts_A_Card_form_10}] 21 
 
 fun parts_prepare_tac ctxt = 
            prepare_tac ctxt THEN
- (*SR_U9*)   dresolve_tac [@{thm Gets_imp_knows_Spy_parts_Snd}] 18 THEN 
- (*SR_U9*)   dresolve_tac [@{thm Gets_imp_knows_Spy_parts_Snd}] 19 THEN 
- (*Oops1*) dresolve_tac [@{thm Outpts_B_Card_form_7}] 25    THEN               
- (*Oops2*) dresolve_tac [@{thm Outpts_A_Card_form_10}] 27 THEN                
+ (*SR_U9*)   dresolve_tac ctxt [@{thm Gets_imp_knows_Spy_parts_Snd}] 18 THEN 
+ (*SR_U9*)   dresolve_tac ctxt [@{thm Gets_imp_knows_Spy_parts_Snd}] 19 THEN 
+ (*Oops1*) dresolve_tac ctxt [@{thm Outpts_B_Card_form_7}] 25    THEN               
+ (*Oops2*) dresolve_tac ctxt [@{thm Outpts_A_Card_form_10}] 27 THEN                
  (*Base*)  (force_tac ctxt) 1
 
 fun analz_prepare_tac ctxt = 
          prepare_tac ctxt THEN
          dtac (@{thm Gets_imp_knows_Spy_analz_Snd}) 18 THEN 
  (*SR_U9*) dtac (@{thm Gets_imp_knows_Spy_analz_Snd}) 19 THEN 
-         REPEAT_FIRST (eresolve_tac [asm_rl, conjE] ORELSE' hyp_subst_tac ctxt)
+         REPEAT_FIRST (eresolve_tac ctxt [asm_rl, conjE] ORELSE' hyp_subst_tac ctxt)
 
 end
 *}
@@ -826,7 +826,7 @@
 method_setup sc_analz_freshK = {*
     Scan.succeed (fn ctxt =>
      (SIMPLE_METHOD
-      (EVERY [REPEAT_FIRST (resolve_tac [allI, ballI, impI]),
+      (EVERY [REPEAT_FIRST (resolve_tac ctxt [allI, ballI, impI]),
           REPEAT_FIRST (rtac @{thm analz_image_freshK_lemma}),
           ALLGOALS (asm_simp_tac (put_simpset Smartcard.analz_image_freshK_ss ctxt
               addsimps [@{thm knows_Spy_Inputs_secureM_srb_Spy},
--- a/src/HOL/Auth/Smartcard/Smartcard.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Auth/Smartcard/Smartcard.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -374,7 +374,7 @@
       setSolver safe_solver))
      THEN
      REPEAT_FIRST (eq_assume_tac ORELSE' 
-                   resolve_tac [refl, conjI, @{thm Nonce_supply}])))
+                   resolve_tac ctxt [refl, conjI, @{thm Nonce_supply}])))
 
 (*For harder protocols (such as Recur) where we have to set up some
   nonces and keys initially*)
@@ -382,7 +382,7 @@
     REPEAT 
     (ALLGOALS (asm_simp_tac (ctxt setSolver safe_solver))
      THEN
-     REPEAT_FIRST (resolve_tac [refl, conjI]))
+     REPEAT_FIRST (resolve_tac ctxt [refl, conjI]))
 
 val analz_image_freshK_ss = 
   simpset_of
@@ -403,7 +403,7 @@
 method_setup analz_freshK = {*
     Scan.succeed (fn ctxt =>
      (SIMPLE_METHOD
-      (EVERY [REPEAT_FIRST (resolve_tac [allI, ballI, impI]),
+      (EVERY [REPEAT_FIRST (resolve_tac ctxt [allI, ballI, impI]),
           REPEAT_FIRST (rtac @{thm analz_image_freshK_lemma}),
           ALLGOALS (asm_simp_tac (put_simpset Smartcard.analz_image_freshK_ss ctxt))]))) *}
     "for proving the Session Key Compromise theorem"
--- a/src/HOL/Bali/AxExample.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Bali/AxExample.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -46,9 +46,9 @@
     SOME i => Rule_Insts.instantiate_tac ctxt [((s, i), t)] xs st
   | NONE => Seq.empty);
 
-val ax_tac =
+fun ax_tac ctxt =
   REPEAT o rtac allI THEN'
-  resolve_tac (@{thm ax_Skip} :: @{thm ax_StatRef} :: @{thm ax_MethdN} :: @{thm ax_Alloc} ::
+  resolve_tac ctxt (@{thm ax_Skip} :: @{thm ax_StatRef} :: @{thm ax_MethdN} :: @{thm ax_Alloc} ::
     @{thm ax_Alloc_Arr} :: @{thm ax_SXAlloc_Normal} :: @{thms ax_derivs.intros(8-)});
 *}
 
@@ -58,11 +58,11 @@
   .test [Class Base]. 
   {\<lambda>Y s Z. abrupt s = Some (Xcpt (Std IndOutBound))}"
 apply (unfold test_def arr_viewed_from_def)
-apply (tactic "ax_tac 1" (*;;*))
+apply (tactic "ax_tac @{context} 1" (*;;*))
 defer (* We begin with the last assertion, to synthesise the intermediate
          assertions, like in the fashion of the weakest
          precondition. *)
-apply  (tactic "ax_tac 1" (* Try *))
+apply  (tactic "ax_tac @{context} 1" (* Try *))
 defer
 apply    (tactic {* inst1_tac @{context} "Q" 
                  "\<lambda>Y s Z. arr_inv (snd s) \<and> tprg,s\<turnstile>catch SXcpt NullPointer" [] *})
@@ -74,26 +74,26 @@
 apply   (rule_tac Q' = "(\<lambda>Y s Z. ?Q Y s Z)\<leftarrow>=False\<down>=\<diamondsuit>" in conseq2)
 prefer 2
 apply    simp
-apply   (tactic "ax_tac 1" (* While *))
+apply   (tactic "ax_tac @{context} 1" (* While *))
 prefer 2
 apply    (rule ax_impossible [THEN conseq1], clarsimp)
 apply   (rule_tac P' = "Normal ?P" in conseq1)
 prefer 2
 apply    clarsimp
-apply   (tactic "ax_tac 1")
-apply   (tactic "ax_tac 1" (* AVar *))
+apply   (tactic "ax_tac @{context} 1")
+apply   (tactic "ax_tac @{context} 1" (* AVar *))
 prefer 2
 apply    (rule ax_subst_Val_allI)
 apply    (tactic {* inst1_tac @{context} "P'" "\<lambda>a. Normal (PP a\<leftarrow>x)" ["PP", "x"] *})
 apply    (simp del: avar_def2 peek_and_def2)
-apply    (tactic "ax_tac 1")
-apply   (tactic "ax_tac 1")
+apply    (tactic "ax_tac @{context} 1")
+apply   (tactic "ax_tac @{context} 1")
       (* just for clarification: *)
 apply   (rule_tac Q' = "Normal (\<lambda>Var:(v, f) u ua. fst (snd (avar tprg (Intg 2) v u)) = Some (Xcpt (Std IndOutBound)))" in conseq2)
 prefer 2
 apply    (clarsimp simp add: split_beta)
-apply   (tactic "ax_tac 1" (* FVar *))
-apply    (tactic "ax_tac 2" (* StatRef *))
+apply   (tactic "ax_tac @{context} 1" (* FVar *))
+apply    (tactic "ax_tac @{context} 2" (* StatRef *))
 apply   (rule ax_derivs.Done [THEN conseq1])
 apply   (clarsimp simp add: arr_inv_def inited_def in_bounds_def)
 defer
@@ -101,20 +101,20 @@
 apply  (rule_tac Q' = "(\<lambda>Y (x, s) Z. x = Some (Xcpt (Std NullPointer)) \<and> arr_inv s) \<and>. heap_free two" in conseq2)
 prefer 2
 apply   (simp add: arr_inv_new_obj)
-apply  (tactic "ax_tac 1") 
+apply  (tactic "ax_tac @{context} 1") 
 apply  (rule_tac C = "Ext" in ax_Call_known_DynT)
 apply     (unfold DynT_prop_def)
 apply     (simp (no_asm))
 apply    (intro strip)
 apply    (rule_tac P' = "Normal ?P" in conseq1)
-apply     (tactic "ax_tac 1" (* Methd *))
+apply     (tactic "ax_tac @{context} 1" (* Methd *))
 apply     (rule ax_thin [OF _ empty_subsetI])
 apply     (simp (no_asm) add: body_def2)
-apply     (tactic "ax_tac 1" (* Body *))
+apply     (tactic "ax_tac @{context} 1" (* Body *))
 (* apply       (rule_tac [2] ax_derivs.Abrupt) *)
 defer
 apply      (simp (no_asm))
-apply      (tactic "ax_tac 1") (* Comp *)
+apply      (tactic "ax_tac @{context} 1") (* Comp *)
             (* The first statement in the  composition 
                  ((Ext)z).vee = 1; Return Null 
                 will throw an exception (since z is null). So we can handle
@@ -122,7 +122,7 @@
 apply       (rule_tac [2] ax_derivs.Abrupt)
              
 apply      (rule ax_derivs.Expr) (* Expr *)
-apply      (tactic "ax_tac 1") (* Ass *)
+apply      (tactic "ax_tac @{context} 1") (* Ass *)
 prefer 2
 apply       (rule ax_subst_Var_allI)
 apply       (tactic {* inst1_tac @{context} "P'" "\<lambda>a vs l vf. PP a vs l vf\<leftarrow>x \<and>. p" ["PP", "x", "p"] *})
@@ -130,9 +130,9 @@
 apply       (tactic {* simp_tac (@{context} delloop "split_all_tac" delsimps [@{thm peek_and_def2}, @{thm heap_def2}, @{thm subst_res_def2}, @{thm normal_def2}]) 1 *})
 apply       (rule ax_derivs.Abrupt)
 apply      (simp (no_asm))
-apply      (tactic "ax_tac 1" (* FVar *))
-apply       (tactic "ax_tac 2", tactic "ax_tac 2", tactic "ax_tac 2")
-apply      (tactic "ax_tac 1")
+apply      (tactic "ax_tac @{context} 1" (* FVar *))
+apply       (tactic "ax_tac @{context} 2", tactic "ax_tac @{context} 2", tactic "ax_tac @{context} 2")
+apply      (tactic "ax_tac @{context} 1")
 apply     (tactic {* inst1_tac @{context} "R" "\<lambda>a'. Normal ((\<lambda>Vals:vs (x, s) Z. arr_inv s \<and> inited Ext (globs s) \<and> a' \<noteq> Null \<and> vs = [Null]) \<and>. heap_free two)" [] *})
 apply     fastforce
 prefer 4
@@ -140,15 +140,15 @@
 apply   (rule ax_subst_Val_allI)
 apply   (tactic {* inst1_tac @{context} "P'" "\<lambda>a. Normal (PP a\<leftarrow>x)" ["PP", "x"] *})
 apply   (simp (no_asm) del: peek_and_def2 heap_free_def2 normal_def2 o_apply)
-apply   (tactic "ax_tac 1")
+apply   (tactic "ax_tac @{context} 1")
 prefer 2
 apply   (rule ax_subst_Val_allI)
 apply    (tactic {* inst1_tac @{context} "P'" "\<lambda>aa v. Normal (QQ aa v\<leftarrow>y)" ["QQ", "y"] *})
 apply    (simp del: peek_and_def2 heap_free_def2 normal_def2)
-apply    (tactic "ax_tac 1")
-apply   (tactic "ax_tac 1")
-apply  (tactic "ax_tac 1")
-apply  (tactic "ax_tac 1")
+apply    (tactic "ax_tac @{context} 1")
+apply   (tactic "ax_tac @{context} 1")
+apply  (tactic "ax_tac @{context} 1")
+apply  (tactic "ax_tac @{context} 1")
 (* end method call *)
 apply (simp (no_asm))
     (* just for clarification: *)
@@ -158,14 +158,14 @@
   in conseq2)
 prefer 2
 apply  clarsimp
-apply (tactic "ax_tac 1")
-apply (tactic "ax_tac 1")
+apply (tactic "ax_tac @{context} 1")
+apply (tactic "ax_tac @{context} 1")
 defer
 apply  (rule ax_subst_Var_allI)
 apply  (tactic {* inst1_tac @{context} "P'" "\<lambda>vf. Normal (PP vf \<and>. p)" ["PP", "p"] *})
 apply  (simp (no_asm) del: split_paired_All peek_and_def2 initd_def2 heap_free_def2 normal_def2)
-apply  (tactic "ax_tac 1" (* NewC *))
-apply  (tactic "ax_tac 1" (* ax_Alloc *))
+apply  (tactic "ax_tac @{context} 1" (* NewC *))
+apply  (tactic "ax_tac @{context} 1" (* ax_Alloc *))
      (* just for clarification: *)
 apply  (rule_tac Q' = "Normal ((\<lambda>Y s Z. arr_inv (store s) \<and> vf=lvar (VName e) (store s)) \<and>. heap_free three \<and>. initd Ext)" in conseq2)
 prefer 2
@@ -187,19 +187,19 @@
 apply    (rule allI)
 apply    (rule_tac P' = "Normal ?P" in conseq1)
 apply     (tactic {* simp_tac (@{context} delloop "split_all_tac") 1 *})
-apply     (tactic "ax_tac 1")
-apply     (tactic "ax_tac 1")
+apply     (tactic "ax_tac @{context} 1")
+apply     (tactic "ax_tac @{context} 1")
 apply     (rule_tac [2] ax_subst_Var_allI)
 apply      (tactic {* inst1_tac @{context} "P'" "\<lambda>vf l vfa. Normal (P vf l vfa)" ["P"] *})
 apply     (tactic {* simp_tac (@{context} delloop "split_all_tac" delsimps [@{thm split_paired_All}, @{thm peek_and_def2}, @{thm heap_free_def2}, @{thm initd_def2}, @{thm normal_def2}, @{thm supd_lupd}]) 2 *})
-apply      (tactic "ax_tac 2" (* NewA *))
-apply       (tactic "ax_tac 3" (* ax_Alloc_Arr *))
-apply       (tactic "ax_tac 3")
+apply      (tactic "ax_tac @{context} 2" (* NewA *))
+apply       (tactic "ax_tac @{context} 3" (* ax_Alloc_Arr *))
+apply       (tactic "ax_tac @{context} 3")
 apply      (tactic {* inst1_tac @{context} "P" "\<lambda>vf l vfa. Normal (P vf l vfa\<leftarrow>\<diamondsuit>)" ["P"] *})
 apply      (tactic {* simp_tac (@{context} delloop "split_all_tac") 2 *})
-apply      (tactic "ax_tac 2")
-apply     (tactic "ax_tac 1" (* FVar *))
-apply      (tactic "ax_tac 2" (* StatRef *))
+apply      (tactic "ax_tac @{context} 2")
+apply     (tactic "ax_tac @{context} 1" (* FVar *))
+apply      (tactic "ax_tac @{context} 2" (* StatRef *))
 apply     (rule ax_derivs.Done [THEN conseq1])
 apply     (tactic {* inst1_tac @{context} "Q" "\<lambda>vf. Normal ((\<lambda>Y s Z. vf=lvar (VName e) (snd s)) \<and>. heap_free four \<and>. initd Base \<and>. initd Ext)" [] *})
 apply     (clarsimp split del: split_if)
@@ -217,7 +217,7 @@
 apply  clarsimp
      (* end init *)
 apply (rule conseq1)
-apply (tactic "ax_tac 1")
+apply (tactic "ax_tac @{context} 1")
 apply clarsimp
 done
 
@@ -234,36 +234,36 @@
         (Expr (Ass (LVar i) (Acc (LVar j))))). {Q}"
 apply (rule_tac P' = "Q" and Q' = "Q\<leftarrow>=False\<down>=\<diamondsuit>" in conseq12)
 apply  safe
-apply  (tactic "ax_tac 1" (* Loop *))
+apply  (tactic "ax_tac @{context} 1" (* Loop *))
 apply   (rule ax_Normal_cases)
 prefer 2
 apply    (rule ax_derivs.Abrupt [THEN conseq1], clarsimp simp add: Let_def)
 apply   (rule conseq1)
-apply    (tactic "ax_tac 1")
+apply    (tactic "ax_tac @{context} 1")
 apply   clarsimp
 prefer 2
 apply  clarsimp
-apply (tactic "ax_tac 1" (* If *))
+apply (tactic "ax_tac @{context} 1" (* If *))
 apply  (tactic 
   {* inst1_tac @{context} "P'" "Normal (\<lambda>s.. (\<lambda>Y s Z. True)\<down>=Val (the (locals s i)))" [] *})
-apply  (tactic "ax_tac 1")
+apply  (tactic "ax_tac @{context} 1")
 apply  (rule conseq1)
-apply   (tactic "ax_tac 1")
+apply   (tactic "ax_tac @{context} 1")
 apply  clarsimp
 apply (rule allI)
 apply (rule ax_escape)
 apply auto
 apply  (rule conseq1)
-apply   (tactic "ax_tac 1" (* Throw *))
-apply   (tactic "ax_tac 1")
-apply   (tactic "ax_tac 1")
+apply   (tactic "ax_tac @{context} 1" (* Throw *))
+apply   (tactic "ax_tac @{context} 1")
+apply   (tactic "ax_tac @{context} 1")
 apply  clarsimp
 apply (rule_tac Q' = "Normal (\<lambda>Y s Z. True)" in conseq2)
 prefer 2
 apply  clarsimp
 apply (rule conseq1)
-apply  (tactic "ax_tac 1")
-apply  (tactic "ax_tac 1")
+apply  (tactic "ax_tac @{context} 1")
+apply  (tactic "ax_tac @{context} 1")
 prefer 2
 apply   (rule ax_subst_Var_allI)
 apply   (tactic {* inst1_tac @{context} "P'" "\<lambda>b Y ba Z vf. \<lambda>Y (x,s) Z. x=None \<and> snd vf = snd (lvar i s)" [] *})
@@ -271,11 +271,11 @@
 apply   (rule_tac P' = "Normal ?P" in conseq1)
 prefer 2
 apply    clarsimp
-apply   (tactic "ax_tac 1")
+apply   (tactic "ax_tac @{context} 1")
 apply   (rule conseq1)
-apply    (tactic "ax_tac 1")
+apply    (tactic "ax_tac @{context} 1")
 apply   clarsimp
-apply  (tactic "ax_tac 1")
+apply  (tactic "ax_tac @{context} 1")
 apply clarsimp
 done
 
--- a/src/HOL/Bali/AxSem.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Bali/AxSem.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -672,7 +672,7 @@
 (* 37 subgoals *)
 prefer 18 (* Methd *)
 apply (rule ax_derivs.Methd, drule spec, erule mp, fast) 
-apply (tactic {* TRYALL (resolve_tac ((funpow 5 tl) @{thms ax_derivs.intros})) *})
+apply (tactic {* TRYALL (resolve_tac @{context} ((funpow 5 tl) @{thms ax_derivs.intros})) *})
 apply auto
 done
 
@@ -691,7 +691,7 @@
  "G,(A::'a triple set)|\<turnstile>(ts'::'a triple set) \<Longrightarrow> !ts. ts \<subseteq> ts' \<longrightarrow> G,A|\<turnstile>ts"
 apply (erule ax_derivs.induct)
 (*42 subgoals*)
-apply       (tactic "ALLGOALS strip_tac")
+apply       (tactic "ALLGOALS (strip_tac @{context})")
 apply       (tactic {* ALLGOALS(REPEAT o (EVERY'[dtac @{thm subset_singletonD},
          etac disjE, fast_tac (@{context} addSIs @{thms ax_derivs.empty})]))*})
 apply       (tactic "TRYALL (hyp_subst_tac @{context})")
@@ -703,7 +703,7 @@
 apply   (fast intro: ax_derivs.weaken)
 apply  (rule ax_derivs.conseq, clarify, tactic "smp_tac @{context} 3 1", blast(* unused *))
 (*37 subgoals*)
-apply (tactic {* TRYALL (resolve_tac ((funpow 5 tl) @{thms ax_derivs.intros}) 
+apply (tactic {* TRYALL (resolve_tac @{context} ((funpow 5 tl) @{thms ax_derivs.intros})
                    THEN_ALL_NEW fast_tac @{context}) *})
 (*1 subgoal*)
 apply (clarsimp simp add: subset_mtriples_iff)
--- a/src/HOL/Bali/Basis.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Bali/Basis.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -9,7 +9,7 @@
 
 subsubsection "misc"
 
-ML {* fun strip_tac i = REPEAT (resolve_tac [impI, allI] i) *}
+ML {* fun strip_tac ctxt i = REPEAT (resolve_tac ctxt [impI, allI] i) *}
 
 declare split_if_asm  [split] option.split [split] option.split_asm [split]
 setup {* map_theory_simpset (fn ctxt => ctxt addloop ("split_all_tac", split_all_tac)) *}
--- a/src/HOL/Bali/Eval.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Bali/Eval.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -1163,7 +1163,7 @@
   "G\<turnstile>s \<midarrow>t\<succ>\<rightarrow> (w, s') \<Longrightarrow> (\<forall>w' s''. G\<turnstile>s \<midarrow>t\<succ>\<rightarrow> (w', s'') \<longrightarrow> w' = w \<and> s'' = s')"
 apply (erule eval_induct)
 apply (tactic {* ALLGOALS (EVERY'
-      [strip_tac, rotate_tac ~1, eresolve_tac @{thms eval_elim_cases}]) *})
+      [strip_tac @{context}, rotate_tac ~1, eresolve_tac @{context} @{thms eval_elim_cases}]) *})
 (* 31 subgoals *)
 prefer 28 (* Try *) 
 apply (simp (no_asm_use) only: split add: split_if_asm)
--- a/src/HOL/Bali/Evaln.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Bali/Evaln.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -448,9 +448,9 @@
 lemma evaln_nonstrict [rule_format (no_asm), elim]: 
   "G\<turnstile>s \<midarrow>t\<succ>\<midarrow>n\<rightarrow> (w, s') \<Longrightarrow> \<forall>m. n\<le>m \<longrightarrow> G\<turnstile>s \<midarrow>t\<succ>\<midarrow>m\<rightarrow> (w, s')"
 apply (erule evaln.induct)
-apply (tactic {* ALLGOALS (EVERY'[strip_tac, TRY o etac @{thm Suc_le_D_lemma},
+apply (tactic {* ALLGOALS (EVERY' [strip_tac @{context}, TRY o etac @{thm Suc_le_D_lemma},
   REPEAT o smp_tac @{context} 1, 
-  resolve_tac @{thms evaln.intros} THEN_ALL_NEW TRY o atac]) *})
+  resolve_tac @{context} @{thms evaln.intros} THEN_ALL_NEW TRY o atac]) *})
 (* 3 subgoals *)
 apply (auto split del: split_if)
 done
--- a/src/HOL/Bali/WellType.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Bali/WellType.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -665,7 +665,7 @@
     thin_tac @{context} "?E,dt\<Turnstile>e2\<Colon>-?T2"] i
   else thin_tac @{context} "All ?P" i) *})
 (*apply (safe del: disjE elim!: wt_elim_cases)*)
-apply (tactic {*ALLGOALS (eresolve_tac @{thms wt_elim_cases})*})
+apply (tactic {*ALLGOALS (eresolve_tac @{context} @{thms wt_elim_cases})*})
 apply (simp_all (no_asm_use) split del: split_if_asm)
 apply (erule_tac [12] V = "All ?P" in thin_rl) (* Call *)
 apply (blast del: equalityCE dest: sym [THEN trans])+
--- a/src/HOL/Datatype_Examples/Stream_Processor.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Datatype_Examples/Stream_Processor.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -136,7 +136,7 @@
       BNF_Util.CONJ_WRAP' (K (rtac @{thm subset_UNIV})) ks, rtac @{thm relcomppI}, atac,
       rtac @{thm conversepI}, rtac @{thm GrpI}, rtac refl, rtac CollectI,
       BNF_Util.CONJ_WRAP' (K (rtac @{thm subset_UNIV})) ks,
-      REPEAT_DETERM o eresolve_tac @{thms relcomppE conversepE GrpE},
+      REPEAT_DETERM o eresolve_tac @{context} @{thms relcomppE conversepE GrpE},
       hyp_subst_tac @{context}, atac])
   end
 *})
--- a/src/HOL/Decision_Procs/Approximation.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Decision_Procs/Approximation.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -3699,7 +3699,7 @@
                       etac @{thm meta_eqE},
                       rtac @{thm impI}] i)
       THEN Subgoal.FOCUS (fn {prems, ...} => reorder_bounds_tac prems i) ctxt i
-      THEN DETERM (TRY (filter_prems_tac (K false) i))
+      THEN DETERM (TRY (filter_prems_tac ctxt (K false) i))
       THEN DETERM (Reification.tac ctxt form_equations NONE i)
       THEN rewrite_interpret_form_tac ctxt prec splitting taylor i
       THEN gen_eval_tac (approximation_conv ctxt) ctxt i))
--- a/src/HOL/Decision_Procs/approximation.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Decision_Procs/approximation.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -100,7 +100,7 @@
 fun prepare_form ctxt term = apply_tactic ctxt term (
     REPEAT (FIRST' [etac @{thm intervalE}, etac @{thm meta_eqE}, rtac @{thm impI}] 1)
     THEN Subgoal.FOCUS (fn {prems, ...} => reorder_bounds_tac prems 1) ctxt 1
-    THEN DETERM (TRY (filter_prems_tac (K false) 1)))
+    THEN DETERM (TRY (filter_prems_tac ctxt (K false) 1)))
 
 fun reify_form ctxt term = apply_tactic ctxt term
    (Reification.tac ctxt form_equations NONE 1)
--- a/src/HOL/Fun.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Fun.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -851,8 +851,8 @@
       | (T, SOME rhs) =>
           SOME (Goal.prove ctxt [] [] (Logic.mk_equals (t, rhs))
             (fn _ =>
-              resolve_tac [eq_reflection] 1 THEN
-              resolve_tac @{thms ext} 1 THEN
+              resolve_tac ctxt [eq_reflection] 1 THEN
+              resolve_tac ctxt @{thms ext} 1 THEN
               simp_tac (put_simpset ss ctxt) 1))
     end
 in proc end
--- a/src/HOL/GCD.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/GCD.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -1398,7 +1398,7 @@
 
 lemma lcm_unique_int: "d >= 0 \<and> (a::int) dvd d \<and> b dvd d \<and>
     (\<forall>e. a dvd e \<and> b dvd e \<longrightarrow> d dvd e) \<longleftrightarrow> d = lcm a b"
-  by (auto intro: dvd_antisym [transferred] lcm_least_int)
+  by (auto intro: dvd_antisym [transferred] lcm_least_int)  (* FIXME slow *)
 
 interpretation lcm_nat: abel_semigroup "lcm :: nat \<Rightarrow> nat \<Rightarrow> nat"
   + lcm_nat: semilattice_neutr "lcm :: nat \<Rightarrow> nat \<Rightarrow> nat" 1
--- a/src/HOL/HOL.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/HOL.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -846,8 +846,9 @@
   shows R
 apply (rule ex1E [OF major])
 apply (rule prem)
-apply (tactic {* ares_tac @{thms allI} 1 *})+
-apply (tactic {* eresolve_tac [Classical.dup_elim NONE @{thm allE}] 1 *})
+apply assumption
+apply (rule allI)+
+apply (tactic {* eresolve_tac @{context} [Classical.dup_elim NONE @{thm allE}] 1 *})
 apply iprover
 done
 
@@ -1796,7 +1797,7 @@
 proof
   assume "PROP ?ofclass"
   show "PROP ?equal"
-    by (tactic {* ALLGOALS (resolve_tac [Thm.unconstrainT @{thm eq_equal}]) *})
+    by (tactic {* ALLGOALS (resolve_tac @{context} [Thm.unconstrainT @{thm eq_equal}]) *})
       (fact `PROP ?ofclass`)
 next
   assume "PROP ?equal"
@@ -1897,7 +1898,7 @@
       let val conv = Code_Runtime.dynamic_holds_conv ctxt
       in
         CONVERSION (Conv.params_conv ~1 (K (Conv.concl_conv ~1 conv)) ctxt) THEN'
-        resolve_tac [TrueI]
+        resolve_tac ctxt [TrueI]
       end
   in
     Scan.succeed (SIMPLE_METHOD' o eval_tac)
@@ -1909,7 +1910,7 @@
     SIMPLE_METHOD'
       (CHANGED_PROP o
         (CONVERSION (Nbe.dynamic_conv ctxt)
-          THEN_ALL_NEW (TRY o resolve_tac [TrueI]))))
+          THEN_ALL_NEW (TRY o resolve_tac ctxt [TrueI]))))
 *} "solve goal by normalization"
 
 
@@ -1949,7 +1950,7 @@
     val filter_right = filter (not o wrong_prem o HOLogic.dest_Trueprop o hd o Thm.prems_of);
   in
     fun smp i = funpow i (fn m => filter_right ([spec] RL m)) ([mp]);
-    fun smp_tac ctxt j = EVERY'[dresolve_tac (smp j), assume_tac ctxt];
+    fun smp_tac ctxt j = EVERY' [dresolve_tac ctxt (smp j), assume_tac ctxt];
   end;
 
   local
--- a/src/HOL/HOLCF/IOA/ABP/Spec.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/HOLCF/IOA/ABP/Spec.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -32,6 +32,6 @@
 
 definition
   spec_ioa :: "('m action, 'm list)ioa" where
-  ioa_def: "spec_ioa = (spec_sig, {[]}, spec_trans)"
+  ioa_def: "spec_ioa = (spec_sig, {[]}, spec_trans, {}, {})"
 
 end
--- a/src/HOL/HOLCF/IOA/NTP/Impl.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/HOLCF/IOA/NTP/Impl.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -208,19 +208,19 @@
   txt {* 10 - 7 *}
   apply (tactic "EVERY1 [tac2,tac2,tac2,tac2]")
   txt {* 6 *}
-  apply (tactic {* forward_tac [rewrite_rule @{context} [@{thm Impl.inv1_def}]
+  apply (tactic {* forward_tac @{context} [rewrite_rule @{context} [@{thm Impl.inv1_def}]
                                (@{thm raw_inv1} RS @{thm invariantE}) RS conjunct1] 1 *})
 
   txt {* 6 - 5 *}
   apply (tactic "EVERY1 [tac2,tac2]")
 
   txt {* 4 *}
-  apply (tactic {* forward_tac [rewrite_rule @{context} [@{thm Impl.inv1_def}]
+  apply (tactic {* forward_tac @{context} [rewrite_rule @{context} [@{thm Impl.inv1_def}]
                                 (@{thm raw_inv1} RS @{thm invariantE}) RS conjunct1] 1 *})
   apply (tactic "tac2 1")
 
   txt {* 3 *}
-  apply (tactic {* forward_tac [rewrite_rule @{context} [@{thm Impl.inv1_def}]
+  apply (tactic {* forward_tac @{context} [rewrite_rule @{context} [@{thm Impl.inv1_def}]
     (@{thm raw_inv1} RS @{thm invariantE})] 1 *})
 
   apply (tactic "tac2 1")
@@ -230,7 +230,7 @@
 
   txt {* 2 *}
   apply (tactic "tac2 1")
-  apply (tactic {* forward_tac [rewrite_rule @{context} [@{thm Impl.inv1_def}]
+  apply (tactic {* forward_tac @{context} [rewrite_rule @{context} [@{thm Impl.inv1_def}]
                                (@{thm raw_inv1} RS @{thm invariantE}) RS conjunct1] 1 *})
   apply (intro strip)
   apply (erule conjE)+
@@ -238,7 +238,7 @@
 
   txt {* 1 *}
   apply (tactic "tac2 1")
-  apply (tactic {* forward_tac [rewrite_rule @{context} [@{thm Impl.inv1_def}]
+  apply (tactic {* forward_tac @{context} [rewrite_rule @{context} [@{thm Impl.inv1_def}]
                                (@{thm raw_inv1} RS @{thm invariantE}) RS conjunct2] 1 *})
   apply (intro strip)
   apply (erule conjE)+
@@ -287,13 +287,13 @@
   apply (intro strip, (erule conjE)+)
   apply (rule imp_disjL [THEN iffD1])
   apply (rule impI)
-  apply (tactic {* forward_tac [rewrite_rule @{context} [@{thm Impl.inv2_def}]
+  apply (tactic {* forward_tac @{context} [rewrite_rule @{context} [@{thm Impl.inv2_def}]
     (@{thm raw_inv2} RS @{thm invariantE})] 1 *})
   apply simp
   apply (erule conjE)+
   apply (rule_tac j = "count (ssent (sen s)) (~sbit (sen s))" and
     k = "count (rsent (rec s)) (sbit (sen s))" in le_trans)
-  apply (tactic {* forward_tac [rewrite_rule @{context} [@{thm inv1_def}]
+  apply (tactic {* forward_tac @{context} [rewrite_rule @{context} [@{thm inv1_def}]
                                 (@{thm raw_inv1} RS @{thm invariantE}) RS conjunct2] 1 *})
   apply (simp add: hdr_sum_def Multiset.count_def)
   apply (rule add_le_mono)
@@ -308,7 +308,7 @@
   apply (intro strip, (erule conjE)+)
   apply (rule imp_disjL [THEN iffD1])
   apply (rule impI)
-  apply (tactic {* forward_tac [rewrite_rule @{context} [@{thm Impl.inv2_def}]
+  apply (tactic {* forward_tac @{context} [rewrite_rule @{context} [@{thm Impl.inv2_def}]
     (@{thm raw_inv2} RS @{thm invariantE})] 1 *})
   apply simp
   done
@@ -334,7 +334,7 @@
   txt {* 2 b *}
 
   apply (intro strip, (erule conjE)+)
-  apply (tactic {* forward_tac [rewrite_rule @{context} [@{thm Impl.inv2_def}]
+  apply (tactic {* forward_tac @{context} [rewrite_rule @{context} [@{thm Impl.inv2_def}]
                                (@{thm raw_inv2} RS @{thm invariantE})] 1 *})
   apply simp
 
@@ -342,9 +342,9 @@
   apply (tactic "tac4 1")
   apply (intro strip, (erule conjE)+)
   apply (rule ccontr)
-  apply (tactic {* forward_tac [rewrite_rule @{context} [@{thm Impl.inv2_def}]
+  apply (tactic {* forward_tac @{context} [rewrite_rule @{context} [@{thm Impl.inv2_def}]
                                (@{thm raw_inv2} RS @{thm invariantE})] 1 *})
-  apply (tactic {* forward_tac [rewrite_rule @{context} [@{thm Impl.inv3_def}]
+  apply (tactic {* forward_tac @{context} [rewrite_rule @{context} [@{thm Impl.inv3_def}]
                                (@{thm raw_inv3} RS @{thm invariantE})] 1 *})
   apply simp
   apply (rename_tac m, erule_tac x = "m" in allE)
--- a/src/HOL/HOLCF/Tools/Domain/domain_constructors.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/HOLCF/Tools/Domain/domain_constructors.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -244,9 +244,9 @@
       let
         val rules = @{thms compact_sinl compact_sinr compact_spair
                            compact_up compact_ONE}
-        val tacs =
+        fun tacs ctxt =
           [rtac (iso_locale RS @{thm iso.compact_abs}) 1,
-           REPEAT (resolve_tac rules 1 ORELSE atac 1)]
+           REPEAT (resolve_tac ctxt rules 1 ORELSE atac 1)]
         fun con_compact (con, args) =
           let
             val vs = vars_of args
@@ -255,7 +255,7 @@
             val assms = map (mk_trp o mk_compact) vs
             val goal = Logic.list_implies (assms, concl)
           in
-            prove thy con_betas goal (K tacs)
+            prove thy con_betas goal (tacs o #context)
           end
       in
         map con_compact spec'
@@ -500,8 +500,8 @@
         val defs = case_beta :: map mk_meta_eq [rep_strict, @{thm cfcomp2}]
         val goal = mk_trp (mk_strict case_app)
         val rules = @{thms sscase1 ssplit1 strictify1 one_case1}
-        val tacs = [resolve_tac rules 1]
-      in prove thy defs goal (K tacs) end
+        fun tacs ctxt = [resolve_tac ctxt rules 1]
+      in prove thy defs goal (tacs o #context) end
 
     (* prove rewrites for case combinator *)
     local
--- a/src/HOL/HOLCF/Tools/Domain/domain_induction.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/HOLCF/Tools/Domain/domain_induction.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -180,7 +180,7 @@
             TRY (safe_tac (put_claset HOL_cs ctxt))]
           fun con_tac _ = 
             asm_simp_tac (put_simpset take_ss ctxt) 1 THEN
-            (resolve_tac prems' THEN_ALL_NEW etac spec) 1
+            (resolve_tac ctxt prems' THEN_ALL_NEW etac spec) 1
           fun cases_tacs (cons, exhaust) =
             res_inst_tac ctxt [(("y", 0), "x")] exhaust 1 ::
             asm_simp_tac (put_simpset take_ss ctxt addsimps prems) 1 ::
@@ -201,8 +201,8 @@
         let
           fun finite_tac (take_induct, fin_ind) =
               rtac take_induct 1 THEN
-              (if is_finite then all_tac else resolve_tac prems 1) THEN
-              (rtac fin_ind THEN_ALL_NEW solve_tac prems) 1
+              (if is_finite then all_tac else resolve_tac ctxt prems 1) THEN
+              (rtac fin_ind THEN_ALL_NEW solve_tac ctxt prems) 1
           val fin_inds = Project_Rule.projections ctxt finite_ind
         in
           TRY (safe_tac (put_claset HOL_cs ctxt)) THEN
--- a/src/HOL/HOLCF/Tools/Domain/domain_isomorphism.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/HOLCF/Tools/Domain/domain_isomorphism.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -311,11 +311,11 @@
          EVERY
           [rewrite_goals_tac ctxt map_apply_thms,
            rtac (map_cont_thm RS @{thm cont_fix_ind}) 1,
-           REPEAT (resolve_tac adm_rules 1),
+           REPEAT (resolve_tac ctxt adm_rules 1),
            simp_tac (put_simpset HOL_basic_ss ctxt addsimps bottom_rules) 1,
            simp_tac (put_simpset HOL_basic_ss ctxt addsimps tuple_rules) 1,
            REPEAT (etac @{thm conjE} 1),
-           REPEAT (resolve_tac (deflation_rules @ prems) 1 ORELSE atac 1)])
+           REPEAT (resolve_tac ctxt (deflation_rules @ prems) 1 ORELSE atac 1)])
       end
     fun conjuncts [] _ = []
       | conjuncts (n::[]) thm = [(n, thm)]
@@ -516,7 +516,7 @@
           Named_Theorems.get (Proof_Context.init_global thy) @{named_theorems domain_defl_simps}
         fun tac ctxt =
           rewrite_goals_tac ctxt (map mk_meta_eq (rev DEFL_simps))
-          THEN TRY (resolve_tac defl_unfold_thms 1)
+          THEN TRY (resolve_tac ctxt defl_unfold_thms 1)
       in
         Goal.prove_global thy [] [] goal (tac o #context)
       end
@@ -625,12 +625,12 @@
           [rewrite_goals_tac ctxt (defl_apply_thms @ map_apply_thms),
            rtac (@{thm cont_parallel_fix_ind}
              OF [defl_cont_thm, map_cont_thm]) 1,
-           REPEAT (resolve_tac adm_rules 1),
+           REPEAT (resolve_tac ctxt adm_rules 1),
            simp_tac (put_simpset HOL_basic_ss ctxt addsimps bottom_rules) 1,
            simp_tac (put_simpset HOL_basic_ss ctxt addsimps tuple_rules) 1,
            simp_tac (put_simpset HOL_basic_ss ctxt addsimps map_ID_simps) 1,
            REPEAT (etac @{thm conjE} 1),
-           REPEAT (resolve_tac (isodefl_rules @ prems) 1 ORELSE atac 1)])
+           REPEAT (resolve_tac ctxt (isodefl_rules @ prems) 1 ORELSE atac 1)])
       end
     val isodefl_binds = map (Binding.prefix_name "isodefl_") dbinds
     fun conjuncts [] _ = []
@@ -654,13 +654,13 @@
         fun is_cpo T = Sign.of_sort thy (T, @{sort cpo})
         val lhs = list_ccomb (map_const, map mk_ID (filter is_cpo Ts))
         val goal = mk_eqs (lhs, mk_ID lhsT)
-        val tac = EVERY
+        fun tac ctxt = EVERY
           [rtac @{thm isodefl_DEFL_imp_ID} 1,
-           stac DEFL_thm 1,
+           stac ctxt DEFL_thm 1,
            rtac isodefl_thm 1,
-           REPEAT (resolve_tac @{thms isodefl_ID_DEFL isodefl_LIFTDEFL} 1)]
+           REPEAT (resolve_tac ctxt @{thms isodefl_ID_DEFL isodefl_LIFTDEFL} 1)]
       in
-        Goal.prove_global thy [] [] goal (K tac)
+        Goal.prove_global thy [] [] goal (tac o #context)
       end
     val map_ID_binds = map (Binding.suffix_name "_map_ID") dbinds
     val map_ID_thms =
--- a/src/HOL/HOLCF/Tools/Domain/domain_take_proofs.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/HOLCF/Tools/Domain/domain_take_proofs.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -324,7 +324,7 @@
            simp_tac (put_simpset HOL_basic_ss ctxt addsimps bottom_rules) 1,
            asm_simp_tac (put_simpset HOL_basic_ss ctxt addsimps take_Suc_thms) 1,
            REPEAT (etac @{thm conjE} 1
-                   ORELSE resolve_tac deflation_rules 1
+                   ORELSE resolve_tac ctxt deflation_rules 1
                    ORELSE atac 1)])
       end
     fun conjuncts [] _ = []
@@ -462,9 +462,9 @@
             EVERY [
             rewrite_goals_tac ctxt finite_defs,
             rtac @{thm lub_ID_finite} 1,
-            resolve_tac chain_take_thms 1,
-            resolve_tac lub_take_thms 1,
-            resolve_tac decisive_thms 1]
+            resolve_tac ctxt chain_take_thms 1,
+            resolve_tac ctxt lub_take_thms 1,
+            resolve_tac ctxt decisive_thms 1]
       in
         Goal.prove_global thy [] [] goal (tac o #context)
       end
--- a/src/HOL/HOLCF/Tools/cont_proc.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/HOLCF/Tools/cont_proc.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -7,7 +7,7 @@
   val is_lcf_term: term -> bool
   val cont_thms: term -> thm list
   val all_cont_thms: term -> thm list
-  val cont_tac: int -> tactic
+  val cont_tac: Proof.context -> int -> tactic
   val cont_proc: theory -> simproc
   val setup: theory -> theory
 end
@@ -95,7 +95,7 @@
   conditional rewrite rule with the unsolved subgoals as premises.
 *)
 
-val cont_tac =
+fun cont_tac ctxt =
   let
     val rules = [cont_K, cont_I, cont_R, cont_A, cont_L]
   
@@ -110,7 +110,7 @@
       in
         if is_lcf_term f'
         then new_cont_tac f'
-        else REPEAT_ALL_NEW (resolve_tac rules)
+        else REPEAT_ALL_NEW (resolve_tac ctxt rules)
       end
       | cont_tac_of_term _ = K no_tac
   in
@@ -123,7 +123,7 @@
     let
       val thy = Proof_Context.theory_of ctxt
       val tr = instantiate' [] [SOME (cterm_of thy t)] @{thm Eq_TrueI}
-    in Option.map fst (Seq.pull (cont_tac 1 tr)) end
+    in Option.map fst (Seq.pull (cont_tac ctxt 1 tr)) end
 in
   fun cont_proc thy =
     Simplifier.simproc_global thy "cont_proc" ["cont f"] solve_cont
--- a/src/HOL/IMPP/Hoare.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/IMPP/Hoare.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -218,7 +218,7 @@
 apply           (rule hoare_derivs.conseq, intro strip, tactic "smp_tac @{context} 2 1", clarify, tactic "smp_tac @{context} 1 1",rule exI, rule exI, erule (1) conjI)
 prefer 7
 apply          (rule_tac hoare_derivs.Body, drule_tac spec, erule_tac mp, fast)
-apply         (tactic {* ALLGOALS (resolve_tac ((funpow 5 tl) @{thms hoare_derivs.intros}) THEN_ALL_NEW (fast_tac @{context})) *})
+apply         (tactic {* ALLGOALS (resolve_tac @{context} ((funpow 5 tl) @{thms hoare_derivs.intros}) THEN_ALL_NEW (fast_tac @{context})) *})
 done
 
 lemma weak_Body: "G|-{P}. the (body pn) .{Q} ==> G|-{P}. BODY pn .{Q}"
@@ -278,7 +278,7 @@
 
 lemma hoare_sound: "G||-ts ==> G||=ts"
 apply (erule hoare_derivs.induct)
-apply              (tactic {* TRYALL (eresolve_tac [@{thm Loop_sound_lemma}, @{thm Body_sound_lemma}] THEN_ALL_NEW atac) *})
+apply              (tactic {* TRYALL (eresolve_tac @{context} [@{thm Loop_sound_lemma}, @{thm Body_sound_lemma}] THEN_ALL_NEW atac) *})
 apply            (unfold hoare_valids_def)
 apply            blast
 apply           blast
--- a/src/HOL/IMPP/Natural.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/IMPP/Natural.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -106,13 +106,12 @@
 lemma com_det [rule_format (no_asm)]: "<c,s> -c-> t ==> (!u. <c,s> -c-> u --> u=t)"
 apply (erule evalc.induct)
 apply (erule_tac [8] V = "<?c,s1> -c-> s2" in thin_rl)
-(*blast needs unify_search_bound = 40*)
-apply (best elim: evalc_WHILE_case)+
+apply (blast elim: evalc_WHILE_case)+
 done
 
 lemma evaln_evalc: "<c,s> -n-> t ==> <c,s> -c-> t"
 apply (erule evaln.induct)
-apply (tactic {* ALLGOALS (resolve_tac @{thms evalc.intros} THEN_ALL_NEW atac) *})
+apply (tactic {* ALLGOALS (resolve_tac @{context} @{thms evalc.intros} THEN_ALL_NEW atac) *})
 done
 
 lemma Suc_le_D_lemma: "[| Suc n <= m'; (!!m. n <= m ==> P (Suc m)) |] ==> P m'"
@@ -140,8 +139,9 @@
 apply (erule evalc.induct)
 apply (tactic {* ALLGOALS (REPEAT o etac exE) *})
 apply (tactic {* TRYALL (EVERY' [dtac @{thm evaln_max2}, assume_tac @{context},
-  REPEAT o eresolve_tac [exE, conjE]]) *})
-apply (tactic {* ALLGOALS (rtac exI THEN' resolve_tac @{thms evaln.intros} THEN_ALL_NEW atac) *})
+  REPEAT o eresolve_tac @{context} [exE, conjE]]) *})
+apply (tactic
+  {* ALLGOALS (rtac exI THEN' resolve_tac @{context} @{thms evaln.intros} THEN_ALL_NEW atac) *})
 done
 
 lemma eval_eq: "<c,s> -c-> t = (? n. <c,s> -n-> t)"
--- a/src/HOL/IOA/Solve.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/IOA/Solve.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -145,7 +145,7 @@
   apply force
   apply (simp (no_asm) add: conj_disj_distribR cong add: conj_cong split add: split_if)
   apply (tactic {*
-    REPEAT((resolve_tac [conjI,impI] 1 ORELSE etac conjE 1) THEN
+    REPEAT((resolve_tac @{context} [conjI, impI] 1 ORELSE etac conjE 1) THEN
       asm_full_simp_tac(@{context} addsimps [@{thm comp1_reachable}, @{thm comp2_reachable}]) 1) *})
   done
 
--- a/src/HOL/Library/Countable.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Library/Countable.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -190,7 +190,7 @@
           [rtac @{thm countable_datatype} i,
            rtac typedef_thm i,
            etac induct_thm' i,
-           REPEAT (resolve_tac rules i ORELSE atac i)]) 1
+           REPEAT (resolve_tac ctxt rules i ORELSE atac i)]) 1
       end)
 *}
 
--- a/src/HOL/Library/Old_SMT/old_z3_proof_methods.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Library/Old_SMT/old_z3_proof_methods.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -72,7 +72,7 @@
   in
     Goal.init (mk_inj_prop ctxt' (Thm.dest_arg ct))
     |> apply (rtac @{thm injI})
-    |> apply (Tactic.solve_tac [rule, rule RS @{thm sym}])
+    |> apply (Tactic.solve_tac ctxt' [rule, rule RS @{thm sym}])
     |> Goal.norm_result ctxt' o Goal.finish ctxt'
     |> singleton (Variable.export ctxt' ctxt)
   end
--- a/src/HOL/Library/Old_SMT/old_z3_proof_reconstruction.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Library/Old_SMT/old_z3_proof_reconstruction.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -636,10 +636,10 @@
 fun skolemize vars =
   apfst Thm oo close vars (yield_singleton Assumption.add_assumes)
 
-fun discharge_sk_tac i st = (
+fun discharge_sk_tac ctxt i st = (
   rtac @{thm trans} i
-  THEN resolve_tac sk_rules i
-  THEN (rtac @{thm refl} ORELSE' discharge_sk_tac) (i+1)
+  THEN resolve_tac ctxt sk_rules i
+  THEN (rtac @{thm refl} ORELSE' discharge_sk_tac ctxt) (i+1)
   THEN rtac @{thm refl} i) st
 
 end
@@ -847,13 +847,13 @@
   fun make_discharge_rules rules = rules @ [@{thm allI}, @{thm refl},
     @{thm reflexive}, Old_Z3_Proof_Literals.true_thm]
 
-  fun discharge_assms_tac rules =
-    REPEAT (HEADGOAL (resolve_tac rules ORELSE' SOLVED' discharge_sk_tac))
+  fun discharge_assms_tac ctxt rules =
+    REPEAT (HEADGOAL (resolve_tac ctxt rules ORELSE' SOLVED' (discharge_sk_tac ctxt)))
     
   fun discharge_assms ctxt rules thm =
     if Thm.nprems_of thm = 0 then Goal.norm_result ctxt thm
     else
-      (case Seq.pull (discharge_assms_tac rules thm) of
+      (case Seq.pull (discharge_assms_tac ctxt rules thm) of
         SOME (thm', _) => Goal.norm_result ctxt thm'
       | NONE => raise THM ("failed to discharge premise", 1, [thm]))
 
--- a/src/HOL/Library/bnf_lfp_countable.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Library/bnf_lfp_countable.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -25,7 +25,7 @@
 
 fun nchotomy_tac nchotomy =
   HEADGOAL (rtac (nchotomy RS @{thm all_reg[rotated]}) THEN'
-    REPEAT_ALL_NEW (resolve_tac [allI, impI] ORELSE' eresolve_tac [exE, disjE]));
+    REPEAT_ALL_NEW (resolve0_tac [allI, impI] ORELSE' eresolve0_tac [exE, disjE]));
 
 fun meta_spec_mp_tac 0 = K all_tac
   | meta_spec_mp_tac depth =
@@ -43,7 +43,7 @@
   HEADGOAL (asm_full_simp_tac
       (ss_only (injects @ recs @ map_congs' @ same_ctr_simps) ctxt) THEN_MAYBE'
     TRY o REPEAT_ALL_NEW (rtac conjI) THEN_ALL_NEW
-    REPEAT_ALL_NEW (eresolve_tac (conjE :: inj_map_strongs')) THEN_ALL_NEW
+    REPEAT_ALL_NEW (eresolve_tac ctxt (conjE :: inj_map_strongs')) THEN_ALL_NEW
     (atac ORELSE' use_induction_hypothesis_tac));
 
 fun distinct_ctrs_tac ctxt recs =
@@ -64,7 +64,7 @@
 
 fun endgame_tac ctxt encode_injectives =
   unfold_thms_tac ctxt @{thms inj_on_def ball_UNIV} THEN
-  ALLGOALS (rtac exI THEN' rtac allI THEN' resolve_tac encode_injectives);
+  ALLGOALS (rtac exI THEN' rtac allI THEN' resolve_tac ctxt encode_injectives);
 
 fun encode_sumN n k t =
   Balanced_Tree.access {init = t,
@@ -188,6 +188,6 @@
   end;
 
 fun countable_datatype_tac ctxt =
-  TRY (Class.intro_classes_tac []) THEN core_countable_datatype_tac ctxt;
+  TRY (Class.intro_classes_tac ctxt []) THEN core_countable_datatype_tac ctxt;
 
 end;
--- a/src/HOL/MicroJava/J/Example.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/MicroJava/J/Example.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -372,34 +372,34 @@
 apply (auto simp add: appl_methds_foo_Base)
 done
 
-ML {* val t = resolve_tac @{thms ty_expr_ty_exprs_wt_stmt.intros} 1 *}
+lemmas t = ty_expr_ty_exprs_wt_stmt.intros
 schematic_lemma wt_test: "(tprg, empty(e\<mapsto>Class Base))\<turnstile>  
   Expr(e::=NewC Ext);; Expr({Base}LAcc e..foo({?pTs'}[Lit Null]))\<surd>"
-apply (tactic t) -- ";;"
-apply  (tactic t) -- "Expr"
-apply  (tactic t) -- "LAss"
+apply (rule ty_expr_ty_exprs_wt_stmt.intros) -- ";;"
+apply  (rule t) -- "Expr"
+apply  (rule t) -- "LAss"
 apply    simp -- {* @{text "e \<noteq> This"} *}
-apply    (tactic t) -- "LAcc"
+apply    (rule t) -- "LAcc"
 apply     (simp (no_asm))
 apply    (simp (no_asm))
-apply   (tactic t) -- "NewC"
+apply   (rule t) -- "NewC"
 apply   (simp (no_asm))
 apply  (simp (no_asm))
-apply (tactic t) -- "Expr"
-apply (tactic t) -- "Call"
-apply   (tactic t) -- "LAcc"
+apply (rule t) -- "Expr"
+apply (rule t) -- "Call"
+apply   (rule t) -- "LAcc"
 apply    (simp (no_asm))
 apply   (simp (no_asm))
-apply  (tactic t) -- "Cons"
-apply   (tactic t) -- "Lit"
+apply  (rule t) -- "Cons"
+apply   (rule t) -- "Lit"
 apply   (simp (no_asm))
-apply  (tactic t) -- "Nil"
+apply  (rule t) -- "Nil"
 apply (simp (no_asm))
 apply (rule max_spec_foo_Base)
 done
 
-ML {* val e = resolve_tac (@{thm NewCI} :: @{thms eval_evals_exec.intros}) 1 *}
 
+lemmas e = NewCI eval_evals_exec.intros
 declare split_if [split del]
 declare init_vars_def [simp] c_hupd_def [simp] cast_ok_def [simp]
 schematic_lemma exec_test: 
@@ -407,37 +407,37 @@
   tprg\<turnstile>s0 -test-> ?s"
 apply (unfold test_def)
 -- "?s = s3 "
-apply (tactic e) -- ";;"
-apply  (tactic e) -- "Expr"
-apply  (tactic e) -- "LAss"
-apply   (tactic e) -- "NewC"
+apply (rule e) -- ";;"
+apply  (rule e) -- "Expr"
+apply  (rule e) -- "LAss"
+apply   (rule e) -- "NewC"
 apply    force
 apply   force
 apply  (simp (no_asm))
 apply (erule thin_rl)
-apply (tactic e) -- "Expr"
-apply (tactic e) -- "Call"
-apply       (tactic e) -- "LAcc"
+apply (rule e) -- "Expr"
+apply (rule e) -- "Call"
+apply       (rule e) -- "LAcc"
 apply      force
-apply     (tactic e) -- "Cons"
-apply      (tactic e) -- "Lit"
-apply     (tactic e) -- "Nil"
+apply     (rule e) -- "Cons"
+apply      (rule e) -- "Lit"
+apply     (rule e) -- "Nil"
 apply    (simp (no_asm))
 apply   (force simp add: foo_Ext_def)
 apply  (simp (no_asm))
-apply  (tactic e) -- "Expr"
-apply  (tactic e) -- "FAss"
-apply       (tactic e) -- "Cast"
-apply        (tactic e) -- "LAcc"
+apply  (rule e) -- "Expr"
+apply  (rule e) -- "FAss"
+apply       (rule e) -- "Cast"
+apply        (rule e) -- "LAcc"
 apply       (simp (no_asm))
 apply      (simp (no_asm))
 apply     (simp (no_asm))
-apply     (tactic e) -- "XcptE"
+apply     (rule e) -- "XcptE"
 apply    (simp (no_asm))
 apply   (rule surjective_pairing [symmetric, THEN[2]trans], subst Pair_eq, force)
 apply  (simp (no_asm))
 apply (simp (no_asm))
-apply (tactic e) -- "XcptE"
+apply (rule e) -- "XcptE"
 done
 
 end
--- a/src/HOL/MicroJava/J/JTypeSafe.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/MicroJava/J/JTypeSafe.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -199,8 +199,8 @@
 
 -- "several simplifications, XcptE, XcptEs, XcptS, Skip, Nil??"
 apply( simp_all)
-apply( tactic "ALLGOALS (REPEAT o resolve_tac [impI, allI])")
-apply( tactic {* ALLGOALS (eresolve_tac [@{thm ty_expr.cases}, @{thm ty_exprs.cases}, @{thm wt_stmt.cases}]
+apply( tactic "ALLGOALS (REPEAT o resolve_tac @{context} [impI, allI])")
+apply( tactic {* ALLGOALS (eresolve_tac @{context} [@{thm ty_expr.cases}, @{thm ty_exprs.cases}, @{thm wt_stmt.cases}]
   THEN_ALL_NEW (full_simp_tac (put_simpset (simpset_of @{theory_context Conform}) @{context}))) *})
 apply(tactic "ALLGOALS (EVERY' [REPEAT o (etac conjE), REPEAT o hyp_subst_tac @{context}])")
 
@@ -240,7 +240,7 @@
 apply( fast elim: conforms_localD [THEN lconfD])
 
 -- "for FAss"
-apply( tactic {* EVERY'[eresolve_tac [@{thm ty_expr.cases}, @{thm ty_exprs.cases}, @{thm wt_stmt.cases}] 
+apply( tactic {* EVERY'[eresolve_tac @{context} [@{thm ty_expr.cases}, @{thm ty_exprs.cases}, @{thm wt_stmt.cases}] 
        THEN_ALL_NEW (full_simp_tac @{context}), REPEAT o (etac conjE), hyp_subst_tac @{context}] 3*})
 
 -- "for if"
@@ -276,7 +276,7 @@
 
 -- "7 LAss"
 apply (fold fun_upd_def)
-apply( tactic {* (eresolve_tac [@{thm ty_expr.cases}, @{thm ty_exprs.cases}, @{thm wt_stmt.cases}] 
+apply( tactic {* (eresolve_tac @{context} [@{thm ty_expr.cases}, @{thm ty_exprs.cases}, @{thm wt_stmt.cases}]
                  THEN_ALL_NEW (full_simp_tac @{context})) 1 *})
 apply (intro strip)
 apply (case_tac E)
--- a/src/HOL/NSA/transfer.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/NSA/transfer.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -63,8 +63,8 @@
       rewrite_goals_tac ctxt (ths' @ refolds' @ unfolds') THEN
       ALLGOALS (Object_Logic.full_atomize_tac ctxt) THEN
       match_tac ctxt [transitive_thm] 1 THEN
-      resolve_tac [@{thm transfer_start}] 1 THEN
-      REPEAT_ALL_NEW (resolve_tac intros) 1 THEN
+      resolve_tac ctxt [@{thm transfer_start}] 1 THEN
+      REPEAT_ALL_NEW (resolve_tac ctxt intros) 1 THEN
       match_tac ctxt [reflexive_thm] 1
   in Goal.prove ctxt [] [] (Logic.mk_equals (t,u)) (K tac) end
 
--- a/src/HOL/NanoJava/Equivalence.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/NanoJava/Equivalence.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -104,7 +104,7 @@
 apply (tactic "split_all_tac @{context} 1", rename_tac P e Q)
 apply (rule hoare_ehoare.induct)
 (*18*)
-apply (tactic {* ALLGOALS (REPEAT o dresolve_tac [@{thm all_conjunct2}, @{thm all3_conjunct2}]) *})
+apply (tactic {* ALLGOALS (REPEAT o dresolve_tac @{context} [@{thm all_conjunct2}, @{thm all3_conjunct2}]) *})
 apply (tactic {* ALLGOALS (REPEAT o thin_tac @{context} "hoare ?x ?y") *})
 apply (tactic {* ALLGOALS (REPEAT o thin_tac @{context} "ehoare ?x ?y") *})
 apply (simp_all only: cnvalid1_eq cenvalid_def2)
--- a/src/HOL/Nominal/nominal_atoms.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Nominal/nominal_atoms.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -503,20 +503,20 @@
            val cls_name = Sign.full_bname thy' ("pt_"^ak_name);
            val at_inst  = Global_Theory.get_thm thy' ("at_" ^ ak_name' ^ "_inst");
 
-           val proof1 = EVERY [Class.intro_classes_tac [],
+           fun proof1 ctxt = EVERY [Class.intro_classes_tac ctxt [],
                                  rtac ((at_inst RS at_pt_inst) RS pt1) 1,
                                  rtac ((at_inst RS at_pt_inst) RS pt2) 1,
                                  rtac ((at_inst RS at_pt_inst) RS pt3) 1,
                                  atac 1];
            fun proof2 ctxt =
-             Class.intro_classes_tac [] THEN
+             Class.intro_classes_tac ctxt [] THEN
              REPEAT (asm_simp_tac
               (put_simpset HOL_basic_ss ctxt addsimps
                 maps (Global_Theory.get_thms thy') [ak_name ^ "_prm_" ^ ak_name' ^ "_def"]) 1);
          in
            thy'
            |> Axclass.prove_arity (qu_name,[],[cls_name])
-              (fn ctxt => if ak_name = ak_name' then proof1 else proof2 ctxt)
+              (fn ctxt => if ak_name = ak_name' then proof1 ctxt else proof2 ctxt)
          end) ak_names thy) ak_names thy12d;
 
      (* show that                       *)
@@ -536,7 +536,7 @@
           val pt_inst  = Global_Theory.get_thm thy ("pt_"^ak_name^"_inst");
 
           fun pt_proof thm ctxt =
-              EVERY [Class.intro_classes_tac [],
+              EVERY [Class.intro_classes_tac ctxt [],
                      rtac (thm RS pt1) 1, rtac (thm RS pt2) 1, rtac (thm RS pt3) 1, atac 1];
 
           val pt_thm_fun   = at_thm RS (pt_inst RS (pt_inst RS pt_fun_inst));
@@ -582,13 +582,13 @@
                (if ak_name = ak_name'
                 then
                   let val at_thm = Global_Theory.get_thm thy' ("at_"^ak_name^"_inst");
-                  in  EVERY [Class.intro_classes_tac [],
+                  in  EVERY [Class.intro_classes_tac ctxt [],
                              rtac ((at_thm RS fs_at_inst) RS fs1) 1] end
                 else
                   let val dj_inst = Global_Theory.get_thm thy' ("dj_"^ak_name'^"_"^ak_name);
                       val simp_s =
                         put_simpset HOL_basic_ss ctxt addsimps [dj_inst RS dj_supp, finite_emptyI];
-                  in EVERY [Class.intro_classes_tac [], asm_simp_tac simp_s 1] end)
+                  in EVERY [Class.intro_classes_tac ctxt [], asm_simp_tac simp_s 1] end)
         in
          Axclass.prove_arity (qu_name,[],[qu_class]) proof thy'
         end) ak_names thy) ak_names thy18;
@@ -605,7 +605,7 @@
         let
           val cls_name = Sign.full_bname thy ("fs_"^ak_name);
           val fs_inst  = Global_Theory.get_thm thy ("fs_"^ak_name^"_inst");
-          fun fs_proof thm ctxt = EVERY [Class.intro_classes_tac [], rtac (thm RS fs1) 1];
+          fun fs_proof thm ctxt = EVERY [Class.intro_classes_tac ctxt [], rtac (thm RS fs1) 1];
 
           val fs_thm_unit  = fs_unit_inst;
           val fs_thm_prod  = fs_inst RS (fs_inst RS fs_prod_inst);
@@ -651,7 +651,7 @@
                     val pt_inst  = Global_Theory.get_thm thy'' ("pt_"^ak_name''^"_inst");
                     val at_inst  = Global_Theory.get_thm thy'' ("at_"^ak_name''^"_inst");
                   in
-                   EVERY [Class.intro_classes_tac [],
+                   EVERY [Class.intro_classes_tac ctxt [],
                           rtac (at_inst RS (pt_inst RS pt_perm_compose)) 1]
                   end)
                 else
@@ -663,7 +663,7 @@
                                            [ak_name' ^"_prm_"^ak_name^"_def",
                                             ak_name''^"_prm_"^ak_name^"_def"]));
                   in
-                    EVERY [Class.intro_classes_tac [], simp_tac simp_s 1]
+                    EVERY [Class.intro_classes_tac ctxt [], simp_tac simp_s 1]
                   end))
               in
                 Axclass.prove_arity (name,[],[cls_name]) proof thy''
@@ -686,7 +686,7 @@
             val pt_inst  = Global_Theory.get_thm thy' ("pt_"^ak_name^"_inst");
             val at_inst  = Global_Theory.get_thm thy' ("at_"^ak_name^"_inst");
 
-            fun cp_proof thm ctxt = EVERY [Class.intro_classes_tac [],rtac (thm RS cp1) 1];
+            fun cp_proof thm ctxt = EVERY [Class.intro_classes_tac ctxt [], rtac (thm RS cp1) 1];
           
             val cp_thm_unit = cp_unit_inst;
             val cp_thm_prod = cp_inst RS (cp_inst RS cp_prod_inst);
@@ -717,7 +717,7 @@
              let
                val qu_class = Sign.full_bname thy ("pt_"^ak_name);
                fun proof ctxt =
-                Class.intro_classes_tac [] THEN
+                Class.intro_classes_tac ctxt [] THEN
                 REPEAT (asm_simp_tac (put_simpset HOL_basic_ss ctxt addsimps [Simpdata.mk_eq defn]) 1);
              in 
                Axclass.prove_arity (discrete_ty, [], [qu_class]) proof thy
@@ -729,7 +729,7 @@
                val qu_class = Sign.full_bname thy ("fs_"^ak_name);
                val supp_def = Simpdata.mk_eq @{thm "Nominal.supp_def"};
                fun proof ctxt =
-                Class.intro_classes_tac [] THEN
+                Class.intro_classes_tac ctxt [] THEN
                 asm_simp_tac (put_simpset HOL_ss ctxt
                   addsimps [supp_def, Collect_const, finite_emptyI, Simpdata.mk_eq defn]) 1;
              in 
@@ -742,7 +742,7 @@
                val qu_class = Sign.full_bname thy ("cp_"^ak_name^"_"^ak_name');
                val supp_def = Simpdata.mk_eq @{thm "Nominal.supp_def"};
                fun proof ctxt =
-                Class.intro_classes_tac [] THEN
+                Class.intro_classes_tac ctxt [] THEN
                 asm_simp_tac (put_simpset HOL_ss ctxt addsimps [Simpdata.mk_eq defn]) 1;
              in
                Axclass.prove_arity (discrete_ty, [], [qu_class]) proof thy
--- a/src/HOL/Nominal/nominal_datatype.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Nominal/nominal_datatype.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -427,7 +427,8 @@
       in
         fold (fn (s, tvs) => fn thy => Axclass.prove_arity
             (s, map (inter_sort thy sort o snd) tvs, [cp_class])
-            (fn _ => Class.intro_classes_tac [] THEN ALLGOALS (resolve_tac thms)) thy)
+            (fn ctxt' =>
+              Class.intro_classes_tac ctxt' [] THEN ALLGOALS (resolve_tac ctxt' thms)) thy)
           (full_new_type_names' ~~ tyvars) thy
       end;
 
@@ -439,10 +440,10 @@
           fold (fn (s, tvs) => fn thy => Axclass.prove_arity
               (s, map (inter_sort thy [pt_name] o snd) tvs, [pt_name])
               (fn ctxt => EVERY
-                [Class.intro_classes_tac [],
-                 resolve_tac perm_empty_thms 1,
-                 resolve_tac perm_append_thms 1,
-                 resolve_tac perm_eq_thms 1, assume_tac ctxt 1]) thy)
+                [Class.intro_classes_tac ctxt [],
+                 resolve_tac ctxt perm_empty_thms 1,
+                 resolve_tac ctxt perm_append_thms 1,
+                 resolve_tac ctxt perm_eq_thms 1, assume_tac ctxt 1]) thy)
             (full_new_type_names' ~~ tyvars) thy
         end) atoms |>
       Global_Theory.add_thmss
@@ -562,7 +563,7 @@
            [Old_Datatype_Aux.ind_tac rep_induct [] 1,
             ALLGOALS (simp_tac (ctxt addsimps
               (Thm.symmetric perm_fun_def :: abs_perm))),
-            ALLGOALS (resolve_tac rep_intrs THEN_ALL_NEW assume_tac ctxt)])),
+            ALLGOALS (resolve_tac ctxt rep_intrs THEN_ALL_NEW assume_tac ctxt)])),
         length new_type_names));
 
     val perm_closed_thmss = map mk_perm_closed atoms;
@@ -578,9 +579,9 @@
             (name, map (fn (v, _) => (v, dummyS)) tvs, mx)  (* FIXME keep constraints!? *)
             (Const (@{const_name Collect}, (U --> HOLogic.boolT) --> HOLogic.mk_setT U) $
                Const (cname, U --> HOLogic.boolT)) NONE
-            (fn _ => rtac exI 1 THEN rtac CollectI 1 THEN
+            (fn ctxt => rtac exI 1 THEN rtac CollectI 1 THEN
               QUIET_BREADTH_FIRST (has_fewer_prems 1)
-              (resolve_tac rep_intrs 1)) thy |> (fn ((_, r), thy) =>
+              (resolve_tac ctxt rep_intrs 1)) thy |> (fn ((_, r), thy) =>
         let
           val permT = mk_permT
             (TFree (singleton (Name.variant_list (map fst tvs)) "'a", @{sort type}));
@@ -619,7 +620,7 @@
           in Axclass.prove_arity
             (Sign.intern_type thy name,
               map (inter_sort thy sort o snd) tvs, [pt_class])
-            (fn ctxt => EVERY [Class.intro_classes_tac [],
+            (fn ctxt => EVERY [Class.intro_classes_tac ctxt [],
               rewrite_goals_tac ctxt [perm_def],
               asm_full_simp_tac (ctxt addsimps [Rep_inverse]) 1,
               asm_full_simp_tac (ctxt addsimps
@@ -648,7 +649,7 @@
           Axclass.prove_arity
             (Sign.intern_type thy name,
               map (inter_sort thy sort o snd) tvs, [cp_class])
-            (fn ctxt => EVERY [Class.intro_classes_tac [],
+            (fn ctxt => EVERY [Class.intro_classes_tac ctxt [],
               rewrite_goals_tac ctxt [perm_def],
               asm_full_simp_tac (ctxt addsimps
                 ((Rep RS perm_closed1 RS Abs_inverse) ::
@@ -801,11 +802,11 @@
         val inj_thms = map (fn r => r RS iffD1) abs_inject_thms;
         val rewrites = constr_defs @ map mk_meta_eq Rep_inverse_thms
       in Goal.prove_global_future thy8 [] [] eqn (fn {context = ctxt, ...} => EVERY
-        [resolve_tac inj_thms 1,
+        [resolve_tac ctxt inj_thms 1,
          rewrite_goals_tac ctxt rewrites,
          rtac refl 3,
-         resolve_tac rep_intrs 2,
-         REPEAT (resolve_tac Rep_thms 1)])
+         resolve_tac ctxt rep_intrs 2,
+         REPEAT (resolve_tac ctxt Rep_thms 1)])
       end;
 
     val constr_rep_thmss = map (map prove_constr_rep_thm) constr_rep_eqns;
@@ -1041,7 +1042,7 @@
             REPEAT (EVERY
               [TRY (rtac conjI 1),
                full_simp_tac (put_simpset HOL_basic_ss ctxt addsimps Rep_inverse_thms) 1,
-               etac mp 1, resolve_tac Rep_thms 1])]);
+               etac mp 1, resolve_tac ctxt Rep_thms 1])]);
 
     val Ps = map head_of (HOLogic.dest_conj (HOLogic.dest_Trueprop (concl_of indrule_lemma)));
     val frees = if length Ps = 1 then [Free ("P", snd (dest_Var (hd Ps)))] else
@@ -1058,9 +1059,10 @@
         [rtac indrule_lemma' 1,
          (Old_Datatype_Aux.ind_tac rep_induct [] THEN_ALL_NEW Object_Logic.atomize_prems_tac ctxt) 1,
          EVERY (map (fn (prem, r) => (EVERY
-           [REPEAT (eresolve_tac Abs_inverse_thms' 1),
+           [REPEAT (eresolve_tac ctxt Abs_inverse_thms' 1),
             simp_tac (put_simpset HOL_basic_ss ctxt addsimps [Thm.symmetric r]) 1,
-            DEPTH_SOLVE_1 (ares_tac [prem] 1 ORELSE etac allE 1)]))
+            DEPTH_SOLVE_1
+              (assume_tac ctxt 1 ORELSE resolve_tac ctxt [prem] 1 ORELSE eresolve_tac ctxt [allE] 1)]))
                 (prems ~~ constr_defs))]);
 
     val case_names_induct = Old_Datatype_Data.mk_case_names_induct descr'';
@@ -1116,7 +1118,7 @@
           val sort = Sign.minimize_sort thy (Sign.certify_sort thy (class :: pt_cp_sort));
         in fold (fn Type (s, Ts) => Axclass.prove_arity
           (s, map (inter_sort thy sort o snd o dest_TFree) Ts, [class])
-          (fn _ => Class.intro_classes_tac [] THEN resolve_tac ths 1)) newTs thy
+          (fn ctxt => Class.intro_classes_tac ctxt [] THEN resolve_tac ctxt ths 1)) newTs thy
         end) (atoms ~~ finite_supp_thms);
 
     (**** strong induction theorem ****)
@@ -1243,7 +1245,7 @@
               fresh_const T (fastype_of p) $
                 Bound 0 $ p)))
           (fn _ => EVERY
-            [resolve_tac exists_fresh' 1,
+            [resolve_tac ctxt exists_fresh' 1,
              simp_tac (put_simpset HOL_ss ctxt addsimps (supp_prod :: finite_Un :: fs_atoms @
                fin_set_supp @ ths)) 1]);
         val (([(_, cx)], ths), ctxt') = Obtain.result
@@ -1354,22 +1356,22 @@
                        val th = Goal.prove context3 [] [] concl' (fn _ => EVERY
                          [simp_tac (ind_ss6 addsimps rename_eq) 1,
                           cut_facts_tac iprems 1,
-                          (resolve_tac prems THEN_ALL_NEW
+                          (resolve_tac context2 prems THEN_ALL_NEW
                             SUBGOAL (fn (t, i) => case Logic.strip_assums_concl t of
                                 _ $ (Const (@{const_name Nominal.fresh}, _) $ _ $ _) =>
                                   simp_tac ind_ss1' i
                               | _ $ (Const (@{const_name Not}, _) $ _) =>
-                                  resolve_tac freshs2' i
+                                  resolve_tac context2 freshs2' i
                               | _ => asm_simp_tac (put_simpset HOL_basic_ss context3 addsimps
                                   pt2_atoms addsimprocs [perm_simproc]) i)) 1])
                        val final = Proof_Context.export context3 context2 [th]
                      in
-                       resolve_tac final 1
+                       resolve_tac context2 final 1
                      end) context1 1) (constrs ~~ constrs')) (descr'' ~~ ndescr)))
       in
         EVERY
           [cut_facts_tac [th] 1,
-           REPEAT (eresolve_tac [conjE, @{thm allE_Nil}] 1),
+           REPEAT (eresolve_tac context [conjE, @{thm allE_Nil}] 1),
            REPEAT (etac allE 1),
            REPEAT (TRY (rtac conjI 1) THEN asm_full_simp_tac ind_ss5 1)]
       end);
@@ -1390,8 +1392,8 @@
       (augment_sort thy9 fs_cp_sort ind_concl)
       (fn {prems, context = ctxt} => EVERY
          [rtac induct_aux' 1,
-          REPEAT (resolve_tac fs_atoms 1),
-          REPEAT ((resolve_tac prems THEN_ALL_NEW
+          REPEAT (resolve_tac ctxt fs_atoms 1),
+          REPEAT ((resolve_tac ctxt prems THEN_ALL_NEW
             (etac @{thm meta_spec} ORELSE'
               full_simp_tac (put_simpset HOL_basic_ss ctxt addsimps [fresh_def]))) 1)])
 
@@ -1538,7 +1540,7 @@
                  (simp_tac (put_simpset HOL_basic_ss ctxt
                     addsimps flat perm_simps'
                     addsimprocs [NominalPermeq.perm_simproc_app]) 1 THEN
-                  (resolve_tac rec_intrs THEN_ALL_NEW
+                  (resolve_tac ctxt rec_intrs THEN_ALL_NEW
                    asm_simp_tac (put_simpset HOL_ss ctxt addsimps (fresh_bij @ perm_bij))) 1))))
         val ths' = map (fn ((P, Q), th) =>
           Goal.prove_global_future thy11 [] []
@@ -1630,7 +1632,7 @@
                       supports_fresh) 1,
                     simp_tac (put_simpset HOL_basic_ss context addsimps
                       [supports_def, Thm.symmetric fresh_def, fresh_prod]) 1,
-                    REPEAT_DETERM (resolve_tac [allI, impI] 1),
+                    REPEAT_DETERM (resolve_tac context [allI, impI] 1),
                     REPEAT_DETERM (etac conjE 1),
                     rtac unique 1,
                     SUBPROOF (fn {prems = prems', params = [(_, a), (_, b)], ...} => EVERY
@@ -1683,8 +1685,8 @@
               fresh_const T (fastype_of p) $ Bound 0 $ p)))
           (fn _ => EVERY
             [cut_facts_tac ths 1,
-             REPEAT_DETERM (dresolve_tac (the (AList.lookup op = rec_fin_supp T)) 1),
-             resolve_tac exists_fresh' 1,
+             REPEAT_DETERM (dresolve_tac ctxt (the (AList.lookup op = rec_fin_supp T)) 1),
+             resolve_tac ctxt exists_fresh' 1,
              asm_simp_tac (put_simpset HOL_ss ctxt addsimps (supp_prod :: finite_Un :: fs_atoms)) 1]);
         val (([(_, cx)], ths), ctxt') = Obtain.result
           (fn _ => EVERY
@@ -1723,7 +1725,7 @@
                            rec_sets ~~ rec_preds)))))
                (fn {context = ctxt, ...} =>
                   rtac rec_induct 1 THEN
-                  REPEAT ((resolve_tac P_ind_ths THEN_ALL_NEW assume_tac ctxt) 1))));
+                  REPEAT ((resolve_tac ctxt P_ind_ths THEN_ALL_NEW assume_tac ctxt) 1))));
            val rec_fin_supp_thms' = map
              (fn (ths, (T, fin_ths)) => (T, map (curry op MRS fin_ths) ths))
              (rec_fin_supp_thms ~~ finite_thss);
@@ -1735,9 +1737,9 @@
                 (finite_thss ~~ finite_ctxt_ths) @
             maps (fn ((_, idxss), elim) => maps (fn idxs =>
               [full_simp_tac (put_simpset HOL_ss context addsimps [Thm.symmetric fresh_def, supp_prod, Un_iff]) 1,
-               REPEAT_DETERM (eresolve_tac @{thms conjE ex1E} 1),
+               REPEAT_DETERM (eresolve_tac context @{thms conjE ex1E} 1),
                rtac @{thm ex1I} 1,
-               (resolve_tac rec_intrs THEN_ALL_NEW atac) 1,
+               (resolve_tac context rec_intrs THEN_ALL_NEW atac) 1,
                rotate_tac ~1 1,
                ((DETERM o etac elim) THEN_ALL_NEW full_simp_tac
                   (put_simpset HOL_ss context addsimps flat distinct_thms)) 1] @
@@ -1907,7 +1909,7 @@
                                     map (fn th => rtac th 1)
                                       (snd (nth finite_thss l)) @
                                     [rtac rec_prem 1, rtac ih 1,
-                                     REPEAT_DETERM (resolve_tac fresh_prems 1)]))
+                                     REPEAT_DETERM (resolve_tac context fresh_prems 1)]))
                             end) atoms
                         end) (rec_prems1 ~~ ihs);
 
@@ -1917,13 +1919,13 @@
                       Goal.prove context'' [] []
                         (HOLogic.mk_Trueprop (fresh_const aT rT $ a $ rhs'))
                         (fn _ => EVERY
-                           [resolve_tac fcbs 1,
-                            REPEAT_DETERM (resolve_tac
+                           [resolve_tac context'' fcbs 1,
+                            REPEAT_DETERM (resolve_tac context''
                               (fresh_prems @ rec_freshs) 1),
-                            REPEAT_DETERM (resolve_tac (maps snd rec_fin_supp_thms') 1
-                              THEN resolve_tac rec_prems 1),
-                            resolve_tac P_ind_ths 1,
-                            REPEAT_DETERM (resolve_tac (P_ths @ rec_prems) 1)]);
+                            REPEAT_DETERM (resolve_tac context'' (maps snd rec_fin_supp_thms') 1
+                              THEN resolve_tac context'' rec_prems 1),
+                            resolve_tac context'' P_ind_ths 1,
+                            REPEAT_DETERM (resolve_tac context'' (P_ths @ rec_prems) 1)]);
 
                     val fresh_results'' = map prove_fresh_result boundsl;
 
@@ -1956,7 +1958,7 @@
                         (HOLogic.mk_Trueprop (fresh_const aT rT $ a $ t))
                         (fn _ => EVERY
                           [cut_facts_tac recs 1,
-                           REPEAT_DETERM (dresolve_tac
+                           REPEAT_DETERM (dresolve_tac context''
                              (the (AList.lookup op = rec_fin_supp_thms' aT)) 1),
                            NominalPermeq.fresh_guess_tac
                              (put_simpset HOL_ss context'' addsimps (freshs2 @
@@ -1986,7 +1988,7 @@
                     val final' = Proof_Context.export context'' context' [final];
                     val _ = warning "finished!"
                   in
-                    resolve_tac final' 1
+                    resolve_tac context' final' 1
                   end) context 1])) idxss) (ndescr ~~ rec_elims))
          end));
 
@@ -2025,8 +2027,8 @@
         val concl' = subst_atomic_types (rec_result_Ts' ~~ rec_result_Ts) concl;
         val prems' = flat finite_premss @ finite_ctxt_prems @
           rec_prems @ rec_prems' @ map (subst_atomic ps) prems;
-        fun solve rules prems = resolve_tac rules THEN_ALL_NEW
-          (resolve_tac prems THEN_ALL_NEW atac)
+        fun solve ctxt rules prems = resolve_tac ctxt rules THEN_ALL_NEW
+          (resolve_tac ctxt prems THEN_ALL_NEW atac)
       in
         Goal.prove_global_future thy12 []
           (map (augment_sort thy12 fs_cp_sort) prems')
@@ -2034,9 +2036,9 @@
           (fn {context = ctxt, prems} => EVERY
             [rewrite_goals_tac ctxt reccomb_defs,
              rtac @{thm the1_equality} 1,
-             solve rec_unique_thms prems 1,
-             resolve_tac rec_intrs 1,
-             REPEAT (solve (prems @ rec_total_thms) prems 1)])
+             solve ctxt rec_unique_thms prems 1,
+             resolve_tac ctxt rec_intrs 1,
+             REPEAT (solve ctxt (prems @ rec_total_thms) prems 1)])
       end) (rec_eq_prems ~~
         Old_Datatype_Prop.make_primrecs reccomb_names descr' thy12);
 
--- a/src/HOL/Nominal/nominal_inductive.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Nominal/nominal_inductive.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -130,7 +130,7 @@
     fun prove t =
       Goal.prove ctxt [] [] t (fn _ =>
         EVERY [cut_facts_tac [th] 1, etac rev_mp 1,
-          REPEAT_DETERM (FIRSTGOAL (resolve_tac monos)),
+          REPEAT_DETERM (FIRSTGOAL (resolve_tac ctxt monos)),
           REPEAT_DETERM (rtac impI 1 THEN (atac 1 ORELSE tac))])
   in Option.map prove (map_term f prop (the_default prop opt)) end;
 
@@ -296,8 +296,8 @@
               NominalDatatype.fresh_const T (fastype_of p) $
                 Bound 0 $ p)))
           (fn _ => EVERY
-            [resolve_tac exists_fresh' 1,
-             resolve_tac fs_atoms 1]);
+            [resolve_tac ctxt exists_fresh' 1,
+             resolve_tac ctxt fs_atoms 1]);
         val (([(_, cx)], ths), ctxt') = Obtain.result
           (fn ctxt' => EVERY
             [etac exE 1,
@@ -388,17 +388,17 @@
                        (simp_tac (put_simpset HOL_basic_ss ctxt''
                           addsimps [inductive_forall_def']
                           addsimprocs [NominalDatatype.perm_simproc]) 1 THEN
-                        resolve_tac gprems2 1)]));
+                        resolve_tac ctxt'' gprems2 1)]));
                  val final = Goal.prove ctxt'' [] [] (term_of concl)
                    (fn _ => cut_facts_tac [th] 1 THEN full_simp_tac (put_simpset HOL_ss ctxt''
                      addsimps vc_compat_ths'' @ freshs2' @
                        perm_fresh_fresh @ fresh_atm) 1);
                  val final' = Proof_Context.export ctxt'' ctxt' [final];
-               in resolve_tac final' 1 end) context 1])
+               in resolve_tac ctxt' final' 1 end) context 1])
                  (prems ~~ thss ~~ ihyps ~~ prems'')))
         in
           cut_facts_tac [th] 1 THEN REPEAT (etac conjE 1) THEN
-          REPEAT (REPEAT (resolve_tac [conjI, impI] 1) THEN
+          REPEAT (REPEAT (resolve_tac ctxt [conjI, impI] 1) THEN
             etac impE 1 THEN atac 1 THEN REPEAT (etac @{thm allE_Nil} 1) THEN
             asm_full_simp_tac ctxt 1)
         end) |> singleton (Proof_Context.export ctxt' ctxt);
@@ -532,10 +532,10 @@
                          in
                            simp_tac case_simpset 1 THEN
                            REPEAT_DETERM (TRY (rtac conjI 1) THEN
-                             resolve_tac case_hyps' 1)
+                             resolve_tac ctxt4 case_hyps' 1)
                          end) ctxt4 1)
                   val final = Proof_Context.export ctxt3 ctxt2 [th]
-                in resolve_tac final 1 end) ctxt1 1)
+                in resolve_tac ctxt2 final 1 end) ctxt1 1)
                   (thss ~~ hyps ~~ prems))) |>
                   singleton (Proof_Context.export ctxt' ctxt))
 
@@ -634,7 +634,7 @@
             val intr' = Drule.cterm_instantiate (map (cterm_of thy) vs ~~
                map (cterm_of thy o NominalDatatype.mk_perm [] pi o term_of o #2) params)
                intr
-          in (rtac intr' THEN_ALL_NEW (TRY o resolve_tac prems'')) 1
+          in (rtac intr' THEN_ALL_NEW (TRY o resolve_tac ctxt'' prems'')) 1
           end) ctxt' 1 st
       in
         case (Seq.pull res handle THM (s, _, _) => eqvt_err s) of
--- a/src/HOL/Nominal/nominal_inductive2.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Nominal/nominal_inductive2.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -135,7 +135,7 @@
     fun prove t =
       Goal.prove ctxt [] [] t (fn _ =>
         EVERY [cut_facts_tac [th] 1, etac rev_mp 1,
-          REPEAT_DETERM (FIRSTGOAL (resolve_tac monos)),
+          REPEAT_DETERM (FIRSTGOAL (resolve_tac ctxt monos)),
           REPEAT_DETERM (rtac impI 1 THEN (atac 1 ORELSE tac))])
   in Option.map prove (map_term f prop (the_default prop opt)) end;
 
@@ -424,17 +424,17 @@
                        (simp_tac (put_simpset HOL_basic_ss ctxt''
                           addsimps [inductive_forall_def']
                           addsimprocs [NominalDatatype.perm_simproc]) 1 THEN
-                        resolve_tac gprems2 1)]));
+                        resolve_tac ctxt'' gprems2 1)]));
                  val final = Goal.prove ctxt'' [] [] (term_of concl)
                    (fn _ => cut_facts_tac [th] 1 THEN full_simp_tac (put_simpset HOL_ss ctxt''
                      addsimps vc_compat_ths1' @ fresh_ths1 @
                        perm_freshs_freshs') 1);
                  val final' = Proof_Context.export ctxt'' ctxt' [final];
-               in resolve_tac final' 1 end) context 1])
+               in resolve_tac ctxt' final' 1 end) context 1])
                  (prems ~~ thss ~~ vc_compat' ~~ ihyps ~~ prems'')))
         in
           cut_facts_tac [th] 1 THEN REPEAT (etac conjE 1) THEN
-          REPEAT (REPEAT (resolve_tac [conjI, impI] 1) THEN
+          REPEAT (REPEAT (resolve_tac ctxt' [conjI, impI] 1) THEN
             etac impE 1 THEN atac 1 THEN REPEAT (etac @{thm allE_Nil} 1) THEN
             asm_full_simp_tac ctxt 1)
         end) |>
--- a/src/HOL/Old_Number_Theory/Chinese.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Old_Number_Theory/Chinese.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -166,11 +166,11 @@
   "0 < n ==> i \<le> n ==> m_cond n mf ==> km_cond n kf mf
     ==> \<exists>!x. 0 \<le> x \<and> x < mf i \<and> [kf i * mhf mf n i * x = bf i] (mod mf i)"
   apply (rule zcong_lineq_unique)
-   apply (tactic {* stac @{thm zgcd_zmult_cancel} 2 *})
+   apply (tactic {* stac @{context} @{thm zgcd_zmult_cancel} 2 *})
     apply (unfold m_cond_def km_cond_def mhf_def)
     apply (simp_all (no_asm_simp))
   apply safe
-    apply (tactic {* stac @{thm zgcd_zmult_cancel} 3 *})
+    apply (tactic {* stac @{context} @{thm zgcd_zmult_cancel} 3 *})
      apply (rule_tac [!] funprod_zgcd)
      apply safe
      apply simp_all
@@ -228,12 +228,12 @@
   apply (rule_tac x = "x_sol n kf bf mf mod funprod mf 0 n" in exI)
   apply (unfold lincong_sol_def)
   apply safe
-    apply (tactic {* stac @{thm zcong_zmod} 3 *})
-    apply (tactic {* stac @{thm mod_mult_eq} 3 *})
-    apply (tactic {* stac @{thm mod_mod_cancel} 3 *})
-      apply (tactic {* stac @{thm x_sol_lin} 4 *})
-        apply (tactic {* stac (@{thm mod_mult_eq} RS sym) 6 *})
-        apply (tactic {* stac (@{thm zcong_zmod} RS sym) 6 *})
+    apply (tactic {* stac @{context} @{thm zcong_zmod} 3 *})
+    apply (tactic {* stac @{context} @{thm mod_mult_eq} 3 *})
+    apply (tactic {* stac @{context} @{thm mod_mod_cancel} 3 *})
+      apply (tactic {* stac @{context} @{thm x_sol_lin} 4 *})
+        apply (tactic {* stac @{context} (@{thm mod_mult_eq} RS sym) 6 *})
+        apply (tactic {* stac @{context} (@{thm zcong_zmod} RS sym) 6 *})
         apply (subgoal_tac [6]
           "0 \<le> xilin_sol i n kf bf mf \<and> xilin_sol i n kf bf mf < mf i
           \<and> [kf i * mhf mf n i * xilin_sol i n kf bf mf = bf i] (mod mf i)")
--- a/src/HOL/Old_Number_Theory/IntPrimes.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Old_Number_Theory/IntPrimes.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -399,7 +399,7 @@
     zgcd a n = 1 ==> \<exists>!x. 0 \<le> x \<and> x < n \<and> [a * x = b] (mod n)"
   apply auto
    apply (rule_tac [2] zcong_zless_imp_eq)
-       apply (tactic {* stac (@{thm zcong_cancel2} RS sym) 6 *})
+       apply (tactic {* stac @{context} (@{thm zcong_cancel2} RS sym) 6 *})
          apply (rule_tac [8] zcong_trans)
           apply (simp_all (no_asm_simp))
    prefer 2
--- a/src/HOL/Old_Number_Theory/WilsonBij.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Old_Number_Theory/WilsonBij.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -139,9 +139,9 @@
   apply (unfold inj_on_def)
   apply auto
   apply (rule zcong_zless_imp_eq)
-      apply (tactic {* stac (@{thm zcong_cancel} RS sym) 5 *})
+      apply (tactic {* stac @{context} (@{thm zcong_cancel} RS sym) 5 *})
         apply (rule_tac [7] zcong_trans)
-         apply (tactic {* stac @{thm zcong_sym} 8 *})
+         apply (tactic {* stac @{context} @{thm zcong_sym} 8 *})
          apply (erule_tac [7] inv_is_inv)
           apply (tactic "asm_simp_tac @{context} 9")
           apply (erule_tac [9] inv_is_inv)
@@ -192,15 +192,15 @@
   apply (unfold reciR_def uniqP_def)
   apply auto
    apply (rule zcong_zless_imp_eq)
-       apply (tactic {* stac (@{thm zcong_cancel2} RS sym) 5 *})
+       apply (tactic {* stac @{context} (@{thm zcong_cancel2} RS sym) 5 *})
          apply (rule_tac [7] zcong_trans)
-          apply (tactic {* stac @{thm zcong_sym} 8 *})
+          apply (tactic {* stac @{context} @{thm zcong_sym} 8 *})
           apply (rule_tac [6] zless_zprime_imp_zrelprime)
             apply auto
   apply (rule zcong_zless_imp_eq)
-      apply (tactic {* stac (@{thm zcong_cancel} RS sym) 5 *})
+      apply (tactic {* stac @{context} (@{thm zcong_cancel} RS sym) 5 *})
         apply (rule_tac [7] zcong_trans)
-         apply (tactic {* stac @{thm zcong_sym} 8 *})
+         apply (tactic {* stac @{context} @{thm zcong_sym} 8 *})
          apply (rule_tac [6] zless_zprime_imp_zrelprime)
            apply auto
   done
--- a/src/HOL/Old_Number_Theory/WilsonRuss.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Old_Number_Theory/WilsonRuss.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -252,7 +252,7 @@
    apply (subst wset.simps)
    apply (auto, unfold Let_def, auto)
   apply (subst setprod.insert)
-    apply (tactic {* stac @{thm setprod.insert} 3 *})
+    apply (tactic {* stac @{context} @{thm setprod.insert} 3 *})
       apply (subgoal_tac [5]
         "zcong (a * inv p a * (\<Prod>x\<in>wset (a - 1) p. x)) (1 * 1) p")
        prefer 5
--- a/src/HOL/Probability/measurable.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Probability/measurable.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -208,9 +208,9 @@
     fun r_tac msg =
       if Config.get ctxt debug
       then FIRST' o
-        map (fn thm => resolve_tac [thm]
+        map (fn thm => resolve_tac ctxt [thm]
           THEN' K (debug_tac ctxt (debug_fact (msg ^ " resolved using") thm) all_tac))
-      else resolve_tac
+      else resolve_tac ctxt
 
     val elem_congI = @{lemma "A = B \<Longrightarrow> x \<in> B \<Longrightarrow> x \<in> A" by simp}
 
@@ -249,7 +249,8 @@
           val f = dest_measurable_fun (HOLogic.dest_Trueprop t)
           fun cert f = map (Option.map (f (Proof_Context.theory_of ctxt)))
           fun inst (ts, Ts) =
-            Drule.instantiate' (cert ctyp_of Ts) (cert cterm_of ts) @{thm measurable_compose_countable}
+            Drule.instantiate' (cert ctyp_of Ts) (cert cterm_of ts)
+              @{thm measurable_compose_countable}
         in r_tac "split countable" (cnt_prefixes ctxt f |> map inst) i end
         handle TERM _ => no_tac) 1)
 
--- a/src/HOL/Product_Type.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Product_Type.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -1327,10 +1327,10 @@
                       SOME (Goal.prove ctxt [] []
                         (Const (@{const_name Pure.eq}, T --> T --> propT) $ S $ S')
                         (K (EVERY
-                          [resolve_tac [eq_reflection] 1,
-                           resolve_tac @{thms subset_antisym} 1,
-                           resolve_tac [subsetI] 1, dresolve_tac [CollectD] 1, simp,
-                           resolve_tac [subsetI] 1, resolve_tac [CollectI] 1, simp])))
+                          [resolve_tac ctxt [eq_reflection] 1,
+                           resolve_tac ctxt @{thms subset_antisym} 1,
+                           resolve_tac ctxt [subsetI] 1, dresolve_tac ctxt [CollectD] 1, simp,
+                           resolve_tac ctxt [subsetI] 1, resolve_tac ctxt [CollectI] 1, simp])))
                     end
                   else NONE)
           | _ => NONE)
--- a/src/HOL/Prolog/prolog.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Prolog/prolog.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -119,8 +119,8 @@
                   asm_full_simp_tac (put_simpset atomize_ss ctxt) THEN'    (* atomize the asms *)
                   (REPEAT_DETERM o (etac conjE))        (* split the asms *)
                 ])
-        ORELSE' resolve_tac [disjI1,disjI2]     (* "P ==> P | Q","Q ==> P | Q"*)
-        ORELSE' ((resolve_tac proga APPEND' hyp_resolve_tac)
+        ORELSE' resolve_tac ctxt [disjI1,disjI2]     (* "P ==> P | Q","Q ==> P | Q"*)
+        ORELSE' ((resolve_tac ctxt proga APPEND' hyp_resolve_tac)
                  THEN' (fn _ => check_HOHH_tac2))
 end;
 
--- a/src/HOL/ROOT	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/ROOT	Wed Feb 11 12:01:56 2015 +0000
@@ -1067,7 +1067,9 @@
     The Alternating Bit Protocol performed in I/O-Automata.
   *}
   options [document = false]
-  theories Correctness
+  theories
+    Correctness
+    Spec
 
 session "IOA-NTP" in "HOLCF/IOA/NTP" = IOA +
   description {*
--- a/src/HOL/SET_Protocol/Cardholder_Registration.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/SET_Protocol/Cardholder_Registration.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -538,7 +538,7 @@
 method_setup valid_certificate_tac = {*
   Args.goal_spec >> (fn quant => fn ctxt => SIMPLE_METHOD'' quant
     (fn i =>
-      EVERY [ftac @{thm Gets_certificate_valid} i,
+      EVERY [forward_tac ctxt @{thms Gets_certificate_valid} i,
              assume_tac ctxt i,
              etac conjE i, REPEAT (hyp_subst_tac ctxt i)]))
 *}
--- a/src/HOL/SET_Protocol/Event_SET.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/SET_Protocol/Event_SET.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -184,7 +184,7 @@
 {*
 fun analz_mono_contra_tac ctxt = 
   rtac @{thm analz_impI} THEN' 
-  REPEAT1 o (dresolve_tac @{thms analz_mono_contra})
+  REPEAT1 o (dresolve_tac ctxt @{thms analz_mono_contra})
   THEN' mp_tac ctxt
 *}
 
--- a/src/HOL/SET_Protocol/Message_SET.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/SET_Protocol/Message_SET.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -850,13 +850,13 @@
 (*Apply rules to break down assumptions of the form
   Y \<in> parts(insert X H)  and  Y \<in> analz(insert X H)
 *)
-val Fake_insert_tac =
-    dresolve_tac [impOfSubs @{thm Fake_analz_insert},
+fun Fake_insert_tac ctxt =
+    dresolve_tac ctxt [impOfSubs @{thm Fake_analz_insert},
                   impOfSubs @{thm Fake_parts_insert}] THEN'
-    eresolve_tac [asm_rl, @{thm synth.Inj}];
+    eresolve_tac ctxt [asm_rl, @{thm synth.Inj}];
 
 fun Fake_insert_simp_tac ctxt i =
-  REPEAT (Fake_insert_tac i) THEN asm_full_simp_tac ctxt i;
+  REPEAT (Fake_insert_tac ctxt i) THEN asm_full_simp_tac ctxt i;
 
 fun atomic_spy_analz_tac ctxt =
   SELECT_GOAL
@@ -874,7 +874,7 @@
            (res_inst_tac ctxt [(("x", 1), "X")] (insert_commute RS ssubst) 1),
        (*...allowing further simplifications*)
        simp_tac ctxt 1,
-       REPEAT (FIRSTGOAL (resolve_tac [allI,impI,notI,conjI,iffI])),
+       REPEAT (FIRSTGOAL (resolve_tac ctxt [allI,impI,notI,conjI,iffI])),
        DEPTH_SOLVE (atomic_spy_analz_tac ctxt 1)]) i);
 *}
 (*>*)
--- a/src/HOL/SET_Protocol/Public_SET.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/SET_Protocol/Public_SET.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -347,7 +347,7 @@
     (ALLGOALS (simp_tac (ctxt delsimps [@{thm used_Says}, @{thm used_Notes}]))
      THEN
      REPEAT_FIRST (eq_assume_tac ORELSE' 
-                   resolve_tac [refl, conjI, @{thm Nonce_supply}]))
+                   resolve_tac ctxt [refl, conjI, @{thm Nonce_supply}]))
 
 (*For harder protocols (such as SET_CR!), where we have to set up some
   nonces and keys initially*)
@@ -355,7 +355,7 @@
     REPEAT 
     (ALLGOALS (asm_simp_tac (ctxt setSolver safe_solver))
      THEN
-     REPEAT_FIRST (resolve_tac [refl, conjI]))
+     REPEAT_FIRST (resolve_tac ctxt [refl, conjI]))
 *}
 
 method_setup possibility = {*
--- a/src/HOL/SET_Protocol/Purchase.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/SET_Protocol/Purchase.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -482,7 +482,7 @@
 method_setup valid_certificate_tac = {*
   Args.goal_spec >> (fn quant =>
     fn ctxt => SIMPLE_METHOD'' quant (fn i =>
-      EVERY [ftac @{thm Gets_certificate_valid} i,
+      EVERY [forward_tac ctxt @{thms Gets_certificate_valid} i,
              assume_tac ctxt i, REPEAT (hyp_subst_tac ctxt i)]))
 *}
 
--- a/src/HOL/SPARK/Tools/spark_vcs.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/SPARK/Tools/spark_vcs.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -242,12 +242,12 @@
            delsimps @{thms atLeastLessThan_iff}) 1);
 
     val lthy' =
-      Class.prove_instantiation_instance (fn _ =>
-        Class.intro_classes_tac [] THEN
+      Class.prove_instantiation_instance (fn ctxt =>
+        Class.intro_classes_tac ctxt [] THEN
         rtac finite_UNIV 1 THEN
         rtac range_pos 1 THEN
-        simp_tac (put_simpset HOL_basic_ss lthy addsimps [def3]) 1 THEN
-        simp_tac (put_simpset HOL_basic_ss lthy addsimps [def2]) 1) lthy;
+        simp_tac (put_simpset HOL_basic_ss ctxt addsimps [def3]) 1 THEN
+        simp_tac (put_simpset HOL_basic_ss ctxt addsimps [def2]) 1) lthy;
 
     val (pos_eqs, val_eqs) = split_list (map_index (fn (i, c) =>
       let
--- a/src/HOL/Set.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Set.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -70,12 +70,12 @@
 
 simproc_setup defined_Collect ("{x. P x & Q x}") = {*
   fn _ => Quantifier1.rearrange_Collect
-    (fn _ =>
-      resolve_tac @{thms Collect_cong} 1 THEN
-      resolve_tac @{thms iffI} 1 THEN
+    (fn ctxt =>
+      resolve_tac ctxt @{thms Collect_cong} 1 THEN
+      resolve_tac ctxt @{thms iffI} 1 THEN
       ALLGOALS
-        (EVERY' [REPEAT_DETERM o eresolve_tac @{thms conjE},
-          DEPTH_SOLVE_1 o ares_tac @{thms conjI}]))
+        (EVERY' [REPEAT_DETERM o eresolve_tac ctxt @{thms conjE},
+          DEPTH_SOLVE_1 o (assume_tac ctxt ORELSE' resolve_tac ctxt @{thms conjI})]))
 *}
 
 lemmas CollectE = CollectD [elim_format]
@@ -359,14 +359,14 @@
   fn _ => Quantifier1.rearrange_bex
     (fn ctxt =>
       unfold_tac ctxt @{thms Bex_def} THEN
-      Quantifier1.prove_one_point_ex_tac)
+      Quantifier1.prove_one_point_ex_tac ctxt)
 *}
 
 simproc_setup defined_All ("ALL x:A. P x --> Q x") = {*
   fn _ => Quantifier1.rearrange_ball
     (fn ctxt =>
       unfold_tac ctxt @{thms Ball_def} THEN
-      Quantifier1.prove_one_point_all_tac)
+      Quantifier1.prove_one_point_all_tac ctxt)
 *}
 
 lemma ballI [intro!]: "(!!x. x:A ==> P x) ==> ALL x:A. P x"
@@ -383,7 +383,7 @@
 
 setup {*
   map_theory_claset (fn ctxt =>
-    ctxt addbefore ("bspec", fn ctxt' => dresolve_tac @{thms bspec} THEN' assume_tac ctxt'))
+    ctxt addbefore ("bspec", fn ctxt' => dresolve_tac ctxt' @{thms bspec} THEN' assume_tac ctxt'))
 *}
 
 ML {*
--- a/src/HOL/Statespace/state_space.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Statespace/state_space.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -354,7 +354,7 @@
         val expr = ([(suffix valuetypesN name,
                      (prefix, Expression.Positional (map SOME pars)))],[]);
       in
-        prove_interpretation_in (ALLGOALS o solve_tac o Assumption.all_prems_of)
+        prove_interpretation_in (fn ctxt => ALLGOALS (solve_tac ctxt (Assumption.all_prems_of ctxt)))
           (suffix valuetypesN name, expr) thy
       end;
 
--- a/src/HOL/TLA/Action.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/TLA/Action.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -263,9 +263,9 @@
 *)
 fun action_simp_tac ctxt intros elims =
     asm_full_simp_tac
-         (ctxt setloop (fn _ => (resolve_tac ((map (action_use ctxt) intros)
+         (ctxt setloop (fn _ => (resolve_tac ctxt ((map (action_use ctxt) intros)
                                     @ [refl,impI,conjI,@{thm actionI},@{thm intI},allI]))
-                      ORELSE' (eresolve_tac ((map (action_use ctxt) elims)
+                      ORELSE' (eresolve_tac ctxt ((map (action_use ctxt) elims)
                                              @ [conjE,disjE,exE]))));
 *}
 
--- a/src/HOL/TLA/Memory/MemoryImplementation.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/TLA/Memory/MemoryImplementation.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -800,7 +800,7 @@
    (TRY (rtac @{thm actionI} 1) THEN
     Induct_Tacs.case_tac ctxt "(s,t) |= unchanged (e p, c p, r p, m p, rmhist!p)" 1 THEN
     rewrite_goals_tac ctxt @{thms action_rews} THEN
-    forward_tac [temp_use ctxt @{thm Step1_4_7}] 1 THEN
+    forward_tac ctxt [temp_use ctxt @{thm Step1_4_7}] 1 THEN
     asm_full_simp_tac ctxt 1);
 *}
 
--- a/src/HOL/TLA/TLA.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/TLA/TLA.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -697,7 +697,8 @@
 
 (* A tactic that "boxes" all fairness conditions. Apply more_temp_simps to "unbox". *)
 ML {*
-val box_fair_tac = SELECT_GOAL (REPEAT (dresolve_tac [@{thm BoxWFI}, @{thm BoxSFI}] 1))
+fun box_fair_tac ctxt =
+  SELECT_GOAL (REPEAT (dresolve_tac ctxt [@{thm BoxWFI}, @{thm BoxSFI}] 1))
 *}
 
 
--- a/src/HOL/TPTP/TPTP_Parser/tptp_reconstruct_library.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/TPTP/TPTP_Parser/tptp_reconstruct_library.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -623,7 +623,7 @@
 
 (*Prove subgoals of form A ==> B1 | ... | A | ... | Bn*)
 val clause_breaker =
-  (REPEAT o (resolve_tac [@{thm "disjI1"}, @{thm "disjI2"}, @{thm "conjI"}]))
+  (REPEAT o (resolve0_tac [@{thm "disjI1"}, @{thm "disjI2"}, @{thm "conjI"}]))
   THEN'  atac
 
 (*
--- a/src/HOL/TPTP/TPTP_Proof_Reconstruction.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/TPTP/TPTP_Proof_Reconstruction.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -474,7 +474,7 @@
       THEN' (REPEAT_DETERM o etac @{thm conjE})
       THEN' (TRY o (expander_animal ctxt))
   in
-    default_tac ORELSE' resolve_tac @{thms flip}
+    default_tac ORELSE' resolve_tac ctxt @{thms flip}
   end
 *}
 
@@ -1154,7 +1154,7 @@
       ASAP
         (rtac @{thm disjI1} APPEND' rtac @{thm disjI2})
         (FIRST' (map closure
-                  [dresolve_tac @{thms dec_commut_eq},
+                  [dresolve_tac ctxt @{thms dec_commut_eq},
                    dtac @{thm dec_commut_disj},
                    elim_tac]))
   in
@@ -1527,7 +1527,7 @@
 
     val ex_free =
       if loop_can_feature [Existential_Free] feats andalso consts_diff = [] then
-        eresolve_tac @{thms polar_exE}
+        eresolve_tac ctxt @{thms polar_exE}
       else K no_tac
   in
     ex_var APPEND' ex_free
@@ -1613,8 +1613,8 @@
             | Not_neg => trace_tac' "mark: not_neg" (dtac @{thm leo2_rules(10)})
             | Or_pos => trace_tac' "mark: or_pos" (dtac @{thm leo2_rules(5)}) (*could add (6) for negated conjunction*)
             | Or_neg => trace_tac' "mark: or_neg" (dtac @{thm leo2_rules(7)})
-            | Equal_pos => trace_tac' "mark: equal_pos" (dresolve_tac (@{thms eq_pos_bool} @ [@{thm leo2_rules(3)}, @{thm eq_pos_func}]))
-            | Equal_neg => trace_tac' "mark: equal_neg" (dresolve_tac [@{thm eq_neg_bool}, @{thm leo2_rules(4)}])
+            | Equal_pos => trace_tac' "mark: equal_pos" (dresolve_tac ctxt (@{thms eq_pos_bool} @ [@{thm leo2_rules(3)}, @{thm eq_pos_func}]))
+            | Equal_neg => trace_tac' "mark: equal_neg" (dresolve_tac ctxt [@{thm eq_neg_bool}, @{thm leo2_rules(4)}])
             | Donkey_Cong => trace_tac' "mark: donkey_cong" (simper_animal ctxt THEN' ex_expander_tac ctxt)
 
             | Extuni_Bool2 => trace_tac' "mark: extuni_bool2" (dtac @{thm extuni_bool2})
@@ -1624,7 +1624,7 @@
             | Extuni_Dec => trace_tac' "mark: extuni_dec_tac" (extuni_dec_tac ctxt)
             | Extuni_FlexRigid => trace_tac' "mark: extuni_flex_rigid" (atac ORELSE' asm_full_simp_tac ctxt)
             | Extuni_Func => trace_tac' "mark: extuni_func" (dtac @{thm extuni_func})
-            | Polarity_switch => trace_tac' "mark: polarity_switch" (eresolve_tac @{thms polarity_switch})
+            | Polarity_switch => trace_tac' "mark: polarity_switch" (eresolve_tac ctxt @{thms polarity_switch})
             | Forall_special_pos => trace_tac' "mark: dorall_special_pos" extcnf_forall_special_pos_tac
 
         val core_tac =
@@ -1804,7 +1804,7 @@
                   member (op =)  (Term.add_frees hyp_lit_body []) (hd hyp_lit_prefix) then
                   no_tac st
                 else
-                  dresolve_tac @{thms drop_redundant_literal_qtfr} i st
+                  dresolve_tac ctxt @{thms drop_redundant_literal_qtfr} i st
               end
           end
      end
--- a/src/HOL/TPTP/atp_problem_import.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/TPTP/atp_problem_import.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -178,7 +178,7 @@
         val (outcome, _) =
           Nitpick.pick_nits_in_term state params Nitpick.Normal i n step subst [] [] conj
       in
-        if outcome = "none" then ALLGOALS Skip_Proof.cheat_tac th else Seq.empty
+        if outcome = "none" then ALLGOALS (Skip_Proof.cheat_tac ctxt) th else Seq.empty
       end
   end
 
--- a/src/HOL/TPTP/sledgehammer_tactics.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/TPTP/sledgehammer_tactics.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -70,7 +70,7 @@
        ("minimize", "false")]
     val xs = run_prover override_params fact_override chained i i ctxt th
   in
-    if is_some xs then ALLGOALS Skip_Proof.cheat_tac th else Seq.empty
+    if is_some xs then ALLGOALS (Skip_Proof.cheat_tac ctxt) th else Seq.empty
   end
 
 end;
--- a/src/HOL/Tools/BNF/bnf_comp_tactics.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/BNF/bnf_comp_tactics.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -171,11 +171,11 @@
   unfold_thms_tac ctxt [collect_set_map] THEN
   unfold_thms_tac ctxt comp_wit_thms THEN
   REPEAT_DETERM ((atac ORELSE'
-    REPEAT_DETERM o eresolve_tac @{thms UnionE UnE} THEN'
-    etac imageE THEN' TRY o dresolve_tac Gwit_thms THEN'
+    REPEAT_DETERM o eresolve_tac ctxt @{thms UnionE UnE} THEN'
+    etac imageE THEN' TRY o dresolve_tac ctxt Gwit_thms THEN'
     (etac FalseE ORELSE'
     hyp_subst_tac ctxt THEN'
-    dresolve_tac Fwit_thms THEN'
+    dresolve_tac ctxt Fwit_thms THEN'
     (etac FalseE ORELSE' atac))) 1);
 
 
@@ -231,7 +231,7 @@
 fun mk_simple_rel_OO_Grp_tac rel_OO_Grp in_alt_thm =
   rtac (trans OF [rel_OO_Grp, in_alt_thm RS @{thm OO_Grp_cong} RS sym]) 1;
 
-fun mk_simple_wit_tac wit_thms = ALLGOALS (atac ORELSE' eresolve_tac (@{thm emptyE} :: wit_thms));
+fun mk_simple_wit_tac wit_thms = ALLGOALS (atac ORELSE' eresolve0_tac (@{thm emptyE} :: wit_thms));
 
 val csum_thms =
   @{thms csum_cong1 csum_cong2 csum_cong  csum_dup[OF natLeq_cinfinite natLeq_Card_order]};
@@ -247,7 +247,7 @@
   unfold_thms_tac ctxt simplified_set_simps THEN rtac refl 1;
 
 val bd_ordIso_natLeq_tac =
-  HEADGOAL (REPEAT_DETERM o resolve_tac
+  HEADGOAL (REPEAT_DETERM o resolve0_tac
     (@{thm ordIso_refl[OF natLeq_Card_order]} :: csum_thms @ cprod_thms));
 
 end;
--- a/src/HOL/Tools/BNF/bnf_def_tactics.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/BNF/bnf_def_tactics.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -58,7 +58,7 @@
 fun mk_in_mono_tac n = if n = 0 then rtac subset_UNIV 1
   else (rtac subsetI THEN'
   rtac CollectI) 1 THEN
-  REPEAT_DETERM (eresolve_tac [CollectE, conjE] 1) THEN
+  REPEAT_DETERM (eresolve0_tac [CollectE, conjE] 1) THEN
   REPEAT_DETERM_N (n - 1)
     ((rtac conjI THEN' etac subset_trans THEN' atac) 1) THEN
   (etac subset_trans THEN' atac) 1;
@@ -102,21 +102,21 @@
     else
       EVERY' [rel_OO_Grps_tac, rtac @{thm antisym}, rtac @{thm predicate2I},
         REPEAT_DETERM o
-          eresolve_tac [CollectE, exE, conjE, @{thm GrpE}, @{thm relcomppE}, @{thm conversepE}],
+          eresolve_tac ctxt [CollectE, exE, conjE, @{thm GrpE}, @{thm relcomppE}, @{thm conversepE}],
         hyp_subst_tac ctxt, rtac @{thm GrpI}, rtac trans, rtac map_comp, rtac map_cong0,
         REPEAT_DETERM_N n o EVERY' [rtac @{thm Collect_split_Grp_eqD}, etac @{thm set_mp}, atac],
         rtac CollectI,
         CONJ_WRAP' (fn thm => EVERY' [rtac (thm RS ord_eq_le_trans),
           rtac @{thm image_subsetI}, rtac @{thm Collect_split_Grp_inD}, etac @{thm set_mp}, atac])
         set_maps,
-        rtac @{thm predicate2I}, REPEAT_DETERM o eresolve_tac [@{thm GrpE}, exE, conjE],
+        rtac @{thm predicate2I}, REPEAT_DETERM o eresolve_tac ctxt [@{thm GrpE}, exE, conjE],
         hyp_subst_tac ctxt,
         rtac @{thm relcomppI}, rtac @{thm conversepI},
         EVERY' (map2 (fn convol => fn map_id0 =>
           EVERY' [rtac @{thm GrpI},
             rtac (@{thm box_equals} OF [map_cong0, map_comp RS sym, map_id0]),
             REPEAT_DETERM_N n o rtac (convol RS fun_cong),
-            REPEAT_DETERM o eresolve_tac [CollectE, conjE],
+            REPEAT_DETERM o eresolve_tac ctxt [CollectE, conjE],
             rtac CollectI,
             CONJ_WRAP' (fn thm =>
               EVERY' [rtac ord_eq_le_trans, rtac thm, rtac @{thm image_subsetI},
@@ -145,11 +145,11 @@
       Goal.conjunction_tac 1 THEN
       unfold_thms_tac ctxt [rel_compp, rel_conversep, rel_Grp, @{thm vimage2p_Grp}] THEN
       TRYALL (EVERY' [rtac iffI, rtac @{thm relcomppI}, rtac @{thm GrpI},
-        resolve_tac [map_id, refl], rtac CollectI,
+        resolve_tac ctxt [map_id, refl], rtac CollectI,
         CONJ_WRAP' (K (rtac @{thm subset_UNIV})) ks, rtac @{thm relcomppI}, atac,
-        rtac @{thm conversepI}, rtac @{thm GrpI}, resolve_tac [map_id, refl], rtac CollectI,
+        rtac @{thm conversepI}, rtac @{thm GrpI}, resolve_tac ctxt [map_id, refl], rtac CollectI,
         CONJ_WRAP' (K (rtac @{thm subset_UNIV})) ks,
-        REPEAT_DETERM o eresolve_tac @{thms relcomppE conversepE GrpE},
+        REPEAT_DETERM o eresolve_tac ctxt @{thms relcomppE conversepE GrpE},
         dtac (trans OF [sym, map_id]), hyp_subst_tac ctxt, atac])
     end;
 
@@ -175,7 +175,7 @@
     else
       EVERY' [rel_OO_Grps_tac, rtac @{thm predicate2I},
         REPEAT_DETERM o
-          eresolve_tac [CollectE, exE, conjE, @{thm GrpE}, @{thm relcomppE}, @{thm conversepE}],
+          eresolve_tac ctxt [CollectE, exE, conjE, @{thm GrpE}, @{thm relcomppE}, @{thm conversepE}],
         hyp_subst_tac ctxt, rtac @{thm conversepI}, rtac @{thm relcomppI}, rtac @{thm conversepI},
         EVERY' (map (fn thm => EVERY' [rtac @{thm GrpI}, rtac sym, rtac trans,
           rtac map_cong0, REPEAT_DETERM_N n o rtac thm,
@@ -204,7 +204,7 @@
     else
       EVERY' [rel_OO_Grps_tac, rtac @{thm predicate2I},
         REPEAT_DETERM o
-          eresolve_tac [CollectE, exE, conjE, @{thm GrpE}, @{thm relcomppE}, @{thm conversepE}],
+          eresolve_tac ctxt [CollectE, exE, conjE, @{thm GrpE}, @{thm relcomppE}, @{thm conversepE}],
         hyp_subst_tac ctxt,
         rtac @{thm relcomppI}, rtac @{thm relcomppI}, rtac @{thm conversepI}, rtac @{thm GrpI},
         rtac trans, rtac map_comp, rtac sym, rtac map_cong0,
@@ -229,7 +229,7 @@
   if null set_maps then atac 1
   else
     unfold_tac ctxt [in_rel] THEN
-    REPEAT_DETERM (eresolve_tac [exE, CollectE, conjE] 1) THEN
+    REPEAT_DETERM (eresolve_tac ctxt [exE, CollectE, conjE] 1) THEN
     hyp_subst_tac ctxt 1 THEN
     EVERY' [rtac exI, rtac @{thm conjI[OF CollectI conjI[OF refl refl]]},
       CONJ_WRAP' (fn thm =>
@@ -245,7 +245,7 @@
   in
     REPEAT_DETERM (HEADGOAL (rtac rel_funI)) THEN
     (HEADGOAL (hyp_subst_tac ctxt THEN' rtac refl) ORELSE
-     REPEAT_DETERM (HEADGOAL (eresolve_tac (Tactic.make_elim (in_rel RS iffD1) ::
+     REPEAT_DETERM (HEADGOAL (eresolve_tac ctxt (Tactic.make_elim (in_rel RS iffD1) ::
        @{thms exE conjE CollectE}))) THEN
      HEADGOAL (hyp_subst_tac ctxt) THEN unfold_thms_tac ctxt rel_map THEN HEADGOAL (rtac iffI) THEN
      last_tac iffD1 THEN last_tac iffD2)
@@ -264,7 +264,7 @@
     unfold_thms_tac ctxt @{thms rel_fun_iff_leq_vimage2p} THEN
     HEADGOAL (EVERY' [rtac @{thm order_trans}, rtac rel_mono, REPEAT_DETERM_N n o atac,
       rtac @{thm predicate2I}, dtac (in_rel RS iffD1),
-      REPEAT_DETERM o eresolve_tac [exE, CollectE, conjE], hyp_subst_tac ctxt,
+      REPEAT_DETERM o eresolve_tac ctxt [exE, CollectE, conjE], hyp_subst_tac ctxt,
       rtac @{thm vimage2pI}, rtac (in_rel RS iffD2), rtac exI, rtac conjI, in_tac,
       rtac conjI,
       EVERY' (map (fn convol =>
@@ -311,7 +311,7 @@
       unfold_thms_tac ctxt @{thms cprod_def Field_card_of} THEN
       EVERY' [rtac (Drule.rotate_prems 1 ctrans), rtac surj_imp_ordLeq_inst, rtac subsetI,
         Method.insert_tac inserts, REPEAT_DETERM o dtac meta_spec,
-        REPEAT_DETERM o eresolve_tac [exE, Tactic.make_elim conjunct1], etac CollectE,
+        REPEAT_DETERM o eresolve_tac ctxt [exE, Tactic.make_elim conjunct1], etac CollectE,
         if live = 1 then K all_tac
         else REPEAT_DETERM_N (live - 2) o (etac conjE THEN' rotate_tac ~1) THEN' etac conjE,
         rtac (Drule.rotate_prems 1 @{thm image_eqI}), rtac @{thm SigmaI}, rtac @{thm UNIV_I},
@@ -325,7 +325,7 @@
         REPEAT_DETERM_N live o rtac (@{thm prod.case} RS trans),
         rtac refl,
         rtac @{thm surj_imp_ordLeq}, rtac subsetI, rtac (Drule.rotate_prems 1 @{thm image_eqI}),
-        REPEAT_DETERM o eresolve_tac [CollectE, conjE], rtac CollectI,
+        REPEAT_DETERM o eresolve_tac ctxt [CollectE, conjE], rtac CollectI,
         CONJ_WRAP' (fn thm =>
           rtac (thm RS ord_eq_le_trans) THEN' etac @{thm subset_trans[OF image_mono Un_upper1]})
         set_maps,
@@ -341,12 +341,12 @@
 fun mk_set_transfer_tac ctxt in_rel set_maps =
   Goal.conjunction_tac 1 THEN
   EVERY (map (fn set_map => HEADGOAL (rtac rel_funI) THEN
-  REPEAT_DETERM (HEADGOAL (eresolve_tac (Tactic.make_elim (in_rel RS iffD1) ::
+  REPEAT_DETERM (HEADGOAL (eresolve_tac ctxt (Tactic.make_elim (in_rel RS iffD1) ::
     @{thms exE conjE CollectE}))) THEN
   HEADGOAL (hyp_subst_tac ctxt THEN' rtac (@{thm iffD2[OF arg_cong2]} OF [set_map, set_map]) THEN'
     rtac @{thm rel_setI}) THEN
   REPEAT (HEADGOAL (etac imageE THEN' dtac @{thm set_mp} THEN' atac THEN'
-    REPEAT_DETERM o (eresolve_tac @{thms CollectE case_prodE}) THEN' hyp_subst_tac ctxt THEN'
+    REPEAT_DETERM o (eresolve_tac ctxt @{thms CollectE case_prodE}) THEN' hyp_subst_tac ctxt THEN'
     rtac bexI THEN' etac @{thm subst_Pair[OF _ refl]} THEN' etac imageI))) set_maps);
 
 end;
--- a/src/HOL/Tools/BNF/bnf_fp_def_sugar_tactics.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/BNF/bnf_fp_def_sugar_tactics.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -120,16 +120,16 @@
 
 fun mk_ctr_transfer_tac ctxt rel_intros rel_eqs =
   HEADGOAL Goal.conjunction_tac THEN
-  ALLGOALS (REPEAT o (resolve_tac (rel_funI :: rel_intros) THEN'
+  ALLGOALS (REPEAT o (resolve_tac ctxt (rel_funI :: rel_intros) THEN'
     TRY o (REPEAT_DETERM1 o (atac ORELSE'
       K (unfold_thms_tac ctxt rel_eqs) THEN' hyp_subst_tac ctxt THEN' rtac refl))));
 
-fun mk_disc_transfer_tac rel_sel exhaust_disc distinct_disc=
+fun mk_disc_transfer_tac rel_sel exhaust_disc distinct_disc =
   let
     fun last_disc_tac iffD =
       HEADGOAL (rtac (rotate_prems ~1 exhaust_disc) THEN' atac THEN'
       REPEAT_DETERM o (rotate_tac ~1 THEN' dtac (rotate_prems 1 iffD) THEN' atac THEN'
-        rotate_tac ~1 THEN' etac (rotate_prems 1 notE) THEN' eresolve_tac distinct_disc));
+        rotate_tac ~1 THEN' etac (rotate_prems 1 notE) THEN' eresolve0_tac distinct_disc));
   in
     HEADGOAL Goal.conjunction_tac THEN
     REPEAT_DETERM (HEADGOAL (rtac rel_funI THEN' dtac (rel_sel RS iffD1) THEN'
@@ -169,7 +169,7 @@
       case_prod_map_prod id_bnf_def map_prod_simp map_sum_if_distrib_then map_sum_if_distrib_else
       if_distrib[THEN sym]};
   in
-    HEADGOAL (subst_tac @{context} (SOME [1, 2]) [co_rec_def] THEN'
+    HEADGOAL (subst_tac ctxt (SOME [1, 2]) [co_rec_def] THEN'
       rtac (xtor_co_rec_o_map RS trans) THEN'
       CONVERSION Thm.eta_long_conversion THEN'
       asm_simp_tac (ss_only (pre_map_defs @ distinct Thm.eq_thm_prop (map_ident0s @ abs_inverses) @
@@ -208,11 +208,11 @@
              HEADGOAL (rtac @{thm vimage2p_rel_fun}) THEN
              unfold_thms_tac ctxt rel_eqs THEN
              EVERY (@{map 2} (fn n => fn xss =>
-                 REPEAT_DETERM (HEADGOAL (resolve_tac
+                 REPEAT_DETERM (HEADGOAL (resolve_tac ctxt
                    [mk_rel_funDN 2 case_sum_transfer_eq, mk_rel_funDN 2 case_sum_transfer])) THEN
                  HEADGOAL (select_prem_tac total_n (dtac asm_rl) (acc + n)) THEN
                  HEADGOAL (SELECT_GOAL (HEADGOAL
-                   (REPEAT_DETERM o (atac ORELSE' resolve_tac
+                   (REPEAT_DETERM o (atac ORELSE' resolve_tac ctxt
                        [mk_rel_funDN 1 case_prod_transfer_eq,
                         mk_rel_funDN 1 case_prod_transfer,
                         rel_funI]) THEN_ALL_NEW
@@ -251,7 +251,7 @@
     val num_pgs = length pgs;
     fun prem_no_of x = 1 + find_index (curry (op =) x) pgs;
 
-    val Inl_Inr_Pair_tac = REPEAT_DETERM o (resolve_tac
+    val Inl_Inr_Pair_tac = REPEAT_DETERM o (resolve_tac ctxt
       [mk_rel_funDN 1 @{thm Inl_transfer},
        mk_rel_funDN 1 @{thm Inl_transfer[of "op =" "op =", unfolded sum.rel_eq]},
        mk_rel_funDN 1 @{thm Inr_transfer},
@@ -314,8 +314,8 @@
   end;
 
 fun solve_prem_prem_tac ctxt =
-  REPEAT o (eresolve_tac @{thms bexE rev_bexI} ORELSE' rtac @{thm rev_bexI[OF UNIV_I]} ORELSE'
-    hyp_subst_tac ctxt ORELSE' resolve_tac @{thms disjI1 disjI2}) THEN'
+  REPEAT o (eresolve_tac ctxt @{thms bexE rev_bexI} ORELSE' rtac @{thm rev_bexI[OF UNIV_I]} ORELSE'
+    hyp_subst_tac ctxt ORELSE' resolve_tac ctxt @{thms disjI1 disjI2}) THEN'
   (rtac refl ORELSE' atac ORELSE' rtac @{thm singletonI});
 
 fun mk_induct_leverage_prem_prems_tac ctxt nn kks fp_abs_inverses abs_inverses set_maps
@@ -361,7 +361,7 @@
   (atac ORELSE' REPEAT o etac conjE THEN'
      full_simp_tac (ss_only (no_refl discs @ rel_eqs @ more_simp_thms) ctxt) THEN'
      REPEAT o etac conjE THEN_MAYBE' REPEAT o hyp_subst_tac ctxt THEN'
-     REPEAT o (resolve_tac [refl, conjI] ORELSE' atac));
+     REPEAT o (resolve_tac ctxt [refl, conjI] ORELSE' atac));
 
 fun mk_coinduct_distinct_ctrs_tac ctxt discs discs' =
   let
@@ -424,7 +424,7 @@
     map (fn thm => thm RS eqTrueI) rel_injects) THEN
   TRYALL (atac ORELSE' etac FalseE ORELSE'
     (REPEAT_DETERM o dtac @{thm meta_spec} THEN'
-     TRY o filter_prems_tac
+     TRY o filter_prems_tac ctxt
        (forall (curry (op <>) (HOLogic.mk_Trueprop @{term False})) o Logic.strip_imp_prems) THEN'
      REPEAT_DETERM o (dtac @{thm meta_mp} THEN' rtac refl) THEN' Goal.assume_rule_tac ctxt));
 
@@ -454,7 +454,7 @@
       fn ctor_inject => fn rel_pre_list_def => fn Abs_inverse =>
         HEADGOAL (rtac exhaust THEN_ALL_NEW (rtac exhaust THEN_ALL_NEW
           (rtac (cterm_instantiate_pos (replicate 4 NONE @ [SOME cterm]) @{thm arg_cong2} RS iffD2)
-            THEN' atac THEN' atac THEN' TRY o resolve_tac assms))) THEN
+            THEN' atac THEN' atac THEN' TRY o resolve_tac ctxt assms))) THEN
         unfold_thms_tac ctxt (ctor_inject :: rel_pre_list_def :: ctor_defs @ nesting_rel_eqs @
           @{thms id_bnf_def vimage2p_def}) THEN
         TRYALL (hyp_subst_tac ctxt) THEN
@@ -470,7 +470,7 @@
   unfold_thms_tac ctxt (sels @ rel_injects @ rel_eqs @
     @{thms simp_thms(6,7,8,11,12,15,16,21,22,24)} @ ((discs @ distincts) RL [eqTrueI, eqFalseI]) @
     (rel_injects RL [eqTrueI]) @ (rel_distincts RL [eqFalseI])) THEN
-  TRYALL (resolve_tac [TrueI, refl]);
+  TRYALL (resolve_tac ctxt [TrueI, refl]);
 
 fun mk_sel_transfer_tac ctxt n sel_defs case_transfer =
   TRYALL Goal.conjunction_tac THEN
@@ -486,8 +486,8 @@
       @{thms not_True_eq_False not_False_eq_True}) THEN
     TRYALL (etac FalseE ORELSE' etac @{thm TrueE}) THEN
     unfold_thms_tac ctxt (sels @ sets) THEN
-    ALLGOALS (REPEAT o (resolve_tac @{thms UnI1 UnI2 imageI} ORELSE'
-        eresolve_tac @{thms UN_I UN_I[rotated] imageE} ORELSE'
+    ALLGOALS (REPEAT o (resolve_tac ctxt @{thms UnI1 UnI2 imageI} ORELSE'
+        eresolve_tac ctxt @{thms UN_I UN_I[rotated] imageE} ORELSE'
         hyp_subst_tac ctxt) THEN'
       (rtac @{thm singletonI} ORELSE' atac));
 
@@ -495,16 +495,16 @@
   HEADGOAL (rtac (cterm_instantiate_pos [SOME ct] exhaust) THEN_ALL_NEW hyp_subst_tac ctxt) THEN
   unfold_thms_tac ctxt sets THEN
   REPEAT_DETERM (HEADGOAL
-    (eresolve_tac @{thms FalseE emptyE singletonE UnE UN_E insertE} ORELSE'
+    (eresolve_tac ctxt @{thms FalseE emptyE singletonE UnE UN_E insertE} ORELSE'
      hyp_subst_tac ctxt ORELSE'
-     SELECT_GOAL (SOLVE (HEADGOAL (eresolve_tac assms THEN' REPEAT_DETERM o atac)))));
+     SELECT_GOAL (SOLVE (HEADGOAL (eresolve_tac ctxt assms THEN' REPEAT_DETERM o atac)))));
 
 fun mk_set_intros_tac ctxt sets =
   TRYALL Goal.conjunction_tac THEN
   unfold_thms_tac ctxt sets THEN
   TRYALL (REPEAT o
-    (resolve_tac @{thms UnI1 UnI2} ORELSE'
-     eresolve_tac @{thms UN_I UN_I[rotated]}) THEN' (rtac @{thm singletonI} ORELSE' atac));
+    (resolve_tac ctxt @{thms UnI1 UnI2} ORELSE'
+     eresolve_tac ctxt @{thms UN_I UN_I[rotated]}) THEN' (rtac @{thm singletonI} ORELSE' atac));
 
 fun mk_set_induct0_tac ctxt cts assms dtor_set_inducts exhausts set_pre_defs ctor_defs dtor_ctors
     Abs_pre_inverses =
@@ -518,15 +518,15 @@
     val exhausts' = map (fn thm => thm RS @{thm asm_rl[of "P x y" for P x y]}) exhausts
       |> map2 (fn ct => cterm_instantiate_pos [NONE, SOME ct]) cts;
   in
-    ALLGOALS (resolve_tac dtor_set_inducts) THEN
-    TRYALL (resolve_tac exhausts' THEN_ALL_NEW
-      (resolve_tac (map (fn ct => refl RS
+    ALLGOALS (resolve_tac ctxt dtor_set_inducts) THEN
+    TRYALL (resolve_tac ctxt exhausts' THEN_ALL_NEW
+      (resolve_tac ctxt (map (fn ct => refl RS
          cterm_instantiate_pos (replicate 4 NONE @ [SOME ct]) @{thm arg_cong2} RS iffD2) cts)
         THEN' atac THEN' hyp_subst_tac ctxt)) THEN
     unfold_thms_tac ctxt (Abs_pre_inverses @ dtor_ctors @ set_pre_defs @ ctor_defs @
       @{thms id_bnf_def o_apply sum_set_simps prod_set_simps UN_empty UN_insert Un_empty_left
         Un_empty_right empty_iff singleton_iff}) THEN
-    REPEAT (HEADGOAL (hyp_subst_tac ctxt ORELSE' eresolve_tac @{thms UN_E UnE singletonE} ORELSE'
+    REPEAT (HEADGOAL (hyp_subst_tac ctxt ORELSE' eresolve_tac ctxt @{thms UN_E UnE singletonE} ORELSE'
       assms_tac))
   end;
 
--- a/src/HOL/Tools/BNF/bnf_fp_n2m_tactics.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/BNF/bnf_fp_n2m_tactics.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -42,10 +42,10 @@
     unfold_thms_tac ctxt vimage2p_unfolds THEN
     HEADGOAL (CONJ_WRAP_GEN' (rtac @{thm context_conjI})
       (fn thm => rtac thm THEN_ALL_NEW (rotate_tac ~1 THEN'
-         REPEAT_ALL_NEW (FIRST' [eresolve_tac C_IHs, eresolve_tac C_IH_monos,
+         REPEAT_ALL_NEW (FIRST' [eresolve_tac ctxt C_IHs, eresolve_tac ctxt C_IH_monos,
            SELECT_GOAL (unfold_thms_tac ctxt nesting_rel_eqs) THEN' rtac @{thm order_refl},
-           assume_tac ctxt, resolve_tac co_inducts,
-           resolve_tac C_IH_monos THEN' REPEAT_ALL_NEW (eresolve_tac nesting_rel_monos)])))
+           assume_tac ctxt, resolve_tac ctxt co_inducts,
+           resolve_tac ctxt C_IH_monos THEN' REPEAT_ALL_NEW (eresolve_tac ctxt nesting_rel_monos)])))
     co_inducts)
   end;
 
--- a/src/HOL/Tools/BNF/bnf_gfp.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/BNF/bnf_gfp.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -440,7 +440,7 @@
           HOLogic.mk_Trueprop (mk_mor Bs ss B''s s''s (map2 (curry HOLogic.mk_comp) gs fs));
       in
         Goal.prove_sorry lthy [] [] (Logic.list_implies (prems, concl))
-          (K (mk_mor_comp_tac mor_def mor_image'_thms morE_thms map_comp_id_thms))
+          (K (mk_mor_comp_tac lthy mor_def mor_image'_thms morE_thms map_comp_id_thms))
         |> Thm.close_derivation
         |> singleton (Proof_Context.export names_lthy lthy)
       end;
--- a/src/HOL/Tools/BNF/bnf_gfp_rec_sugar_tactics.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/BNF/bnf_gfp_rec_sugar_tactics.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -52,7 +52,7 @@
 val exhaust_inst_as_projs_tac = PRIMITIVE oo exhaust_inst_as_projs;
 
 fun distinct_in_prems_tac distincts =
-  eresolve_tac (map (fn thm => thm RS neq_eq_eq_contradict) distincts) THEN' atac;
+  eresolve0_tac (map (fn thm => thm RS neq_eq_eq_contradict) distincts) THEN' atac;
 
 fun mk_primcorec_nchotomy_tac ctxt exhaust_discs =
   HEADGOAL (Method.insert_tac exhaust_discs THEN' clean_blast_tac ctxt);
@@ -74,9 +74,9 @@
   SELECT_GOAL (unfold_thms_tac ctxt @{thms fst_conv snd_conv not_not not_False_eq_True
       not_True_eq_False de_Morgan_conj de_Morgan_disj} THEN
     SOLVE (HEADGOAL (REPEAT o (rtac refl ORELSE' atac ORELSE' etac conjE ORELSE'
-    eresolve_tac falseEs ORELSE'
-    resolve_tac @{thms TrueI conjI disjI1 disjI2} ORELSE'
-    dresolve_tac discIs THEN' atac ORELSE'
+    eresolve_tac ctxt falseEs ORELSE'
+    resolve_tac ctxt @{thms TrueI conjI disjI1 disjI2} ORELSE'
+    dresolve_tac ctxt discIs THEN' atac ORELSE'
     etac notE THEN' atac ORELSE'
     etac disjE))));
 
@@ -121,21 +121,21 @@
             rtac FalseE THEN'
             (rotate_tac 1 THEN' dtac fun_disc' THEN' REPEAT_DETERM o atac ORELSE'
              cut_tac fun_disc') THEN'
-            dresolve_tac distinct_discs THEN' etac notE THEN' atac)
+            dresolve_tac ctxt distinct_discs THEN' etac notE THEN' atac)
       fun_discss) THEN'
     (etac FalseE ORELSE'
-     resolve_tac (map (unfold_thms ctxt [atomize_conjL]) fun_discs) THEN_MAYBE' atac));
+     resolve_tac ctxt (map (unfold_thms ctxt [atomize_conjL]) fun_discs) THEN_MAYBE' atac));
 
 fun mk_primcorec_sel_tac ctxt defs distincts splits split_asms mapsx map_ident0s map_comps fun_sel k
     m excludesss =
   prelude_tac ctxt defs (fun_sel RS trans) THEN
   cases_tac ctxt k m excludesss THEN
   HEADGOAL (REPEAT_DETERM o (rtac refl ORELSE'
-    eresolve_tac falseEs ORELSE'
-    resolve_tac split_connectI ORELSE'
+    eresolve_tac ctxt falseEs ORELSE'
+    resolve_tac ctxt split_connectI ORELSE'
     Splitter.split_asm_tac ctxt (split_if_asm :: split_asms) ORELSE'
     Splitter.split_tac ctxt (split_if :: splits) ORELSE'
-    eresolve_tac (map (fn thm => thm RS neq_eq_eq_contradict) distincts) THEN' atac ORELSE'
+    eresolve_tac ctxt (map (fn thm => thm RS neq_eq_eq_contradict) distincts) THEN' atac ORELSE'
     etac notE THEN' atac ORELSE'
     (CHANGED o SELECT_GOAL (unfold_thms_tac ctxt (@{thms fst_conv snd_conv id_def comp_def split_def
          sum.case sum.sel sum.distinct[THEN eq_False[THEN iffD2]]} @
@@ -165,17 +165,17 @@
     val splits' =
       map (fn th => th RS iffD2) (@{thm split_if_eq2} :: map (inst_split_eq ctxt) splits);
   in
-    HEADGOAL (REPEAT o (resolve_tac (splits' @ split_connectI))) THEN
+    HEADGOAL (REPEAT o (resolve_tac ctxt (splits' @ split_connectI))) THEN
     prelude_tac ctxt [] (fun_ctr RS trans) THEN
     HEADGOAL ((REPEAT_DETERM_N m o mk_primcorec_assumption_tac ctxt discIs) THEN'
       SELECT_GOAL (SOLVE (HEADGOAL (REPEAT_DETERM o
       (rtac refl ORELSE' atac ORELSE'
-       resolve_tac (@{thm Code.abort_def} :: split_connectI) ORELSE'
+       resolve_tac ctxt (@{thm Code.abort_def} :: split_connectI) ORELSE'
        Splitter.split_tac ctxt (split_if :: splits) ORELSE'
        Splitter.split_asm_tac ctxt (split_if_asm :: split_asms) ORELSE'
        mk_primcorec_assumption_tac ctxt discIs ORELSE'
        distinct_in_prems_tac distincts ORELSE'
-       (TRY o dresolve_tac discIs) THEN' etac notE THEN' atac)))))
+       (TRY o dresolve_tac ctxt discIs) THEN' etac notE THEN' atac)))))
   end;
 
 fun rulify_nchotomy n = funpow (n - 1) (fn thm => thm RS @{thm Meson.make_pos_rule'});
@@ -196,14 +196,14 @@
   in
     EVERY (map2 (raw_code_single_tac ctxt distincts discIs splits split_asms) ms' fun_ctrs') THEN
     IF_UNSOLVED (unfold_thms_tac ctxt @{thms Code.abort_def} THEN
-      HEADGOAL (REPEAT_DETERM o resolve_tac (refl :: split_connectI)))
+      HEADGOAL (REPEAT_DETERM o resolve_tac ctxt (refl :: split_connectI)))
   end;
 
 fun mk_primcorec_code_tac ctxt distincts splits raw =
   HEADGOAL (rtac raw ORELSE' rtac (raw RS trans) THEN'
     SELECT_GOAL (unfold_thms_tac ctxt unfold_lets) THEN' REPEAT_DETERM o
     (rtac refl ORELSE' atac ORELSE'
-     resolve_tac split_connectI ORELSE'
+     resolve_tac ctxt split_connectI ORELSE'
      Splitter.split_tac ctxt (split_if :: splits) ORELSE'
      distinct_in_prems_tac distincts ORELSE'
      rtac sym THEN' atac ORELSE'
--- a/src/HOL/Tools/BNF/bnf_gfp_tactics.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/BNF/bnf_gfp_tactics.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -56,7 +56,7 @@
     thm list -> thm list -> thm list list -> thm list list list -> thm list list list ->
     thm list list -> thm list -> thm list -> tactic
   val mk_mor_case_sum_tac: 'a list -> thm -> tactic
-  val mk_mor_comp_tac: thm -> thm list -> thm list -> thm list -> tactic
+  val mk_mor_comp_tac: Proof.context -> thm -> thm list -> thm list -> thm list -> tactic
   val mk_mor_elim_tac: thm -> tactic
   val mk_mor_col_tac: int -> int -> cterm option list -> int -> thm list -> thm list ->
     thm list -> thm list list -> thm list list -> tactic
@@ -116,7 +116,7 @@
   dtac (coalg_def RS iffD1) 1 THEN
   REPEAT_DETERM (etac conjE 1) THEN
   EVERY' [dtac rev_bspec, atac] 1 THEN
-  REPEAT_DETERM (eresolve_tac [CollectE, conjE] 1) THEN atac 1;
+  REPEAT_DETERM (eresolve0_tac [CollectE, conjE] 1) THEN atac 1;
 
 fun mk_mor_elim_tac mor_def =
   (dtac (mor_def RS iffD1) THEN'
@@ -133,12 +133,12 @@
   CONJ_WRAP' (fn thm =>
     (EVERY' [rtac ballI, rtac (thm RS trans), rtac sym, rtac (id_apply RS arg_cong)])) map_ids) 1;
 
-fun mk_mor_comp_tac mor_def mor_images morEs map_comp_ids =
+fun mk_mor_comp_tac ctxt mor_def mor_images morEs map_comp_ids =
   let
     fun fbetw_tac image = EVERY' [rtac ballI, rtac (o_apply RS @{thm ssubst_mem}), etac image,
       etac image, atac];
     fun mor_tac ((mor_image, morE), map_comp_id) =
-      EVERY' [rtac ballI, stac o_apply, rtac trans, rtac (map_comp_id RS sym), rtac trans,
+      EVERY' [rtac ballI, stac ctxt o_apply, rtac trans, rtac (map_comp_id RS sym), rtac trans,
         etac (morE RS arg_cong), atac, etac morE, etac mor_image, atac];
   in
     (rtac (mor_def RS iffD2) THEN' rtac conjI THEN'
@@ -183,14 +183,14 @@
         if m = 0 then K all_tac
         else (rtac @{thm Un_least} THEN' Goal.assume_rule_tac ctxt),
         CONJ_WRAP_GEN' (rtac (Thm.permute_prems 0 1 @{thm Un_least}))
-          (K (EVERY' [rtac @{thm UN_least}, REPEAT_DETERM o eresolve_tac [allE, conjE],
+          (K (EVERY' [rtac @{thm UN_least}, REPEAT_DETERM o eresolve_tac ctxt [allE, conjE],
             rtac subset_trans, atac, Goal.assume_rule_tac ctxt])) rec_0s])
       rec_Sucs] 1;
 
 fun mk_Jset_minimal_tac ctxt n col_minimal =
   (CONJ_WRAP' (K (EVERY' [rtac @{thm UN_least}, rtac rev_mp, rtac col_minimal,
     EVERY' (replicate ((n + 1) * n) (Goal.assume_rule_tac ctxt)), rtac impI,
-    REPEAT_DETERM o eresolve_tac [allE, conjE], atac])) (1 upto n)) 1
+    REPEAT_DETERM o eresolve_tac ctxt [allE, conjE], atac])) (1 upto n)) 1
 
 fun mk_mor_col_tac m n cts j rec_0s rec_Sucs morEs set_map0ss coalg_setss =
   EVERY' [rtac (Drule.instantiate' [] cts nat_induct),
@@ -222,7 +222,7 @@
     fun mk_if_tac ((((i, map_comp0), map_cong0), set_map0s), in_rel) =
       EVERY' [rtac allI, rtac allI, rtac impI, dtac (mk_conjunctN n i),
         etac allE, etac allE, etac impE, atac, etac bexE,
-        REPEAT_DETERM o eresolve_tac [CollectE, conjE],
+        REPEAT_DETERM o eresolve0_tac [CollectE, conjE],
         rtac (in_rel RS iffD2), rtac exI, rtac (Drule.rotate_prems 1 conjI),
         CONJ_WRAP' (fn thm => EVERY' [rtac trans, rtac trans, rtac map_comp0, rtac map_cong0,
           REPEAT_DETERM_N m o rtac thm, REPEAT_DETERM_N n o rtac (@{thm comp_id} RS fun_cong),
@@ -242,7 +242,7 @@
       EVERY' [dtac (mk_conjunctN n i), rtac allI, rtac allI, rtac impI,
         etac allE, etac allE, etac impE, atac,
         dtac (in_rel RS @{thm iffD1}),
-        REPEAT_DETERM o eresolve_tac ([CollectE, conjE, exE] @
+        REPEAT_DETERM o eresolve0_tac ([CollectE, conjE, exE] @
           @{thms CollectE Collect_split_in_rel_leE}),
         rtac bexI, rtac conjI, rtac trans, rtac map_comp0, rtac trans, rtac map_cong0,
         REPEAT_DETERM_N m o rtac (@{thm id_comp} RS fun_cong),
@@ -327,7 +327,7 @@
     val n = length lsbis_defs;
   in
     EVERY' [rtac (Thm.permute_prems 0 1 bis_cong), EVERY' (map rtac lsbis_defs),
-      rtac bis_Union, rtac ballI, REPEAT_DETERM o eresolve_tac [CollectE, conjE, exE],
+      rtac bis_Union, rtac ballI, REPEAT_DETERM o eresolve_tac ctxt [CollectE, conjE, exE],
       hyp_subst_tac ctxt, etac bis_cong, EVERY' (map (rtac o mk_nth_conv n) (1 upto n))] 1
   end;
 
@@ -357,7 +357,7 @@
     val n = length strT_defs;
     val ks = 1 upto n;
     fun coalg_tac (i, (active_sets, def)) =
-      EVERY' [rtac ballI, REPEAT_DETERM o eresolve_tac [CollectE, exE, conjE],
+      EVERY' [rtac ballI, REPEAT_DETERM o eresolve_tac ctxt [CollectE, exE, conjE],
         hyp_subst_tac ctxt, rtac (def RS trans RS @{thm ssubst_mem}), etac (arg_cong RS trans),
         rtac (mk_sum_caseN n i), rtac CollectI,
         REPEAT_DETERM_N m o EVERY' [rtac conjI, rtac subset_UNIV],
@@ -370,7 +370,7 @@
             CONJ_WRAP' (fn i => EVERY' [rtac ballI, etac CollectE, dtac @{thm ShiftD},
               dtac bspec, etac thin_rl, atac, dtac (mk_conjunctN n i),
               dtac bspec, rtac CollectI, etac @{thm set_mp[OF equalityD1[OF Succ_Shift]]},
-              REPEAT_DETERM o eresolve_tac [exE, conjE], rtac exI,
+              REPEAT_DETERM o eresolve_tac ctxt [exE, conjE], rtac exI,
               rtac conjI, rtac (@{thm shift_def} RS fun_cong RS trans),
               rtac (@{thm append_Cons} RS sym RS arg_cong RS trans), atac,
               CONJ_WRAP' (K (EVERY' [etac trans, rtac @{thm Collect_cong},
@@ -378,7 +378,7 @@
                 rtac (@{thm append_Cons} RS sym RS arg_cong)])) ks]) ks,
           dtac bspec, atac, dtac (mk_conjunctN n i), dtac bspec,
           etac @{thm set_mp[OF equalityD1]}, atac,
-          REPEAT_DETERM o eresolve_tac [exE, conjE], rtac exI,
+          REPEAT_DETERM o eresolve_tac ctxt [exE, conjE], rtac exI,
           rtac conjI, rtac (@{thm shift_def} RS fun_cong RS trans),
           etac (@{thm append_Nil} RS sym RS arg_cong RS trans),
           REPEAT_DETERM_N m o (rtac conjI THEN' atac),
@@ -405,7 +405,7 @@
         EVERY' [rtac impI, dtac (Lev_Suc RS equalityD1 RS set_mp),
           CONJ_WRAP_GEN' (etac (Thm.permute_prems 1 1 UnE))
             (fn i =>
-              EVERY' [REPEAT_DETERM o eresolve_tac [CollectE, exE, conjE], hyp_subst_tac ctxt,
+              EVERY' [REPEAT_DETERM o eresolve_tac ctxt [CollectE, exE, conjE], hyp_subst_tac ctxt,
                 rtac trans, rtac @{thm length_Cons}, rtac @{thm arg_cong[of _ _ Suc]},
                 REPEAT_DETERM o etac allE, dtac (mk_conjunctN n i), etac mp, atac]) ks])
       Lev_Sucs] 1
@@ -467,7 +467,7 @@
         EVERY' [rtac impI, dtac (Lev_Suc RS equalityD1 RS set_mp),
           CONJ_WRAP_GEN' (etac (Thm.permute_prems 1 1 UnE))
             (fn (i, from_to_sbd) =>
-              EVERY' [REPEAT_DETERM o eresolve_tac [CollectE, exE, conjE], hyp_subst_tac ctxt,
+              EVERY' [REPEAT_DETERM o eresolve_tac ctxt [CollectE, exE, conjE], hyp_subst_tac ctxt,
                 CONJ_WRAP' (fn i' => rtac impI THEN'
                   CONJ_WRAP' (fn i'' =>
                     EVERY' [rtac impI, rtac (Lev_Suc RS equalityD2 RS set_mp),
@@ -502,7 +502,7 @@
                 dtac (Lev_Suc RS equalityD1 RS set_mp), dtac (mk_InN_inject n i),
                 hyp_subst_tac ctxt,
                 CONJ_WRAP_GEN' (etac (Thm.permute_prems 1 1 UnE))
-                  (fn k => REPEAT_DETERM o eresolve_tac [CollectE, exE, conjE] THEN'
+                  (fn k => REPEAT_DETERM o eresolve_tac ctxt [CollectE, exE, conjE] THEN'
                     dtac list_inject_iffD1 THEN' etac conjE THEN'
                     (if k = i'
                     then EVERY' [dtac (mk_InN_inject n k), hyp_subst_tac ctxt, etac imageI]
@@ -517,12 +517,12 @@
         EVERY' [rtac impI, dtac (Lev_Suc RS equalityD1 RS set_mp),
           CONJ_WRAP_GEN' (etac (Thm.permute_prems 1 1 UnE))
             (fn (i, (from_to_sbd, to_sbd_inj)) =>
-              REPEAT_DETERM o eresolve_tac [CollectE, exE, conjE] THEN' hyp_subst_tac ctxt THEN'
+              REPEAT_DETERM o eresolve_tac ctxt [CollectE, exE, conjE] THEN' hyp_subst_tac ctxt THEN'
               CONJ_WRAP' (fn i' => rtac impI THEN'
                 dtac @{thm ssubst_mem[OF sym[OF append_Cons]]} THEN'
                 dtac (Lev_Suc RS equalityD1 RS set_mp) THEN'
                 CONJ_WRAP_GEN' (etac (Thm.permute_prems 1 1 UnE)) (fn k =>
-                  REPEAT_DETERM o eresolve_tac [CollectE, exE, conjE] THEN'
+                  REPEAT_DETERM o eresolve_tac ctxt [CollectE, exE, conjE] THEN'
                   dtac list_inject_iffD1 THEN' etac conjE THEN'
                   (if k = i
                   then EVERY' [dtac (mk_InN_inject n i),
@@ -563,7 +563,7 @@
           CONJ_WRAP' (fn (i, (rv_last, (isNode_def, (set_map0s,
             (set_Levs, set_image_Levs))))) =>
             EVERY' [rtac ballI,
-              REPEAT_DETERM o eresolve_tac [CollectE, @{thm SuccE}, @{thm UN_E}],
+              REPEAT_DETERM o eresolve_tac ctxt [CollectE, @{thm SuccE}, @{thm UN_E}],
               rtac (rev_mp OF [rv_last, impI]), etac exE, rtac (isNode_def RS iffD2),
               rtac exI, rtac conjI,
               if n = 1 then rtac refl
@@ -572,7 +572,7 @@
                 EVERY' [rtac (set_map0 RS trans), rtac equalityI, rtac @{thm image_subsetI},
                   rtac CollectI, rtac @{thm SuccI}, rtac @{thm UN_I}, rtac UNIV_I, etac set_Lev,
                   if n = 1 then rtac refl else atac, atac, rtac subsetI,
-                  REPEAT_DETERM o eresolve_tac [CollectE, @{thm SuccE}, @{thm UN_E}],
+                  REPEAT_DETERM o eresolve_tac ctxt [CollectE, @{thm SuccE}, @{thm UN_E}],
                   REPEAT_DETERM_N 4 o etac thin_rl,
                   rtac set_image_Lev,
                   atac, dtac length_Lev, hyp_subst_tac ctxt, dtac length_Lev',
@@ -591,7 +591,7 @@
               rtac CollectI, rtac @{thm SuccI}, rtac @{thm UN_I}, rtac UNIV_I, rtac set_Lev,
               rtac (Lev_0 RS equalityD2 RS set_mp), rtac @{thm singletonI}, rtac rv_Nil,
               atac, rtac subsetI,
-              REPEAT_DETERM o eresolve_tac [CollectE, @{thm SuccE}, @{thm UN_E}],
+              REPEAT_DETERM o eresolve_tac ctxt [CollectE, @{thm SuccE}, @{thm UN_E}],
               rtac set_image_Lev, rtac (Lev_0 RS equalityD2 RS set_mp),
               rtac @{thm singletonI}, dtac length_Lev',
               etac @{thm set_mp[OF equalityD1[OF arg_cong[OF
@@ -612,11 +612,11 @@
           DETERM o EVERY' [rtac trans, rtac o_apply, rtac prod_injectI, rtac conjI,
             rtac trans, rtac @{thm Shift_def},
             rtac equalityI, rtac subsetI, etac thin_rl,
-            REPEAT_DETERM o eresolve_tac [CollectE, @{thm UN_E}], dtac length_Lev', dtac asm_rl,
+            REPEAT_DETERM o eresolve_tac ctxt [CollectE, @{thm UN_E}], dtac length_Lev', dtac asm_rl,
             etac thin_rl, dtac @{thm set_rev_mp[OF _ equalityD1]},
             rtac (@{thm length_Cons} RS arg_cong RS trans), rtac Lev_Suc,
             CONJ_WRAP_GEN' (etac (Thm.permute_prems 1 1 UnE)) (fn i'' =>
-              EVERY' [REPEAT_DETERM o eresolve_tac [CollectE, exE, conjE],
+              EVERY' [REPEAT_DETERM o eresolve_tac ctxt [CollectE, exE, conjE],
                 dtac list_inject_iffD1, etac conjE,
                 if i' = i'' then EVERY' [dtac (mk_InN_inject n i'),
                   dtac (Thm.permute_prems 0 2 (to_sbd_inj RS iffD1)),
@@ -648,7 +648,7 @@
 
 fun mk_congruent_str_final_tac m lsbisE map_comp_id map_cong0 equiv_LSBISs =
   EVERY' [rtac @{thm congruentI}, dtac lsbisE,
-    REPEAT_DETERM o eresolve_tac [CollectE, conjE, bexE], rtac (o_apply RS trans),
+    REPEAT_DETERM o eresolve0_tac [CollectE, conjE, bexE], rtac (o_apply RS trans),
     etac (sym RS arg_cong RS trans), rtac (map_comp_id RS trans),
     rtac (map_cong0 RS trans), REPEAT_DETERM_N m o rtac refl,
     EVERY' (map (fn equiv_LSBIS =>
@@ -818,8 +818,8 @@
     EVERY' ([rtac rev_mp, coinduct_tac] @
       maps (fn ((((((map_comp_trans, dtor_maps_trans), map_cong0), set_map0s), set_Jsets),
         set_Jset_Jsetss), in_rel) =>
-        [REPEAT_DETERM o resolve_tac [allI, impI, in_rel RS iffD2],
-         REPEAT_DETERM o eresolve_tac [exE, conjE], hyp_subst_tac ctxt, rtac exI,
+        [REPEAT_DETERM o resolve_tac ctxt [allI, impI, in_rel RS iffD2],
+         REPEAT_DETERM o eresolve_tac ctxt [exE, conjE], hyp_subst_tac ctxt, rtac exI,
          rtac (Drule.rotate_prems 1 conjI),
          rtac conjI, rtac map_comp_trans, rtac sym, rtac dtor_maps_trans, rtac map_cong0,
          REPEAT_DETERM_N m o (rtac o_apply_trans_sym THEN' rtac @{thm fst_conv}),
@@ -910,17 +910,17 @@
   rel_Jrels le_rel_OOs) 1;
 
 fun mk_wit_tac ctxt n dtor_ctors dtor_set wit coind_wits =
-  ALLGOALS (TRY o (eresolve_tac coind_wits THEN' rtac refl)) THEN
+  ALLGOALS (TRY o (eresolve_tac ctxt coind_wits THEN' rtac refl)) THEN
   REPEAT_DETERM (atac 1 ORELSE
-    EVERY' [dtac set_rev_mp, rtac equalityD1, resolve_tac dtor_set,
+    EVERY' [dtac set_rev_mp, rtac equalityD1, resolve_tac ctxt dtor_set,
     K (unfold_thms_tac ctxt dtor_ctors),
     REPEAT_DETERM_N n o etac UnE,
     REPEAT_DETERM o
       (TRY o REPEAT_DETERM o etac UnE THEN' TRY o etac @{thm UN_E} THEN'
-        (eresolve_tac wit ORELSE'
-        (dresolve_tac wit THEN'
+        (eresolve_tac ctxt wit ORELSE'
+        (dresolve_tac ctxt wit THEN'
           (etac FalseE ORELSE'
-          EVERY' [hyp_subst_tac ctxt, dtac set_rev_mp, rtac equalityD1, resolve_tac dtor_set,
+          EVERY' [hyp_subst_tac ctxt, dtac set_rev_mp, rtac equalityD1, resolve_tac ctxt dtor_set,
             K (unfold_thms_tac ctxt dtor_ctors), REPEAT_DETERM_N n o etac UnE]))))] 1);
 
 fun mk_coind_wit_tac ctxt induct unfolds set_nats wits =
@@ -928,7 +928,7 @@
   unfold_thms_tac ctxt (unfolds @ set_nats @ @{thms image_id id_apply}) THEN
   ALLGOALS (REPEAT_DETERM o etac imageE THEN' TRY o hyp_subst_tac ctxt) THEN
   ALLGOALS (TRY o
-    FIRST' [rtac TrueI, rtac refl, etac (refl RSN (2, mp)), dresolve_tac wits THEN' etac FalseE]);
+    FIRST' [rtac TrueI, rtac refl, etac (refl RSN (2, mp)), dresolve_tac ctxt wits THEN' etac FalseE]);
 
 fun mk_dtor_corec_transfer_tac ctxt n m dtor_corec_defs dtor_unfold_transfer pre_T_map_transfers
     dtor_rels =
@@ -955,7 +955,7 @@
     val (passive_set_map0s, active_set_map0s) = chop m set_map0s;
     val in_Jrel = nth in_Jrels (i - 1);
     val if_tac =
-      EVERY' [dtac (in_Jrel RS iffD1), REPEAT_DETERM o eresolve_tac [exE, conjE, CollectE],
+      EVERY' [dtac (in_Jrel RS iffD1), REPEAT_DETERM o eresolve_tac ctxt [exE, conjE, CollectE],
         rtac (in_rel RS iffD2), rtac exI, rtac conjI, rtac CollectI,
         EVERY' (map2 (fn set_map0 => fn set_incl =>
           EVERY' [rtac conjI, rtac ord_eq_le_trans, rtac set_map0,
@@ -975,7 +975,7 @@
           rtac trans, rtac sym, rtac dtor_map, rtac (dtor_inject RS iffD2), atac])
         @{thms fst_conv snd_conv}];
     val only_if_tac =
-      EVERY' [dtac (in_rel RS iffD1), REPEAT_DETERM o eresolve_tac [exE, conjE, CollectE],
+      EVERY' [dtac (in_rel RS iffD1), REPEAT_DETERM o eresolve_tac ctxt [exE, conjE, CollectE],
         rtac (in_Jrel RS iffD2), rtac exI, rtac conjI, rtac CollectI,
         CONJ_WRAP' (fn (dtor_set, passive_set_map0) =>
           EVERY' [rtac ord_eq_le_trans, rtac dtor_set, rtac @{thm Un_least},
@@ -987,12 +987,12 @@
                 rtac active_set_map0, rtac (dtor_ctor RS sym RS arg_cong), rtac @{thm UN_least},
                 dtac set_rev_mp, etac @{thm image_mono}, etac imageE,
                 dtac @{thm ssubst_mem[OF pair_collapse]},
-                REPEAT_DETERM o eresolve_tac (CollectE :: conjE ::
+                REPEAT_DETERM o eresolve_tac ctxt (CollectE :: conjE ::
                   @{thms case_prodE iffD1[OF prod.inject, elim_format]}),
                 hyp_subst_tac ctxt,
                 dtac (in_Jrel RS iffD1),
                 dtac @{thm someI_ex}, REPEAT_DETERM o etac conjE,
-                REPEAT_DETERM o eresolve_tac [CollectE, conjE], atac])
+                REPEAT_DETERM o eresolve_tac ctxt [CollectE, conjE], atac])
             (rev (active_set_map0s ~~ in_Jrels))])
         (dtor_sets ~~ passive_set_map0s),
         rtac conjI,
@@ -1001,7 +1001,7 @@
           rtac map_cong0, REPEAT_DETERM_N m o rtac @{thm fun_cong[OF comp_id]},
           EVERY' (map (fn in_Jrel => EVERY' [rtac trans, rtac o_apply, dtac set_rev_mp, atac,
             dtac @{thm ssubst_mem[OF pair_collapse]},
-            REPEAT_DETERM o eresolve_tac (CollectE :: conjE ::
+            REPEAT_DETERM o eresolve_tac ctxt (CollectE :: conjE ::
               @{thms case_prodE iffD1[OF prod.inject, elim_format]}),
             hyp_subst_tac ctxt, dtac (in_Jrel RS iffD1),
             dtac @{thm someI_ex}, REPEAT_DETERM o etac conjE, atac]) in_Jrels),
@@ -1020,10 +1020,10 @@
     EVERY' [rtac coinduct,
       EVERY' (@{map 8} (fn i => fn map_comp0 => fn map_cong => fn map_arg_cong => fn set_map0s =>
           fn dtor_unfold => fn dtor_map => fn in_rel =>
-        EVERY' [REPEAT_DETERM o resolve_tac [allI, impI, in_rel RS iffD2],
-          REPEAT_DETERM o eresolve_tac [exE, conjE],
+        EVERY' [REPEAT_DETERM o resolve_tac ctxt [allI, impI, in_rel RS iffD2],
+          REPEAT_DETERM o eresolve_tac ctxt [exE, conjE],
           select_prem_tac (length ks) (dtac @{thm spec2}) i, dtac mp, atac,
-          REPEAT_DETERM o eresolve_tac [CollectE, conjE], hyp_subst_tac ctxt,
+          REPEAT_DETERM o eresolve_tac ctxt [CollectE, conjE], hyp_subst_tac ctxt,
           rtac exI, rtac (Drule.rotate_prems 1 conjI), rtac conjI,
           rtac (map_comp0 RS trans), rtac (dtor_map RS trans RS sym),
           rtac (dtor_unfold RS map_arg_cong RS trans), rtac (trans OF [map_comp0, map_cong]),
@@ -1051,20 +1051,20 @@
   in
     rtac set_induct 1 THEN
     EVERY' (@{map 3} (fn unfold => fn set_map0s => fn i =>
-      EVERY' [REPEAT_DETERM o resolve_tac [allI, impI], etac conjE,
+      EVERY' [REPEAT_DETERM o resolve_tac ctxt [allI, impI], etac conjE,
         select_prem_tac n (dtac @{thm spec2}) i, dtac mp, atac,
-        REPEAT_DETERM o eresolve_tac [CollectE, conjE, Collect_splitD_set_mp, set_rev_mp],
+        REPEAT_DETERM o eresolve_tac ctxt [CollectE, conjE, Collect_splitD_set_mp, set_rev_mp],
         hyp_subst_tac ctxt,
         SELECT_GOAL (unfold_thms_tac ctxt ([unfold, nth set_map0s (j - 1)] @ split_id_unfolds)),
         rtac subset_refl])
     unfolds set_map0ss ks) 1 THEN
     EVERY' (@{map 3} (fn unfold => fn set_map0s => fn i =>
       EVERY' (map (fn set_map0 =>
-        EVERY' [REPEAT_DETERM o resolve_tac [allI, impI], etac conjE,
+        EVERY' [REPEAT_DETERM o resolve_tac ctxt [allI, impI], etac conjE,
         select_prem_tac n (dtac @{thm spec2}) i, dtac mp, atac,
-        REPEAT_DETERM o eresolve_tac [CollectE, conjE], hyp_subst_tac ctxt,
+        REPEAT_DETERM o eresolve_tac ctxt [CollectE, conjE], hyp_subst_tac ctxt,
         SELECT_GOAL (unfold_thms_tac ctxt ([unfold, set_map0] @ split_id_unfolds)),
-        etac imageE, hyp_subst_tac ctxt, REPEAT_DETERM o eresolve_tac [allE, mp],
+        etac imageE, hyp_subst_tac ctxt, REPEAT_DETERM o eresolve_tac ctxt [allE, mp],
         rtac conjI, etac Collect_splitD_set_mp, atac, rtac (@{thm surjective_pairing} RS arg_cong)])
       (drop m set_map0s)))
     unfolds set_map0ss ks) 1
@@ -1083,8 +1083,8 @@
           CONJ_WRAP' (fn helper_ind =>
             EVERY' [rtac (helper_ind RS rev_mp), REPEAT_DETERM_N n o atac,
               REPEAT_DETERM_N n o etac thin_rl, rtac impI,
-              REPEAT_DETERM o resolve_tac [subsetI, CollectI, @{thm iffD2[OF split_beta]}],
-              dtac bspec, atac, REPEAT_DETERM o eresolve_tac [allE, mp, conjE],
+              REPEAT_DETERM o resolve_tac ctxt [subsetI, CollectI, @{thm iffD2[OF split_beta]}],
+              dtac bspec, atac, REPEAT_DETERM o eresolve_tac ctxt [allE, mp, conjE],
               etac (refl RSN (2, conjI))])
           helper_inds,
         rtac conjI,
@@ -1103,9 +1103,9 @@
       @{thms rel_fun_def_butlast all_conj_distrib[symmetric] imp_conjR[symmetric]} THEN
     unfold_thms_tac ctxt @{thms rel_fun_iff_geq_image2p} THEN
     HEADGOAL (EVERY'
-      [REPEAT_DETERM o resolve_tac [allI, impI], rtac ctor_rel_coinduct,
+      [REPEAT_DETERM o resolve_tac ctxt [allI, impI], rtac ctor_rel_coinduct,
       EVERY' (map (fn map_transfer => EVERY'
-        [REPEAT_DETERM o resolve_tac [allI, impI], etac @{thm image2pE}, hyp_subst_tac ctxt,
+        [REPEAT_DETERM o resolve_tac ctxt [allI, impI], etac @{thm image2pE}, hyp_subst_tac ctxt,
         SELECT_GOAL (unfold_thms_tac ctxt unfolds),
         rtac (funpow (m + n + 1) (fn thm => thm RS rel_funD) map_transfer),
         REPEAT_DETERM_N m o rtac @{thm id_transfer},
--- a/src/HOL/Tools/BNF/bnf_lfp.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/BNF/bnf_lfp.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -368,7 +368,7 @@
         val concl = HOLogic.mk_Trueprop (mk_mor Bs ss Bs_copy ss active_ids);
       in
         Goal.prove_sorry lthy [] [] (Logic.list_implies (prems, concl))
-          (K (mk_mor_incl_tac mor_def map_ids))
+          (fn {context = ctxt, ...} => mk_mor_incl_tac ctxt mor_def map_ids)
         |> Thm.close_derivation
         |> singleton (Proof_Context.export names_lthy lthy)
       end;
@@ -860,7 +860,8 @@
       lthy
       |> @{fold_map 3} (fn b => fn mx => fn car_init =>
         typedef (b, params, mx) car_init NONE
-          (fn _ => EVERY' [rtac iffD2, rtac @{thm ex_in_conv}, resolve_tac alg_not_empty_thms,
+          (fn ctxt =>
+            EVERY' [rtac iffD2, rtac @{thm ex_in_conv}, resolve_tac ctxt alg_not_empty_thms,
             rtac alg_init_thm] 1)) bs mixfixes car_inits
       |>> apsnd split_list o split_list;
 
@@ -1024,7 +1025,8 @@
       in
         Goal.prove_sorry lthy [] []
           (HOLogic.mk_Trueprop (mk_mor UNIVs ctors active_UNIVs ss (map (mk_fold Ts ss) ks)))
-          (K (mk_mor_fold_tac cT ct fold_defs init_ex_mor_thm mor_cong))
+          (fn {context = ctxt, ...} =>
+            mk_mor_fold_tac ctxt cT ct fold_defs init_ex_mor_thm mor_cong)
         |> Thm.close_derivation
         |> singleton (Proof_Context.export names_lthy lthy)
       end;
--- a/src/HOL/Tools/BNF/bnf_lfp_size.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/BNF/bnf_lfp_size.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -221,7 +221,7 @@
           (Class.instantiation (T_names, map dest_TFree As, [HOLogic.class_size])
            #> @{fold_map 3} define_overloaded_size overloaded_size_def_bs overloaded_size_consts
              overloaded_size_rhss
-           ##> Class.prove_instantiation_instance (K (Class.intro_classes_tac []))
+           ##> Class.prove_instantiation_instance (fn ctxt => Class.intro_classes_tac ctxt [])
            ##> Local_Theory.exit_global);
 
       val size_defs' =
--- a/src/HOL/Tools/BNF/bnf_lfp_tactics.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/BNF/bnf_lfp_tactics.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -56,8 +56,8 @@
   val mk_mor_comp_tac: thm -> thm list list -> thm list -> tactic
   val mk_mor_convol_tac: 'a list -> thm -> tactic
   val mk_mor_elim_tac: thm -> tactic
-  val mk_mor_incl_tac: thm -> thm list -> tactic
-  val mk_mor_fold_tac: ctyp -> cterm -> thm list -> thm -> thm -> tactic
+  val mk_mor_incl_tac: Proof.context -> thm -> thm list -> tactic
+  val mk_mor_fold_tac: Proof.context -> ctyp -> cterm -> thm list -> thm -> thm -> tactic
   val mk_mor_select_tac: thm -> thm -> thm -> thm -> thm -> thm -> thm list -> thm list list ->
     thm list -> tactic
   val mk_mor_str_tac: 'a list -> thm -> tactic
@@ -94,11 +94,11 @@
    REPEAT_DETERM o (rtac (subset_UNIV RS conjI) ORELSE' etac conjI), atac] 1;
 
 fun mk_alg_not_empty_tac ctxt alg_set alg_sets wits =
-  (EVERY' [rtac notI, hyp_subst_tac ctxt, ftac alg_set] THEN'
+  (EVERY' [rtac notI, hyp_subst_tac ctxt, forward_tac ctxt [alg_set]] THEN'
   REPEAT_DETERM o FIRST'
-    [EVERY' [rtac @{thm subset_emptyI}, eresolve_tac wits],
-    EVERY' [rtac subsetI, rtac FalseE, eresolve_tac wits],
-    EVERY' [rtac subsetI, dresolve_tac wits, hyp_subst_tac ctxt,
+    [EVERY' [rtac @{thm subset_emptyI}, eresolve_tac ctxt wits],
+    EVERY' [rtac subsetI, rtac FalseE, eresolve_tac ctxt wits],
+    EVERY' [rtac subsetI, dresolve_tac ctxt wits, hyp_subst_tac ctxt,
       FIRST' (map (fn thm => rtac thm THEN' atac) alg_sets)]] THEN'
   etac @{thm emptyE}) 1;
 
@@ -109,13 +109,13 @@
   etac bspec THEN'
   atac) 1;
 
-fun mk_mor_incl_tac mor_def map_ids =
+fun mk_mor_incl_tac ctxt mor_def map_ids =
   (rtac (mor_def RS iffD2) THEN'
   rtac conjI THEN'
   CONJ_WRAP' (K (EVERY' [rtac ballI, etac set_mp, etac (id_apply RS @{thm ssubst_mem})]))
     map_ids THEN'
   CONJ_WRAP' (fn thm =>
-    (EVERY' [rtac ballI, rtac trans, rtac id_apply, stac thm, rtac refl])) map_ids) 1;
+    (EVERY' [rtac ballI, rtac trans, rtac id_apply, stac ctxt thm, rtac refl])) map_ids) 1;
 
 fun mk_mor_comp_tac mor_def set_maps map_comp_ids =
   let
@@ -124,7 +124,7 @@
     fun mor_tac (set_map, map_comp_id) =
       EVERY' [rtac ballI, rtac (o_apply RS trans), rtac trans,
         rtac trans, dtac rev_bspec, atac, etac arg_cong,
-         REPEAT o eresolve_tac [CollectE, conjE], etac bspec, rtac CollectI] THEN'
+         REPEAT o eresolve0_tac [CollectE, conjE], etac bspec, rtac CollectI] THEN'
       CONJ_WRAP' (fn thm =>
         FIRST' [rtac subset_UNIV,
           (EVERY' [rtac ord_eq_le_trans, rtac thm, rtac @{thm image_subsetI},
@@ -170,14 +170,14 @@
         rtac equalityD1, etac @{thm bij_betw_imageE}];
     val alg_tac =
       CONJ_WRAP' (fn (set_maps, alg_set) =>
-        EVERY' [rtac ballI, REPEAT_DETERM o eresolve_tac [CollectE, conjE], rtac set_mp,
+        EVERY' [rtac ballI, REPEAT_DETERM o eresolve0_tac [CollectE, conjE], rtac set_mp,
           rtac equalityD1, etac @{thm bij_betw_imageE[OF bij_betw_the_inv_into]},
           rtac imageI, etac alg_set, EVERY' (map set_tac (drop m set_maps))])
       (set_mapss ~~ alg_sets);
 
     val mor_tac = rtac conjI THEN' CONJ_WRAP' (K (etac @{thm bij_betwE})) alg_sets THEN'
       CONJ_WRAP' (fn (set_maps, alg_set) =>
-        EVERY' [rtac ballI, REPEAT_DETERM o eresolve_tac [CollectE, conjE],
+        EVERY' [rtac ballI, REPEAT_DETERM o eresolve0_tac [CollectE, conjE],
           etac @{thm f_the_inv_into_f_bij_betw}, etac alg_set,
           EVERY' (map set_tac (drop m set_maps))])
       (set_mapss ~~ alg_sets);
@@ -251,7 +251,7 @@
       rtac @{thm csum_absorb1}, rtac Asuc_Cinfinite, rtac @{thm ctwo_ordLeq_Cinfinite},
       rtac Asuc_Cinfinite, rtac bd_Card_order,
       rtac @{thm ordIso_imp_ordLeq}, rtac @{thm cexp_cprod_ordLeq},
-      resolve_tac @{thms Card_order_csum Card_order_ctwo}, rtac suc_Cinfinite,
+      resolve0_tac @{thms Card_order_csum Card_order_ctwo}, rtac suc_Cinfinite,
       rtac bd_Cnotzero, rtac @{thm cardSuc_ordLeq}, rtac bd_Card_order, rtac Asuc_Cinfinite];
   in
     (rtac induct THEN'
@@ -269,7 +269,7 @@
 
     fun mk_minH_tac (min_alg, alg_set) = EVERY' [rtac ord_eq_le_trans, etac min_alg,
       rtac @{thm Un_least}, minG_tac, rtac @{thm image_subsetI},
-      REPEAT_DETERM o eresolve_tac [CollectE, conjE], etac alg_set,
+      REPEAT_DETERM o eresolve0_tac [CollectE, conjE], etac alg_set,
       REPEAT_DETERM o (etac subset_trans THEN' minG_tac)];
   in
     (rtac induct THEN'
@@ -283,9 +283,9 @@
     val n = length min_algs;
     fun mk_cardSuc_UNION_tac set_bds (mono, def) = EVERY'
       [rtac bexE, rtac @{thm cardSuc_UNION_Cinfinite}, rtac bd_Cinfinite, rtac mono,
-       etac (def RSN (2, @{thm subset_trans[OF _ equalityD1]})), resolve_tac set_bds];
+       etac (def RSN (2, @{thm subset_trans[OF _ equalityD1]})), resolve0_tac set_bds];
     fun mk_conjunct_tac (set_bds, (min_alg, min_alg_def)) =
-      EVERY' [rtac ballI, REPEAT_DETERM o eresolve_tac [CollectE, conjE],
+      EVERY' [rtac ballI, REPEAT_DETERM o eresolve0_tac [CollectE, conjE],
         EVERY' (map (mk_cardSuc_UNION_tac set_bds) (min_alg_monos ~~ min_alg_defs)), rtac bexE,
         rtac bd_limit, REPEAT_DETERM_N (n - 1) o etac conjI, atac,
         rtac (min_alg_def RS @{thm set_mp[OF equalityD2]}),
@@ -314,7 +314,8 @@
     REPEAT_DETERM o etac conjE, atac] 1;
 
 fun mk_alg_select_tac ctxt Abs_inverse =
-  EVERY' [rtac ballI, REPEAT_DETERM o eresolve_tac [CollectE, exE, conjE], hyp_subst_tac ctxt] 1 THEN
+  EVERY' [rtac ballI,
+    REPEAT_DETERM o eresolve_tac ctxt [CollectE, exE, conjE], hyp_subst_tac ctxt] 1 THEN
   unfold_thms_tac ctxt (Abs_inverse :: fst_snd_convs) THEN atac 1;
 
 fun mk_mor_select_tac mor_def mor_cong mor_comp mor_incl_min_alg alg_def alg_select alg_sets
@@ -326,9 +327,9 @@
     val mor_tac =
       CONJ_WRAP' (fn thm => EVERY' [rtac ballI, rtac thm]) str_init_defs;
     fun alg_epi_tac ((alg_set, str_init_def), set_map) =
-      EVERY' [rtac ballI, REPEAT_DETERM o eresolve_tac [CollectE, conjE], rtac CollectI,
+      EVERY' [rtac ballI, REPEAT_DETERM o eresolve0_tac [CollectE, conjE], rtac CollectI,
         rtac ballI, ftac (alg_select RS bspec), rtac (str_init_def RS @{thm ssubst_mem}),
-        etac alg_set, REPEAT_DETERM o EVERY' [rtac ord_eq_le_trans, resolve_tac set_map,
+        etac alg_set, REPEAT_DETERM o EVERY' [rtac ord_eq_le_trans, resolve0_tac set_map,
           rtac subset_trans, etac @{thm image_mono}, rtac @{thm image_Collect_subsetI}, etac bspec,
           atac]];
   in
@@ -344,7 +345,7 @@
   in
     EVERY' [Method.insert_tac (map (fn thm => thm RS @{thm ex_bij_betw}) card_of_min_algs),
       REPEAT_DETERM o etac exE, rtac rev_mp, rtac copy, REPEAT_DETERM_N n o atac,
-      rtac impI, REPEAT_DETERM o eresolve_tac [exE, conjE], REPEAT_DETERM_N n o rtac exI,
+      rtac impI, REPEAT_DETERM o eresolve0_tac [exE, conjE], REPEAT_DETERM_N n o rtac exI,
       rtac mor_comp, rtac mor_Rep, rtac mor_select, rtac CollectI, REPEAT_DETERM o rtac exI,
       rtac conjI, rtac refl, atac,
       SELECT_GOAL (unfold_thms_tac ctxt (Abs_inverse :: fst_snd_convs)),
@@ -367,7 +368,7 @@
 
     fun mk_alg_tac (ct, (alg_set, (in_mono, (morE, map_cong0)))) =
       EVERY' [rtac ballI, rtac CollectI,
-        REPEAT_DETERM o eresolve_tac [CollectE, conjE], rtac conjI, rtac (alg_min_alg RS alg_set),
+        REPEAT_DETERM o eresolve0_tac [CollectE, conjE], rtac conjI, rtac (alg_min_alg RS alg_set),
         REPEAT_DETERM_N n o (etac subset_trans THEN' rtac @{thm Collect_restrict}),
         rtac trans, mor_tac morE in_mono,
         rtac trans, cong_tac ct map_cong0,
@@ -386,7 +387,7 @@
     val n = length least_min_algs;
 
     fun mk_alg_tac alg_set = EVERY' [rtac ballI, rtac CollectI,
-      REPEAT_DETERM o eresolve_tac [CollectE, conjE], rtac conjI, rtac (alg_min_alg RS alg_set),
+      REPEAT_DETERM o eresolve0_tac [CollectE, conjE], rtac conjI, rtac (alg_min_alg RS alg_set),
       REPEAT_DETERM_N n o (etac subset_trans THEN' rtac @{thm Collect_restrict}),
       rtac mp, etac bspec, rtac CollectI,
       REPEAT_DETERM_N m o (rtac conjI THEN' atac),
@@ -417,15 +418,15 @@
   EVERY' [rtac conjI,
     CONJ_WRAP' (K (rtac ballI THEN' rtac UNIV_I)) Abs_inverses,
     CONJ_WRAP' (fn (ct, thm) =>
-      EVERY' [rtac ballI, REPEAT_DETERM o eresolve_tac [CollectE, conjE],
+      EVERY' [rtac ballI, REPEAT_DETERM o eresolve_tac ctxt [CollectE, conjE],
         rtac (thm RS (cterm_instantiate_pos [NONE, NONE, SOME ct] arg_cong) RS sym),
         EVERY' (map (fn Abs_inverse =>
           EVERY' [rtac (o_apply RS trans RS ballI), etac (set_mp RS Abs_inverse), atac])
         Abs_inverses)])
     (cts ~~ map2 mk_trans map_comp_ids map_congLs)] 1;;
 
-fun mk_mor_fold_tac cT ct fold_defs ex_mor mor =
-  (EVERY' (map stac fold_defs) THEN' EVERY' [rtac rev_mp, rtac ex_mor, rtac impI] THEN'
+fun mk_mor_fold_tac ctxt cT ct fold_defs ex_mor mor =
+  (EVERY' (map (stac ctxt) fold_defs) THEN' EVERY' [rtac rev_mp, rtac ex_mor, rtac impI] THEN'
   REPEAT_DETERM_N (length fold_defs) o etac exE THEN'
   rtac (Drule.instantiate' [SOME cT] [SOME ct] @{thm someI}) THEN' etac mor) 1;
 
@@ -433,7 +434,7 @@
   let
     fun mk_unique type_def =
       EVERY' [rtac @{thm surj_fun_eq}, rtac (type_def RS @{thm type_definition.Abs_image}),
-        rtac ballI, resolve_tac init_unique_mors,
+        rtac ballI, resolve0_tac init_unique_mors,
         EVERY' (map (fn thm => atac ORELSE' rtac thm) Reps),
         rtac mor_comp, rtac mor_Abs, atac,
         rtac mor_comp, rtac mor_Abs, rtac mor_fold];
@@ -472,7 +473,7 @@
     fun mk_closed_tac (k, (morE, set_maps)) =
       EVERY' [select_prem_tac n (dtac asm_rl) k, rtac ballI, rtac impI,
         rtac (mor_Abs RS morE RS arg_cong RS iffD2), atac,
-        REPEAT_DETERM o eresolve_tac [CollectE, conjE], dtac @{thm meta_spec},
+        REPEAT_DETERM o eresolve_tac ctxt [CollectE, conjE], dtac @{thm meta_spec},
         EVERY' (@{map 3} mk_IH_tac Rep_invs Abs_invs (drop m set_maps)), atac];
 
     fun mk_induct_tac (Rep, Rep_inv) =
@@ -498,7 +499,7 @@
   in
     EVERY' [rtac rev_mp, rtac (Drule.instantiate' cTs cts ctor_induct),
       EVERY' (map2 mk_inner_induct_tac weak_ctor_inducts ks), rtac impI,
-      REPEAT_DETERM o eresolve_tac [conjE, allE],
+      REPEAT_DETERM o eresolve_tac ctxt [conjE, allE],
       CONJ_WRAP' (K atac) ks] 1
   end;
 
@@ -626,13 +627,13 @@
 
 fun mk_wit_tac ctxt n ctor_set wit =
   REPEAT_DETERM (atac 1 ORELSE
-    EVERY' [dtac set_rev_mp, rtac equalityD1, resolve_tac ctor_set,
+    EVERY' [dtac set_rev_mp, rtac equalityD1, resolve_tac ctxt ctor_set,
     REPEAT_DETERM o
       (TRY o REPEAT_DETERM o etac UnE THEN' TRY o etac @{thm UN_E} THEN'
-        (eresolve_tac wit ORELSE'
-        (dresolve_tac wit THEN'
+        (eresolve_tac ctxt wit ORELSE'
+        (dresolve_tac ctxt wit THEN'
           (etac FalseE ORELSE'
-          EVERY' [hyp_subst_tac ctxt, dtac set_rev_mp, rtac equalityD1, resolve_tac ctor_set,
+          EVERY' [hyp_subst_tac ctxt, dtac set_rev_mp, rtac equalityD1, resolve_tac ctxt ctor_set,
             REPEAT_DETERM_N n o etac UnE]))))] 1);
 
 fun mk_ctor_rel_tac ctxt in_Irels i in_rel map_comp0 map_cong0 ctor_map ctor_sets ctor_inject
@@ -646,7 +647,7 @@
     val le_arg_cong_ctor_dtor = ctor_dtor RS arg_cong RS ord_eq_le_trans;
     val eq_arg_cong_ctor_dtor = ctor_dtor RS arg_cong RS trans;
     val if_tac =
-      EVERY' [dtac (in_Irel RS iffD1), REPEAT_DETERM o eresolve_tac [exE, conjE, CollectE],
+      EVERY' [dtac (in_Irel RS iffD1), REPEAT_DETERM o eresolve_tac ctxt [exE, conjE, CollectE],
         rtac (in_rel RS iffD2), rtac exI, rtac conjI, rtac CollectI,
         EVERY' (map2 (fn set_map0 => fn ctor_set_incl =>
           EVERY' [rtac conjI, rtac ord_eq_le_trans, rtac set_map0,
@@ -669,7 +670,7 @@
           etac eq_arg_cong_ctor_dtor])
         fst_snd_convs];
     val only_if_tac =
-      EVERY' [dtac (in_rel RS iffD1), REPEAT_DETERM o eresolve_tac [exE, conjE, CollectE],
+      EVERY' [dtac (in_rel RS iffD1), REPEAT_DETERM o eresolve_tac ctxt [exE, conjE, CollectE],
         rtac (in_Irel RS iffD2), rtac exI, rtac conjI, rtac CollectI,
         CONJ_WRAP' (fn (ctor_set, passive_set_map0) =>
           EVERY' [rtac ord_eq_le_trans, rtac ctor_set, rtac @{thm Un_least},
@@ -680,11 +681,11 @@
                 rtac @{thm SUP_cong[OF _ refl]}, rtac active_set_map0, rtac @{thm UN_least},
                 dtac set_rev_mp, etac @{thm image_mono}, etac imageE,
                 dtac @{thm ssubst_mem[OF pair_collapse]},
-                REPEAT_DETERM o eresolve_tac (CollectE :: conjE ::
+                REPEAT_DETERM o eresolve_tac ctxt (CollectE :: conjE ::
                   @{thms case_prodE iffD1[OF prod.inject, elim_format]}),
                 hyp_subst_tac ctxt,
                 dtac (in_Irel RS iffD1), dtac @{thm someI_ex}, REPEAT_DETERM o etac conjE,
-                REPEAT_DETERM o eresolve_tac [CollectE, conjE], atac])
+                REPEAT_DETERM o eresolve_tac ctxt [CollectE, conjE], atac])
             (rev (active_set_map0s ~~ in_Irels))])
         (ctor_sets ~~ passive_set_map0s),
         rtac conjI,
@@ -693,7 +694,7 @@
           REPEAT_DETERM_N m o rtac @{thm fun_cong[OF comp_id]},
           EVERY' (map (fn in_Irel => EVERY' [rtac trans, rtac o_apply, dtac set_rev_mp, atac,
             dtac @{thm ssubst_mem[OF pair_collapse]},
-            REPEAT_DETERM o eresolve_tac (CollectE :: conjE ::
+            REPEAT_DETERM o eresolve_tac ctxt (CollectE :: conjE ::
               @{thms case_prodE iffD1[OF prod.inject, elim_format]}),
             hyp_subst_tac ctxt,
             dtac (in_Irel RS iffD1), dtac @{thm someI_ex}, REPEAT_DETERM o etac conjE, atac])
@@ -743,9 +744,9 @@
       @{thms rel_fun_def_butlast all_conj_distrib[symmetric] imp_conjR[symmetric]} THEN
     unfold_thms_tac ctxt @{thms rel_fun_iff_leq_vimage2p} THEN
     HEADGOAL (EVERY'
-      [REPEAT_DETERM o resolve_tac [allI, impI], rtac ctor_rel_induct,
+      [REPEAT_DETERM o resolve_tac ctxt [allI, impI], rtac ctor_rel_induct,
       EVERY' (map (fn map_transfer => EVERY'
-        [REPEAT_DETERM o resolve_tac [allI, impI, @{thm vimage2pI}],
+        [REPEAT_DETERM o resolve_tac ctxt [allI, impI, @{thm vimage2pI}],
         SELECT_GOAL (unfold_thms_tac ctxt folds),
         etac @{thm predicate2D_vimage2p},
         rtac (funpow (m + n + 1) (fn thm => thm RS rel_funD) map_transfer),
--- a/src/HOL/Tools/Ctr_Sugar/ctr_sugar_code.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/Ctr_Sugar/ctr_sugar_code.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -93,7 +93,8 @@
         (def, lthy')
       end;
 
-    fun tac ctxt thms = Class.intro_classes_tac [] THEN ALLGOALS (Proof_Context.fact_tac ctxt thms);
+    fun tac ctxt thms =
+      Class.intro_classes_tac ctxt [] THEN ALLGOALS (Proof_Context.fact_tac ctxt thms);
 
     val qualify =
       Binding.qualify true (Long_Name.base_name fcT_name) o Binding.qualify true eqN o Binding.name;
--- a/src/HOL/Tools/Ctr_Sugar/ctr_sugar_tactics.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/Ctr_Sugar/ctr_sugar_tactics.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -85,7 +85,7 @@
 
 fun mk_exhaust_sel_tac n exhaust_disc collapses =
   mk_exhaust_disc_or_sel_tac n exhaust_disc collapses ORELSE
-  HEADGOAL (etac meta_mp THEN' resolve_tac collapses);
+  HEADGOAL (etac meta_mp THEN' resolve0_tac collapses);
 
 fun mk_collapse_tac ctxt m discD sels =
   HEADGOAL (dtac discD THEN'
@@ -101,7 +101,7 @@
     (hyp_subst_tac ctxt THEN'
      SELECT_GOAL (unfold_thms_tac ctxt (@{thms not_True_eq_False not_False_eq_True} @ cases @
        ((refl :: discs @ distincts) RL [eqTrueI, eqFalseI]))) THEN'
-     resolve_tac @{thms TrueI True_not_False False_not_True}));
+     resolve_tac ctxt @{thms TrueI True_not_False False_not_True}));
 
 fun mk_expand_tac ctxt n ms uexhaust_disc vexhaust_disc uncollapses distinct_discsss
     distinct_discsss' =
--- a/src/HOL/Tools/Function/function_common.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/Function/function_common.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -279,7 +279,8 @@
     preproc1)
 )
 
-val termination_rule_tac = resolve_tac o #1 o Data.get o Context.Proof
+fun termination_rule_tac ctxt = resolve_tac ctxt (#1 (Data.get (Context.Proof ctxt)))
+
 val store_termination_rule = Data.map o @{apply 4(1)} o cons
 
 val get_functions = #2 o Data.get o Context.Proof
--- a/src/HOL/Tools/Function/function_core.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/Function/function_core.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -707,8 +707,8 @@
       |> cterm_of thy
   in
     Goal.init goal
-    |> (SINGLE (resolve_tac [accI] 1)) |> the
-    |> (SINGLE (eresolve_tac [Thm.forall_elim_vars 0 R_cases] 1))  |> the
+    |> (SINGLE (resolve_tac ctxt [accI] 1)) |> the
+    |> (SINGLE (eresolve_tac ctxt [Thm.forall_elim_vars 0 R_cases] 1))  |> the
     |> (SINGLE (auto_tac ctxt)) |> the
     |> Goal.conclude
     |> fold_rev forall_intr_rename (map fst oqs ~~ cqs)
--- a/src/HOL/Tools/Function/function_elims.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/Function/function_elims.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -60,8 +60,8 @@
 
 fun bool_subst_tac ctxt i =
   REPEAT (EqSubst.eqsubst_asm_tac ctxt [1] eq_bool i)
-  THEN REPEAT (dresolve_tac boolD i)
-  THEN REPEAT (eresolve_tac boolE i)
+  THEN REPEAT (dresolve_tac ctxt boolD i)
+  THEN REPEAT (eresolve_tac ctxt boolE i)
 
 fun mk_bool_elims ctxt elim =
   let
@@ -69,7 +69,7 @@
     fun mk_bool_elim b =
       elim
       |> Thm.forall_elim b
-      |> Tactic.rule_by_tactic ctxt (TRY (resolve_tac eq_boolI 1))
+      |> Tactic.rule_by_tactic ctxt (TRY (resolve_tac ctxt eq_boolI 1))
       |> Tactic.rule_by_tactic ctxt tac;
   in
     map mk_bool_elim [@{cterm True}, @{cterm False}]
@@ -125,7 +125,7 @@
         val asms_thms = map Thm.assume asms;
 
         fun prep_subgoal_tac i =
-          REPEAT (eresolve_tac @{thms Pair_inject} i)
+          REPEAT (eresolve_tac ctxt @{thms Pair_inject} i)
           THEN Method.insert_tac (case asms_thms of thm :: thms => (thm RS sym) :: thms) i
           THEN propagate_tac ctxt i
           THEN TRY ((EqSubst.eqsubst_asm_tac ctxt [1] psimps i) THEN assume_tac ctxt i)
--- a/src/HOL/Tools/Function/function_lib.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/Function/function_lib.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -113,7 +113,7 @@
             then mk (foldr1 mk (map (nth xs) is), Const (neu, ty))
             else mk (foldr1 mk (map (nth xs) is), foldr1 mk (map (nth xs) js)))))
      (K (rewrite_goals_tac ctxt ac
-         THEN resolve_tac [Drule.reflexive_thm] 1))
+         THEN resolve_tac ctxt [Drule.reflexive_thm] 1))
  end
 
 (* instance for unions *)
--- a/src/HOL/Tools/Function/measure_functions.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/Function/measure_functions.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -18,7 +18,7 @@
   Const (@{const_name is_measure}, fastype_of t --> HOLogic.boolT) $ t
 
 fun find_measures ctxt T =
-  DEPTH_SOLVE (resolve_tac (rev (Named_Theorems.get ctxt @{named_theorems measure_function})) 1)
+  DEPTH_SOLVE (resolve_tac ctxt (rev (Named_Theorems.get ctxt @{named_theorems measure_function})) 1)
     (HOLogic.mk_Trueprop (mk_is_measure (Var (("f",0), T --> HOLogic.natT)))
      |> cterm_of (Proof_Context.theory_of ctxt) |> Goal.init)
   |> Seq.map (prop_of #> (fn _ $ (_ $ (_ $ f)) => f))
--- a/src/HOL/Tools/Function/mutual.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/Function/mutual.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -267,8 +267,8 @@
       @{thms HOL.notE[OF Sum_Type.sum.distinct(1)] HOL.notE[OF Sum_Type.sum.distinct(2)]}
 
     fun prep_subgoal i =
-      REPEAT (eresolve_tac @{thms Pair_inject Inl_inject[elim_format] Inr_inject[elim_format]} i)
-      THEN REPEAT (Tactic.eresolve_tac sum_elims i)
+      REPEAT (eresolve_tac ctxt @{thms Pair_inject Inl_inject[elim_format] Inr_inject[elim_format]} i)
+      THEN REPEAT (eresolve_tac ctxt sum_elims i)
   in
     cases_rule
     |> Thm.forall_elim P
--- a/src/HOL/Tools/Function/partial_function.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/Function/partial_function.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -80,7 +80,7 @@
   | _ => NONE;
 
 (*split on case expressions*)
-val split_cases_tac = Subgoal.FOCUS_PARAMS (fn {context=ctxt, ...} =>
+val split_cases_tac = Subgoal.FOCUS_PARAMS (fn {context = ctxt, ...} =>
   SUBGOAL (fn (t, i) => case t of
     _ $ (_ $ Abs (_, _, body)) =>
       (case dest_case ctxt body of
@@ -90,7 +90,7 @@
               if Term.is_open arg then no_tac
               else ((DETERM o strip_cases o Induct.cases_tac ctxt false [[SOME arg]] NONE [])
                 THEN_ALL_NEW (rewrite_with_asm_tac ctxt 0)
-                THEN_ALL_NEW eresolve_tac @{thms thin_rl}
+                THEN_ALL_NEW eresolve_tac ctxt @{thms thin_rl}
                 THEN_ALL_NEW (CONVERSION
                   (params_conv ~1 (fn ctxt' =>
                     arg_conv (arg_conv (abs_conv (K conv) ctxt'))) ctxt))) i
@@ -101,7 +101,7 @@
 fun mono_tac ctxt =
   K (Local_Defs.unfold_tac ctxt [@{thm curry_def}])
   THEN' (TRY o REPEAT_ALL_NEW
-   (resolve_tac (rev (Named_Theorems.get ctxt @{named_theorems partial_function_mono}))
+   (resolve_tac ctxt (rev (Named_Theorems.get ctxt @{named_theorems partial_function_mono}))
      ORELSE' split_cases_tac ctxt));
 
 
@@ -290,7 +290,7 @@
     val rec_rule = let open Conv in
       Goal.prove lthy' (map (fst o dest_Free) args) [] eqn (fn _ =>
         CONVERSION ((arg_conv o arg1_conv o head_conv o rewr_conv) (mk_meta_eq unfold)) 1
-        THEN resolve_tac @{thms refl} 1) end;
+        THEN resolve_tac lthy' @{thms refl} 1) end;
   in
     lthy'
     |> Local_Theory.note (eq_abinding, [rec_rule])
--- a/src/HOL/Tools/Function/scnp_reconstruct.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/Function/scnp_reconstruct.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -282,7 +282,7 @@
          THEN PRIMITIVE (instantiate' [] [SOME level_mapping])
          THEN unfold_tac ctxt @{thms rp_inv_image_def}
          THEN Local_Defs.unfold_tac ctxt @{thms split_conv fst_conv snd_conv}
-         THEN REPEAT (SOMEGOAL (resolve_tac [@{thm Un_least}, @{thm empty_subsetI}]))
+         THEN REPEAT (SOMEGOAL (resolve_tac ctxt [@{thm Un_least}, @{thm empty_subsetI}]))
          THEN EVERY (map (prove_lev true) sl)
          THEN EVERY (map (prove_lev false) (subtract (op =) sl (0 upto length cs - 1))))
     end
--- a/src/HOL/Tools/Lifting/lifting_def.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/Lifting/lifting_def.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -33,8 +33,8 @@
     val refl_rules = Lifting_Info.get_reflexivity_rules ctxt
     val transfer_rules = Transfer.get_transfer_raw ctxt
     
-    fun main_tac i = (REPEAT_ALL_NEW (DETERM o resolve_tac refl_rules) THEN_ALL_NEW 
-      (REPEAT_ALL_NEW (DETERM o resolve_tac transfer_rules))) i
+    fun main_tac i = (REPEAT_ALL_NEW (DETERM o resolve_tac ctxt refl_rules) THEN_ALL_NEW 
+      (REPEAT_ALL_NEW (DETERM o resolve_tac ctxt transfer_rules))) i
   in
     SOME (Goal.prove ctxt [] [] prop (K (main_tac 1)))
       handle ERROR _ => NONE
@@ -545,7 +545,7 @@
         fun binop_conv2 cv1 cv2 = Conv.combination_conv (Conv.arg_conv cv1) cv2
         val eq_onp_assms_tac_rules = @{thm left_unique_OO} :: 
             eq_onp_assms_tac_fixed_rules @ (Transfer.get_transfer_raw lthy)
-        val eq_onp_assms_tac = (TRY o REPEAT_ALL_NEW (resolve_tac eq_onp_assms_tac_rules) 
+        val eq_onp_assms_tac = (TRY o REPEAT_ALL_NEW (resolve_tac lthy eq_onp_assms_tac_rules) 
           THEN_ALL_NEW (DETERM o Transfer.eq_tac lthy)) 1
         val relator_eq_onp_conv = Conv.bottom_conv
           (K (Conv.try_conv (assms_rewrs_conv eq_onp_assms_tac
--- a/src/HOL/Tools/Lifting/lifting_setup.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/Lifting/lifting_setup.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -310,7 +310,8 @@
           val init_goal = Goal.init (cterm_of thy fixed_goal)
           val rules = Transfer.get_transfer_raw ctxt
           val rules = constraint :: OO_rules @ rules
-          val tac = K (Local_Defs.unfold_tac ctxt [pcr_def]) THEN' REPEAT_ALL_NEW (resolve_tac rules)
+          val tac =
+            K (Local_Defs.unfold_tac ctxt [pcr_def]) THEN' REPEAT_ALL_NEW (resolve_tac ctxt rules)
         in
           (singleton (Variable.export ctxt orig_ctxt) o Goal.conclude) (the (SINGLE (tac 1) init_goal))
         end
@@ -414,7 +415,8 @@
     let
       val goal = thm |> prems_of |> hd
       val var = goal |> HOLogic.dest_Trueprop |> dest_comb |> snd |> dest_Var 
-      val reduced_assm = reduce_goal [var] goal (TRY (REPEAT_ALL_NEW (resolve_tac rules) 1)) ctxt
+      val reduced_assm =
+        reduce_goal [var] goal (TRY (REPEAT_ALL_NEW (resolve_tac ctxt rules) 1)) ctxt
     in
       reduced_assm RS thm
     end
@@ -424,7 +426,8 @@
       fun reduce_first_assm ctxt rules thm =
         let
           val goal = thm |> prems_of |> hd
-          val reduced_assm = reduce_goal [] goal (TRY (REPEAT_ALL_NEW (resolve_tac rules) 1)) ctxt
+          val reduced_assm =
+            reduce_goal [] goal (TRY (REPEAT_ALL_NEW (resolve_tac ctxt rules) 1)) ctxt
         in
           reduced_assm RS thm
         end
--- a/src/HOL/Tools/Lifting/lifting_term.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/Lifting/lifting_term.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -473,7 +473,7 @@
       fun prove_extra_assms ctxt ctm distr_rule =
         let
           fun prove_assm assm = try (Goal.prove ctxt [] [] (term_of assm))
-            (fn _ => SOLVED' (REPEAT_ALL_NEW (resolve_tac (Transfer.get_transfer_raw ctxt))) 1)
+            (fn _ => SOLVED' (REPEAT_ALL_NEW (resolve_tac ctxt (Transfer.get_transfer_raw ctxt))) 1)
   
           fun is_POS_or_NEG ctm =
             case (head_of o term_of o Thm.dest_arg) ctm of
--- a/src/HOL/Tools/Meson/meson.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/Meson/meson.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -170,14 +170,14 @@
    property of the form "... c ... c ... c ..." will lead to a huge unification
    problem, due to the (spurious) choices between projection and imitation. The
    workaround is to instantiate "?P := (%c. ... c ... c ... c ...)" manually. *)
-fun quant_resolve_tac th i st =
+fun quant_resolve_tac ctxt th i st =
   case (concl_of st, prop_of th) of
     (@{const Trueprop} $ (Var _ $ (c as Free _)), @{const Trueprop} $ _) =>
     let
       val cc = cterm_of (theory_of_thm th) c
       val ct = Thm.dest_arg (cprop_of th)
-    in resolve_tac [th] i (Drule.instantiate' [] [SOME (Thm.lambda cc ct)] st) end
-  | _ => resolve_tac [th] i st
+    in resolve_tac ctxt [th] i (Drule.instantiate' [] [SOME (Thm.lambda cc ct)] st) end
+  | _ => resolve_tac ctxt [th] i st
 
 (*Permits forward proof from rules that discharge assumptions. The supplied proof state st,
   e.g. from conj_forward, should have the form
@@ -185,7 +185,7 @@
   and the effect should be to instantiate ?P and ?Q with normalized versions of P' and Q'.*)
 fun forward_res ctxt nf st =
   let
-    fun tacf [prem] = quant_resolve_tac (nf prem) 1
+    fun tacf [prem] = quant_resolve_tac ctxt (nf prem) 1
       | tacf prems =
         error (cat_lines
           ("Bad proof state in forward_res, please inform lcp@cl.cam.ac.uk:" ::
@@ -287,7 +287,7 @@
   case Seq.pull
         (REPEAT
          (Misc_Legacy.METAHYPS ctxt
-           (fn major::minors => resolve_tac [nf (minors @ hyps) major] 1) 1)
+           (fn major::minors => resolve_tac ctxt [nf (minors @ hyps) major] 1) 1)
          st)
   of SOME(th,_) => th
    | NONE => raise THM("forward_res2", 0, [st]);
@@ -390,7 +390,7 @@
                 cnf_nil. The normal form is given to resolve_tac, instantiate a Boolean
                 variable created by resolution with disj_forward. Since (cnf_nil prem)
                 returns a LIST of theorems, we can backtrack to get all combinations.*)
-              let val tac = Misc_Legacy.METAHYPS ctxt (fn [prem] => resolve_tac (cnf_nil prem) 1) 1
+              let val tac = Misc_Legacy.METAHYPS ctxt (fn [prem] => resolve_tac ctxt (cnf_nil prem) 1) 1
               in  Seq.list_of ((tac THEN tac) (th RS disj_forward)) @ ths  end
           | _ => nodups ctxt th :: ths  (*no work to do*)
       and cnf_nil th = cnf_aux (th, [])
@@ -500,7 +500,7 @@
 
 (* resolve_from_net_tac actually made it slower... *)
 fun prolog_step_tac ctxt horns i =
-    (assume_tac ctxt i APPEND resolve_tac horns i) THEN check_tac THEN
+    (assume_tac ctxt i APPEND resolve_tac ctxt horns i) THEN check_tac THEN
     TRYALL_eq_assume_tac;
 
 (*Sums the sizes of the subgoals, ignoring hypotheses (ancestors)*)
@@ -698,14 +698,14 @@
 fun gocls cls = name_thms "Goal#" (map make_goal (neg_clauses cls));
 
 fun skolemize_prems_tac ctxt prems =
-  cut_facts_tac (maps (try_skolemize_etc ctxt) prems) THEN' REPEAT o eresolve_tac [exE]
+  cut_facts_tac (maps (try_skolemize_etc ctxt) prems) THEN' REPEAT o eresolve_tac ctxt [exE]
 
 (*Basis of all meson-tactics.  Supplies cltac with clauses: HOL disjunctions.
   Function mkcl converts theorems to clauses.*)
 fun MESON preskolem_tac mkcl cltac ctxt i st =
   SELECT_GOAL
     (EVERY [Object_Logic.atomize_prems_tac ctxt 1,
-            resolve_tac @{thms ccontr} 1,
+            resolve_tac ctxt @{thms ccontr} 1,
             preskolem_tac,
             Subgoal.FOCUS (fn {context = ctxt', prems = negs, ...} =>
                       EVERY1 [skolemize_prems_tac ctxt negs,
@@ -719,7 +719,7 @@
 fun best_meson_tac sizef ctxt =
   MESON all_tac (make_clauses ctxt)
     (fn cls =>
-         THEN_BEST_FIRST (resolve_tac (gocls cls) 1)
+         THEN_BEST_FIRST (resolve_tac ctxt (gocls cls) 1)
                          (has_fewer_prems 1, sizef)
                          (prolog_step_tac ctxt (make_horns cls) 1))
     ctxt
@@ -732,7 +732,7 @@
 
 fun depth_meson_tac ctxt =
   MESON all_tac (make_clauses ctxt)
-    (fn cls => EVERY [resolve_tac (gocls cls) 1, depth_prolog_tac ctxt (make_horns cls)])
+    (fn cls => EVERY [resolve_tac ctxt (gocls cls) 1, depth_prolog_tac ctxt (make_horns cls)])
     ctxt
 
 (** Iterative deepening version **)
@@ -764,7 +764,7 @@
               ["clauses:"] @ map (Display.string_of_thm ctxt) horns))
         in
           THEN_ITER_DEEPEN iter_deepen_limit
-            (resolve_tac goes 1) (has_fewer_prems 1) (prolog_step_tac' ctxt horns)
+            (resolve_tac ctxt goes 1) (has_fewer_prems 1) (prolog_step_tac' ctxt horns)
         end));
 
 fun meson_tac ctxt ths =
--- a/src/HOL/Tools/Meson/meson_clausify.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/Meson/meson_clausify.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -208,7 +208,7 @@
       |> Drule.beta_conv cabs |> Thm.apply cTrueprop
     fun tacf [prem] =
       rewrite_goals_tac ctxt @{thms skolem_def [abs_def]}
-      THEN resolve_tac [(prem |> rewrite_rule ctxt @{thms skolem_def [abs_def]})
+      THEN resolve_tac ctxt [(prem |> rewrite_rule ctxt @{thms skolem_def [abs_def]})
                  RS Global_Theory.get_thm thy "Hilbert_Choice.someI_ex"] 1
   in
     Goal.prove_internal ctxt [ex_tm] conc tacf
--- a/src/HOL/Tools/Metis/metis_reconstruct.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/Metis/metis_reconstruct.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -530,17 +530,19 @@
 
 val copy_prem = @{lemma "P ==> (P ==> P ==> Q) ==> Q" by fast}
 
-fun copy_prems_tac [] ns i =
-    if forall (curry (op =) 1) ns then all_tac else copy_prems_tac (rev ns) [] i
-  | copy_prems_tac (1 :: ms) ns i = rotate_tac 1 i THEN copy_prems_tac ms (1 :: ns) i
-  | copy_prems_tac (m :: ms) ns i =
-    eresolve_tac [copy_prem] i THEN copy_prems_tac ms (m div 2 :: (m + 1) div 2 :: ns) i
+fun copy_prems_tac ctxt [] ns i =
+    if forall (curry (op =) 1) ns then all_tac else copy_prems_tac ctxt (rev ns) [] i
+  | copy_prems_tac ctxt (1 :: ms) ns i = rotate_tac 1 i THEN copy_prems_tac ctxt ms (1 :: ns) i
+  | copy_prems_tac ctxt (m :: ms) ns i =
+    eresolve_tac ctxt [copy_prem] i THEN copy_prems_tac ctxt ms (m div 2 :: (m + 1) div 2 :: ns) i
 
 (* Metis generates variables of the form _nnn. *)
 val is_metis_fresh_variable = String.isPrefix "_"
 
-fun instantiate_forall_tac thy t i st =
+fun instantiate_forall_tac ctxt t i st =
   let
+    val thy = Proof_Context.theory_of ctxt
+
     val params = Logic.strip_params (Logic.get_goal (prop_of st) i) |> rev
 
     fun repair (t as (Var ((s, _), _))) =
@@ -581,16 +583,16 @@
         end
       | _ => raise Fail "expected a single non-zapped, non-Metis Var")
   in
-    (DETERM (eresolve_tac @{thms allE} i THEN rotate_tac ~1 i) THEN PRIMITIVE do_instantiate) st
+    (DETERM (eresolve_tac ctxt @{thms allE} i THEN rotate_tac ~1 i) THEN PRIMITIVE do_instantiate) st
   end
 
-fun fix_exists_tac t = eresolve_tac [exE] THEN' rename_tac [t |> dest_Var |> fst |> fst]
+fun fix_exists_tac ctxt t = eresolve_tac ctxt [exE] THEN' rename_tac [t |> dest_Var |> fst |> fst]
 
-fun release_quantifier_tac thy (skolem, t) =
-  (if skolem then fix_exists_tac else instantiate_forall_tac thy) t
+fun release_quantifier_tac ctxt (skolem, t) =
+  (if skolem then fix_exists_tac ctxt else instantiate_forall_tac ctxt) t
 
 fun release_clusters_tac _ _ _ [] = K all_tac
-  | release_clusters_tac thy ax_counts substs ((ax_no, cluster_no) :: clusters) =
+  | release_clusters_tac ctxt ax_counts substs ((ax_no, cluster_no) :: clusters) =
     let
       val cluster_of_var = Meson_Clausify.cluster_of_zapped_var_name o fst o fst o dest_Var
       fun in_right_cluster ((_, (cluster_no', _)), _) = cluster_no' = cluster_no
@@ -605,13 +607,13 @@
                           else
                             NONE)
       fun do_cluster_subst cluster_subst =
-        map (release_quantifier_tac thy) cluster_subst @ [rotate_tac 1]
+        map (release_quantifier_tac ctxt) cluster_subst @ [rotate_tac 1]
       val first_prem = find_index (fn (ax_no', _) => ax_no' = ax_no) substs
     in
       rotate_tac first_prem
       THEN' (EVERY' (maps do_cluster_subst cluster_substs))
       THEN' rotate_tac (~ first_prem - length cluster_substs)
-      THEN' release_clusters_tac thy ax_counts substs clusters
+      THEN' release_clusters_tac ctxt ax_counts substs clusters
     end
 
 fun cluster_key ((ax_no, (cluster_no, index_no)), skolem) =
@@ -731,21 +733,20 @@
       val _ = tracing ("SUBSTS (" ^ string_of_int (length substs) ^ "):\n" ^
                        cat_lines (map string_of_subst_info substs))
 *)
+      val ctxt' = fold Thm.declare_hyps (#hyps (Thm.crep_thm prems_imp_false)) ctxt
 
       fun cut_and_ex_tac axiom =
-        cut_tac axiom 1 THEN TRY (REPEAT_ALL_NEW (eresolve_tac @{thms exE}) 1)
+        cut_tac axiom 1 THEN TRY (REPEAT_ALL_NEW (eresolve_tac ctxt' @{thms exE}) 1)
       fun rotation_of_subgoal i =
         find_index (fn (_, (subgoal_no, _)) => subgoal_no = i) substs
-
-      val ctxt' = fold Thm.declare_hyps (#hyps (Thm.crep_thm prems_imp_false)) ctxt
     in
       Goal.prove ctxt' [] [] @{prop False}
         (K (DETERM (EVERY (map (cut_and_ex_tac o fst o the o nth axioms o fst o fst) ax_counts)
               THEN rename_tac outer_param_names 1
-              THEN copy_prems_tac (map snd ax_counts) [] 1)
-            THEN release_clusters_tac thy ax_counts substs ordered_clusters 1
+              THEN copy_prems_tac ctxt' (map snd ax_counts) [] 1)
+            THEN release_clusters_tac ctxt' ax_counts substs ordered_clusters 1
             THEN match_tac ctxt' [prems_imp_false] 1
-            THEN ALLGOALS (fn i => resolve_tac @{thms Meson.skolem_COMBK_I} i
+            THEN ALLGOALS (fn i => resolve_tac ctxt' @{thms Meson.skolem_COMBK_I} i
               THEN rotate_tac (rotation_of_subgoal i) i
               THEN PRIMITIVE (unify_first_prem_with_concl thy i)
               THEN assume_tac ctxt' i
--- a/src/HOL/Tools/Metis/metis_tactic.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/Metis/metis_tactic.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -61,7 +61,7 @@
 fun lam_lifted_of_metis ctxt type_enc sym_tab concealed mth =
   let
     val thy = Proof_Context.theory_of ctxt
-    val tac = rewrite_goals_tac ctxt @{thms lambda_def [abs_def]} THEN resolve_tac [refl] 1
+    val tac = rewrite_goals_tac ctxt @{thms lambda_def [abs_def]} THEN resolve_tac ctxt [refl] 1
     val t = hol_clause_of_metis ctxt type_enc sym_tab concealed mth
     val ct = cterm_of thy (HOLogic.mk_Trueprop t)
   in Goal.prove_internal ctxt [] ct (K tac) |> Meson.make_meta_clause end
@@ -102,7 +102,7 @@
          so that "Thm.equal_elim" works below. *)
       val t0 $ _ $ t2 = prop_of eq_th
       val eq_ct = t0 $ prop_of th $ t2 |> cterm_of thy
-      val eq_th' = Goal.prove_internal ctxt [] eq_ct (K (resolve_tac [eq_th] 1))
+      val eq_th' = Goal.prove_internal ctxt [] eq_ct (K (resolve_tac ctxt [eq_th] 1))
     in Thm.equal_elim eq_th' th end
 
 fun clause_params ordering =
@@ -257,7 +257,7 @@
       "Metis called with theorems\n" ^ cat_lines (map (Display.string_of_thm ctxt) ths))
     val type_encs = type_encs |> maps unalias_type_enc
     val combs = (lam_trans = combsN)
-    fun tac clause = resolve_tac (FOL_SOLVE unused type_encs lam_trans ctxt clause ths) 1
+    fun tac clause = resolve_tac ctxt (FOL_SOLVE unused type_encs lam_trans ctxt clause ths) 1
     val seq = Meson.MESON (preskolem_tac ctxt) (maps (neg_clausify ctxt combs)) tac ctxt i st0
   in
     (!unused, seq)
--- a/src/HOL/Tools/Old_Datatype/old_datatype.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/Old_Datatype/old_datatype.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -188,9 +188,9 @@
         (fn (((name, mx), tvs), c) =>
           Typedef.add_typedef_global false (name, tvs, mx)
             (Collect $ Const (c, UnivT')) NONE
-            (fn _ => rtac exI 1 THEN rtac CollectI 1 THEN
+            (fn ctxt => rtac exI 1 THEN rtac CollectI 1 THEN
               QUIET_BREADTH_FIRST (has_fewer_prems 1)
-              (resolve_tac rep_intrs 1)))
+              (resolve_tac ctxt rep_intrs 1)))
         (types_syntax ~~ tyvars ~~ take (length newTs) rep_set_names)
       ||> Sign.add_path big_name;
 
@@ -425,15 +425,15 @@
                   REPEAT (EVERY
                     [hyp_subst_tac ctxt 1,
                      rewrite_goals_tac ctxt rewrites,
-                     REPEAT (dresolve_tac [In0_inject, In1_inject] 1),
-                     (eresolve_tac [In0_not_In1 RS notE, In1_not_In0 RS notE] 1)
+                     REPEAT (dresolve_tac ctxt [In0_inject, In1_inject] 1),
+                     (eresolve_tac ctxt [In0_not_In1 RS notE, In1_not_In0 RS notE] 1)
                      ORELSE (EVERY
-                       [REPEAT (eresolve_tac (Scons_inject ::
+                       [REPEAT (eresolve_tac ctxt (Scons_inject ::
                           map make_elim [Leaf_inject, Inl_inject, Inr_inject]) 1),
                         REPEAT (cong_tac ctxt 1), rtac refl 1,
                         REPEAT (assume_tac ctxt 1 ORELSE (EVERY
                           [REPEAT (rtac @{thm ext} 1),
-                           REPEAT (eresolve_tac (mp :: allE ::
+                           REPEAT (eresolve_tac ctxt (mp :: allE ::
                              map make_elim (Suml_inject :: Sumr_inject ::
                                Lim_inject :: inj_thms') @ fun_congs) 1),
                            assume_tac ctxt 1]))])])])]);
@@ -447,7 +447,7 @@
               EVERY [
                 (Old_Datatype_Aux.ind_tac induct [] THEN_ALL_NEW Object_Logic.atomize_prems_tac ctxt) 1,
                 rewrite_goals_tac ctxt rewrites,
-                REPEAT ((resolve_tac rep_intrs THEN_ALL_NEW
+                REPEAT ((resolve_tac ctxt rep_intrs THEN_ALL_NEW
                   ((REPEAT o etac allE) THEN' ares_tac elem_thms)) 1)]);
 
       in (inj_thms'' @ inj_thms, elem_thms @ Old_Datatype_Aux.split_conj_thm elem_thm) end;
@@ -488,11 +488,11 @@
                 Thm.symmetric (mk_meta_eq @{thm fun_eq_iff}) :: range_eqs),
               rewrite_goals_tac ctxt (map Thm.symmetric range_eqs),
               REPEAT (EVERY
-                [REPEAT (eresolve_tac ([rangeE, @{thm ex1_implies_ex} RS exE] @
+                [REPEAT (eresolve_tac ctxt ([rangeE, @{thm ex1_implies_ex} RS exE] @
                    maps (mk_funs_inv thy5 o #1) newT_iso_axms) 1),
                  TRY (hyp_subst_tac ctxt 1),
                  rtac (sym RS range_eqI) 1,
-                 resolve_tac iso_char_thms 1])])));
+                 resolve_tac ctxt iso_char_thms 1])])));
 
     val Abs_inverse_thms' =
       map #1 newT_iso_axms @
@@ -514,11 +514,11 @@
       in
         Goal.prove_sorry_global thy5 [] [] eqn
         (fn {context = ctxt, ...} => EVERY
-          [resolve_tac inj_thms 1,
+          [resolve_tac ctxt inj_thms 1,
            rewrite_goals_tac ctxt rewrites,
            rtac refl 3,
-           resolve_tac rep_intrs 2,
-           REPEAT (resolve_tac iso_elem_thms 1)])
+           resolve_tac ctxt rep_intrs 2,
+           REPEAT (resolve_tac ctxt iso_elem_thms 1)])
       end;
 
     (*--------------------------------------------------------------*)
@@ -560,11 +560,11 @@
           (fn {context = ctxt, ...} => EVERY
             [rtac iffI 1,
              REPEAT (etac conjE 2), hyp_subst_tac ctxt 2, rtac refl 2,
-             dresolve_tac rep_congs 1, dtac @{thm box_equals} 1,
-             REPEAT (resolve_tac rep_thms 1),
-             REPEAT (eresolve_tac inj_thms 1),
+             dresolve_tac ctxt rep_congs 1, dtac @{thm box_equals} 1,
+             REPEAT (resolve_tac ctxt rep_thms 1),
+             REPEAT (eresolve_tac ctxt inj_thms 1),
              REPEAT (ares_tac [conjI] 1 ORELSE (EVERY [REPEAT (rtac @{thm ext} 1),
-               REPEAT (eresolve_tac (make_elim fun_cong :: inj_thms) 1),
+               REPEAT (eresolve_tac ctxt (make_elim fun_cong :: inj_thms) 1),
                assume_tac ctxt 1]))])
       end;
 
@@ -616,12 +616,12 @@
         (Logic.mk_implies
           (HOLogic.mk_Trueprop (Old_Datatype_Aux.mk_conj indrule_lemma_prems),
            HOLogic.mk_Trueprop (Old_Datatype_Aux.mk_conj indrule_lemma_concls)))
-        (fn _ =>
+        (fn {context = ctxt, ...} =>
           EVERY
            [REPEAT (etac conjE 1),
             REPEAT (EVERY
-              [TRY (rtac conjI 1), resolve_tac Rep_inverse_thms 1,
-               etac mp 1, resolve_tac iso_elem_thms 1])]);
+              [TRY (rtac conjI 1), resolve_tac ctxt Rep_inverse_thms 1,
+               etac mp 1, resolve_tac ctxt iso_elem_thms 1])]);
 
     val Ps = map head_of (HOLogic.dest_conj (HOLogic.dest_Trueprop (concl_of indrule_lemma)));
     val frees =
@@ -640,7 +640,7 @@
            (Old_Datatype_Aux.ind_tac rep_induct [] THEN_ALL_NEW
               Object_Logic.atomize_prems_tac ctxt) 1,
            EVERY (map (fn (prem, r) => (EVERY
-             [REPEAT (eresolve_tac Abs_inverse_thms 1),
+             [REPEAT (eresolve_tac ctxt Abs_inverse_thms 1),
               simp_tac (put_simpset HOL_basic_ss ctxt
                 addsimps (Thm.symmetric r :: Rep_inverse_thms')) 1,
               DEPTH_SOLVE_1 (ares_tac [prem] 1 ORELSE etac allE 1)]))
--- a/src/HOL/Tools/Old_Datatype/old_datatype_aux.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/Old_Datatype/old_datatype_aux.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -150,7 +150,7 @@
           NONE => NONE
         | SOME u' => SOME (t |> getP |> snd |> head_of |> cert, cert u'))) (ts ~~ ts');
     val indrule' = cterm_instantiate insts indrule;
-  in resolve_tac [indrule'] i end);
+  in resolve0_tac [indrule'] i end);
 
 
 (* perform exhaustive case analysis on last parameter of subgoal i *)
--- a/src/HOL/Tools/Old_Datatype/old_primrec.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/Old_Datatype/old_primrec.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -248,7 +248,7 @@
       in
         map (fn eq => Goal.prove ctxt frees [] eq
           (fn {context = ctxt', ...} =>
-            EVERY [rewrite_goals_tac ctxt' rewrites, resolve_tac [refl] 1])) eqs
+            EVERY [rewrite_goals_tac ctxt' rewrites, resolve_tac ctxt' [refl] 1])) eqs
       end;
   in ((prefix, (fs, defs)), prove) end
   handle PrimrecError (msg, some_eqn) =>
--- a/src/HOL/Tools/Old_Datatype/old_rep_datatype.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/Old_Datatype/old_rep_datatype.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -55,12 +55,12 @@
         Goal.prove_sorry_global thy []
           (Logic.strip_imp_prems t)
           (Logic.strip_imp_concl t)
-          (fn {prems, ...} =>
+          (fn {context = ctxt, prems, ...} =>
             EVERY
-              [resolve_tac [induct'] 1,
-               REPEAT (resolve_tac [TrueI] 1),
-               REPEAT ((resolve_tac [impI] 1) THEN (eresolve_tac prems 1)),
-               REPEAT (resolve_tac [TrueI] 1)])
+              [resolve_tac ctxt [induct'] 1,
+               REPEAT (resolve_tac ctxt [TrueI] 1),
+               REPEAT ((resolve_tac ctxt [impI] 1) THEN (eresolve_tac ctxt prems 1)),
+               REPEAT (resolve_tac ctxt [TrueI] 1)])
       end;
 
     val casedist_thms =
@@ -176,16 +176,17 @@
           in
             (EVERY
               [DETERM tac,
-                REPEAT (eresolve_tac @{thms ex1E} 1), resolve_tac @{thms ex1I} 1,
+                REPEAT (eresolve_tac ctxt @{thms ex1E} 1), resolve_tac ctxt @{thms ex1I} 1,
                 DEPTH_SOLVE_1 (ares_tac [intr] 1),
-                REPEAT_DETERM_N k (eresolve_tac [thin_rl] 1 THEN rotate_tac 1 1),
-                eresolve_tac [elim] 1,
+                REPEAT_DETERM_N k (eresolve_tac ctxt [thin_rl] 1 THEN rotate_tac 1 1),
+                eresolve_tac ctxt [elim] 1,
                 REPEAT_DETERM_N j distinct_tac,
-                TRY (dresolve_tac inject 1),
-                REPEAT (eresolve_tac [conjE] 1), hyp_subst_tac ctxt 1,
-                REPEAT (EVERY [eresolve_tac [allE] 1, dresolve_tac [mp] 1, assume_tac ctxt 1]),
+                TRY (dresolve_tac ctxt inject 1),
+                REPEAT (eresolve_tac ctxt [conjE] 1), hyp_subst_tac ctxt 1,
+                REPEAT
+                  (EVERY [eresolve_tac ctxt [allE] 1, dresolve_tac ctxt [mp] 1, assume_tac ctxt 1]),
                 TRY (hyp_subst_tac ctxt 1),
-                resolve_tac [refl] 1,
+                resolve_tac ctxt [refl] 1,
                 REPEAT_DETERM_N (n - j - 1) distinct_tac],
               intrs, j + 1)
           end;
@@ -211,7 +212,7 @@
           (HOLogic.mk_Trueprop (Old_Datatype_Aux.mk_conj rec_unique_ts))
           (fn {context = ctxt, ...} =>
             #1 (fold (mk_unique_tac ctxt) (descr' ~~ rec_elims ~~ recTs ~~ rec_result_Ts)
-              (((resolve_tac [induct'] THEN_ALL_NEW Object_Logic.atomize_prems_tac ctxt) 1 THEN
+              (((resolve_tac ctxt [induct'] THEN_ALL_NEW Object_Logic.atomize_prems_tac ctxt) 1 THEN
                   rewrite_goals_tac ctxt [mk_meta_eq @{thm choice_eq}], rec_intrs)))))
       end;
 
@@ -254,10 +255,10 @@
         Goal.prove_sorry_global thy2 [] [] t
           (fn {context = ctxt, ...} => EVERY
             [rewrite_goals_tac ctxt reccomb_defs,
-             resolve_tac @{thms the1_equality} 1,
-             resolve_tac rec_unique_thms 1,
-             resolve_tac rec_intrs 1,
-             REPEAT (resolve_tac [allI] 1 ORELSE resolve_tac rec_total_thms 1)]))
+             resolve_tac ctxt @{thms the1_equality} 1,
+             resolve_tac ctxt rec_unique_thms 1,
+             resolve_tac ctxt rec_intrs 1,
+             REPEAT (resolve_tac ctxt [allI] 1 ORELSE resolve_tac ctxt rec_total_thms 1)]))
        (Old_Datatype_Prop.make_primrecs reccomb_names descr thy2);
   in
     thy2
@@ -339,7 +340,7 @@
     fun prove_case t =
       Goal.prove_sorry_global thy2 [] [] t (fn {context = ctxt, ...} =>
         EVERY [rewrite_goals_tac ctxt (case_defs @ map mk_meta_eq primrec_thms),
-          resolve_tac [refl] 1]);
+          resolve_tac ctxt [refl] 1]);
 
     fun prove_cases (Type (Tcon, _)) ts =
       (case Ctr_Sugar.ctr_sugar_of ctxt Tcon of
@@ -380,7 +381,7 @@
         val _ $ (_ $ lhs $ _) = hd (Logic.strip_assums_hyp (hd (prems_of exhaustion)));
         val exhaustion' = cterm_instantiate [(cert lhs, cert (Free ("x", T)))] exhaustion;
         fun tac ctxt =
-          EVERY [resolve_tac [exhaustion'] 1,
+          EVERY [resolve_tac ctxt [exhaustion'] 1,
             ALLGOALS (asm_simp_tac
               (put_simpset HOL_ss ctxt addsimps (dist_rewrites' @ inject @ case_thms')))];
       in
@@ -406,7 +407,8 @@
   let
     fun prove_case_cong_weak t =
      Goal.prove_sorry_global thy [] (Logic.strip_imp_prems t) (Logic.strip_imp_concl t)
-       (fn {prems, ...} => EVERY [resolve_tac [hd prems RS arg_cong] 1]);
+       (fn {context = ctxt, prems, ...} =>
+         EVERY [resolve_tac ctxt [hd prems RS arg_cong] 1]);
 
     val case_cong_weaks =
       map prove_case_cong_weak (Old_Datatype_Prop.make_case_cong_weaks case_names descr thy);
@@ -424,13 +426,13 @@
       let
         (* For goal i, select the correct disjunct to attack, then prove it *)
         fun tac ctxt i 0 =
-              EVERY [TRY (resolve_tac [disjI1] i), hyp_subst_tac ctxt i,
-                REPEAT (resolve_tac [exI] i), resolve_tac [refl] i]
-          | tac ctxt i n = resolve_tac [disjI2] i THEN tac ctxt i (n - 1);
+              EVERY [TRY (resolve_tac ctxt [disjI1] i), hyp_subst_tac ctxt i,
+                REPEAT (resolve_tac ctxt [exI] i), resolve_tac ctxt [refl] i]
+          | tac ctxt i n = resolve_tac ctxt [disjI2] i THEN tac ctxt i (n - 1);
       in
         Goal.prove_sorry_global thy [] [] t
           (fn {context = ctxt, ...} =>
-            EVERY [resolve_tac [allI] 1,
+            EVERY [resolve_tac ctxt [allI] 1,
              Old_Datatype_Aux.exh_tac ctxt (K exhaustion) 1,
              ALLGOALS (fn i => tac ctxt i (i - 1))])
       end;
@@ -459,8 +461,9 @@
               EVERY [
                 simp_tac (put_simpset HOL_ss ctxt addsimps [hd prems]) 1,
                 cut_tac nchotomy'' 1,
-                REPEAT (eresolve_tac [disjE] 1 THEN REPEAT (eresolve_tac [exE] 1) THEN simplify 1),
-                REPEAT (eresolve_tac [exE] 1) THEN simplify 1 (* Get last disjunct *)]
+                REPEAT (eresolve_tac ctxt [disjE] 1 THEN
+                  REPEAT (eresolve_tac ctxt [exE] 1) THEN simplify 1),
+                REPEAT (eresolve_tac ctxt [exE] 1) THEN simplify 1 (* Get last disjunct *)]
             end)
       end;
 
--- a/src/HOL/Tools/Old_Datatype/old_size.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/Old_Datatype/old_size.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -131,7 +131,7 @@
           ||> Class.instantiation (tycos, map dest_TFree paramTs, [HOLogic.class_size])
           ||>> fold_map define_overloaded
             (def_names' ~~ map Logic.mk_equals (overloaded_size_fns ~~ map (app fs') rec_combs1))
-          ||> Class.prove_instantiation_instance (K (Class.intro_classes_tac []))
+          ||> Class.prove_instantiation_instance (fn ctxt => Class.intro_classes_tac ctxt [])
           ||> Local_Theory.exit_global;
 
         val ctxt = Proof_Context.init_global thy';
--- a/src/HOL/Tools/Predicate_Compile/core_data.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/Predicate_Compile/core_data.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -9,7 +9,7 @@
   type mode = Predicate_Compile_Aux.mode
   type compilation = Predicate_Compile_Aux.compilation
   type compilation_funs = Predicate_Compile_Aux.compilation_funs
-  
+
   datatype predfun_data = PredfunData of {
     definition : thm,
     intro : thm,
@@ -28,21 +28,21 @@
   };
 
   structure PredData : THEORY_DATA  (* FIXME keep data private *)
-  
+
   (* queries *)
   val defined_functions : compilation -> Proof.context -> string -> bool
   val is_registered : Proof.context -> string -> bool
   val function_name_of : compilation -> Proof.context -> string -> mode -> string
   val the_elim_of : Proof.context -> string -> thm
   val has_elim : Proof.context -> string -> bool
-  
+
   val needs_random : Proof.context -> string -> mode -> bool
-  
+
   val predfun_intro_of : Proof.context -> string -> mode -> thm
   val predfun_neg_intro_of : Proof.context -> string -> mode -> thm option
   val predfun_elim_of : Proof.context -> string -> mode -> thm
   val predfun_definition_of : Proof.context -> string -> mode -> thm
-  
+
   val all_preds_of : Proof.context -> string list
   val modes_of: compilation -> Proof.context -> string -> mode list
   val all_modes_of : compilation -> Proof.context -> (string * mode list) list
@@ -51,9 +51,9 @@
   val names_of : Proof.context -> string -> string option list
 
   val intros_graph_of : Proof.context -> thm list Graph.T
-  
+
   (* updaters *)
-  
+
   val register_predicate : (string * thm list * thm) -> theory -> theory
   val register_intros : string * thm list -> theory -> theory
 
@@ -67,7 +67,7 @@
   (* sophisticated updaters *)
   val extend_intro_graph : string list -> theory -> theory
   val preprocess_intros : string -> theory -> theory
-  
+
   (* alternative function definitions *)
   val register_alternative_function : string -> mode -> string -> theory -> theory
   val alternative_compilation_of_global : theory -> string -> mode ->
@@ -127,7 +127,7 @@
   | eq_option eq (SOME x, SOME y) = eq (x, y)
   | eq_option eq _ = false
 
-fun eq_pred_data (PredData d1, PredData d2) = 
+fun eq_pred_data (PredData d1, PredData d2) =
   eq_list (eq_pair (op =) Thm.eq_thm) (#intros d1, #intros d2) andalso
   eq_option Thm.eq_thm (#elim d1, #elim d2)
 
@@ -153,7 +153,7 @@
 
 fun the_pred_data ctxt name =
   (case lookup_pred_data ctxt name of
-    NONE => error ("No such predicate: " ^ quote name)  
+    NONE => error ("No such predicate: " ^ quote name)
   | SOME data => data)
 
 val is_registered = is_some oo lookup_pred_data
@@ -168,7 +168,7 @@
   (case #elim (the_pred_data ctxt name) of
     NONE => error ("No elimination rule for predicate " ^ quote name)
   | SOME thm => thm)
-  
+
 val has_elim = is_some o #elim oo the_pred_data
 
 fun function_names_of compilation ctxt name =
@@ -227,38 +227,38 @@
   let
     val thy = Proof_Context.theory_of ctxt
     val nargs = length (binder_types (fastype_of pred))
-    fun PEEK f dependent_tactic st = dependent_tactic (f st) st
     fun meta_eq_of th = th RS @{thm eq_reflection}
     val tuple_rew_rules = map meta_eq_of [@{thm fst_conv}, @{thm snd_conv}, @{thm Pair_eq}]
-    fun instantiate i n {prems, ...} =
+
+    fun instantiate i n ({context = ctxt2, prems, ...}: Subgoal.focus) =
       let
-        fun term_pair_of (ix, (ty,t)) = (Var (ix,ty), t)
-        fun inst_of_matches tts = fold (Pattern.match thy) tts (Vartab.empty, Vartab.empty)
+        fun term_pair_of (ix, (ty, t)) = (Var (ix, ty), t)
+        fun inst_of_matches tts =
+          fold (Pattern.match thy) tts (Vartab.empty, Vartab.empty)
           |> snd |> Vartab.dest |> map (apply2 (cterm_of thy) o term_pair_of)
-        val (cases, (eqs, prems)) = apsnd (chop (nargs - nparams)) (chop n prems)
+        val (cases, (eqs, prems1)) = apsnd (chop (nargs - nparams)) (chop n prems)
         val case_th =
-          rewrite_rule ctxt (@{thm Predicate.eq_is_eq} :: map meta_eq_of eqs) (nth cases (i - 1))
-        val prems' = maps (dest_conjunct_prem o rewrite_rule ctxt tuple_rew_rules) prems
+          rewrite_rule ctxt2 (@{thm Predicate.eq_is_eq} :: map meta_eq_of eqs) (nth cases (i - 1))
+        val prems2 = maps (dest_conjunct_prem o rewrite_rule ctxt2 tuple_rew_rules) prems1
         val pats =
-          map (swap o HOLogic.dest_eq o HOLogic.dest_Trueprop) (take nargs (prems_of case_th))
-        val case_th' = Thm.instantiate ([], inst_of_matches pats) case_th
-          OF (replicate nargs @{thm refl})
+          map (swap o HOLogic.dest_eq o HOLogic.dest_Trueprop)
+            (take nargs (Thm.prems_of case_th))
+        val case_th' =
+          Thm.instantiate ([], inst_of_matches pats) case_th
+            OF replicate nargs @{thm refl}
         val thesis =
-          Thm.instantiate ([], inst_of_matches (prems_of case_th' ~~ map prop_of prems')) case_th'
-            OF prems'
-      in
-        (rtac thesis 1)
-      end
-    val tac =
-      etac pre_cases_rule 1
-      THEN
-      (PEEK nprems_of
-        (fn n =>
-          ALLGOALS (fn i =>
-            rewrite_goal_tac ctxt [@{thm split_paired_all}] i
-            THEN (SUBPROOF (instantiate i n) ctxt i))))
+          Thm.instantiate ([], inst_of_matches (prems_of case_th' ~~ map prop_of prems2)) case_th'
+            OF prems2
+      in rtac thesis 1 end
   in
-    Goal.prove ctxt (Term.add_free_names cases_rule []) [] cases_rule (fn _ => tac)
+    Goal.prove ctxt (Term.add_free_names cases_rule []) [] cases_rule
+      (fn {context = ctxt1, ...} =>
+        eresolve_tac ctxt1 [pre_cases_rule] 1 THEN (fn st =>
+          let val n = Thm.nprems_of st in
+            st |> ALLGOALS (fn i =>
+              rewrite_goal_tac ctxt1 @{thms split_paired_all} i THEN
+              SUBPROOF (instantiate i n) ctxt1 i)
+          end))
   end
 
 
@@ -270,7 +270,7 @@
 
 fun fetch_pred_data ctxt name =
   (case try (Inductive.the_inductive ctxt) name of
-    SOME (info as (_, result)) => 
+    SOME (info as (_, result)) =>
       let
         val thy = Proof_Context.theory_of ctxt
 
@@ -357,7 +357,7 @@
           commas (map constname_of_intro pre_intros))
       else ()
     val pred = Const (constname, T)
-    val pre_elim = 
+    val pre_elim =
       (Drule.export_without_context o Skip_Proof.make_thm thy)
       (mk_casesrule (Proof_Context.init_global thy) pred pre_intros)
   in register_predicate (constname, pre_intros, pre_elim) thy end
@@ -382,7 +382,7 @@
     val set = (apsnd o apsnd o apsnd o apsnd) (K modes)
   in
     PredData.map (Graph.map_node name (map_pred_data set))
-  end  
+  end
 
 fun extend' value_of edges_of key (G, visited) =
   let
@@ -398,7 +398,7 @@
     (fold (Graph.add_edge o (pair key)) (edges_of (key, v)) G'', visited')
   end;
 
-fun extend value_of edges_of key G = fst (extend' value_of edges_of key (G, [])) 
+fun extend value_of edges_of key G = fst (extend' value_of edges_of key (G, []))
 
 fun extend_intro_graph names thy =
   let
@@ -421,7 +421,7 @@
       in
         ((named_intros', SOME elim'), true)
       end)))))
-    thy  
+    thy
 
 
 (* registration of alternative function names *)
--- a/src/HOL/Tools/Predicate_Compile/predicate_compile_aux.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/Predicate_Compile/predicate_compile_aux.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -1216,7 +1216,7 @@
           HOLogic.mk_Trueprop (list_comb (const, map Free vs')))
     val intro =
       Goal.prove (Proof_Context.init_global thy1) (map fst vs') [] t
-        (fn _ => ALLGOALS Skip_Proof.cheat_tac)
+        (fn {context = ctxt, ...} => ALLGOALS (Skip_Proof.cheat_tac ctxt))
   in
     ((((full_constname, constT), vs'), intro), thy1)
   end
--- a/src/HOL/Tools/Predicate_Compile/predicate_compile_data.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/Predicate_Compile/predicate_compile_data.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -151,7 +151,7 @@
     val t' = Pattern.rewrite_term thy rewr [] t
     val th'' =
       Goal.prove ctxt (Term.add_free_names t' []) [] t'
-        (fn _ => ALLGOALS Skip_Proof.cheat_tac)
+        (fn _ => ALLGOALS (Skip_Proof.cheat_tac ctxt))
     val th''' = Local_Defs.unfold ctxt [@{thm split_conv}, @{thm fst_conv}, @{thm snd_conv}] th''
   in
     th'''
--- a/src/HOL/Tools/Predicate_Compile/predicate_compile_pred.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/Predicate_Compile/predicate_compile_pred.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -135,7 +135,7 @@
       (flatten constname) (map prop_of intros) ([], thy)
     val ctxt'' = Proof_Context.transfer thy' ctxt'
     val intros'' =
-      map (fn t => Goal.prove ctxt'' [] [] t (fn _ => ALLGOALS Skip_Proof.cheat_tac)) intros'
+      map (fn t => Goal.prove ctxt'' [] [] t (fn _ => ALLGOALS (Skip_Proof.cheat_tac ctxt''))) intros'
       |> Variable.export ctxt'' ctxt
   in
     (intros'', (local_defs, thy'))
--- a/src/HOL/Tools/Predicate_Compile/predicate_compile_proof.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/Predicate_Compile/predicate_compile_proof.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -502,7 +502,7 @@
         THEN trace_tac ctxt options "proved one direction"
         THEN prove_other_direction options ctxt pred mode moded_clauses
         THEN trace_tac ctxt options "proved other direction")
-      else (fn _ => ALLGOALS Skip_Proof.cheat_tac))
+      else (fn _ => ALLGOALS (Skip_Proof.cheat_tac ctxt)))
   end
 
 end
\ No newline at end of file
--- a/src/HOL/Tools/Quickcheck/exhaustive_generators.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/Quickcheck/exhaustive_generators.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -211,7 +211,7 @@
       |> Quickcheck_Common.define_functions
           (fn functerms => mk_equations functerms (descr, vs, Ts @ Us), NONE)
           prfx argnames fullnames (map mk_T (Ts @ Us))
-      |> Class.prove_instantiation_exit (K (Class.intro_classes_tac []))
+      |> Class.prove_instantiation_exit (fn ctxt => Class.intro_classes_tac ctxt [])
     end
   else
     (Old_Datatype_Aux.message config
--- a/src/HOL/Tools/Quickcheck/narrowing_generators.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/Quickcheck/narrowing_generators.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -54,7 +54,7 @@
     |> `(fn lthy => Syntax.check_term lthy eq)
     |-> (fn eq => Specification.definition (NONE, ((Binding.name (triv_name_of eq), []), eq)))
     |> snd
-    |> Class.prove_instantiation_exit (K (Class.intro_classes_tac []))
+    |> Class.prove_instantiation_exit (fn ctxt => Class.intro_classes_tac ctxt [])
   end;
 
 fun ensure_partial_term_of (tyco, (raw_vs, _)) thy =
@@ -187,7 +187,7 @@
       |> Quickcheck_Common.define_functions
         (fn narrowings => mk_equations descr vs narrowings, NONE)
         prfx [] narrowingsN (map narrowingT (Ts @ Us))
-      |> Class.prove_instantiation_exit (K (Class.intro_classes_tac []))
+      |> Class.prove_instantiation_exit (fn ctxt => Class.intro_classes_tac ctxt [])
     else
       thy
   end;
--- a/src/HOL/Tools/Quickcheck/quickcheck_common.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/Quickcheck/quickcheck_common.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -379,7 +379,7 @@
       let
         val eqs_t = mk_equations consts
         val eqs = map (fn eq => Goal.prove lthy argnames [] eq
-          (fn _ => ALLGOALS Skip_Proof.cheat_tac)) eqs_t
+          (fn {context = ctxt, ...} => ALLGOALS (Skip_Proof.cheat_tac ctxt))) eqs_t
       in
         fold (fn (name, eq) => Local_Theory.note
           ((Binding.qualify true prfx
--- a/src/HOL/Tools/Quickcheck/random_generators.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/Quickcheck/random_generators.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -263,7 +263,7 @@
           Specification.definition (NONE, (apfst Binding.conceal
             Attrib.empty_binding, random_def))) random_defs')
     |> snd
-    |> Class.prove_instantiation_exit (K (Class.intro_classes_tac []))
+    |> Class.prove_instantiation_exit (fn ctxt => Class.intro_classes_tac ctxt [])
   end;
 
 
--- a/src/HOL/Tools/Quotient/quotient_tacs.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/Quotient/quotient_tacs.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -55,14 +55,14 @@
 (** solvers for equivp and quotient assumptions **)
 
 fun equiv_tac ctxt =
-  REPEAT_ALL_NEW (resolve_tac (rev (Named_Theorems.get ctxt @{named_theorems quot_equiv})))
+  REPEAT_ALL_NEW (resolve_tac ctxt (rev (Named_Theorems.get ctxt @{named_theorems quot_equiv})))
 
 val equiv_solver = mk_solver "Equivalence goal solver" equiv_tac
 
 fun quotient_tac ctxt =
   (REPEAT_ALL_NEW (FIRST'
     [rtac @{thm identity_quotient3},
-     resolve_tac (rev (Named_Theorems.get ctxt @{named_theorems quot_thm}))]))
+     resolve_tac ctxt (rev (Named_Theorems.get ctxt @{named_theorems quot_thm}))]))
 
 val quotient_solver = mk_solver "Quotient goal solver" quotient_tac
 
@@ -167,10 +167,10 @@
   in
     simp_tac simpset THEN'
     TRY o REPEAT_ALL_NEW (CHANGED o FIRST'
-      [resolve_tac @{thms ball_reg_right bex_reg_left bex1_bexeq_reg},
-       resolve_tac (Inductive.get_monos ctxt),
-       resolve_tac @{thms ball_all_comm bex_ex_comm},
-       resolve_tac eq_eqvs,
+      [resolve_tac ctxt @{thms ball_reg_right bex_reg_left bex1_bexeq_reg},
+       resolve_tac ctxt (Inductive.get_monos ctxt),
+       resolve_tac ctxt @{thms ball_all_comm bex_ex_comm},
+       resolve_tac ctxt eq_eqvs,
        simp_tac simpset])
   end
 
@@ -371,7 +371,7 @@
 
      (* respectfulness of constants; in particular of a simple relation *)
   | _ $ (Const _) $ (Const _)  (* rel_fun, list_rel, etc but not equality *)
-      => resolve_tac (rev (Named_Theorems.get ctxt @{named_theorems quot_respect}))
+      => resolve_tac ctxt (rev (Named_Theorems.get ctxt @{named_theorems quot_respect}))
           THEN_ALL_NEW quotient_tac ctxt
 
       (* R (...) (Rep (Abs ...)) ----> R (...) (...) *)
@@ -403,7 +403,7 @@
 
     (* reflexivity of the basic relations *)
     (* R ... ... *)
-    resolve_tac rel_refl]
+    resolve_tac ctxt rel_refl]
 
 fun injection_tac ctxt =
   let
--- a/src/HOL/Tools/SMT/z3_replay.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/SMT/z3_replay.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -147,10 +147,10 @@
     by (metis someI_ex)+}
 in
 
-fun discharge_sk_tac i st =
+fun discharge_sk_tac ctxt i st =
   (rtac @{thm trans} i
-   THEN resolve_tac sk_rules i
-   THEN (rtac @{thm refl} ORELSE' discharge_sk_tac) (i+1)
+   THEN resolve_tac ctxt sk_rules i
+   THEN (rtac @{thm refl} ORELSE' discharge_sk_tac ctxt) (i+1)
    THEN rtac @{thm refl} i) st
 
 end
@@ -163,14 +163,16 @@
   "(P | ~ P) & (~ P | P)"
   by fast+}
 
-fun discharge_assms_tac rules =
-  REPEAT (HEADGOAL (resolve_tac (intro_def_rules @ rules) ORELSE' SOLVED' discharge_sk_tac))
+fun discharge_assms_tac ctxt rules =
+  REPEAT
+    (HEADGOAL (resolve_tac ctxt (intro_def_rules @ rules) ORELSE'
+      SOLVED' (discharge_sk_tac ctxt)))
 
 fun discharge_assms ctxt rules thm =
   (if Thm.nprems_of thm = 0 then
      thm
    else
-     (case Seq.pull (discharge_assms_tac rules thm) of
+     (case Seq.pull (discharge_assms_tac ctxt rules thm) of
        SOME (thm', _) => thm'
      | NONE => raise THM ("failed to discharge premise", 1, [thm])))
   |> Goal.norm_result ctxt
--- a/src/HOL/Tools/SMT/z3_replay_methods.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/SMT/z3_replay_methods.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -309,7 +309,7 @@
 (* congruence *)
 
 fun ctac ctxt prems i st = st |> (
-  resolve_tac (@{thm refl} :: prems) i
+  resolve_tac ctxt (@{thm refl} :: prems) i
   ORELSE (cong_tac ctxt i THEN ctac ctxt prems (i + 1) THEN ctac ctxt prems i))
 
 fun cong_basic ctxt thms t =
@@ -328,7 +328,7 @@
 fun cong_full ctxt thms t = prove ctxt t (fn ctxt' =>
   Method.insert_tac thms
   THEN' (Classical.fast_tac ctxt'
-    ORELSE' dresolve_tac cong_dest_rules
+    ORELSE' dresolve_tac ctxt cong_dest_rules
     THEN' Classical.fast_tac ctxt'))
 
 fun cong ctxt thms = try_provers ctxt Z3_Proof.Monotonicity [
@@ -346,7 +346,7 @@
   by fast+}
 
 fun quant_intro ctxt [thm] t =
-    prove ctxt t (K (REPEAT_ALL_NEW (resolve_tac (thm :: quant_intro_rules))))
+    prove ctxt t (K (REPEAT_ALL_NEW (resolve_tac ctxt (thm :: quant_intro_rules))))
   | quant_intro ctxt thms t = replay_rule_error ctxt Z3_Proof.Quant_Intro thms t
 
 
--- a/src/HOL/Tools/TFL/post.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/TFL/post.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -125,7 +125,7 @@
 (*lcp: put a theorem into Isabelle form, using meta-level connectives*)
 fun meta_outer ctxt =
   curry_rule ctxt o Drule.export_without_context o
-  rule_by_tactic ctxt (REPEAT (FIRSTGOAL (resolve_tac [allI, impI, conjI] ORELSE' etac conjE)));
+  rule_by_tactic ctxt (REPEAT (FIRSTGOAL (resolve_tac ctxt [allI, impI, conjI] ORELSE' etac conjE)));
 
 (*Strip off the outer !P*)
 val spec'= Rule_Insts.read_instantiate @{context} [(("x", 0), "P::'b=>bool")] [] spec;
--- a/src/HOL/Tools/Transfer/transfer.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/Transfer/transfer.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -611,12 +611,12 @@
       |> Thm.instantiate (map tinst binsts, map inst binsts)
   end
 
-fun eq_rules_tac eq_rules = TRY o REPEAT_ALL_NEW (resolve_tac eq_rules)
+fun eq_rules_tac eq_rules = TRY o REPEAT_ALL_NEW (resolve0_tac eq_rules)
   THEN_ALL_NEW rtac @{thm is_equality_eq}
 
 fun eq_tac ctxt = eq_rules_tac (get_relator_eq_raw ctxt)
 
-fun transfer_step_tac ctxt = (REPEAT_ALL_NEW (resolve_tac (get_transfer_raw ctxt))
+fun transfer_step_tac ctxt = (REPEAT_ALL_NEW (resolve_tac ctxt (get_transfer_raw ctxt))
   THEN_ALL_NEW (DETERM o eq_rules_tac (get_relator_eq_raw ctxt)))
 
 fun transfer_tac equiv ctxt i =
@@ -633,7 +633,9 @@
       rtac start_rule i THEN
       (rtac (transfer_rule_of_term ctxt equiv (HOLogic.dest_Trueprop t))
         THEN_ALL_NEW
-          (SOLVED' (REPEAT_ALL_NEW (resolve_tac rules) THEN_ALL_NEW (DETERM o eq_rules_tac eq_rules))
+          (SOLVED'
+            (REPEAT_ALL_NEW (resolve_tac ctxt rules) THEN_ALL_NEW
+              (DETERM o eq_rules_tac eq_rules))
             ORELSE' end_tac)) (i + 1)
         handle TERM (_, ts) => raise TERM (err_msg, ts)
   in
@@ -658,7 +660,8 @@
        rtac @{thm transfer_prover_start} i,
        ((rtac rule1 ORELSE' (CONVERSION expand_eq_in_rel THEN' rtac rule1))
         THEN_ALL_NEW
-         (REPEAT_ALL_NEW (resolve_tac rules) THEN_ALL_NEW (DETERM o eq_rules_tac eq_rules))) (i+1),
+         (REPEAT_ALL_NEW (resolve_tac ctxt rules) THEN_ALL_NEW
+           (DETERM o eq_rules_tac eq_rules))) (i + 1),
        rtac @{thm refl} i]
   end)
 
@@ -682,10 +685,10 @@
     val t = HOLogic.dest_Trueprop (Thm.concl_of thm2)
     val rule = transfer_rule_of_lhs ctxt' t
     val tac =
-      resolve_tac [thm2 RS start_rule', thm2 RS start_rule] 1 THEN
+      resolve_tac ctxt' [thm2 RS start_rule', thm2 RS start_rule] 1 THEN
       (rtac rule
         THEN_ALL_NEW
-          (SOLVED' (REPEAT_ALL_NEW (resolve_tac rules)
+          (SOLVED' (REPEAT_ALL_NEW (resolve_tac ctxt' rules)
             THEN_ALL_NEW (DETERM o eq_rules_tac eq_rules)))) 1
         handle TERM (_, ts) => raise TERM (err_msg, ts)
     val thm3 = Goal.prove_internal ctxt' [] @{cpat "Trueprop ?P"} (K tac)
@@ -721,7 +724,7 @@
       rtac (thm2 RS start_rule) 1 THEN
       (rtac rule
         THEN_ALL_NEW
-          (SOLVED' (REPEAT_ALL_NEW (resolve_tac rules)
+          (SOLVED' (REPEAT_ALL_NEW (resolve_tac ctxt' rules)
             THEN_ALL_NEW (DETERM o eq_rules_tac eq_rules)))) 1
         handle TERM (_, ts) => raise TERM (err_msg, ts)
     val thm3 = Goal.prove_internal ctxt' [] @{cpat "Trueprop ?P"} (K tac)
--- a/src/HOL/Tools/Transfer/transfer_bnf.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/Transfer/transfer_bnf.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -201,19 +201,20 @@
   in
     EVERY' [rtac ext, SELECT_GOAL (Local_Defs.unfold_tac ctxt [@{thm Domainp.simps},
         in_rel_of_bnf bnf, pred_def]), rtac iffI,
-        REPEAT_DETERM o eresolve_tac [exE, conjE, CollectE], hyp_subst_tac ctxt,
+        REPEAT_DETERM o eresolve_tac ctxt [exE, conjE, CollectE], hyp_subst_tac ctxt,
         CONJ_WRAP' (fn set_map => EVERY' [rtac ballI, dtac (set_map RS equalityD1 RS set_mp),
           etac imageE, dtac set_rev_mp, assume_tac ctxt,
-          REPEAT_DETERM o eresolve_tac [CollectE, @{thm case_prodE}],
+          REPEAT_DETERM o eresolve_tac ctxt [CollectE, @{thm case_prodE}],
           hyp_subst_tac ctxt, rtac @{thm iffD2[OF arg_cong2[of _ _ _ _ Domainp, OF refl fst_conv]]},
           etac @{thm DomainPI}]) set_map's,
-        REPEAT_DETERM o etac conjE, REPEAT_DETERM o resolve_tac [exI, (refl RS conjI), rotate_prems 1 conjI],
+        REPEAT_DETERM o etac conjE,
+        REPEAT_DETERM o resolve_tac ctxt [exI, (refl RS conjI), rotate_prems 1 conjI],
         rtac refl, rtac (box_equals OF [map_cong0_of_bnf bnf, map_comp_of_bnf bnf RS sym,
           map_id_of_bnf bnf]),
         REPEAT_DETERM_N n o (EVERY' [rtac @{thm box_equals[OF _ sym[OF o_apply] sym[OF id_apply]]},
           rtac @{thm fst_conv}]), rtac CollectI,
         CONJ_WRAP' (fn set_map => EVERY' [rtac (set_map RS @{thm ord_eq_le_trans}),
-          REPEAT_DETERM o resolve_tac [@{thm image_subsetI}, CollectI, @{thm case_prodI}],
+          REPEAT_DETERM o resolve_tac ctxt [@{thm image_subsetI}, CollectI, @{thm case_prodI}],
           dtac (rotate_prems 1 bspec), assume_tac ctxt,
           etac @{thm DomainpE}, etac @{thm someI}]) set_map's
       ] i
--- a/src/HOL/Tools/cnf.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/cnf.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -39,7 +39,7 @@
   val is_clause: term -> bool
   val clause_is_trivial: term -> bool
 
-  val clause2raw_thm: thm -> thm
+  val clause2raw_thm: Proof.context -> thm -> thm
   val make_nnf_thm: theory -> term -> thm
 
   val weakening_tac: Proof.context -> int -> tactic  (* removes the first hypothesis of a subgoal *)
@@ -132,7 +132,7 @@
 (*      where each xi' is the negation normal form of ~xi                    *)
 (* ------------------------------------------------------------------------- *)
 
-fun clause2raw_thm clause =
+fun clause2raw_thm ctxt clause =
   let
     (* eliminates negated disjunctions from the i-th premise, possibly *)
     (* adding new premises, then continues with the (i+1)-th premise   *)
@@ -141,7 +141,8 @@
       if i > nprems_of thm then
         thm
       else
-        not_disj_to_prem (i+1) (Seq.hd (REPEAT_DETERM (resolve_tac [clause2raw_not_disj] i) thm))
+        not_disj_to_prem (i+1)
+          (Seq.hd (REPEAT_DETERM (resolve_tac ctxt [clause2raw_not_disj] i) thm))
     (* moves all premises to hyps, i.e. "[...] |- A1 ==> ... ==> An ==> B" *)
     (* becomes "[..., A1, ..., An] |- B"                                   *)
     (* Thm.thm -> Thm.thm *)
@@ -154,7 +155,7 @@
     (* [...] |- ~x1 ==> ... ==> ~xn ==> False *)
     |> not_disj_to_prem 1
     (* [...] |- x1' ==> ... ==> xn' ==> False *)
-    |> Seq.hd o TRYALL (resolve_tac [clause2raw_not_not])
+    |> Seq.hd o TRYALL (resolve_tac ctxt [clause2raw_not_not])
     (* [..., x1', ..., xn'] |- False *)
     |> prems_to_hyps
   end;
@@ -529,7 +530,7 @@
 (* ------------------------------------------------------------------------- *)
 
 fun weakening_tac ctxt i =
-  dresolve_tac [weakening_thm] i THEN assume_tac ctxt (i+1);
+  dresolve_tac ctxt [weakening_thm] i THEN assume_tac ctxt (i+1);
 
 (* ------------------------------------------------------------------------- *)
 (* cnf_rewrite_tac: converts all premises of the 'i'-th subgoal to CNF       *)
--- a/src/HOL/Tools/code_evaluation.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/code_evaluation.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -45,7 +45,7 @@
     |> `(fn lthy => Syntax.check_term lthy eq)
     |-> (fn eq => Specification.definition (NONE, ((Binding.name (triv_name_of eq), []), eq)))
     |> snd
-    |> Class.prove_instantiation_exit (K (Class.intro_classes_tac []))
+    |> Class.prove_instantiation_exit (fn ctxt => Class.intro_classes_tac ctxt [])
   end;
 
 fun ensure_term_of (tyco, (raw_vs, _)) thy =
--- a/src/HOL/Tools/coinduction.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/coinduction.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -34,7 +34,7 @@
   let
     val n = nth (prems_of st) (i - 1) |> Logic.strip_assums_hyp |> length;
   in
-    (THEN_ALL_NEW_SKIP skip tac (REPEAT_DETERM_N n o eresolve_tac [thin_rl])) i st
+    (THEN_ALL_NEW_SKIP skip tac (REPEAT_DETERM_N n o eresolve0_tac [thin_rl])) i st
   end;
 
 fun coinduction_tac ctxt raw_vars opt_raw_thm prems = HEADGOAL (SUBGOAL_CASES (fn (goal, _, _) =>
@@ -84,17 +84,17 @@
           val e = length eqs;
           val p = length prems;
         in
-          HEADGOAL (EVERY' [resolve_tac [thm],
+          HEADGOAL (EVERY' [resolve_tac ctxt [thm],
             EVERY' (map (fn var =>
-              resolve_tac
+              resolve_tac ctxt
                 [Ctr_Sugar_Util.cterm_instantiate_pos
                   [NONE, SOME (Ctr_Sugar_Util.certify ctxt var)] exI]) vars),
-            if p = 0 then Ctr_Sugar_Util.CONJ_WRAP' (K (resolve_tac [refl])) eqs
+            if p = 0 then Ctr_Sugar_Util.CONJ_WRAP' (K (resolve_tac ctxt [refl])) eqs
             else
-              REPEAT_DETERM_N e o (resolve_tac [conjI] THEN' resolve_tac [refl]) THEN'
-              Ctr_Sugar_Util.CONJ_WRAP' (resolve_tac o single) prems,
+              REPEAT_DETERM_N e o (resolve_tac ctxt [conjI] THEN' resolve_tac ctxt [refl]) THEN'
+              Ctr_Sugar_Util.CONJ_WRAP' (resolve_tac ctxt o single) prems,
             K (ALLGOALS_SKIP skip
-               (REPEAT_DETERM_N (length vars) o (eresolve_tac [exE] THEN' rotate_tac ~1) THEN'
+               (REPEAT_DETERM_N (length vars) o (eresolve_tac ctxt [exE] THEN' rotate_tac ~1) THEN'
                DELETE_PREMS_AFTER 0 (Subgoal.FOCUS (fn {prems, params, context = ctxt, ...} =>
                  (case prems of
                    [] => all_tac
--- a/src/HOL/Tools/datatype_realizer.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/datatype_realizer.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -117,7 +117,7 @@
             rtac (cterm_instantiate inst induct) 1,
             ALLGOALS (Object_Logic.atomize_prems_tac ctxt),
             rewrite_goals_tac ctxt (@{thm o_def} :: map mk_meta_eq rec_rewrites),
-            REPEAT ((resolve_tac prems THEN_ALL_NEW (fn i =>
+            REPEAT ((resolve_tac ctxt prems THEN_ALL_NEW (fn i =>
               REPEAT (etac allE i) THEN assume_tac ctxt i)) 1)])
       |> Drule.export_without_context;
 
@@ -194,7 +194,7 @@
             rtac (cterm_instantiate [(cert y, cert y')] exhaust) 1,
             ALLGOALS (EVERY'
               [asm_simp_tac (put_simpset HOL_basic_ss ctxt addsimps case_rewrites),
-               resolve_tac prems, asm_simp_tac (put_simpset HOL_basic_ss ctxt)])])
+               resolve_tac ctxt prems, asm_simp_tac (put_simpset HOL_basic_ss ctxt)])])
       |> Drule.export_without_context;
 
     val exh_name = Thm.derivation_name exhaust;
--- a/src/HOL/Tools/inductive.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/inductive.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -169,8 +169,8 @@
   | mk_names a n = map (fn i => a ^ string_of_int i) (1 upto n);
 
 fun select_disj 1 1 = []
-  | select_disj _ 1 = [resolve_tac [disjI1]]
-  | select_disj n i = resolve_tac [disjI2] :: select_disj (n - 1) (i - 1);
+  | select_disj _ 1 = [resolve0_tac [disjI1]]
+  | select_disj n i = resolve0_tac [disjI2] :: select_disj (n - 1) (i - 1);
 
 
 
@@ -261,7 +261,7 @@
     | _ $ (Const (@{const_name HOL.eq}, _) $ _ $ _) => eq_to_mono thm
     | _ $ (Const (@{const_name Orderings.less_eq}, _) $ _ $ _) =>
       dest_less_concl (Seq.hd (REPEAT (FIRSTGOAL
-        (resolve_tac [@{thm le_funI}, @{thm le_boolI'}])) thm))
+        (resolve_tac ctxt [@{thm le_funI}, @{thm le_boolI'}])) thm))
     | _ => thm)
   end handle THM _ => error ("Bad monotonicity theorem:\n" ^ Display.string_of_thm ctxt thm);
 
@@ -378,13 +378,13 @@
     [] []
     (HOLogic.mk_Trueprop
       (Const (@{const_name Orderings.mono}, (predT --> predT) --> HOLogic.boolT) $ fp_fun))
-    (fn _ => EVERY [resolve_tac @{thms monoI} 1,
-      REPEAT (resolve_tac [@{thm le_funI}, @{thm le_boolI'}] 1),
+    (fn _ => EVERY [resolve_tac ctxt @{thms monoI} 1,
+      REPEAT (resolve_tac ctxt [@{thm le_funI}, @{thm le_boolI'}] 1),
       REPEAT (FIRST
         [assume_tac ctxt 1,
-         resolve_tac (map (mk_mono ctxt) monos @ get_monos ctxt) 1,
-         eresolve_tac @{thms le_funE} 1,
-         dresolve_tac @{thms le_boolD} 1])]));
+         resolve_tac ctxt (map (mk_mono ctxt) monos @ get_monos ctxt) 1,
+         eresolve_tac ctxt @{thms le_funE} 1,
+         dresolve_tac ctxt @{thms le_boolD} 1])]));
 
 
 (* prove introduction rules *)
@@ -402,11 +402,11 @@
     val intrs = map_index (fn (i, intr) =>
       Goal.prove_sorry ctxt [] [] intr (fn _ => EVERY
        [rewrite_goals_tac ctxt rec_preds_defs,
-        resolve_tac [unfold RS iffD2] 1,
+        resolve_tac ctxt [unfold RS iffD2] 1,
         EVERY1 (select_disj (length intr_ts) (i + 1)),
         (*Not ares_tac, since refl must be tried before any equality assumptions;
           backtracking may occur if the premises have extra variables!*)
-        DEPTH_SOLVE_1 (resolve_tac rules 1 APPEND assume_tac ctxt 1)])
+        DEPTH_SOLVE_1 (resolve_tac ctxt rules 1 APPEND assume_tac ctxt 1)])
        |> singleton (Proof_Context.export ctxt ctxt')) intr_ts
 
   in (intrs, unfold) end;
@@ -448,11 +448,12 @@
           (fn {context = ctxt4, prems} => EVERY
             [cut_tac (hd prems) 1,
              rewrite_goals_tac ctxt4 rec_preds_defs,
-             dresolve_tac [unfold RS iffD1] 1,
-             REPEAT (FIRSTGOAL (eresolve_tac rules1)),
-             REPEAT (FIRSTGOAL (eresolve_tac rules2)),
+             dresolve_tac ctxt4 [unfold RS iffD1] 1,
+             REPEAT (FIRSTGOAL (eresolve_tac ctxt4 rules1)),
+             REPEAT (FIRSTGOAL (eresolve_tac ctxt4 rules2)),
              EVERY (map (fn prem =>
-               DEPTH_SOLVE_1 (ares_tac [rewrite_rule ctxt4 rec_preds_defs prem, conjI] 1))
+               DEPTH_SOLVE_1 (assume_tac ctxt4 1 ORELSE
+                resolve_tac ctxt [rewrite_rule ctxt4 rec_preds_defs prem, conjI] 1))
                 (tl prems))])
           |> singleton (Proof_Context.export ctxt'' ctxt'''),
          map #2 c_intrs, length Ts)
@@ -493,42 +494,42 @@
           if null c_intrs then @{term False}
           else foldr1 HOLogic.mk_disj (map mk_intr_conj c_intrs);
         val eq = HOLogic.mk_Trueprop (HOLogic.mk_eq (lhs, rhs));
-        fun prove_intr1 (i, _) = Subgoal.FOCUS_PREMS (fn {params, prems, ...} =>
+        fun prove_intr1 (i, _) = Subgoal.FOCUS_PREMS (fn {context = ctxt'', params, prems, ...} =>
             EVERY1 (select_disj (length c_intrs) (i + 1)) THEN
-            EVERY (replicate (length params) (resolve_tac @{thms exI} 1)) THEN
-            (if null prems then resolve_tac @{thms TrueI} 1
+            EVERY (replicate (length params) (resolve_tac ctxt'' @{thms exI} 1)) THEN
+            (if null prems then resolve_tac ctxt'' @{thms TrueI} 1
              else
               let
                 val (prems', last_prem) = split_last prems;
               in
                 EVERY (map (fn prem =>
-                  (resolve_tac @{thms conjI} 1 THEN resolve_tac [prem] 1)) prems') THEN
-                resolve_tac [last_prem] 1
+                  (resolve_tac ctxt'' @{thms conjI} 1 THEN resolve_tac ctxt'' [prem] 1)) prems')
+                THEN resolve_tac ctxt'' [last_prem] 1
               end)) ctxt' 1;
         fun prove_intr2 (((_, _, us, _), ts, params'), intr) =
-          EVERY (replicate (length params') (eresolve_tac @{thms exE} 1)) THEN
-          (if null ts andalso null us then resolve_tac [intr] 1
+          EVERY (replicate (length params') (eresolve_tac ctxt' @{thms exE} 1)) THEN
+          (if null ts andalso null us then resolve_tac ctxt' [intr] 1
            else
-            EVERY (replicate (length ts + length us - 1) (eresolve_tac @{thms conjE} 1)) THEN
+            EVERY (replicate (length ts + length us - 1) (eresolve_tac ctxt' @{thms conjE} 1)) THEN
             Subgoal.FOCUS_PREMS (fn {context = ctxt'', prems, ...} =>
               let
                 val (eqs, prems') = chop (length us) prems;
                 val rew_thms = map (fn th => th RS @{thm eq_reflection}) eqs;
               in
                 rewrite_goal_tac ctxt'' rew_thms 1 THEN
-                resolve_tac [intr] 1 THEN
-                EVERY (map (fn p => resolve_tac [p] 1) prems')
+                resolve_tac ctxt'' [intr] 1 THEN
+                EVERY (map (fn p => resolve_tac ctxt'' [p] 1) prems')
               end) ctxt' 1);
       in
         Goal.prove_sorry ctxt' [] [] eq (fn _ =>
-          resolve_tac @{thms iffI} 1 THEN
-          eresolve_tac [#1 elim] 1 THEN
+          resolve_tac ctxt' @{thms iffI} 1 THEN
+          eresolve_tac ctxt' [#1 elim] 1 THEN
           EVERY (map_index prove_intr1 c_intrs) THEN
-          (if null c_intrs then eresolve_tac @{thms FalseE} 1
+          (if null c_intrs then eresolve_tac ctxt' @{thms FalseE} 1
            else
             let val (c_intrs', last_c_intr) = split_last c_intrs in
-              EVERY (map (fn ci => eresolve_tac @{thms disjE} 1 THEN prove_intr2 ci) c_intrs') THEN
-              prove_intr2 last_c_intr
+              EVERY (map (fn ci => eresolve_tac ctxt' @{thms disjE} 1 THEN prove_intr2 ci) c_intrs')
+              THEN prove_intr2 last_c_intr
             end))
         |> rulify ctxt'
         |> singleton (Proof_Context.export ctxt' ctxt'')
@@ -546,10 +547,13 @@
 val refl_thin = Goal.prove_global @{theory HOL} [] [] @{prop "!!P. a = a ==> P ==> P"}
   (fn {context = ctxt, ...} => assume_tac ctxt 1);
 val elim_rls = [asm_rl, FalseE, refl_thin, conjE, exE];
-val elim_tac = REPEAT o eresolve_tac elim_rls;
+fun elim_tac ctxt = REPEAT o eresolve_tac ctxt elim_rls;
 
 fun simp_case_tac ctxt i =
-  EVERY' [elim_tac, asm_full_simp_tac ctxt, elim_tac, REPEAT o bound_hyp_subst_tac ctxt] i;
+  EVERY' [elim_tac ctxt,
+    asm_full_simp_tac ctxt,
+    elim_tac ctxt,
+    REPEAT o bound_hyp_subst_tac ctxt] i;
 
 in
 
@@ -732,26 +736,29 @@
     val induct = Goal.prove_sorry ctxt'' [] ind_prems ind_concl
       (fn {context = ctxt3, prems} => EVERY
         [rewrite_goals_tac ctxt3 [inductive_conj_def],
-         DETERM (resolve_tac [raw_fp_induct] 1),
-         REPEAT (resolve_tac [@{thm le_funI}, @{thm le_boolI}] 1),
+         DETERM (resolve_tac ctxt3 [raw_fp_induct] 1),
+         REPEAT (resolve_tac ctxt3 [@{thm le_funI}, @{thm le_boolI}] 1),
          rewrite_goals_tac ctxt3 simp_thms2,
          (*This disjE separates out the introduction rules*)
-         REPEAT (FIRSTGOAL (eresolve_tac [disjE, exE, FalseE])),
+         REPEAT (FIRSTGOAL (eresolve_tac ctxt3 [disjE, exE, FalseE])),
          (*Now break down the individual cases.  No disjE here in case
            some premise involves disjunction.*)
-         REPEAT (FIRSTGOAL (eresolve_tac [conjE] ORELSE' bound_hyp_subst_tac ctxt3)),
+         REPEAT (FIRSTGOAL (eresolve_tac ctxt3 [conjE] ORELSE' bound_hyp_subst_tac ctxt3)),
          REPEAT (FIRSTGOAL
-           (resolve_tac [conjI, impI] ORELSE' (eresolve_tac [notE] THEN' assume_tac ctxt3))),
-         EVERY (map (fn prem => DEPTH_SOLVE_1 (ares_tac [rewrite_rule ctxt3
-             (inductive_conj_def :: rec_preds_defs @ simp_thms2) prem,
-           conjI, refl] 1)) prems)]);
+           (resolve_tac ctxt3 [conjI, impI] ORELSE'
+           (eresolve_tac ctxt3 [notE] THEN' assume_tac ctxt3))),
+         EVERY (map (fn prem =>
+            DEPTH_SOLVE_1 (assume_tac ctxt3 1 ORELSE
+              resolve_tac ctxt3
+                [rewrite_rule ctxt3 (inductive_conj_def :: rec_preds_defs @ simp_thms2) prem,
+                  conjI, refl] 1)) prems)]);
 
     val lemma = Goal.prove_sorry ctxt'' [] []
       (Logic.mk_implies (ind_concl, mutual_ind_concl)) (fn {context = ctxt3, ...} => EVERY
         [rewrite_goals_tac ctxt3 rec_preds_defs,
          REPEAT (EVERY
-           [REPEAT (resolve_tac [conjI, impI] 1),
-            REPEAT (eresolve_tac [@{thm le_funE}, @{thm le_boolE}] 1),
+           [REPEAT (resolve_tac ctxt3 [conjI, impI] 1),
+            REPEAT (eresolve_tac ctxt3 [@{thm le_funE}, @{thm le_boolE}] 1),
             assume_tac ctxt3 1,
             rewrite_goals_tac ctxt3 simp_thms1,
             assume_tac ctxt3 1])]);
--- a/src/HOL/Tools/inductive_realizer.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/inductive_realizer.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -395,7 +395,7 @@
           (fn {context = ctxt, prems} => EVERY
           [rtac (#raw_induct ind_info) 1,
            rewrite_goals_tac ctxt rews,
-           REPEAT ((resolve_tac prems THEN_ALL_NEW EVERY'
+           REPEAT ((resolve_tac ctxt prems THEN_ALL_NEW EVERY'
              [K (rewrite_goals_tac ctxt rews), Object_Logic.atomize_prems_tac ctxt,
               DEPTH_SOLVE_1 o FIRST' [assume_tac ctxt, etac allE, etac impE]]) 1)]);
         val (thm', thy') = Global_Theory.store_thm (Binding.qualified_name (space_implode "_"
@@ -459,7 +459,7 @@
              etac elimR 1,
              ALLGOALS (asm_simp_tac (put_simpset HOL_basic_ss ctxt)),
              rewrite_goals_tac ctxt rews,
-             REPEAT ((resolve_tac prems THEN_ALL_NEW (Object_Logic.atomize_prems_tac ctxt THEN'
+             REPEAT ((resolve_tac ctxt prems THEN_ALL_NEW (Object_Logic.atomize_prems_tac ctxt THEN'
                DEPTH_SOLVE_1 o FIRST' [assume_tac ctxt, etac allE, etac impE])) 1)]);
         val (thm', thy') = Global_Theory.store_thm (Binding.qualified_name (space_implode "_"
           (name_of_thm elim :: vs @ Ps @ ["correctness"])), thm) thy
--- a/src/HOL/Tools/inductive_set.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/inductive_set.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -75,14 +75,15 @@
               SOME (close (Goal.prove ctxt [] [])
                 (Logic.mk_equals (t, fold_rev Term.abs xs (m $ p $ (bop $ S $ S'))))
                 (K (EVERY
-                  [resolve_tac [eq_reflection] 1, REPEAT (resolve_tac @{thms ext} 1),
-                   resolve_tac [iffI] 1,
-                   EVERY [eresolve_tac [conjE] 1, resolve_tac [IntI] 1, simp, simp,
-                     eresolve_tac [IntE] 1, resolve_tac [conjI] 1, simp, simp] ORELSE
-                   EVERY [eresolve_tac [disjE] 1, resolve_tac [UnI1] 1, simp,
-                     resolve_tac [UnI2] 1, simp,
-                     eresolve_tac [UnE] 1, resolve_tac [disjI1] 1, simp,
-                     resolve_tac [disjI2] 1, simp]])))
+                  [resolve_tac ctxt [eq_reflection] 1,
+                   REPEAT (resolve_tac ctxt @{thms ext} 1),
+                   resolve_tac ctxt [iffI] 1,
+                   EVERY [eresolve_tac ctxt [conjE] 1, resolve_tac ctxt [IntI] 1, simp, simp,
+                     eresolve_tac ctxt [IntE] 1, resolve_tac ctxt [conjI] 1, simp, simp] ORELSE
+                   EVERY [eresolve_tac ctxt [disjE] 1, resolve_tac ctxt [UnI1] 1, simp,
+                     resolve_tac ctxt [UnI2] 1, simp,
+                     eresolve_tac ctxt [UnE] 1, resolve_tac ctxt [disjI1] 1, simp,
+                     resolve_tac ctxt [disjI2] 1, simp]])))
                 handle ERROR _ => NONE))
     in
       case strip_comb t of
@@ -505,7 +506,7 @@
                fold_rev (Term.abs o pair "x") Ts
                 (HOLogic.mk_mem (HOLogic.mk_ptuple fs U (map Bound (length fs downto 0)),
                   list_comb (c, params))))))
-            (K (REPEAT (resolve_tac @{thms ext} 1) THEN
+            (K (REPEAT (resolve_tac lthy @{thms ext} 1) THEN
               simp_tac (put_simpset HOL_basic_ss lthy addsimps
                 [def, mem_Collect_eq, @{thm split_conv}]) 1))
         in
--- a/src/HOL/Tools/lin_arith.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/lin_arith.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -732,11 +732,12 @@
       end)
   in
     EVERY' [
-      REPEAT_DETERM o eresolve_tac [rev_mp],
+      REPEAT_DETERM o eresolve_tac ctxt [rev_mp],
       cond_split_tac,
-      resolve_tac @{thms ccontr},
+      resolve_tac ctxt @{thms ccontr},
       prem_nnf_tac ctxt,
-      TRY o REPEAT_ALL_NEW (DETERM o (eresolve_tac [conjE, exE] ORELSE' eresolve_tac [disjE]))
+      TRY o REPEAT_ALL_NEW
+        (DETERM o (eresolve_tac ctxt [conjE, exE] ORELSE' eresolve_tac ctxt [disjE]))
     ]
   end;
 
@@ -753,13 +754,13 @@
     fun is_relevant t = is_some (decomp ctxt t)
   in
     DETERM (
-      TRY (filter_prems_tac is_relevant i)
+      TRY (filter_prems_tac ctxt is_relevant i)
         THEN (
           (TRY o REPEAT_ALL_NEW (split_once_tac ctxt split_thms))
             THEN_ALL_NEW
               (CONVERSION Drule.beta_eta_conversion
                 THEN'
-              (TRY o (eresolve_tac [notE] THEN' eq_assume_tac)))
+              (TRY o (eresolve_tac ctxt [notE] THEN' eq_assume_tac)))
         ) i
     )
   end;
@@ -834,14 +835,14 @@
 fun refute_tac ctxt test prep_tac ref_tac =
   let val refute_prems_tac =
         REPEAT_DETERM
-              (eresolve_tac [@{thm conjE}, @{thm exE}] 1 ORELSE
-               filter_prems_tac test 1 ORELSE
-               eresolve_tac @{thms disjE} 1) THEN
-        (DETERM (eresolve_tac @{thms notE} 1 THEN eq_assume_tac 1) ORELSE
+              (eresolve_tac ctxt [@{thm conjE}, @{thm exE}] 1 ORELSE
+               filter_prems_tac ctxt test 1 ORELSE
+               eresolve_tac ctxt @{thms disjE} 1) THEN
+        (DETERM (eresolve_tac ctxt @{thms notE} 1 THEN eq_assume_tac 1) ORELSE
          ref_tac 1);
-  in EVERY'[TRY o filter_prems_tac test,
-            REPEAT_DETERM o eresolve_tac @{thms rev_mp}, prep_tac,
-              resolve_tac @{thms ccontr}, prem_nnf_tac ctxt,
+  in EVERY'[TRY o filter_prems_tac ctxt test,
+            REPEAT_DETERM o eresolve_tac ctxt @{thms rev_mp}, prep_tac,
+              resolve_tac ctxt @{thms ccontr}, prem_nnf_tac ctxt,
             SELECT_GOAL (DEPTH_SOLVE refute_prems_tac)]
   end;
 
@@ -875,7 +876,7 @@
 fun gen_tac ex ctxt =
   FIRST' [simple_tac ctxt,
     Object_Logic.full_atomize_tac ctxt THEN'
-    (REPEAT_DETERM o resolve_tac [impI]) THEN' raw_tac ctxt ex];
+    (REPEAT_DETERM o resolve_tac ctxt [impI]) THEN' raw_tac ctxt ex];
 
 val tac = gen_tac true;
 
--- a/src/HOL/Tools/record.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/record.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -1128,7 +1128,7 @@
       (fn {context = ctxt, ...} =>
         simp_tac (put_simpset ss ctxt) 1 THEN
         REPEAT_DETERM (Iso_Tuple_Support.iso_tuple_intros_tac ctxt 1) THEN
-        TRY (resolve_tac [updacc_cong_idI] 1))
+        TRY (resolve_tac ctxt [updacc_cong_idI] 1))
   end;
 
 
@@ -1634,7 +1634,7 @@
         Goal.prove_sorry_global defs_thy [] [assm] concl
           (fn {context = ctxt, prems, ...} =>
             cut_tac (split_meta RS Drule.equal_elim_rule2) 1 THEN
-            resolve_tac prems 2 THEN
+            resolve_tac ctxt prems 2 THEN
             asm_simp_tac (put_simpset HOL_ss ctxt) 1)
       end);
 
@@ -1724,7 +1724,7 @@
     |> `(fn lthy => Syntax.check_term lthy eq)
     |-> (fn eq => Specification.definition (NONE, (apfst Binding.conceal Attrib.empty_binding, eq)))
     |> snd
-    |> Class.prove_instantiation_exit (K (Class.intro_classes_tac []))
+    |> Class.prove_instantiation_exit (fn ctxt => Class.intro_classes_tac ctxt [])
   end;
 
 fun ensure_sort_record (sort, mk_eq) ext_tyco vs extN Ts thy =
@@ -1749,7 +1749,7 @@
           (Const (@{const_name HOL.equal}, extT --> extT --> HOLogic.boolT),
            Const (@{const_name HOL.eq}, extT --> extT --> HOLogic.boolT)));
       fun tac ctxt eq_def =
-        Class.intro_classes_tac []
+        Class.intro_classes_tac ctxt []
         THEN rewrite_goals_tac ctxt [Simpdata.mk_eq eq_def]
         THEN ALLGOALS (rtac @{thm refl});
       fun mk_eq thy eq_def =
@@ -2128,7 +2128,7 @@
         (fn {context = ctxt, prems, ...} =>
           try_param_tac ctxt rN induct_scheme 1
           THEN try_param_tac ctxt "more" @{thm unit.induct} 1
-          THEN resolve_tac prems 1));
+          THEN resolve_tac ctxt prems 1));
 
     val surjective = timeit_msg ctxt "record surjective proof:" (fn () =>
       Goal.prove_sorry_global defs_thy [] [] surjective_prop
@@ -2144,8 +2144,8 @@
 
     val cases_scheme = timeit_msg ctxt "record cases_scheme proof:" (fn () =>
       Goal.prove_sorry_global defs_thy [] [#1 cases_scheme_prop] (#2 cases_scheme_prop)
-        (fn {prems, ...} =>
-          resolve_tac prems 1 THEN
+        (fn {context = ctxt, prems, ...} =>
+          resolve_tac ctxt prems 1 THEN
           rtac surjective 1));
 
     val cases = timeit_msg ctxt "record cases proof:" (fn () =>
--- a/src/HOL/Tools/sat.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/sat.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -226,7 +226,7 @@
           (* convert the original clause *)
           let
             val _ = cond_tracing ctxt (fn () => "Using original clause #" ^ string_of_int id)
-            val raw = CNF.clause2raw_thm thm
+            val raw = CNF.clause2raw_thm ctxt thm
             val hyps = sort (lit_ord o apply2 fst) (map_filter (fn chyp =>
               Option.map (rpair chyp) (index_of_literal chyp)) (#hyps (Thm.crep_thm raw)))
             val clause = (raw, hyps)
@@ -409,7 +409,7 @@
 
 fun rawsat_tac ctxt i =
   Subgoal.FOCUS (fn {context = ctxt', prems, ...} =>
-    resolve_tac [rawsat_thm ctxt' (map cprop_of prems)] 1) ctxt i;
+    resolve_tac ctxt' [rawsat_thm ctxt' (map cprop_of prems)] 1) ctxt i;
 
 (* ------------------------------------------------------------------------- *)
 (* pre_cnf_tac: converts the i-th subgoal                                    *)
@@ -424,7 +424,7 @@
 (* ------------------------------------------------------------------------- *)
 
 fun pre_cnf_tac ctxt =
-  resolve_tac @{thms ccontr} THEN'
+  resolve_tac ctxt @{thms ccontr} THEN'
   Object_Logic.atomize_prems_tac ctxt THEN'
   CONVERSION Drule.beta_eta_conversion;
 
@@ -436,7 +436,8 @@
 (* ------------------------------------------------------------------------- *)
 
 fun cnfsat_tac ctxt i =
-  (eresolve_tac [FalseE] i) ORELSE (REPEAT_DETERM (eresolve_tac [conjE] i) THEN rawsat_tac ctxt i);
+  (eresolve_tac  ctxt [FalseE] i) ORELSE
+  (REPEAT_DETERM (eresolve_tac ctxt [conjE] i) THEN rawsat_tac ctxt i);
 
 (* ------------------------------------------------------------------------- *)
 (* cnfxsat_tac: checks if the empty clause "False" occurs among the          *)
@@ -446,8 +447,9 @@
 (* ------------------------------------------------------------------------- *)
 
 fun cnfxsat_tac ctxt i =
-  (eresolve_tac [FalseE] i) ORELSE
-    (REPEAT_DETERM (eresolve_tac [conjE] i ORELSE eresolve_tac [exE] i) THEN rawsat_tac ctxt i);
+  (eresolve_tac ctxt [FalseE] i) ORELSE
+    (REPEAT_DETERM (eresolve_tac ctxt [conjE] i ORELSE eresolve_tac ctxt [exE] i) THEN
+      rawsat_tac ctxt i);
 
 (* ------------------------------------------------------------------------- *)
 (* sat_tac: tactic for calling an external SAT solver, taking as input an    *)
--- a/src/HOL/Tools/set_comprehension_pointfree.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/set_comprehension_pointfree.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -314,96 +314,99 @@
 val collectI' = @{lemma "\<not> P a ==> a \<notin> {x. P x}" by auto}
 val collectE' = @{lemma "a \<notin> {x. P x} ==> (\<not> P a ==> Q) ==> Q" by auto}
 
-fun elim_Collect_tac ctxt = dresolve_tac @{thms iffD1 [OF mem_Collect_eq]}
-  THEN' (REPEAT_DETERM o (eresolve_tac @{thms exE}))
-  THEN' REPEAT_DETERM o eresolve_tac @{thms conjE}
+fun elim_Collect_tac ctxt =
+  dresolve_tac ctxt @{thms iffD1 [OF mem_Collect_eq]}
+  THEN' (REPEAT_DETERM o (eresolve_tac ctxt @{thms exE}))
+  THEN' REPEAT_DETERM o eresolve_tac ctxt @{thms conjE}
   THEN' TRY o hyp_subst_tac ctxt;
 
-fun intro_image_tac ctxt = resolve_tac @{thms image_eqI}
-    THEN' (REPEAT_DETERM1 o
-      (resolve_tac @{thms refl}
-      ORELSE' resolve_tac @{thms arg_cong2 [OF refl, where f = "op =", OF prod.case, THEN iffD2]}
+fun intro_image_tac ctxt =
+  resolve_tac ctxt @{thms image_eqI}
+  THEN' (REPEAT_DETERM1 o
+      (resolve_tac ctxt @{thms refl}
+      ORELSE' resolve_tac ctxt @{thms arg_cong2 [OF refl, where f = "op =", OF prod.case, THEN iffD2]}
       ORELSE' CONVERSION (Conv.params_conv ~1 (K (Conv.concl_conv ~1
         (HOLogic.Trueprop_conv
           (HOLogic.eq_conv Conv.all_conv (Conv.rewr_conv (mk_meta_eq case_prod_distrib)))))) ctxt)))
 
-fun elim_image_tac ctxt = eresolve_tac @{thms imageE}
+fun elim_image_tac ctxt =
+  eresolve_tac ctxt @{thms imageE}
   THEN' REPEAT_DETERM o CHANGED o
     (TRY o full_simp_tac (put_simpset HOL_basic_ss ctxt addsimps @{thms split_paired_all prod.case})
-    THEN' REPEAT_DETERM o eresolve_tac @{thms Pair_inject}
+    THEN' REPEAT_DETERM o eresolve_tac ctxt @{thms Pair_inject}
     THEN' TRY o hyp_subst_tac ctxt)
 
 fun tac1_of_formula ctxt (Int (fm1, fm2)) =
-    TRY o eresolve_tac @{thms conjE}
-    THEN' resolve_tac @{thms IntI}
+    TRY o eresolve_tac ctxt @{thms conjE}
+    THEN' resolve_tac ctxt @{thms IntI}
     THEN' (fn i => tac1_of_formula ctxt fm2 (i + 1))
     THEN' tac1_of_formula ctxt fm1
   | tac1_of_formula ctxt (Un (fm1, fm2)) =
-    eresolve_tac @{thms disjE} THEN' resolve_tac @{thms UnI1}
+    eresolve_tac ctxt @{thms disjE} THEN' resolve_tac ctxt @{thms UnI1}
     THEN' tac1_of_formula ctxt fm1
-    THEN' resolve_tac @{thms UnI2}
+    THEN' resolve_tac ctxt @{thms UnI2}
     THEN' tac1_of_formula ctxt fm2
   | tac1_of_formula ctxt (Atom _) =
     REPEAT_DETERM1 o (assume_tac ctxt
-      ORELSE' resolve_tac @{thms SigmaI}
-      ORELSE' ((resolve_tac @{thms CollectI} ORELSE' resolve_tac [collectI']) THEN'
+      ORELSE' resolve_tac ctxt @{thms SigmaI}
+      ORELSE' ((resolve_tac ctxt @{thms CollectI} ORELSE' resolve_tac ctxt [collectI']) THEN'
         TRY o simp_tac (put_simpset HOL_basic_ss ctxt addsimps [@{thm prod.case}]))
-      ORELSE' ((resolve_tac @{thms vimageI2} ORELSE' resolve_tac [vimageI2']) THEN'
+      ORELSE' ((resolve_tac ctxt @{thms vimageI2} ORELSE' resolve_tac ctxt [vimageI2']) THEN'
         TRY o simp_tac (put_simpset HOL_basic_ss ctxt addsimps [@{thm prod.case}]))
-      ORELSE' (resolve_tac @{thms image_eqI} THEN'
+      ORELSE' (resolve_tac ctxt @{thms image_eqI} THEN'
     (REPEAT_DETERM o
-      (resolve_tac @{thms refl}
-      ORELSE' resolve_tac @{thms arg_cong2[OF refl, where f = "op =", OF prod.case, THEN iffD2]})))
-      ORELSE' resolve_tac @{thms UNIV_I}
-      ORELSE' resolve_tac @{thms iffD2[OF Compl_iff]}
+      (resolve_tac ctxt @{thms refl}
+      ORELSE' resolve_tac ctxt @{thms arg_cong2[OF refl, where f = "op =", OF prod.case, THEN iffD2]})))
+      ORELSE' resolve_tac ctxt @{thms UNIV_I}
+      ORELSE' resolve_tac ctxt @{thms iffD2[OF Compl_iff]}
       ORELSE' assume_tac ctxt)
 
 fun tac2_of_formula ctxt (Int (fm1, fm2)) =
-    TRY o eresolve_tac @{thms IntE}
-    THEN' TRY o resolve_tac @{thms conjI}
+    TRY o eresolve_tac ctxt @{thms IntE}
+    THEN' TRY o resolve_tac ctxt @{thms conjI}
     THEN' (fn i => tac2_of_formula ctxt fm2 (i + 1))
     THEN' tac2_of_formula ctxt fm1
   | tac2_of_formula ctxt (Un (fm1, fm2)) =
-    eresolve_tac @{thms UnE} THEN' resolve_tac @{thms disjI1}
+    eresolve_tac ctxt @{thms UnE} THEN' resolve_tac ctxt @{thms disjI1}
     THEN' tac2_of_formula ctxt fm1
-    THEN' resolve_tac @{thms disjI2}
+    THEN' resolve_tac ctxt @{thms disjI2}
     THEN' tac2_of_formula ctxt fm2
   | tac2_of_formula ctxt (Atom _) =
     REPEAT_DETERM o
       (assume_tac ctxt
-       ORELSE' dresolve_tac @{thms iffD1[OF mem_Sigma_iff]}
-       ORELSE' eresolve_tac @{thms conjE}
-       ORELSE' ((eresolve_tac @{thms CollectE} ORELSE' eresolve_tac [collectE']) THEN'
+       ORELSE' dresolve_tac ctxt @{thms iffD1[OF mem_Sigma_iff]}
+       ORELSE' eresolve_tac ctxt @{thms conjE}
+       ORELSE' ((eresolve_tac ctxt @{thms CollectE} ORELSE' eresolve_tac ctxt [collectE']) THEN'
          TRY o full_simp_tac (put_simpset HOL_basic_ss ctxt addsimps [@{thm prod.case}]) THEN'
-         REPEAT_DETERM o eresolve_tac @{thms Pair_inject} THEN' TRY o hyp_subst_tac ctxt THEN'
-         TRY o resolve_tac @{thms refl})
-       ORELSE' (eresolve_tac @{thms imageE}
+         REPEAT_DETERM o eresolve_tac ctxt @{thms Pair_inject} THEN' TRY o hyp_subst_tac ctxt THEN'
+         TRY o resolve_tac ctxt @{thms refl})
+       ORELSE' (eresolve_tac ctxt @{thms imageE}
          THEN' (REPEAT_DETERM o CHANGED o
          (TRY o full_simp_tac (put_simpset HOL_basic_ss ctxt addsimps @{thms split_paired_all prod.case})
-         THEN' REPEAT_DETERM o eresolve_tac @{thms Pair_inject}
-         THEN' TRY o hyp_subst_tac ctxt THEN' TRY o resolve_tac @{thms refl})))
-       ORELSE' eresolve_tac @{thms ComplE}
-       ORELSE' ((eresolve_tac @{thms vimageE} ORELSE' eresolve_tac [vimageE'])
+         THEN' REPEAT_DETERM o eresolve_tac ctxt @{thms Pair_inject}
+         THEN' TRY o hyp_subst_tac ctxt THEN' TRY o resolve_tac ctxt @{thms refl})))
+       ORELSE' eresolve_tac ctxt @{thms ComplE}
+       ORELSE' ((eresolve_tac ctxt @{thms vimageE} ORELSE' eresolve_tac ctxt [vimageE'])
         THEN' TRY o full_simp_tac (put_simpset HOL_basic_ss ctxt addsimps [@{thm prod.case}])
-        THEN' TRY o hyp_subst_tac ctxt THEN' TRY o resolve_tac @{thms refl}))
+        THEN' TRY o hyp_subst_tac ctxt THEN' TRY o resolve_tac ctxt @{thms refl}))
 
 fun tac ctxt fm =
   let
-    val subset_tac1 = resolve_tac @{thms subsetI}
+    val subset_tac1 = resolve_tac ctxt @{thms subsetI}
       THEN' elim_Collect_tac ctxt
       THEN' intro_image_tac ctxt
       THEN' tac1_of_formula ctxt fm
-    val subset_tac2 = resolve_tac @{thms subsetI}
+    val subset_tac2 = resolve_tac ctxt @{thms subsetI}
       THEN' elim_image_tac ctxt
-      THEN' resolve_tac @{thms iffD2[OF mem_Collect_eq]}
-      THEN' REPEAT_DETERM o resolve_tac @{thms exI}
-      THEN' (TRY o REPEAT_ALL_NEW (resolve_tac @{thms conjI}))
-      THEN' (K (TRY (FIRSTGOAL ((TRY o hyp_subst_tac ctxt) THEN' resolve_tac @{thms refl}))))
+      THEN' resolve_tac ctxt @{thms iffD2[OF mem_Collect_eq]}
+      THEN' REPEAT_DETERM o resolve_tac ctxt @{thms exI}
+      THEN' (TRY o REPEAT_ALL_NEW (resolve_tac ctxt @{thms conjI}))
+      THEN' (K (TRY (FIRSTGOAL ((TRY o hyp_subst_tac ctxt) THEN' resolve_tac ctxt @{thms refl}))))
       THEN' (fn i => EVERY (rev (map_index (fn (j, f) =>
-        REPEAT_DETERM (eresolve_tac @{thms IntE} (i + j)) THEN
+        REPEAT_DETERM (eresolve_tac ctxt @{thms IntE} (i + j)) THEN
         tac2_of_formula ctxt f (i + j)) (strip_Int fm))))
   in
-    resolve_tac @{thms subset_antisym} THEN' subset_tac1 THEN' subset_tac2
+    resolve_tac ctxt @{thms subset_antisym} THEN' subset_tac1 THEN' subset_tac2
   end;
 
 
@@ -430,14 +433,14 @@
     fun is_eq th = is_some (try (HOLogic.dest_eq o HOLogic.dest_Trueprop) (prop_of th))
     val unfold_thms = @{thms split_paired_all mem_Collect_eq prod.case}
     fun tac ctxt = 
-      resolve_tac @{thms set_eqI}
+      resolve_tac ctxt @{thms set_eqI}
       THEN' simp_tac (put_simpset HOL_basic_ss ctxt addsimps unfold_thms)
-      THEN' resolve_tac @{thms iffI}
-      THEN' REPEAT_DETERM o resolve_tac @{thms exI}
-      THEN' resolve_tac @{thms conjI} THEN' resolve_tac @{thms refl} THEN' assume_tac ctxt
-      THEN' REPEAT_DETERM o eresolve_tac @{thms exE}
-      THEN' eresolve_tac @{thms conjE}
-      THEN' REPEAT_DETERM o eresolve_tac @{thms Pair_inject}
+      THEN' resolve_tac ctxt @{thms iffI}
+      THEN' REPEAT_DETERM o resolve_tac ctxt @{thms exI}
+      THEN' resolve_tac ctxt @{thms conjI} THEN' resolve_tac ctxt @{thms refl} THEN' assume_tac ctxt
+      THEN' REPEAT_DETERM o eresolve_tac ctxt @{thms exE}
+      THEN' eresolve_tac ctxt @{thms conjE}
+      THEN' REPEAT_DETERM o eresolve_tac ctxt @{thms Pair_inject}
       THEN' Subgoal.FOCUS (fn {prems, ...} =>
         (* FIXME inner context!? *)
         simp_tac (put_simpset HOL_basic_ss ctxt addsimps (filter is_eq prems)) 1) ctxt
--- a/src/HOL/Tools/simpdata.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Tools/simpdata.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -73,19 +73,23 @@
           (mk_simp_implies @{prop "(x::'a) = y"})
           (fn {context = ctxt, prems} => EVERY
            [rewrite_goals_tac ctxt @{thms simp_implies_def},
-            REPEAT (ares_tac (@{thm meta_eq_to_obj_eq} ::
-              map (rewrite_rule ctxt @{thms simp_implies_def}) prems) 1)])
+            REPEAT (assume_tac ctxt 1 ORELSE
+              resolve_tac ctxt
+                (@{thm meta_eq_to_obj_eq} ::
+                  map (rewrite_rule ctxt @{thms simp_implies_def}) prems) 1)])
       end
   end;
 
 (*Congruence rules for = (instead of ==)*)
-fun mk_meta_cong (_: Proof.context) rl = zero_var_indexes
-  (let val rl' = Seq.hd (TRYALL (fn i => fn st =>
-     resolve_tac [lift_meta_eq_to_obj_eq i st] i st) rl)
-   in mk_meta_eq rl' handle THM _ =>
-     if can Logic.dest_equals (concl_of rl') then rl'
-     else error "Conclusion of congruence rules must be =-equality"
-   end);
+fun mk_meta_cong ctxt rl =
+  let
+    val rl' = Seq.hd (TRYALL (fn i => fn st =>
+      resolve_tac ctxt [lift_meta_eq_to_obj_eq i st] i st) rl)
+  in
+    mk_meta_eq rl' handle THM _ =>
+      if can Logic.dest_equals (concl_of rl') then rl'
+      else error "Conclusion of congruence rules must be =-equality"
+  end |> zero_var_indexes;
 
 fun mk_atomize ctxt pairs =
   let
@@ -120,7 +124,10 @@
     val sol_thms =
       reflexive_thm :: @{thm TrueI} :: @{thm refl} :: Simplifier.prems_of ctxt;
     fun sol_tac i =
-      FIRST [resolve_tac sol_thms i, assume_tac ctxt i , eresolve_tac @{thms FalseE} i] ORELSE
+      FIRST
+       [resolve_tac ctxt sol_thms i,
+        assume_tac ctxt i,
+        eresolve_tac ctxt @{thms FalseE} i] ORELSE
       (match_tac ctxt intros THEN_ALL_NEW sol_tac) i
   in
     (fn i => REPEAT_DETERM (match_tac ctxt @{thms simp_impliesI} i)) THEN' sol_tac
--- a/src/HOL/Typerep.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Typerep.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -60,7 +60,7 @@
     |> `(fn lthy => Syntax.check_term lthy eq)
     |-> (fn eq => Specification.definition (NONE, (Attrib.empty_binding, eq)))
     |> snd
-    |> Class.prove_instantiation_exit (K (Class.intro_classes_tac []))
+    |> Class.prove_instantiation_exit (fn ctxt => Class.intro_classes_tac ctxt [])
   end;
 
 fun ensure_typerep tyco thy =
--- a/src/HOL/UNITY/Simple/NSP_Bad.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/UNITY/Simple/NSP_Bad.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -105,7 +105,7 @@
   SELECT_GOAL
     (EVERY
      [REPEAT (etac @{thm Always_ConstrainsI} 1),
-      REPEAT (resolve_tac [@{thm StableI}, @{thm stableI}, @{thm constrains_imp_Constrains}] 1),
+      REPEAT (resolve_tac ctxt [@{thm StableI}, @{thm stableI}, @{thm constrains_imp_Constrains}] 1),
       rtac @{thm ns_constrainsI} 1,
       full_simp_tac ctxt 1,
       REPEAT (FIRSTGOAL (etac disjE)),
--- a/src/HOL/UNITY/UNITY_tactics.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/UNITY/UNITY_tactics.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -21,7 +21,7 @@
       (*reduce the fancy safety properties to "constrains"*)
       REPEAT (etac @{thm Always_ConstrainsI} 1
               ORELSE
-              resolve_tac [@{thm StableI}, @{thm stableI},
+              resolve_tac ctxt [@{thm StableI}, @{thm stableI},
                            @{thm constrains_imp_Constrains}] 1),
       (*for safety, the totalize operator can be ignored*)
       simp_tac (put_simpset HOL_ss ctxt
--- a/src/HOL/Word/Word.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Word/Word.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -1561,7 +1561,7 @@
           |> fold Splitter.add_split @{thms uint_splits}
           |> fold Simplifier.add_cong @{thms power_False_cong})),
       rewrite_goals_tac ctxt @{thms word_size}, 
-      ALLGOALS  (fn n => REPEAT (resolve_tac [allI, impI] n) THEN      
+      ALLGOALS  (fn n => REPEAT (resolve_tac ctxt [allI, impI] n) THEN
                          REPEAT (etac conjE n) THEN
                          REPEAT (dtac @{thm word_of_int_inverse} n 
                                  THEN assume_tac ctxt n 
@@ -2063,7 +2063,7 @@
           |> fold Splitter.add_split @{thms unat_splits}
           |> fold Simplifier.add_cong @{thms power_False_cong})),
       rewrite_goals_tac ctxt @{thms word_size}, 
-      ALLGOALS  (fn n => REPEAT (resolve_tac [allI, impI] n) THEN      
+      ALLGOALS  (fn n => REPEAT (resolve_tac ctxt [allI, impI] n) THEN      
                          REPEAT (etac conjE n) THEN
                          REPEAT (dtac @{thm of_nat_inverse} n THEN atac n)),
       TRYALL arith_tac' ] 
--- a/src/HOL/Word/WordBitwise.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/HOL/Word/WordBitwise.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -518,7 +518,7 @@
       in
         try (fn () =>
           Goal.prove_internal ctxt [] prop 
-            (K (REPEAT_DETERM (resolve_tac @{thms upt_eq_list_intros} 1
+            (K (REPEAT_DETERM (resolve_tac ctxt @{thms upt_eq_list_intros} 1
                 ORELSE simp_tac (put_simpset word_ss ctxt) 1))) |> mk_meta_eq) ()
       end
   | _ => NONE;
--- a/src/LCF/LCF.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/LCF/LCF.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -322,7 +322,7 @@
   Scan.lift Args.name_inner_syntax >> (fn v => fn ctxt =>
     SIMPLE_METHOD' (fn i =>
       res_inst_tac ctxt [(("f", 0), v)] @{thm induct} i THEN
-      REPEAT (resolve_tac @{thms adm_lemmas} i)))
+      REPEAT (resolve_tac ctxt @{thms adm_lemmas} i)))
 *}
 
 lemma least_FIX: "f(p) = p \<Longrightarrow> FIX(f) << p"
@@ -381,7 +381,7 @@
 ML {*
 fun induct2_tac ctxt (f, g) i =
   res_inst_tac ctxt [(("f", 0), f), (("g", 0), g)] @{thm induct2} i THEN
-  REPEAT(resolve_tac @{thms adm_lemmas} i)
+  REPEAT(resolve_tac ctxt @{thms adm_lemmas} i)
 *}
 
 end
--- a/src/Provers/Arith/cancel_numerals.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Provers/Arith/cancel_numerals.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -92,12 +92,12 @@
     Option.map (export o Data.simplify_meta_eq ctxt)
       (if n2 <= n1 then
          Data.prove_conv
-           [Data.trans_tac reshape, resolve_tac [Data.bal_add1] 1,
+           [Data.trans_tac reshape, resolve_tac ctxt [Data.bal_add1] 1,
             Data.numeral_simp_tac ctxt] ctxt prems
            (t', Data.mk_bal (newshape(n1-n2,terms1'), Data.mk_sum T terms2'))
        else
          Data.prove_conv
-           [Data.trans_tac reshape, resolve_tac [Data.bal_add2] 1,
+           [Data.trans_tac reshape, resolve_tac ctxt [Data.bal_add2] 1,
             Data.numeral_simp_tac ctxt] ctxt prems
            (t', Data.mk_bal (Data.mk_sum T terms1', newshape(n2-n1,terms2'))))
   end
--- a/src/Provers/Arith/combine_numerals.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Provers/Arith/combine_numerals.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -83,7 +83,7 @@
   in
     Option.map (export o Data.simplify_meta_eq ctxt)
       (Data.prove_conv
-         [Data.trans_tac reshape, resolve_tac [Data.left_distrib] 1,
+         [Data.trans_tac reshape, resolve_tac ctxt [Data.left_distrib] 1,
           Data.numeral_simp_tac ctxt] ctxt
          (t', Data.mk_sum T (Data.mk_coeff(Data.add(m,n), u) :: terms)))
   end
--- a/src/Provers/Arith/fast_lin_arith.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Provers/Arith/fast_lin_arith.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -810,15 +810,15 @@
       fun just1 j =
         (* eliminate inequalities *)
         (if split_neq then
-          REPEAT_DETERM (eresolve_tac neqE i)
+          REPEAT_DETERM (eresolve_tac ctxt neqE i)
         else
           all_tac) THEN
           PRIMITIVE (trace_thm ctxt ["State after neqE:"]) THEN
           (* use theorems generated from the actual justifications *)
-          Subgoal.FOCUS (fn {prems, ...} => resolve_tac [mkthm ctxt prems j] 1) ctxt i
+          Subgoal.FOCUS (fn {prems, ...} => resolve_tac ctxt [mkthm ctxt prems j] 1) ctxt i
     in
       (* rewrite "[| A1; ...; An |] ==> B" to "[| A1; ...; An; ~B |] ==> False" *)
-      DETERM (resolve_tac [LA_Logic.notI, LA_Logic.ccontr] i) THEN
+      DETERM (resolve_tac ctxt [LA_Logic.notI, LA_Logic.ccontr] i) THEN
       (* user-defined preprocessing of the subgoal *)
       DETERM (LA_Data.pre_tac ctxt i) THEN
       PRIMITIVE (trace_thm ctxt ["State after pre_tac:"]) THEN
--- a/src/Provers/blast.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Provers/blast.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -488,8 +488,11 @@
 
 (*Resolution/matching tactics: if upd then the proof state may be updated.
   Matching makes the tactics more deterministic in the presence of Vars.*)
-fun emtac ctxt upd rl = TRACE ctxt rl (if upd then eresolve_tac [rl] else ematch_tac ctxt [rl]);
-fun rmtac ctxt upd rl = TRACE ctxt rl (if upd then resolve_tac [rl] else match_tac ctxt [rl]);
+fun emtac ctxt upd rl =
+  TRACE ctxt rl (if upd then eresolve_tac ctxt [rl] else ematch_tac ctxt [rl]);
+
+fun rmtac ctxt upd rl =
+  TRACE ctxt rl (if upd then resolve_tac ctxt [rl] else match_tac ctxt [rl]);
 
 (*Tableau rule from elimination rule.
   Flag "upd" says that the inference updated the branch.
@@ -624,7 +627,7 @@
 
 (*Tactic.  Convert *Goal* to negated assumption in FIRST position*)
 fun negOfGoal_tac ctxt i =
-  TRACE ctxt Data.ccontr (resolve_tac [Data.ccontr]) i THEN rotate_tac ~1 i;
+  TRACE ctxt Data.ccontr (resolve_tac ctxt [Data.ccontr]) i THEN rotate_tac ~1 i;
 
 fun traceTerm ctxt t =
   let val thy = Proof_Context.theory_of ctxt
--- a/src/Provers/classical.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Provers/classical.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -157,7 +157,7 @@
       val rule'' =
         rule' |> ALLGOALS (SUBGOAL (fn (goal, i) =>
           if i = 1 orelse redundant_hyp goal
-          then eresolve_tac [thin_rl] i
+          then eresolve0_tac [thin_rl] i
           else all_tac))
         |> Seq.hd
         |> Drule.zero_var_indexes;
@@ -180,11 +180,12 @@
   No backtracking if it finds an equal assumption.  Perhaps should call
   ematch_tac instead of eresolve_tac, but then cannot prove ZF/cantor.*)
 fun contr_tac ctxt =
-  eresolve_tac [Data.not_elim] THEN' (eq_assume_tac ORELSE' assume_tac ctxt);
+  eresolve_tac ctxt [Data.not_elim] THEN' (eq_assume_tac ORELSE' assume_tac ctxt);
 
 (*Finds P-->Q and P in the assumptions, replaces implication by Q.
   Could do the same thing for P<->Q and P... *)
-fun mp_tac ctxt i = eresolve_tac [Data.not_elim, Data.imp_elim] i THEN assume_tac ctxt i;
+fun mp_tac ctxt i =
+  eresolve_tac ctxt [Data.not_elim, Data.imp_elim] i THEN assume_tac ctxt i;
 
 (*Like mp_tac but instantiates no variables*)
 fun eq_mp_tac ctxt i = ematch_tac ctxt [Data.not_elim, Data.imp_elim] i THEN eq_assume_tac i;
@@ -199,7 +200,7 @@
   let fun addrl rl brls = (false, rl) :: (true, rl RSN (2, Data.swap)) :: brls in
     assume_tac ctxt ORELSE'
     contr_tac ctxt ORELSE'
-    biresolve_tac (fold_rev addrl rls [])
+    biresolve_tac ctxt (fold_rev addrl rls [])
   end;
 
 (*Duplication of hazardous rules, for complete provers*)
@@ -212,7 +213,7 @@
         SOME c => Context.proof_of c
       | NONE => Proof_Context.init_global (Thm.theory_of_thm th));
     val rl = (th RSN (2, revcut_rl)) |> Thm.assumption (SOME ctxt) 2 |> Seq.hd;
-  in rule_by_tactic ctxt (TRYALL (eresolve_tac [revcut_rl])) rl end;
+  in rule_by_tactic ctxt (TRYALL (eresolve_tac ctxt [revcut_rl])) rl end;
 
 
 (**** Classical rule sets ****)
@@ -679,9 +680,9 @@
   ctxt addWrapper (name, fn ctxt => fn tac1 => tac1 APPEND' tac2 ctxt);
 
 fun ctxt addD2 (name, thm) =
-  ctxt addafter (name, fn ctxt' => dresolve_tac [thm] THEN' assume_tac ctxt');
+  ctxt addafter (name, fn ctxt' => dresolve_tac ctxt' [thm] THEN' assume_tac ctxt');
 fun ctxt addE2 (name, thm) =
-  ctxt addafter (name, fn ctxt' => eresolve_tac [thm] THEN' assume_tac ctxt');
+  ctxt addafter (name, fn ctxt' => eresolve_tac ctxt' [thm] THEN' assume_tac ctxt');
 fun ctxt addSD2 (name, thm) =
   ctxt addSafter (name, fn ctxt' => dmatch_tac ctxt' [thm] THEN' eq_assume_tac);
 fun ctxt addSE2 (name, thm) =
@@ -902,7 +903,7 @@
     val ruleq = Drule.multi_resolves (SOME ctxt) facts rules;
     val _ = Method.trace ctxt rules;
   in
-    fn st => Seq.maps (fn rule => resolve_tac [rule] i st) ruleq
+    fn st => Seq.maps (fn rule => resolve_tac ctxt [rule] i st) ruleq
   end)
   THEN_ALL_NEW Goal.norm_hhf_tac ctxt;
 
--- a/src/Provers/hypsubst.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Provers/hypsubst.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -51,7 +51,7 @@
   val hyp_subst_thin         : bool Config.T
   val hyp_subst_tac          : Proof.context -> int -> tactic
   val blast_hyp_subst_tac    : Proof.context -> bool -> int -> tactic
-  val stac                   : thm -> int -> tactic
+  val stac                   : Proof.context -> thm -> int -> tactic
 end;
 
 functor Hypsubst(Data: HYPSUBST_DATA): HYPSUBST =
@@ -122,13 +122,14 @@
 
   in  eq_var_aux 0 t [] end;
 
-val thin_free_eq_tac = SUBGOAL (fn (t, i) => let
-     val (k, _) = eq_var false false false t
-     val ok = (eq_var false false true t |> fst) > k
-        handle EQ_VAR => true
-   in if ok then EVERY [rotate_tac k i, eresolve_tac [thin_rl] i, rotate_tac (~k) i]
+fun thin_free_eq_tac ctxt = SUBGOAL (fn (t, i) =>
+  let
+    val (k, _) = eq_var false false false t
+    val ok = (eq_var false false true t |> fst) > k handle EQ_VAR => true
+  in
+    if ok then EVERY [rotate_tac k i, eresolve_tac ctxt [thin_rl] i, rotate_tac (~k) i]
     else no_tac
-   end handle EQ_VAR => no_tac)
+  end handle EQ_VAR => no_tac)
 
 (*For the simpset.  Adds ALL suitable equalities, even if not first!
   No vars are allowed here, as simpsets are built from meta-assumptions*)
@@ -151,11 +152,11 @@
         val (k, (orient, is_free)) = eq_var bnd true true Bi
         val hyp_subst_ctxt = empty_simpset ctxt |> Simplifier.set_mksimps (K (mk_eqs bnd))
       in EVERY [rotate_tac k i, asm_lr_simp_tac hyp_subst_ctxt i,
-        if not is_free then eresolve_tac [thin_rl] i
-          else if orient then eresolve_tac [Data.rev_mp] i
-          else eresolve_tac [Data.sym RS Data.rev_mp] i,
+        if not is_free then eresolve_tac ctxt [thin_rl] i
+          else if orient then eresolve_tac ctxt [Data.rev_mp] i
+          else eresolve_tac ctxt [Data.sym RS Data.rev_mp] i,
         rotate_tac (~k) i,
-        if is_free then resolve_tac [Data.imp_intr] i else all_tac]
+        if is_free then resolve_tac ctxt [Data.imp_intr] i else all_tac]
       end handle THM _ => no_tac | EQ_VAR => no_tac)
 
 end;
@@ -194,7 +195,7 @@
       end
   | NONE => no_tac);
 
-val imp_intr_tac = resolve_tac [Data.imp_intr];
+fun imp_intr_tac ctxt = resolve_tac ctxt [Data.imp_intr];
 
 fun rev_dup_elim ctxt th = (th RSN (2, revcut_rl)) |> Thm.assumption (SOME ctxt) 2 |> Seq.hd;
 fun dup_subst ctxt = rev_dup_elim ctxt ssubst
@@ -211,11 +212,11 @@
           val rl = if orient then rl else Data.sym RS rl
       in
          DETERM
-           (EVERY [REPEAT_DETERM_N k (eresolve_tac [Data.rev_mp] i),
+           (EVERY [REPEAT_DETERM_N k (eresolve_tac ctxt [Data.rev_mp] i),
                    rotate_tac 1 i,
-                   REPEAT_DETERM_N (n-k) (eresolve_tac [Data.rev_mp] i),
+                   REPEAT_DETERM_N (n-k) (eresolve_tac ctxt [Data.rev_mp] i),
                    inst_subst_tac ctxt orient rl i,
-                   REPEAT_DETERM_N n (imp_intr_tac i THEN rotate_tac ~1 i)])
+                   REPEAT_DETERM_N n (imp_intr_tac ctxt i THEN rotate_tac ~1 i)])
       end
       handle THM _ => no_tac | EQ_VAR => no_tac);
 
@@ -225,7 +226,7 @@
 fun hyp_subst_tac_thin thin ctxt =
   REPEAT_DETERM1 o FIRST' [ematch_tac ctxt [Data.thin_refl],
     gen_hyp_subst_tac ctxt false, vars_gen_hyp_subst_tac ctxt false,
-    if thin then thin_free_eq_tac else K no_tac];
+    if thin then thin_free_eq_tac ctxt else K no_tac];
 
 val hyp_subst_thin = Attrib.setup_config_bool @{binding hypsubst_thin} (K false);
 
@@ -242,16 +243,16 @@
     substitutions in the arguments of a function Var. **)
 
 (*final re-reversal of the changed assumptions*)
-fun reverse_n_tac 0 i = all_tac
-  | reverse_n_tac 1 i = rotate_tac ~1 i
-  | reverse_n_tac n i =
-      REPEAT_DETERM_N n (rotate_tac ~1 i THEN eresolve_tac [Data.rev_mp] i) THEN
-      REPEAT_DETERM_N n (imp_intr_tac i THEN rotate_tac ~1 i);
+fun reverse_n_tac _ 0 i = all_tac
+  | reverse_n_tac _ 1 i = rotate_tac ~1 i
+  | reverse_n_tac ctxt n i =
+      REPEAT_DETERM_N n (rotate_tac ~1 i THEN eresolve_tac ctxt [Data.rev_mp] i) THEN
+      REPEAT_DETERM_N n (imp_intr_tac ctxt i THEN rotate_tac ~1 i);
 
 (*Use imp_intr, comparing the old hyps with the new ones as they come out.*)
-fun all_imp_intr_tac hyps i =
+fun all_imp_intr_tac ctxt hyps i =
   let
-    fun imptac (r, []) st = reverse_n_tac r i st
+    fun imptac (r, []) st = reverse_n_tac ctxt r i st
       | imptac (r, hyp::hyps) st =
           let
             val (hyp', _) =
@@ -260,8 +261,8 @@
               |> Data.dest_Trueprop |> Data.dest_imp;
             val (r', tac) =
               if Envir.aeconv (hyp, hyp')
-              then (r, imp_intr_tac i THEN rotate_tac ~1 i)
-              else (*leave affected hyps at end*) (r + 1, imp_intr_tac i);
+              then (r, imp_intr_tac ctxt i THEN rotate_tac ~1 i)
+              else (*leave affected hyps at end*) (r + 1, imp_intr_tac ctxt i);
           in
             (case Seq.pull (tac st) of
               NONE => Seq.single st
@@ -270,28 +271,29 @@
   in imptac (0, rev hyps) end;
 
 
-fun blast_hyp_subst_tac ctxt trace = SUBGOAL(fn (Bi,i) =>
-      let val (k, (symopt, _)) = eq_var false false false Bi
-          val hyps0 = map Data.dest_Trueprop (Logic.strip_assums_hyp Bi)
-          (*omit selected equality, returning other hyps*)
-          val hyps = List.take(hyps0, k) @ List.drop(hyps0, k+1)
-          val n = length hyps
-      in
-         if trace then tracing "Substituting an equality" else ();
-         DETERM
-           (EVERY [REPEAT_DETERM_N k (eresolve_tac [Data.rev_mp] i),
-                   rotate_tac 1 i,
-                   REPEAT_DETERM_N (n-k) (eresolve_tac [Data.rev_mp] i),
-                   inst_subst_tac ctxt symopt (if symopt then ssubst else Data.subst) i,
-                   all_imp_intr_tac hyps i])
-      end
-      handle THM _ => no_tac | EQ_VAR => no_tac);
+fun blast_hyp_subst_tac ctxt trace = SUBGOAL(fn (Bi, i) =>
+  let
+    val (k, (symopt, _)) = eq_var false false false Bi
+    val hyps0 = map Data.dest_Trueprop (Logic.strip_assums_hyp Bi)
+    (*omit selected equality, returning other hyps*)
+    val hyps = List.take(hyps0, k) @ List.drop(hyps0, k+1)
+    val n = length hyps
+  in
+    if trace then tracing "Substituting an equality" else ();
+    DETERM
+      (EVERY [REPEAT_DETERM_N k (eresolve_tac ctxt [Data.rev_mp] i),
+              rotate_tac 1 i,
+              REPEAT_DETERM_N (n-k) (eresolve_tac ctxt [Data.rev_mp] i),
+              inst_subst_tac ctxt symopt (if symopt then ssubst else Data.subst) i,
+              all_imp_intr_tac ctxt hyps i])
+  end
+  handle THM _ => no_tac | EQ_VAR => no_tac);
 
 (*apply an equality or definition ONCE;
   fails unless the substitution has an effect*)
-fun stac th =
+fun stac ctxt th =
   let val th' = th RS Data.rev_eq_reflection handle THM _ => th
-  in CHANGED_GOAL (resolve_tac [th' RS ssubst]) end;
+  in CHANGED_GOAL (resolve_tac ctxt [th' RS ssubst]) end;
 
 
 (* method setup *)
@@ -305,7 +307,8 @@
       (Scan.succeed (fn ctxt => SIMPLE_METHOD'
           (CHANGED_PROP o hyp_subst_tac_thin true ctxt)))
       "substitution using an assumption, eliminating assumptions" #>
-    Method.setup @{binding simplesubst} (Attrib.thm >> (fn th => K (SIMPLE_METHOD' (stac th))))
+    Method.setup @{binding simplesubst}
+      (Attrib.thm >> (fn th => fn ctxt => SIMPLE_METHOD' (stac ctxt th)))
       "simple substitution");
 
 end;
--- a/src/Provers/order.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Provers/order.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -1241,12 +1241,13 @@
    val prfs = gen_solve mkconcl thy (lesss, C);
    val (subgoals, prf) = mkconcl decomp less_thms thy C;
   in
-   Subgoal.FOCUS (fn {prems = asms, ...} =>
+   Subgoal.FOCUS (fn {context = ctxt', prems = asms, ...} =>
      let val thms = map (prove (prems @ asms)) prfs
-     in resolve_tac [prove thms prf] 1 end) ctxt n st
+     in resolve_tac ctxt' [prove thms prf] 1 end) ctxt n st
   end
   handle Contr p =>
-      (Subgoal.FOCUS (fn {prems = asms, ...} => resolve_tac [prove asms p] 1) ctxt n st
+      (Subgoal.FOCUS (fn {context = ctxt', prems = asms, ...} =>
+          resolve_tac ctxt' [prove asms p] 1) ctxt n st
         handle General.Subscript => Seq.empty)
    | Cannot => Seq.empty
    | General.Subscript => Seq.empty)
--- a/src/Provers/quantifier1.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Provers/quantifier1.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -64,8 +64,8 @@
 
 signature QUANTIFIER1 =
 sig
-  val prove_one_point_all_tac: tactic
-  val prove_one_point_ex_tac: tactic
+  val prove_one_point_all_tac: Proof.context -> tactic
+  val prove_one_point_ex_tac: Proof.context -> tactic
   val rearrange_all: Proof.context -> cterm -> thm option
   val rearrange_ex: Proof.context -> cterm -> thm option
   val rearrange_ball: (Proof.context -> tactic) -> Proof.context -> cterm -> thm option
@@ -126,10 +126,12 @@
       yield_singleton (Variable.import_terms true) (Logic.mk_equals tu) ctxt;
     val thm =
       Goal.prove ctxt' [] [] goal
-        (fn {context = ctxt'', ...} => resolve_tac [Data.iff_reflection] 1 THEN tac ctxt'');
+        (fn {context = ctxt'', ...} =>
+          resolve_tac ctxt'' [Data.iff_reflection] 1 THEN tac ctxt'');
   in singleton (Variable.export ctxt' ctxt) thm end;
 
-fun qcomm_tac qcomm qI i = REPEAT_DETERM (resolve_tac [qcomm] i THEN resolve_tac [qI] i);
+fun qcomm_tac ctxt qcomm qI i =
+  REPEAT_DETERM (resolve_tac ctxt [qcomm] i THEN resolve_tac ctxt [qI] i);
 
 (* Proves (? x0..xn. ... & x0 = t & ...) = (? x1..xn x0. x0 = t & ... & ...)
    Better: instantiate exI
@@ -137,11 +139,11 @@
 local
   val excomm = Data.ex_comm RS Data.iff_trans;
 in
-  val prove_one_point_ex_tac =
-    qcomm_tac excomm Data.iff_exI 1 THEN resolve_tac [Data.iffI] 1 THEN
+  fun prove_one_point_ex_tac ctxt =
+    qcomm_tac ctxt excomm Data.iff_exI 1 THEN resolve_tac ctxt [Data.iffI] 1 THEN
     ALLGOALS
-      (EVERY' [eresolve_tac [Data.exE], REPEAT_DETERM o eresolve_tac [Data.conjE],
-        resolve_tac [Data.exI],
+      (EVERY' [eresolve_tac ctxt [Data.exE], REPEAT_DETERM o eresolve_tac ctxt [Data.conjE],
+        resolve_tac ctxt [Data.exI],
         DEPTH_SOLVE_1 o ares_tac [Data.conjI]])
 end;
 
@@ -149,19 +151,19 @@
           (! x1..xn x0. x0 = t --> (... & ...) --> P x0)
 *)
 local
-  val tac =
+  fun tac ctxt =
     SELECT_GOAL
-      (EVERY1 [REPEAT o dresolve_tac [Data.uncurry],
-        REPEAT o resolve_tac [Data.impI],
-        eresolve_tac [Data.mp],
-        REPEAT o eresolve_tac [Data.conjE],
+      (EVERY1 [REPEAT o dresolve_tac ctxt [Data.uncurry],
+        REPEAT o resolve_tac ctxt [Data.impI],
+        eresolve_tac ctxt [Data.mp],
+        REPEAT o eresolve_tac ctxt [Data.conjE],
         REPEAT o ares_tac [Data.conjI]]);
   val allcomm = Data.all_comm RS Data.iff_trans;
 in
-  val prove_one_point_all_tac =
-    EVERY1 [qcomm_tac allcomm Data.iff_allI,
-      resolve_tac [Data.iff_allI],
-      resolve_tac [Data.iffI], tac, tac];
+  fun prove_one_point_all_tac ctxt =
+    EVERY1 [qcomm_tac ctxt allcomm Data.iff_allI,
+      resolve_tac ctxt [Data.iff_allI],
+      resolve_tac ctxt [Data.iffI], tac ctxt, tac ctxt];
 end
 
 fun renumber l u (Bound i) =
@@ -185,7 +187,7 @@
         NONE => NONE
       | SOME (xs, eq, Q) =>
           let val R = quantify all x T xs (Data.imp $ eq $ Q)
-          in SOME (prove_conv ctxt (F, R) (K prove_one_point_all_tac)) end)
+          in SOME (prove_conv ctxt (F, R) prove_one_point_all_tac) end)
   | _ => NONE);
 
 fun rearrange_ball tac ctxt ct =
@@ -207,7 +209,7 @@
         NONE => NONE
       | SOME (xs, eq, Q) =>
           let val R = quantify ex x T xs (Data.conj $ eq $ Q)
-          in SOME (prove_conv ctxt (F, R) (K prove_one_point_ex_tac)) end)
+          in SOME (prove_conv ctxt (F, R) prove_one_point_ex_tac) end)
   | _ => NONE);
 
 fun rearrange_bex tac ctxt ct =
--- a/src/Provers/quasi.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Provers/quasi.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -563,12 +563,14 @@
 
   val (subgoal, prf) = mkconcl_trans thy C;
  in
-  Subgoal.FOCUS (fn {prems, ...} =>
+  Subgoal.FOCUS (fn {context = ctxt', prems, ...} =>
     let val thms = map (prove prems) prfs
-    in resolve_tac [prove thms prf] 1 end) ctxt n st
+    in resolve_tac ctxt' [prove thms prf] 1 end) ctxt n st
  end
- handle Contr p => Subgoal.FOCUS (fn {prems, ...} => resolve_tac [prove prems p] 1) ctxt n st
-  | Cannot  => Seq.empty);
+ handle Contr p =>
+    Subgoal.FOCUS (fn {context = ctxt', prems, ...} =>
+      resolve_tac ctxt' [prove prems p] 1) ctxt n st
+  | Cannot => Seq.empty);
 
 
 (* quasi_tac - solves quasi orders *)
@@ -583,13 +585,13 @@
   val prfs = solveQuasiOrder thy (lesss, C);
   val (subgoals, prf) = mkconcl_quasi thy C;
  in
-  Subgoal.FOCUS (fn {prems, ...} =>
+  Subgoal.FOCUS (fn {context = ctxt', prems, ...} =>
     let val thms = map (prove prems) prfs
-    in resolve_tac [prove thms prf] 1 end) ctxt n st
+    in resolve_tac ctxt' [prove thms prf] 1 end) ctxt n st
  end
  handle Contr p =>
-    (Subgoal.FOCUS (fn {prems, ...} => resolve_tac [prove prems p] 1) ctxt n st
-      handle General.Subscript => Seq.empty)
+    (Subgoal.FOCUS (fn {context = ctxt', prems, ...} =>
+      resolve_tac ctxt' [prove prems p] 1) ctxt n st handle General.Subscript => Seq.empty)
   | Cannot => Seq.empty
   | General.Subscript => Seq.empty);
 
--- a/src/Provers/splitter.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Provers/splitter.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -99,7 +99,8 @@
 val lift = Goal.prove_global Pure.thy ["P", "Q", "R"]
   [Syntax.read_prop_global Pure.thy "!!x :: 'b. Q(x) == R(x) :: 'c"]
   (Syntax.read_prop_global Pure.thy "P(%x. Q(x)) == P(%x. R(x))")
-  (fn {context = ctxt, prems} => rewrite_goals_tac ctxt prems THEN resolve_tac [reflexive_thm] 1)
+  (fn {context = ctxt, prems} =>
+    rewrite_goals_tac ctxt prems THEN resolve_tac ctxt [reflexive_thm] 1)
 
 val _ $ _ $ (_ $ (_ $ abs_lift) $ _) = prop_of lift;
 
@@ -365,11 +366,11 @@
                    (case apsns of
                       [] => compose_tac ctxt (false, inst_split Ts t tt thm TB state i, 0) i state
                     | p::_ => EVERY [lift_tac Ts t p,
-                                     resolve_tac [reflexive_thm] (i+1),
+                                     resolve_tac ctxt [reflexive_thm] (i+1),
                                      lift_split_tac] state)
             end
   in COND (has_fewer_prems i) no_tac
-          (resolve_tac [meta_iffD] i THEN lift_split_tac)
+          (resolve_tac ctxt [meta_iffD] i THEN lift_split_tac)
   end;
 
 in (split_tac, exported_split_posns) end;  (* mk_case_split_tac *)
@@ -400,16 +401,16 @@
       (* does not work properly if the split variable is bound by a quantifier *)
               fun flat_prems_tac i = SUBGOAL (fn (t,i) =>
                            (if first_prem_is_disj t
-                            then EVERY[eresolve_tac [Data.disjE] i, rotate_tac ~1 i,
+                            then EVERY[eresolve_tac ctxt [Data.disjE] i, rotate_tac ~1 i,
                                        rotate_tac ~1  (i+1),
                                        flat_prems_tac (i+1)]
                             else all_tac)
-                           THEN REPEAT (eresolve_tac [Data.conjE,Data.exE] i)
-                           THEN REPEAT (dresolve_tac [Data.notnotD]   i)) i;
+                           THEN REPEAT (eresolve_tac ctxt [Data.conjE,Data.exE] i)
+                           THEN REPEAT (dresolve_tac ctxt [Data.notnotD]   i)) i;
           in if n<0 then  no_tac  else (DETERM (EVERY'
-                [rotate_tac n, eresolve_tac [Data.contrapos2],
+                [rotate_tac n, eresolve_tac ctxt [Data.contrapos2],
                  split_tac ctxt splits,
-                 rotate_tac ~1, eresolve_tac [Data.contrapos], rotate_tac ~1,
+                 rotate_tac ~1, eresolve_tac ctxt [Data.contrapos], rotate_tac ~1,
                  flat_prems_tac] i))
           end;
   in SUBGOAL tac
--- a/src/Provers/trancl.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Provers/trancl.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -541,11 +541,11 @@
   val prems = flat (map_index (mkasm_trancl rel o swap) Hs);
   val prfs = solveTrancl (prems, C);
  in
-  Subgoal.FOCUS (fn {prems, concl, ...} =>
+  Subgoal.FOCUS (fn {context = ctxt', prems, concl, ...} =>
     let
       val SOME (_, _, rel', _) = decomp (term_of concl);
       val thms = map (prove thy rel' prems) prfs
-    in resolve_tac [prove thy rel' thms prf] 1 end) ctxt n st
+    in resolve_tac ctxt' [prove thy rel' thms prf] 1 end) ctxt n st
  end
  handle Cannot => Seq.empty);
 
@@ -560,11 +560,11 @@
   val prems = flat (map_index (mkasm_rtrancl rel o swap) Hs);
   val prfs = solveRtrancl (prems, C);
  in
-  Subgoal.FOCUS (fn {prems, concl, ...} =>
+  Subgoal.FOCUS (fn {context = ctxt', prems, concl, ...} =>
     let
       val SOME (_, _, rel', _) = decomp (term_of concl);
       val thms = map (prove thy rel' prems) prfs
-    in resolve_tac [prove thy rel' thms prf] 1 end) ctxt n st
+    in resolve_tac ctxt' [prove thy rel' thms prf] 1 end) ctxt n st
  end
  handle Cannot => Seq.empty | General.Subscript => Seq.empty);
 
--- a/src/Provers/typedsimp.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Provers/typedsimp.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -109,16 +109,16 @@
 (*Single step for conditional rewriting: prove_cond_tac handles new subgoals.*)
 fun cond_step_tac ctxt (prove_cond_tac, congr_rls, asms) =
     asm_res_tac ctxt asms   ORELSE'  rewrite_res_tac ctxt  ORELSE'
-    (resolve_tac [trans, red_trans]  THEN'  prove_cond_tac)  ORELSE'
+    (resolve_tac ctxt [trans, red_trans]  THEN'  prove_cond_tac)  ORELSE'
     subconv_res_tac ctxt congr_rls;
 
 (*Unconditional normalization tactic*)
 fun norm_tac ctxt arg = REPEAT_FIRST (step_tac ctxt arg)  THEN
-    TRYALL (resolve_tac [red_if_equal]);
+    TRYALL (resolve_tac ctxt [red_if_equal]);
 
 (*Conditional normalization tactic*)
 fun cond_norm_tac ctxt arg = REPEAT_FIRST (cond_step_tac ctxt arg)  THEN
-    TRYALL (resolve_tac [red_if_equal]);
+    TRYALL (resolve_tac ctxt [red_if_equal]);
 
 end;
 end;
--- a/src/Pure/Isar/class.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Pure/Isar/class.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -47,7 +47,7 @@
     -> morphism -> local_theory -> local_theory
 
   (*tactics*)
-  val intro_classes_tac: thm list -> tactic
+  val intro_classes_tac: Proof.context -> thm list -> tactic
   val default_intro_tac: Proof.context -> thm list -> tactic
 
   (*diagnostics*)
@@ -437,7 +437,7 @@
         (fst o rules thy) sub];
     val classrel =
       Goal.prove_sorry_global thy [] [] (Logic.mk_classrel (sub, sup))
-        (K (EVERY (map (TRYALL o resolve_tac o single) intros)));
+        (fn {context = ctxt, ...} => EVERY (map (TRYALL o resolve_tac ctxt o single) intros));
     val diff_sort = Sign.complete_sort thy [sup]
       |> subtract (op =) (Sign.complete_sort thy [sub])
       |> filter (is_class thy);
@@ -702,7 +702,7 @@
 
 (** tactics and methods **)
 
-fun intro_classes_tac facts st =
+fun intro_classes_tac ctxt facts st =
   let
     val thy = Thm.theory_of_thm st;
     val classes = Sign.all_classes thy;
@@ -710,12 +710,12 @@
     val class_intros = map_filter (try (#intro o Axclass.get_info thy)) classes;
     val assm_intros = all_assm_intros thy;
   in
-    Method.intros_tac (class_trivs @ class_intros @ assm_intros) facts st
+    Method.intros_tac ctxt (class_trivs @ class_intros @ assm_intros) facts st
   end;
 
 fun default_intro_tac ctxt [] =
       COND Thm.no_prems no_tac
-        (intro_classes_tac [] ORELSE Locale.intro_locales_tac true ctxt [])
+        (intro_classes_tac ctxt [] ORELSE Locale.intro_locales_tac true ctxt [])
   | default_intro_tac _ _ = no_tac;
 
 fun default_tac rules ctxt facts =
@@ -723,7 +723,7 @@
     default_intro_tac ctxt facts;
 
 val _ = Theory.setup
- (Method.setup @{binding intro_classes} (Scan.succeed (K (METHOD intro_classes_tac)))
+ (Method.setup @{binding intro_classes} (Scan.succeed (METHOD o intro_classes_tac))
     "back-chain introduction rules of classes" #>
   Method.setup @{binding default} (Attrib.thms >> (METHOD oo default_tac))
     "apply some intro/elim rule");
--- a/src/Pure/Isar/class_declaration.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Pure/Isar/class_declaration.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -56,7 +56,7 @@
         val loc_intro_tac =
           (case Locale.intros_of thy class of
             (_, NONE) => all_tac
-          | (_, SOME intro) => ALLGOALS (resolve_tac [intro]));
+          | (_, SOME intro) => ALLGOALS (resolve_tac empty_ctxt [intro]));
         val tac = loc_intro_tac
           THEN ALLGOALS (Proof_Context.fact_tac empty_ctxt (sup_axioms @ the_list assm_axiom));
       in Element.prove_witness empty_ctxt prop tac end) some_prop;
--- a/src/Pure/Isar/element.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Pure/Isar/element.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -270,14 +270,14 @@
   Witness (t,
     Thm.close_derivation
       (Goal.prove ctxt [] [] (mark_witness t)
-        (fn _ => resolve_tac [Drule.protectI] 1 THEN tac)));
+        (fn _ => resolve_tac ctxt [Drule.protectI] 1 THEN tac)));
 
 
 local
 
 val refine_witness =
-  Proof.refine (Method.Basic (K (NO_CASES o
-    K (ALLGOALS (CONJUNCTS (ALLGOALS (CONJUNCTS (TRYALL (resolve_tac [Drule.protectI])))))))));
+  Proof.refine (Method.Basic (fn ctxt => NO_CASES o
+    K (ALLGOALS (CONJUNCTS (ALLGOALS (CONJUNCTS (TRYALL (resolve_tac ctxt [Drule.protectI]))))))));
 
 fun gen_witness_proof proof after_qed wit_propss eq_props =
   let
--- a/src/Pure/Isar/local_defs.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Pure/Isar/local_defs.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -225,7 +225,7 @@
           ALLGOALS
             (CONVERSION (meta_rewrite_conv ctxt'') THEN'
               rewrite_goal_tac ctxt'' [def] THEN'
-              resolve_tac [Drule.reflexive_thm]))
+              resolve_tac ctxt'' [Drule.reflexive_thm]))
       handle ERROR msg => cat_error msg "Failed to prove definitional specification";
   in (((c, T), rhs), prove) end;
 
--- a/src/Pure/Isar/locale.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Pure/Isar/locale.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -636,7 +636,7 @@
 (* Tactics *)
 
 fun gen_intro_locales_tac intros_tac eager ctxt =
-  intros_tac
+  intros_tac ctxt
     (get_witnesses ctxt @ get_intros ctxt @ (if eager then get_unfolds ctxt else []));
 
 val intro_locales_tac = gen_intro_locales_tac Method.intros_tac;
--- a/src/Pure/Isar/method.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Pure/Isar/method.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -23,7 +23,7 @@
   val unfold: thm list -> Proof.context -> method
   val fold: thm list -> Proof.context -> method
   val atomize: bool -> Proof.context -> method
-  val this: method
+  val this: Proof.context -> method
   val fact: thm list -> Proof.context -> method
   val assm_tac: Proof.context -> int -> tactic
   val all_assm_tac: Proof.context -> tactic
@@ -32,8 +32,8 @@
   val trace: Proof.context -> thm list -> unit
   val rule_tac: Proof.context -> thm list -> thm list -> int -> tactic
   val some_rule_tac: Proof.context -> thm list -> thm list -> int -> tactic
-  val intros_tac: thm list -> thm list -> tactic
-  val try_intros_tac: thm list -> thm list -> tactic
+  val intros_tac: Proof.context -> thm list -> thm list -> tactic
+  val try_intros_tac: Proof.context -> thm list -> thm list -> tactic
   val rule: Proof.context -> thm list -> method
   val erule: Proof.context -> int -> thm list -> method
   val drule: Proof.context -> int -> thm list -> method
@@ -99,7 +99,7 @@
 local
 
 fun cut_rule_tac rule =
-  resolve_tac [Drule.forall_intr_vars rule COMP_INCR revcut_rl];
+  resolve0_tac [Drule.forall_intr_vars rule COMP_INCR revcut_rl];
 
 in
 
@@ -120,7 +120,7 @@
 
 fun cheating ctxt int = METHOD (fn _ => fn st =>
   if int orelse Config.get ctxt quick_and_dirty then
-    ALLGOALS Skip_Proof.cheat_tac st
+    ALLGOALS (Skip_Proof.cheat_tac ctxt) st
   else error "Cheating requires quick_and_dirty mode!");
 
 
@@ -146,7 +146,7 @@
 
 (* this -- resolve facts directly *)
 
-val this = METHOD (EVERY o map (HEADGOAL o resolve_tac o single));
+fun this ctxt = METHOD (EVERY o map (HEADGOAL o resolve_tac ctxt o single));
 
 
 (* fact -- composition by facts from context *)
@@ -159,17 +159,17 @@
 
 local
 
-fun cond_rtac cond rule = SUBGOAL (fn (prop, i) =>
+fun cond_rtac ctxt cond rule = SUBGOAL (fn (prop, i) =>
   if cond (Logic.strip_assums_concl prop)
-  then resolve_tac [rule] i else no_tac);
+  then resolve_tac ctxt [rule] i else no_tac);
 
 in
 
 fun assm_tac ctxt =
   assume_tac ctxt APPEND'
   Goal.assume_rule_tac ctxt APPEND'
-  cond_rtac (can Logic.dest_equals) Drule.reflexive_thm APPEND'
-  cond_rtac (can Logic.dest_term) Drule.termI;
+  cond_rtac ctxt (can Logic.dest_equals) Drule.reflexive_thm APPEND'
+  cond_rtac ctxt (can Logic.dest_term) Drule.termI;
 
 fun all_assm_tac ctxt =
   let
@@ -180,7 +180,7 @@
 
 fun assumption ctxt = METHOD (HEADGOAL o
   (fn [] => assm_tac ctxt
-    | [fact] => solve_tac [fact]
+    | [fact] => solve_tac ctxt [fact]
     | _ => K no_tac));
 
 fun finish immed ctxt =
@@ -203,9 +203,9 @@
 
 fun gen_rule_tac tac ctxt rules facts =
   (fn i => fn st =>
-    if null facts then tac rules i st
+    if null facts then tac ctxt rules i st
     else
-      Seq.maps (fn rule => (tac o single) rule i st)
+      Seq.maps (fn rule => (tac ctxt o single) rule i st)
         (Drule.multi_resolves (SOME ctxt) facts rules))
   THEN_ALL_NEW Goal.norm_hhf_tac ctxt;
 
@@ -238,9 +238,9 @@
 
 (* intros_tac -- pervasive search spanned by intro rules *)
 
-fun gen_intros_tac goals intros facts =
+fun gen_intros_tac goals ctxt intros facts =
   goals (insert_tac facts THEN'
-      REPEAT_ALL_NEW (resolve_tac intros))
+      REPEAT_ALL_NEW (resolve_tac ctxt intros))
     THEN Tactic.distinct_subgoals_tac;
 
 val intros_tac = gen_intros_tac ALLGOALS;
@@ -313,7 +313,7 @@
 fun primitive_text r = Basic (SIMPLE_METHOD o PRIMITIVE o r);
 val succeed_text = Basic (K succeed);
 val default_text = Source (Token.src ("default", Position.none) []);
-val this_text = Basic (K this);
+val this_text = Basic this;
 val done_text = Basic (K (SIMPLE_METHOD all_tac));
 fun sorry_text int = Basic (fn ctxt => cheating ctxt int);
 
@@ -603,7 +603,7 @@
   setup @{binding erule} (xrule_meth erule) "apply rule in elimination manner (improper)" #>
   setup @{binding drule} (xrule_meth drule) "apply rule in destruct manner (improper)" #>
   setup @{binding frule} (xrule_meth frule) "apply rule in forward manner (improper)" #>
-  setup @{binding this} (Scan.succeed (K this)) "apply current facts as rules" #>
+  setup @{binding this} (Scan.succeed this) "apply current facts as rules" #>
   setup @{binding fact} (Attrib.thms >> fact) "composition by facts from context" #>
   setup @{binding assumption} (Scan.succeed assumption)
     "proof by assumption, preferring facts" #>
--- a/src/Pure/Isar/proof.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Pure/Isar/proof.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -440,12 +440,12 @@
       Goal.norm_hhf_tac ctxt THEN'
       SUBGOAL (fn (goal, i) =>
         if can Logic.unprotect (Logic.strip_assums_concl goal) then
-          eresolve_tac [Drule.protectI] i THEN finish_tac ctxt (n - 1) i
+          eresolve_tac ctxt [Drule.protectI] i THEN finish_tac ctxt (n - 1) i
         else finish_tac ctxt (n - 1) (i + 1));
 
 fun goal_tac ctxt rule =
   Goal.norm_hhf_tac ctxt THEN'
-  resolve_tac [rule] THEN'
+  resolve_tac ctxt [rule] THEN'
   finish_tac ctxt (Thm.nprems_of rule);
 
 fun FINDGOAL tac st =
@@ -883,9 +883,9 @@
   in map (Logic.mk_term o Var) vars end;
 
 fun refine_terms n =
-  refine (Method.Basic (K (NO_CASES o
+  refine (Method.Basic (fn ctxt => NO_CASES o
     K (HEADGOAL (PRECISE_CONJUNCTS n
-      (HEADGOAL (CONJUNCTS (ALLGOALS (resolve_tac [Drule.termI])))))))))
+      (HEADGOAL (CONJUNCTS (ALLGOALS (resolve_tac ctxt [Drule.termI]))))))))
   #> Seq.hd;
 
 in
--- a/src/Pure/Tools/find_theorems.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Pure/Tools/find_theorems.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -188,9 +188,9 @@
 
     fun limited_etac thm i =
       Seq.take (Options.default_int @{system_option find_theorems_tactic_limit}) o
-        eresolve_tac [thm] i;
+        eresolve_tac ctxt' [thm] i;
     fun try_thm thm =
-      if Thm.no_prems thm then resolve_tac [thm] 1 goal'
+      if Thm.no_prems thm then resolve_tac ctxt' [thm] 1 goal'
       else
         (limited_etac thm THEN_ALL_NEW (Goal.norm_hhf_tac ctxt' THEN' Method.assm_tac ctxt'))
           1 goal';
--- a/src/Pure/Tools/rule_insts.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Pure/Tools/rule_insts.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -338,13 +338,13 @@
 (*warning: rule_tac etc. refer to dynamic subgoal context!*)
 
 val _ = Theory.setup
- (Method.setup @{binding rule_tac} (method res_inst_tac (K resolve_tac))
+ (Method.setup @{binding rule_tac} (method res_inst_tac resolve_tac)
     "apply rule (dynamic instantiation)" #>
-  Method.setup @{binding erule_tac} (method eres_inst_tac (K eresolve_tac))
+  Method.setup @{binding erule_tac} (method eres_inst_tac eresolve_tac)
     "apply rule in elimination manner (dynamic instantiation)" #>
-  Method.setup @{binding drule_tac} (method dres_inst_tac (K dresolve_tac))
+  Method.setup @{binding drule_tac} (method dres_inst_tac dresolve_tac)
     "apply rule in destruct manner (dynamic instantiation)" #>
-  Method.setup @{binding frule_tac} (method forw_inst_tac (K forward_tac))
+  Method.setup @{binding frule_tac} (method forw_inst_tac forward_tac)
     "apply rule in forward manner (dynamic instantiation)" #>
   Method.setup @{binding cut_tac} (method cut_inst_tac (K cut_rules_tac))
     "cut rule (dynamic instantiation)" #>
--- a/src/Pure/goal.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Pure/goal.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -205,7 +205,7 @@
     val stmt = Thm.weaken_sorts sorts (Conjunction.mk_conjunction_balanced cprops);
 
     fun tac' args st =
-      if skip then ALLGOALS Skip_Proof.cheat_tac st before Skip_Proof.report ctxt
+      if skip then ALLGOALS (Skip_Proof.cheat_tac ctxt) st before Skip_Proof.report ctxt
       else tac args st;
     fun result () =
       (case SINGLE (tac' {prems = prems, context = ctxt'}) (init stmt) of
@@ -255,7 +255,7 @@
 
 fun prove_sorry ctxt xs asms prop tac =
   if Config.get ctxt quick_and_dirty then
-    prove ctxt xs asms prop (fn _ => ALLGOALS Skip_Proof.cheat_tac)
+    prove ctxt xs asms prop (fn _ => ALLGOALS (Skip_Proof.cheat_tac ctxt))
   else (if future_enabled 1 then prove_future_pri ~2 else prove) ctxt xs asms prop tac;
 
 fun prove_sorry_global thy xs asms prop tac =
@@ -294,7 +294,7 @@
 
 val adhoc_conjunction_tac = REPEAT_ALL_NEW
   (SUBGOAL (fn (goal, i) =>
-    if can Logic.dest_conjunction goal then resolve_tac [Conjunction.conjunctionI] i
+    if can Logic.dest_conjunction goal then resolve0_tac [Conjunction.conjunctionI] i
     else no_tac));
 
 val conjunction_tac = SUBGOAL (fn (goal, i) =>
@@ -318,7 +318,7 @@
 (* hhf normal form *)
 
 fun norm_hhf_tac ctxt =
-  resolve_tac [Drule.asm_rl]  (*cheap approximation -- thanks to builtin Logic.flatten_params*)
+  resolve_tac ctxt [Drule.asm_rl]  (*cheap approximation -- thanks to builtin Logic.flatten_params*)
   THEN' SUBGOAL (fn (t, i) =>
     if Drule.is_norm_hhf t then all_tac
     else rewrite_goal_tac ctxt Drule.norm_hhf_eqs i);
@@ -336,7 +336,7 @@
     val goal'' = Drule.cterm_rule (singleton (Variable.export ctxt' ctxt)) goal';
     val Rs = filter (non_atomic o Thm.term_of) (Drule.strip_imp_prems goal'');
     val tacs = Rs |> map (fn R =>
-      eresolve_tac [Raw_Simplifier.norm_hhf ctxt (Thm.trivial R)] THEN_ALL_NEW assume_tac ctxt);
+      eresolve_tac ctxt [Raw_Simplifier.norm_hhf ctxt (Thm.trivial R)] THEN_ALL_NEW assume_tac ctxt);
   in fold_rev (curry op APPEND') tacs (K no_tac) i end);
 
 end;
--- a/src/Pure/raw_simplifier.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Pure/raw_simplifier.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -1309,7 +1309,7 @@
   in bottomc (mode, Option.map (Drule.flexflex_unique (SOME ctxt)) oo prover, maxidx) ctxt ct end;
 
 val simple_prover =
-  SINGLE o (fn ctxt => ALLGOALS (resolve_tac (prems_of ctxt)));
+  SINGLE o (fn ctxt => ALLGOALS (resolve_tac ctxt (prems_of ctxt)));
 
 fun rewrite _ _ [] = Thm.reflexive
   | rewrite ctxt full thms =
--- a/src/Pure/simplifier.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Pure/simplifier.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -384,7 +384,7 @@
     val trivialities = Drule.reflexive_thm :: trivs;
 
     fun unsafe_solver_tac ctxt =
-      FIRST' [resolve_tac (trivialities @ Raw_Simplifier.prems_of ctxt), assume_tac ctxt];
+      FIRST' [resolve_tac ctxt (trivialities @ Raw_Simplifier.prems_of ctxt), assume_tac ctxt];
     val unsafe_solver = mk_solver "easy unsafe" unsafe_solver_tac;
 
     (*no premature instantiation of variables during simplification*)
--- a/src/Pure/skip_proof.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Pure/skip_proof.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -12,7 +12,7 @@
   val report: Proof.context -> unit
   val make_thm_cterm: cterm -> thm
   val make_thm: theory -> term -> thm
-  val cheat_tac: int -> tactic
+  val cheat_tac: Proof.context -> int -> tactic
 end;
 
 structure Skip_Proof: SKIP_PROOF =
@@ -37,7 +37,7 @@
 
 (* cheat_tac *)
 
-fun cheat_tac i st =
-  resolve_tac [make_thm (Thm.theory_of_thm st) (Var (("A", 0), propT))] i st;
+fun cheat_tac ctxt i st =
+  resolve_tac ctxt [make_thm (Thm.theory_of_thm st) (Var (("A", 0), propT))] i st;
 
 end;
--- a/src/Pure/tactic.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Pure/tactic.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -12,18 +12,23 @@
   val eq_assume_tac: int -> tactic
   val compose_tac: Proof.context -> (bool * thm * int) -> int -> tactic
   val make_elim: thm -> thm
-  val biresolve_tac: (bool * thm) list -> int -> tactic
-  val resolve_tac: thm list -> int -> tactic
-  val eresolve_tac: thm list -> int -> tactic
-  val forward_tac: thm list -> int -> tactic
-  val dresolve_tac: thm list -> int -> tactic
+  val biresolve0_tac: (bool * thm) list -> int -> tactic
+  val biresolve_tac: Proof.context -> (bool * thm) list -> int -> tactic
+  val resolve0_tac: thm list -> int -> tactic
+  val resolve_tac: Proof.context -> thm list -> int -> tactic
+  val eresolve0_tac: thm list -> int -> tactic
+  val eresolve_tac: Proof.context -> thm list -> int -> tactic
+  val forward0_tac: thm list -> int -> tactic
+  val forward_tac: Proof.context -> thm list -> int -> tactic
+  val dresolve0_tac: thm list -> int -> tactic
+  val dresolve_tac: Proof.context -> thm list -> int -> tactic
   val atac: int -> tactic
   val rtac: thm -> int -> tactic
   val dtac: thm -> int -> tactic
   val etac: thm -> int -> tactic
   val ftac: thm -> int -> tactic
   val ares_tac: thm list -> int -> tactic
-  val solve_tac: thm list -> int -> tactic
+  val solve_tac: Proof.context -> thm list -> int -> tactic
   val bimatch_tac: Proof.context -> (bool * thm) list -> int -> tactic
   val match_tac: Proof.context -> thm list -> int -> tactic
   val ematch_tac: Proof.context -> thm list -> int -> tactic
@@ -50,7 +55,7 @@
   val rotate_tac: int -> int -> tactic
   val defer_tac: int -> tactic
   val prefer_tac: int -> tactic
-  val filter_prems_tac: (term -> bool) -> int -> tactic
+  val filter_prems_tac: Proof.context -> (term -> bool) -> int -> tactic
 end;
 
 signature TACTIC =
@@ -114,30 +119,35 @@
 fun make_elim rl = zero_var_indexes (rl RS revcut_rl);
 
 (*Attack subgoal i by resolution, using flags to indicate elimination rules*)
-fun biresolve_tac brules i = PRIMSEQ (Thm.biresolution NONE false brules i);
+fun biresolve0_tac brules i = PRIMSEQ (Thm.biresolution NONE false brules i);
+fun biresolve_tac ctxt brules i = PRIMSEQ (Thm.biresolution (SOME ctxt) false brules i);
 
 (*Resolution: the simple case, works for introduction rules*)
-fun resolve_tac rules = biresolve_tac (map (pair false) rules);
+fun resolve0_tac rules = biresolve0_tac (map (pair false) rules);
+fun resolve_tac ctxt rules = biresolve_tac ctxt (map (pair false) rules);
 
 (*Resolution with elimination rules only*)
-fun eresolve_tac rules = biresolve_tac (map (pair true) rules);
+fun eresolve0_tac rules = biresolve0_tac (map (pair true) rules);
+fun eresolve_tac ctxt rules = biresolve_tac ctxt (map (pair true) rules);
 
 (*Forward reasoning using destruction rules.*)
-fun forward_tac rls = resolve_tac (map make_elim rls) THEN' atac;
+fun forward0_tac rls = resolve0_tac (map make_elim rls) THEN' atac;
+fun forward_tac ctxt rls = resolve_tac ctxt (map make_elim rls) THEN' atac;
 
 (*Like forward_tac, but deletes the assumption after use.*)
-fun dresolve_tac rls = eresolve_tac (map make_elim rls);
+fun dresolve0_tac rls = eresolve0_tac (map make_elim rls);
+fun dresolve_tac ctxt rls = eresolve_tac ctxt (map make_elim rls);
 
 (*Shorthand versions: for resolution with a single theorem*)
-fun rtac rl =  resolve_tac [rl];
-fun dtac rl = dresolve_tac [rl];
-fun etac rl = eresolve_tac [rl];
-fun ftac rl =  forward_tac [rl];
+fun rtac rl =  resolve0_tac [rl];
+fun dtac rl = dresolve0_tac [rl];
+fun etac rl = eresolve0_tac [rl];
+fun ftac rl =  forward0_tac [rl];
 
 (*Use an assumption or some rules ... A popular combination!*)
-fun ares_tac rules = atac  ORELSE'  resolve_tac rules;
+fun ares_tac rules = atac  ORELSE'  resolve0_tac rules;
 
-fun solve_tac rules = resolve_tac rules THEN_ALL_NEW atac;
+fun solve_tac ctxt rules = resolve_tac ctxt rules THEN_ALL_NEW assume_tac ctxt;
 
 (*Matching tactics -- as above, but forbid updating of state*)
 fun bimatch_tac ctxt brules i = PRIMSEQ (Thm.biresolution (SOME ctxt) true brules i);
@@ -175,7 +185,7 @@
 
 (*The conclusion of the rule gets assumed in subgoal i,
   while subgoal i+1,... are the premises of the rule.*)
-fun cut_tac rule i = resolve_tac [cut_rl] i THEN resolve_tac [rule] (i + 1);
+fun cut_tac rule i = resolve0_tac [cut_rl] i THEN resolve0_tac [rule] (i + 1);
 
 (*"Cut" a list of rules into the goal.  Their premises will become new
   subgoals.*)
@@ -300,12 +310,12 @@
 fun prefer_tac i = PRIMITIVE (Thm.permute_prems (i - 1) 1 #> Thm.permute_prems 0 ~1);
 
 (* remove premises that do not satisfy p; fails if all prems satisfy p *)
-fun filter_prems_tac p =
+fun filter_prems_tac ctxt p =
   let fun Then NONE tac = SOME tac
         | Then (SOME tac) tac' = SOME(tac THEN' tac');
       fun thins H (tac,n) =
         if p H then (tac,n+1)
-        else (Then tac (rotate_tac n THEN' eresolve_tac [thin_rl]),0);
+        else (Then tac (rotate_tac n THEN' eresolve_tac ctxt [thin_rl]),0);
   in SUBGOAL(fn (subg,n) =>
        let val Hs = Logic.strip_assums_hyp subg
        in case fst(fold thins Hs (NONE,0)) of
--- a/src/Sequents/LK.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Sequents/LK.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -180,7 +180,7 @@
    apply (tactic {*
      REPEAT (rtac @{thm cut} 1 THEN
        DEPTH_SOLVE_1
-         (resolve_tac [@{thm thinL}, @{thm thinR}, @{thm p2} COMP @{thm monotonic}] 1) THEN
+         (resolve_tac @{context} [@{thm thinL}, @{thm thinR}, @{thm p2} COMP @{thm monotonic}] 1) THEN
            Cla.safe_tac @{context} 1) *})
   done
 
@@ -193,7 +193,7 @@
    apply (tactic {*
      REPEAT (rtac @{thm cut} 1 THEN
        DEPTH_SOLVE_1
-         (resolve_tac [@{thm thinL}, @{thm thinR}, @{thm p2} COMP @{thm monotonic}] 1) THEN
+         (resolve_tac @{context} [@{thm thinL}, @{thm thinR}, @{thm p2} COMP @{thm monotonic}] 1) THEN
            Cla.safe_tac @{context} 1) *})
   done
 
--- a/src/Sequents/modal.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Sequents/modal.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -50,22 +50,22 @@
 (*Like filt_resolve_tac, using could_resolve_seq
   Much faster than resolve_tac when there are many rules.
   Resolve subgoal i using the rules, unless more than maxr are compatible. *)
-fun filseq_resolve_tac rules maxr = SUBGOAL(fn (prem,i) =>
+fun filseq_resolve_tac ctxt rules maxr = SUBGOAL(fn (prem,i) =>
   let val rls = filter_thms could_resolve_seq (maxr+1, prem, rules)
-  in  if length rls > maxr  then  no_tac  else resolve_tac rls i
+  in  if length rls > maxr  then  no_tac  else resolve_tac ctxt rls i
   end);
 
-fun fresolve_tac rls n = filseq_resolve_tac rls 999 n;
+fun fresolve_tac ctxt rls n = filseq_resolve_tac ctxt rls 999 n;
 
 (* NB No back tracking possible with aside rules *)
 
 val aside_net = Tactic.build_net Modal_Rule.aside_rls;
 fun aside_tac ctxt n = DETERM (REPEAT (filt_resolve_from_net_tac ctxt 999 aside_net n));
-fun rule_tac ctxt rls n = fresolve_tac rls n THEN aside_tac ctxt n;
+fun rule_tac ctxt rls n = fresolve_tac ctxt rls n THEN aside_tac ctxt n;
 
-val fres_safe_tac = fresolve_tac Modal_Rule.safe_rls;
-fun fres_unsafe_tac ctxt = fresolve_tac Modal_Rule.unsafe_rls THEN' aside_tac ctxt;
-val fres_bound_tac = fresolve_tac Modal_Rule.bound_rls;
+fun fres_safe_tac ctxt = fresolve_tac ctxt Modal_Rule.safe_rls;
+fun fres_unsafe_tac ctxt = fresolve_tac ctxt Modal_Rule.unsafe_rls THEN' aside_tac ctxt;
+fun fres_bound_tac ctxt = fresolve_tac ctxt Modal_Rule.bound_rls;
 
 fun UPTOGOAL n tf = let fun tac i = if i<n then all_tac
                                     else tf(i) THEN tac(i-1)
@@ -75,16 +75,16 @@
 fun solven_tac ctxt d n st = st |>
  (if d < 0 then no_tac
   else if nprems_of st = 0 then all_tac
-  else (DETERM(fres_safe_tac n) THEN UPTOGOAL n (solven_tac ctxt d)) ORELSE
+  else (DETERM(fres_safe_tac ctxt n) THEN UPTOGOAL n (solven_tac ctxt d)) ORELSE
            ((fres_unsafe_tac ctxt n  THEN UPTOGOAL n (solven_tac ctxt d)) APPEND
-             (fres_bound_tac n  THEN UPTOGOAL n (solven_tac ctxt (d - 1)))));
+             (fres_bound_tac ctxt n  THEN UPTOGOAL n (solven_tac ctxt (d - 1)))));
 
 fun solve_tac ctxt d =
   rewrite_goals_tac ctxt Modal_Rule.rewrite_rls THEN solven_tac ctxt d 1;
 
 fun step_tac ctxt n =
   COND (has_fewer_prems 1) all_tac
-       (DETERM(fres_safe_tac n) ORELSE
-        (fres_unsafe_tac ctxt n APPEND fres_bound_tac n));
+       (DETERM(fres_safe_tac ctxt n) ORELSE
+        (fres_unsafe_tac ctxt n APPEND fres_bound_tac ctxt n));
 
 end;
--- a/src/Sequents/prover.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Sequents/prover.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -146,13 +146,13 @@
 (*Like filt_resolve_tac, using could_resolve_seq
   Much faster than resolve_tac when there are many rules.
   Resolve subgoal i using the rules, unless more than maxr are compatible. *)
-fun filseq_resolve_tac rules maxr = SUBGOAL(fn (prem,i) =>
+fun filseq_resolve_tac ctxt rules maxr = SUBGOAL(fn (prem,i) =>
   let val rls = filter_thms could_resolve_seq (maxr+1, prem, rules)
   in  if length rls > maxr  then  no_tac
           else (*((rtac derelict 1 THEN rtac impl 1
                  THEN (rtac identity 2 ORELSE rtac ll_mp 2)
                  THEN rtac context1 1)
-                 ORELSE *) resolve_tac rls i
+                 ORELSE *) resolve_tac ctxt rls i
   end);
 
 
@@ -170,23 +170,23 @@
   The abstraction over state prevents needless divergence in recursion.
   The 9999 should be a parameter, to delay treatment of flexible goals. *)
 
-fun RESOLVE_THEN rules =
+fun RESOLVE_THEN ctxt rules =
   let val [rls0,rls1,rls2] = partition_list has_prems 0 2 rules;
       fun tac nextac i state = state |>
-             (filseq_resolve_tac rls0 9999 i
+             (filseq_resolve_tac ctxt rls0 9999 i
               ORELSE
-              (DETERM(filseq_resolve_tac rls1 9999 i) THEN  TRY(nextac i))
+              (DETERM(filseq_resolve_tac ctxt rls1 9999 i) THEN  TRY(nextac i))
               ORELSE
-              (DETERM(filseq_resolve_tac rls2 9999 i) THEN  TRY(nextac(i+1))
+              (DETERM(filseq_resolve_tac ctxt rls2 9999 i) THEN  TRY(nextac(i+1))
                                             THEN  TRY(nextac i)))
   in  tac  end;
 
 
 
 (*repeated resolution applied to the designated goal*)
-fun reresolve_tac rules =
+fun reresolve_tac ctxt rules =
   let
-    val restac = RESOLVE_THEN rules;  (*preprocessing done now*)
+    val restac = RESOLVE_THEN ctxt rules;  (*preprocessing done now*)
     fun gtac i = restac gtac i;
   in gtac end;
 
@@ -194,8 +194,8 @@
 fun repeat_goal_tac ctxt =
   let
     val (safes, unsafes) = get_rules ctxt;
-    val restac = RESOLVE_THEN safes;
-    val lastrestac = RESOLVE_THEN unsafes;
+    val restac = RESOLVE_THEN ctxt safes;
+    val lastrestac = RESOLVE_THEN ctxt unsafes;
     fun gtac i =
       restac gtac i ORELSE
        (if Config.get ctxt trace then print_tac ctxt "" THEN lastrestac gtac i
@@ -204,11 +204,11 @@
 
 
 (*Tries safe rules only*)
-fun safe_tac ctxt = reresolve_tac (#1 (get_rules ctxt));
+fun safe_tac ctxt = reresolve_tac ctxt (#1 (get_rules ctxt));
 
 (*Tries a safe rule or else a unsafe rule.  Single-step for tracing. *)
 fun step_tac ctxt =
-  safe_tac ctxt ORELSE' filseq_resolve_tac (#2 (get_rules ctxt)) 9999;
+  safe_tac ctxt ORELSE' filseq_resolve_tac ctxt (#2 (get_rules ctxt)) 9999;
 
 
 (* Tactic for reducing a goal, using Predicate Calculus rules.
--- a/src/Sequents/simpdata.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Sequents/simpdata.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -43,7 +43,7 @@
 (*Replace premises x=y, X<->Y by X==Y*)
 fun mk_meta_prems ctxt =
     rule_by_tactic ctxt
-      (REPEAT_FIRST (resolve_tac [@{thm meta_eq_to_obj_eq}, @{thm def_imp_iff}]));
+      (REPEAT_FIRST (resolve_tac ctxt [@{thm meta_eq_to_obj_eq}, @{thm def_imp_iff}]));
 
 (*Congruence rules for = or <-> (instead of ==)*)
 fun mk_meta_cong ctxt rl =
@@ -58,7 +58,7 @@
   @{thm iff_refl}, reflexive_thm];
 
 fun unsafe_solver ctxt =
-  FIRST' [resolve_tac (triv_rls @ Simplifier.prems_of ctxt), assume_tac ctxt];
+  FIRST' [resolve_tac ctxt (triv_rls @ Simplifier.prems_of ctxt), assume_tac ctxt];
 
 (*No premature instantiation of variables during simplification*)
 fun safe_solver ctxt =
--- a/src/Tools/case_product.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Tools/case_product.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -70,9 +70,10 @@
     val (p_cons1 :: p_cons2 :: premss) = unflat struc prems
     val thm2' = thm2 OF p_cons2
   in
-    resolve_tac [thm1 OF p_cons1]
+    resolve_tac ctxt [thm1 OF p_cons1]
      THEN' EVERY' (map (fn p =>
-       resolve_tac [thm2'] THEN' EVERY' (map (Proof_Context.fact_tac ctxt o single) p)) premss)
+       resolve_tac ctxt [thm2'] THEN'
+       EVERY' (map (Proof_Context.fact_tac ctxt o single) p)) premss)
   end
 
 fun combine ctxt thm1 thm2 =
--- a/src/Tools/coherent.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Tools/coherent.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -215,7 +215,7 @@
 (** external interface **)
 
 fun coherent_tac ctxt rules = SUBPROOF (fn {prems, concl, params, context = ctxt', ...} =>
-  resolve_tac [rulify_elim_conv ctxt' concl RS Drule.equal_elim_rule2] 1 THEN
+  resolve_tac ctxt' [rulify_elim_conv ctxt' concl RS Drule.equal_elim_rule2] 1 THEN
   SUBPROOF (fn {prems = prems', concl, context = ctxt'', ...} =>
     let
       val xs =
@@ -227,7 +227,7 @@
         valid ctxt'' (map (mk_rule ctxt'') (prems' @ prems @ rules)) (term_of concl)
           (mk_dom xs) Net.empty 0 0 of
         NONE => no_tac
-      | SOME prf => resolve_tac [thm_of_cl_prf ctxt'' concl [] prf] 1)
+      | SOME prf => resolve_tac ctxt'' [thm_of_cl_prf ctxt'' concl [] prf] 1)
     end) ctxt' 1) ctxt;
 
 val _ = Theory.setup
--- a/src/Tools/eqsubst.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Tools/eqsubst.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -250,7 +250,7 @@
   RW_Inst.rw ctxt m rule conclthm
   |> unfix_frees cfvs
   |> Conv.fconv_rule Drule.beta_eta_conversion
-  |> (fn r => resolve_tac [r] i st);
+  |> (fn r => resolve_tac ctxt [r] i st);
 
 (* substitute within the conclusion of goal i of gth, using a meta
 equation rule. Note that we assume rule has var indicies zero'd *)
@@ -332,7 +332,8 @@
       |> Conv.fconv_rule Drule.beta_eta_conversion; (* normal form *)
   in
     (* ~j because new asm starts at back, thus we subtract 1 *)
-    Seq.map (Thm.rotate_rule (~ j) (Thm.nprems_of rule + i)) (dresolve_tac [preelimrule] i st2)
+    Seq.map (Thm.rotate_rule (~ j) (Thm.nprems_of rule + i))
+      (dresolve_tac ctxt [preelimrule] i st2)
   end;
 
 
--- a/src/Tools/induct.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/Tools/induct.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -507,7 +507,7 @@
         in
           CASES (Rule_Cases.make_common (thy,
               Thm.prop_of (Rule_Cases.internalize_params rule')) cases)
-            ((Method.insert_tac more_facts THEN' resolve_tac [rule'] THEN_ALL_NEW
+            ((Method.insert_tac more_facts THEN' resolve_tac ctxt [rule'] THEN_ALL_NEW
                 (if simp then TRY o trivial_tac ctxt else K all_tac)) i) st
         end)
   end;
@@ -680,7 +680,7 @@
     (case goal_concl n [] goal of
       SOME concl =>
         (compose_tac ctxt (false, spec_rule (goal_prefix n goal) concl, 1) THEN'
-          resolve_tac [asm_rl]) i
+          resolve_tac ctxt [asm_rl]) i
     | NONE => all_tac)
   end);
 
@@ -801,7 +801,7 @@
               |> Seq.map (rule_instance ctxt (burrow_options (Variable.polymorphic ctxt) taking))
               |> Seq.maps (fn rule' =>
                 CASES (rule_cases ctxt rule' cases)
-                  (resolve_tac [rule'] i THEN
+                  (resolve_tac ctxt [rule'] i THEN
                     PRIMITIVE (singleton (Proof_Context.export defs_ctxt ctxt))) st')))
       end)
       THEN_ALL_NEW_CASES
@@ -859,7 +859,7 @@
         |> Seq.maps (fn rule' =>
           CASES (Rule_Cases.make_common (thy,
               Thm.prop_of (Rule_Cases.internalize_params rule')) cases)
-            (Method.insert_tac more_facts i THEN resolve_tac [rule'] i) st))
+            (Method.insert_tac more_facts i THEN resolve_tac ctxt [rule'] i) st))
   end);
 
 end;
--- a/src/ZF/Datatype_ZF.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/ZF/Datatype_ZF.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -95,7 +95,7 @@
          else ();
        val goal = Logic.mk_equals (old, new)
        val thm = Goal.prove ctxt [] [] goal
-         (fn _ => resolve_tac @{thms iff_reflection} 1 THEN
+         (fn _ => resolve_tac ctxt @{thms iff_reflection} 1 THEN
            simp_tac (put_simpset datatype_ss ctxt addsimps #free_iffs lcon_info) 1)
          handle ERROR msg =>
          (warning (msg ^ "\ndata_free simproc:\nfailed to prove " ^ Syntax.string_of_term ctxt goal);
--- a/src/ZF/OrdQuant.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/ZF/OrdQuant.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -370,14 +370,14 @@
   fn _ => Quantifier1.rearrange_bex
     (fn ctxt =>
       unfold_tac ctxt @{thms rex_def} THEN
-      Quantifier1.prove_one_point_ex_tac)
+      Quantifier1.prove_one_point_ex_tac ctxt)
 *}
 
 simproc_setup defined_rall ("\<forall>x[M]. P(x) \<longrightarrow> Q(x)") = {*
   fn _ => Quantifier1.rearrange_ball
     (fn ctxt =>
       unfold_tac ctxt @{thms rall_def} THEN
-      Quantifier1.prove_one_point_all_tac)
+      Quantifier1.prove_one_point_all_tac ctxt)
 *}
 
 end
--- a/src/ZF/Tools/datatype_package.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/ZF/Tools/datatype_package.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -286,9 +286,9 @@
       (*Proves a single case equation.  Could use simp_tac, but it's slower!*)
       (fn {context = ctxt, ...} => EVERY
         [rewrite_goals_tac ctxt [con_def],
-         resolve_tac [case_trans] 1,
+         resolve_tac ctxt [case_trans] 1,
          REPEAT
-           (resolve_tac [@{thm refl}, split_trans,
+           (resolve_tac ctxt [@{thm refl}, split_trans,
              Su.case_inl RS @{thm trans}, Su.case_inr RS @{thm trans}] 1)]);
 
   val free_iffs = map Drule.export_without_context (con_defs RL [@{thm def_swap_iff}]);
@@ -327,7 +327,7 @@
             (Ind_Syntax.traceIt "next recursor equation = " thy1 (mk_recursor_eqn arg))
             (*Proves a single recursor equation.*)
             (fn {context = ctxt, ...} => EVERY
-              [resolve_tac [recursor_trans] 1,
+              [resolve_tac ctxt [recursor_trans] 1,
                simp_tac (put_simpset rank_ss ctxt addsimps case_eqns) 1,
                IF_UNSOLVED (simp_tac (put_simpset rank_ss ctxt addsimps tl con_defs) 1)]);
       in
--- a/src/ZF/Tools/inductive_package.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/ZF/Tools/inductive_package.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -187,8 +187,8 @@
 
   val bnd_mono =
     Goal.prove_global thy1 [] [] (FOLogic.mk_Trueprop (Fp.bnd_mono $ dom_sum $ fp_abs))
-      (fn _ => EVERY
-        [resolve_tac [@{thm Collect_subset} RS @{thm bnd_monoI}] 1,
+      (fn {context = ctxt, ...} => EVERY
+        [resolve_tac ctxt [@{thm Collect_subset} RS @{thm bnd_monoI}] 1,
          REPEAT (ares_tac (@{thms basic_monos} @ monos) 1)]);
 
   val dom_subset = Drule.export_without_context (big_rec_def RS Fp.subs);
@@ -214,21 +214,21 @@
   (*Type-checking is hardest aspect of proof;
     disjIn selects the correct disjunct after unfolding*)
   fun intro_tacsf disjIn ctxt =
-    [DETERM (stac unfold 1),
-     REPEAT (resolve_tac [@{thm Part_eqI}, @{thm CollectI}] 1),
+    [DETERM (stac ctxt unfold 1),
+     REPEAT (resolve_tac ctxt [@{thm Part_eqI}, @{thm CollectI}] 1),
      (*Now 2-3 subgoals: typechecking, the disjunction, perhaps equality.*)
-     resolve_tac [disjIn] 2,
+     resolve_tac ctxt [disjIn] 2,
      (*Not ares_tac, since refl must be tried before equality assumptions;
        backtracking may occur if the premises have extra variables!*)
-     DEPTH_SOLVE_1 (resolve_tac [@{thm refl}, @{thm exI}, @{thm conjI}] 2 APPEND assume_tac ctxt 2),
+     DEPTH_SOLVE_1 (resolve_tac ctxt [@{thm refl}, @{thm exI}, @{thm conjI}] 2 APPEND assume_tac ctxt 2),
      (*Now solve the equations like Tcons(a,f) = Inl(?b4)*)
      rewrite_goals_tac ctxt con_defs,
-     REPEAT (resolve_tac @{thms refl} 2),
+     REPEAT (resolve_tac ctxt @{thms refl} 2),
      (*Typechecking; this can fail*)
      if !Ind_Syntax.trace then print_tac ctxt "The type-checking subgoal:"
      else all_tac,
-     REPEAT (FIRSTGOAL (        dresolve_tac rec_typechecks
-                        ORELSE' eresolve_tac (asm_rl :: @{thm PartE} :: @{thm SigmaE2} ::
+     REPEAT (FIRSTGOAL (dresolve_tac ctxt rec_typechecks
+                        ORELSE' eresolve_tac ctxt (asm_rl :: @{thm PartE} :: @{thm SigmaE2} ::
                                               type_elims)
                         ORELSE' hyp_subst_tac ctxt)),
      if !Ind_Syntax.trace then print_tac ctxt "The subgoal after monos, type_elims:"
@@ -252,7 +252,7 @@
 
   (*Breaks down logical connectives in the monotonic function*)
   fun basic_elim_tac ctxt =
-      REPEAT (SOMEGOAL (eresolve_tac (Ind_Syntax.elim_rls @ Su.free_SEs)
+      REPEAT (SOMEGOAL (eresolve_tac ctxt (Ind_Syntax.elim_rls @ Su.free_SEs)
                 ORELSE' bound_hyp_subst_tac ctxt))
       THEN prune_params_tac ctxt
           (*Mutual recursion: collapse references to Part(D,h)*)
@@ -329,25 +329,25 @@
            (empty_simpset (Proof_Context.init_global thy)
              |> Simplifier.set_mksimps (K (map mk_eq o ZF_atomize o gen_all)))
            setSolver (mk_solver "minimal"
-                      (fn ctxt => resolve_tac (triv_rls @ Simplifier.prems_of ctxt)
+                      (fn ctxt => resolve_tac ctxt (triv_rls @ Simplifier.prems_of ctxt)
                                    ORELSE' assume_tac ctxt
-                                   ORELSE' eresolve_tac @{thms FalseE}));
+                                   ORELSE' eresolve_tac ctxt @{thms FalseE}));
 
      val quant_induct =
-       Goal.prove_global thy1 [] ind_prems
+       Goal.prove_global thy [] ind_prems
          (FOLogic.mk_Trueprop (Ind_Syntax.mk_all_imp (big_rec_tm, pred)))
          (fn {context = ctxt, prems} => EVERY
            [rewrite_goals_tac ctxt part_rec_defs,
-            resolve_tac [@{thm impI} RS @{thm allI}] 1,
-            DETERM (eresolve_tac [raw_induct] 1),
+            resolve_tac ctxt [@{thm impI} RS @{thm allI}] 1,
+            DETERM (eresolve_tac ctxt [raw_induct] 1),
             (*Push Part inside Collect*)
             full_simp_tac (min_ss addsimps [@{thm Part_Collect}]) 1,
             (*This CollectE and disjE separates out the introduction rules*)
-            REPEAT (FIRSTGOAL (eresolve_tac [@{thm CollectE}, @{thm disjE}])),
+            REPEAT (FIRSTGOAL (eresolve_tac ctxt [@{thm CollectE}, @{thm disjE}])),
             (*Now break down the individual cases.  No disjE here in case
               some premise involves disjunction.*)
-            REPEAT (FIRSTGOAL (eresolve_tac [@{thm CollectE}, @{thm exE}, @{thm conjE}]
-                               ORELSE' (bound_hyp_subst_tac ctxt1))),
+            REPEAT (FIRSTGOAL (eresolve_tac ctxt [@{thm CollectE}, @{thm exE}, @{thm conjE}]
+                               ORELSE' (bound_hyp_subst_tac ctxt))),
             ind_tac (rev (map (rewrite_rule ctxt part_rec_defs) prems)) (length prems)]);
 
      val dummy =
@@ -410,20 +410,21 @@
              else ();
 
 
-     val lemma_tac = FIRST' [eresolve_tac [@{thm asm_rl}, @{thm conjE}, @{thm PartE}, @{thm mp}],
-                             resolve_tac [@{thm allI}, @{thm impI}, @{thm conjI}, @{thm Part_eqI}],
-                             dresolve_tac [@{thm spec}, @{thm mp}, Pr.fsplitD]];
+     fun lemma_tac ctxt =
+      FIRST' [eresolve_tac ctxt [@{thm asm_rl}, @{thm conjE}, @{thm PartE}, @{thm mp}],
+              resolve_tac ctxt [@{thm allI}, @{thm impI}, @{thm conjI}, @{thm Part_eqI}],
+              dresolve_tac ctxt [@{thm spec}, @{thm mp}, Pr.fsplitD]];
 
      val need_mutual = length rec_names > 1;
 
      val lemma = (*makes the link between the two induction rules*)
        if need_mutual then
           (writeln "  Proving the mutual induction rule...";
-           Goal.prove_global thy1 [] []
+           Goal.prove_global thy [] []
              (Logic.mk_implies (induct_concl, mutual_induct_concl))
              (fn {context = ctxt, ...} => EVERY
                [rewrite_goals_tac ctxt part_rec_defs,
-                REPEAT (rewrite_goals_tac ctxt [Pr.split_eq] THEN lemma_tac 1)]))
+                REPEAT (rewrite_goals_tac ctxt [Pr.split_eq] THEN lemma_tac ctxt 1)]))
        else (writeln "  [ No mutual induction rule needed ]"; @{thm TrueI});
 
      val dummy =
@@ -469,20 +470,20 @@
                       (mut_ss addsimps @{thms conj_simps} @ @{thms imp_simps} @ @{thms quant_simps}) 1
                    THEN
                    (*unpackage and use "prem" in the corresponding place*)
-                   REPEAT (resolve_tac @{thms impI} 1)  THEN
-                   resolve_tac [rewrite_rule ctxt all_defs prem] 1  THEN
+                   REPEAT (resolve_tac ctxt @{thms impI} 1)  THEN
+                   resolve_tac ctxt [rewrite_rule ctxt all_defs prem] 1  THEN
                    (*prem must not be REPEATed below: could loop!*)
                    DEPTH_SOLVE (FIRSTGOAL (ares_tac [@{thm impI}] ORELSE'
-                                           eresolve_tac (@{thm conjE} :: @{thm mp} :: cmonos))))
+                                           eresolve_tac ctxt (@{thm conjE} :: @{thm mp} :: cmonos))))
                ) i)
             THEN mutual_ind_tac ctxt prems (i-1);
 
      val mutual_induct_fsplit =
        if need_mutual then
-         Goal.prove_global thy1 [] (map (induct_prem (rec_tms~~preds)) intr_tms)
+         Goal.prove_global thy [] (map (induct_prem (rec_tms~~preds)) intr_tms)
            mutual_induct_concl
            (fn {context = ctxt, prems} => EVERY
-             [resolve_tac [quant_induct RS lemma] 1,
+             [resolve_tac ctxt [quant_induct RS lemma] 1,
               mutual_ind_tac ctxt (rev prems) (length prems)])
        else @{thm TrueI};
 
@@ -493,8 +494,8 @@
        The name "x.1" comes from the "RS spec" !*)
      val inst =
          case elem_frees of [_] => I
-            | _ => Drule.instantiate_normalize ([], [(cterm_of thy1 (Var(("x",1), Ind_Syntax.iT)),
-                                      cterm_of thy1 elem_tuple)]);
+            | _ => Drule.instantiate_normalize ([], [(cterm_of thy (Var(("x",1), Ind_Syntax.iT)),
+                                      cterm_of thy elem_tuple)]);
 
      (*strip quantifier and the implication*)
      val induct0 = inst (quant_induct RS @{thm spec} RSN (2, @{thm rev_mp}));
--- a/src/ZF/Tools/primrec_package.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/ZF/Tools/primrec_package.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -177,7 +177,7 @@
       eqn_terms |> map (fn t =>
         Goal.prove_global thy1 [] [] (Ind_Syntax.traceIt "next primrec equation = " thy1 t)
           (fn {context = ctxt, ...} =>
-            EVERY [rewrite_goals_tac ctxt rewrites, resolve_tac @{thms refl} 1]));
+            EVERY [rewrite_goals_tac ctxt rewrites, resolve_tac ctxt @{thms refl} 1]));
 
     val (eqn_thms', thy2) =
       thy1
--- a/src/ZF/Tools/typechk.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/ZF/Tools/typechk.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -68,12 +68,12 @@
 (* tactics *)
 
 (*resolution using a net rather than rules*)
-fun net_res_tac maxr net =
+fun net_res_tac ctxt maxr net =
   SUBGOAL
-    (fn (prem,i) =>
+    (fn (prem, i) =>
       let val rls = Net.unify_term net (Logic.strip_assums_concl prem)
       in
-         if length rls <= maxr then resolve_tac rls i else no_tac
+         if length rls <= maxr then resolve_tac ctxt rls i else no_tac
       end);
 
 fun is_rigid_elem (Const(@{const_name Trueprop},_) $ (Const(@{const_name mem},_) $ a $ _)) =
@@ -89,7 +89,7 @@
   match_tac is too strict; would refuse to instantiate ?A*)
 fun typecheck_step_tac ctxt =
   let val TC {net, ...} = tcset_of ctxt
-  in FIRSTGOAL (test_assume_tac ctxt ORELSE' net_res_tac 3 net) end;
+  in FIRSTGOAL (test_assume_tac ctxt ORELSE' net_res_tac ctxt 3 net) end;
 
 fun typecheck_tac ctxt = REPEAT (typecheck_step_tac ctxt);
 
@@ -100,7 +100,7 @@
 (*Instantiates variables in typing conditions.
   drawback: does not simplify conjunctions*)
 fun type_solver_tac ctxt hyps = SELECT_GOAL
-    (DEPTH_SOLVE (eresolve_tac @{thms FalseE} 1
+    (DEPTH_SOLVE (eresolve_tac ctxt @{thms FalseE} 1
                   ORELSE resolve_from_net_tac ctxt basic_net 1
                   ORELSE (ares_tac hyps 1
                           APPEND typecheck_step_tac ctxt)));
--- a/src/ZF/UNITY/Constrains.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/ZF/UNITY/Constrains.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -472,7 +472,7 @@
       (EVERY [REPEAT (Always_Int_tac ctxt 1),
               REPEAT (etac @{thm Always_ConstrainsI} 1
                       ORELSE
-                      resolve_tac [@{thm StableI}, @{thm stableI},
+                      resolve_tac ctxt [@{thm StableI}, @{thm stableI},
                                    @{thm constrains_imp_Constrains}] 1),
               rtac @{thm constrainsI} 1,
               (* Three subgoals *)
--- a/src/ZF/arith_data.ML	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/ZF/arith_data.ML	Wed Feb 11 12:01:56 2015 +0000
@@ -51,7 +51,7 @@
 
 (*Apply the given rewrite (if present) just once*)
 fun gen_trans_tac th2 NONE      = all_tac
-  | gen_trans_tac th2 (SOME th) = ALLGOALS (resolve_tac [th RS th2]);
+  | gen_trans_tac th2 (SOME th) = ALLGOALS (resolve0_tac [th RS th2]);
 
 (*Use <-> or = depending on the type of t*)
 fun mk_eq_iff(t,u) =
--- a/src/ZF/pair.thy	Tue Feb 10 17:37:06 2015 +0000
+++ b/src/ZF/pair.thy	Wed Feb 11 12:01:56 2015 +0000
@@ -22,14 +22,14 @@
   fn _ => Quantifier1.rearrange_bex
     (fn ctxt =>
       unfold_tac ctxt @{thms Bex_def} THEN
-      Quantifier1.prove_one_point_ex_tac)
+      Quantifier1.prove_one_point_ex_tac ctxt)
 *}
 
 simproc_setup defined_Ball ("\<forall>x\<in>A. P(x) \<longrightarrow> Q(x)") = {*
   fn _ => Quantifier1.rearrange_ball
     (fn ctxt =>
       unfold_tac ctxt @{thms Ball_def} THEN
-      Quantifier1.prove_one_point_all_tac)
+      Quantifier1.prove_one_point_all_tac ctxt)
 *}