merged
authorwenzelm
Fri, 27 Apr 2012 23:17:58 +0200
changeset 47817 5d2d63f4363e
parent 47812 bb477988edb4 (current diff)
parent 47816 cd0dfb06b0c8 (diff)
child 47818 151d137f1095
merged
--- a/src/HOL/Tools/choice_specification.ML	Fri Apr 27 22:36:27 2012 +0200
+++ b/src/HOL/Tools/choice_specification.ML	Fri Apr 27 23:17:58 2012 +0200
@@ -202,7 +202,7 @@
                              |> apfst undo_imps
                              |> apfst Drule.export_without_context
                              |-> Thm.theory_attributes
-                                (map (Attrib.attribute thy)
+                                (map (Attrib.attribute_cmd_global thy)
                                   (@{attributes [nitpick_choice_spec]} @ atts))
                              |> add_final
                              |> swap
--- a/src/HOL/Tools/recdef.ML	Fri Apr 27 22:36:27 2012 +0200
+++ b/src/HOL/Tools/recdef.ML	Fri Apr 27 23:17:58 2012 +0200
@@ -220,7 +220,7 @@
       |> Sign.parent_path;
   in (thy, result) end;
 
-val add_recdef = gen_add_recdef Tfl.define Attrib.attribute prepare_hints;
+val add_recdef = gen_add_recdef Tfl.define Attrib.attribute_cmd_global prepare_hints;
 fun add_recdef_i x y z w = gen_add_recdef Tfl.define_i (K I) prepare_hints_i x y z w ();
 
 
--- a/src/Pure/Isar/attrib.ML	Fri Apr 27 22:36:27 2012 +0200
+++ b/src/Pure/Isar/attrib.ML	Fri Apr 27 23:17:58 2012 +0200
@@ -15,8 +15,10 @@
   val intern_src: theory -> src -> src
   val pretty_attribs: Proof.context -> src list -> Pretty.T list
   val defined: theory -> string -> bool
-  val attribute: theory -> src -> attribute
-  val attribute_i: theory -> src -> attribute
+  val attribute: Proof.context -> src -> attribute
+  val attribute_global: theory -> src -> attribute
+  val attribute_cmd: Proof.context -> src -> attribute
+  val attribute_cmd_global: theory -> src -> attribute
   val map_specs: ('a list -> 'att list) ->
     (('c * 'a list) * 'b) list -> (('c * 'att list) * 'b) list
   val map_facts: ('a list -> 'att list) ->
@@ -120,18 +122,24 @@
 
 val defined = Symtab.defined o #2 o Attributes.get;
 
-fun attribute_i thy =
+fun attribute_generic context =
   let
+    val thy = Context.theory_of context;
     val (space, tab) = Attributes.get thy;
     fun attr src =
       let val ((name, _), pos) = Args.dest_src src in
         (case Symtab.lookup tab name of
           NONE => error ("Unknown attribute: " ^ quote name ^ Position.str_of pos)
-        | SOME (att, _) => (Position.report pos (Name_Space.markup space name); att src))
+        | SOME (att, _) =>
+            (Context_Position.report_generic context pos (Name_Space.markup space name); att src))
       end;
   in attr end;
 
-fun attribute thy = attribute_i thy o intern_src thy;
+val attribute = attribute_generic o Context.Proof;
+val attribute_global = attribute_generic o Context.Theory;
+
+fun attribute_cmd ctxt = attribute ctxt o intern_src (Proof_Context.theory_of ctxt);
+fun attribute_cmd_global thy = attribute_global thy o intern_src thy;
 
 
 (* attributed declarations *)
@@ -145,17 +153,17 @@
 (* fact expressions *)
 
 fun global_notes kind facts thy = thy |>
-  Global_Theory.note_thmss kind (map_facts (map (attribute_i thy)) facts);
+  Global_Theory.note_thmss kind (map_facts (map (attribute_global thy)) facts);
 
 fun local_notes kind facts ctxt = ctxt |>
-  Proof_Context.note_thmss kind (map_facts (map (attribute_i (Proof_Context.theory_of ctxt))) facts);
+  Proof_Context.note_thmss kind (map_facts (map (attribute ctxt)) facts);
 
 fun generic_notes kind facts context = context |>
   Context.mapping_result (global_notes kind facts) (local_notes kind facts);
 
 fun eval_thms ctxt srcs = ctxt
   |> Proof_Context.note_thmss ""
-    (map_facts_refs (map (attribute (Proof_Context.theory_of ctxt))) (Proof_Context.get_fact ctxt)
+    (map_facts_refs (map (attribute_cmd ctxt)) (Proof_Context.get_fact ctxt)
       [((Binding.empty, []), srcs)])
   |> fst |> maps snd;
 
@@ -203,7 +211,7 @@
   in
     Parse.$$$ "[" |-- Args.attribs (intern thy) --| Parse.$$$ "]" >> (fn srcs =>
       let
-        val atts = map (attribute_i thy) srcs;
+        val atts = map (attribute_generic context) srcs;
         val (th', context') = fold (uncurry o Thm.apply_attribute) atts (Drule.dummy_thm, context);
       in (context', pick "" [th']) end)
     ||
@@ -215,7 +223,7 @@
     -- Args.opt_attribs (intern thy) >> (fn ((name, thmref, fact), srcs) =>
       let
         val ths = Facts.select thmref fact;
-        val atts = map (attribute_i thy) srcs;
+        val atts = map (attribute_generic context) srcs;
         val (ths', context') =
           fold_map (curry (fold (uncurry o Thm.apply_attribute) atts)) ths context;
       in (context', pick name ths') end)
@@ -240,7 +248,7 @@
 fun apply_att src (context, th) =
   let
     val src1 = Args.assignable src;
-    val result = attribute_i (Context.theory_of context) src1 (context, th);
+    val result = attribute_generic context src1 (context, th);
     val src2 = Args.closure src1;
   in (src2, result) end;
 
--- a/src/Pure/Isar/element.ML	Fri Apr 27 22:36:27 2012 +0200
+++ b/src/Pure/Isar/element.ML	Fri Apr 27 23:17:58 2012 +0200
@@ -485,16 +485,14 @@
   | init (Constrains _) = I
   | init (Assumes asms) = Context.map_proof (fn ctxt =>
       let
-        val asms' =
-          Attrib.map_specs (map (Attrib.attribute_i (Proof_Context.theory_of ctxt))) asms;
+        val asms' = Attrib.map_specs (map (Attrib.attribute ctxt)) asms;
         val (_, ctxt') = ctxt
           |> fold Variable.auto_fixes (maps (map #1 o #2) asms')
           |> Proof_Context.add_assms_i Assumption.assume_export asms';
       in ctxt' end)
   | init (Defines defs) = Context.map_proof (fn ctxt =>
       let
-        val defs' =
-          Attrib.map_specs (map (Attrib.attribute_i (Proof_Context.theory_of ctxt))) defs;
+        val defs' = Attrib.map_specs (map (Attrib.attribute ctxt)) defs;
         val asms = defs' |> map (fn ((name, atts), (t, ps)) =>
             let val ((c, _), t') = Local_Defs.cert_def ctxt t  (* FIXME adapt ps? *)
             in (t', ((Thm.def_binding_optional (Binding.name c) name, atts), [(t', ps)])) end);
--- a/src/Pure/Isar/isar_cmd.ML	Fri Apr 27 22:36:27 2012 +0200
+++ b/src/Pure/Isar/isar_cmd.ML	Fri Apr 27 23:17:58 2012 +0200
@@ -192,7 +192,8 @@
 fun add_defs ((unchecked, overloaded), args) thy =
   thy |>
     (if unchecked then Global_Theory.add_defs_unchecked_cmd else Global_Theory.add_defs_cmd)
-      overloaded (map (fn ((b, ax), srcs) => ((b, ax), map (Attrib.attribute thy) srcs)) args)
+      overloaded
+      (map (fn ((b, ax), srcs) => ((b, ax), map (Attrib.attribute_cmd_global thy) srcs)) args)
   |> snd;
 
 
--- a/src/Pure/Isar/obtain.ML	Fri Apr 27 22:36:27 2012 +0200
+++ b/src/Pure/Isar/obtain.ML	Fri Apr 27 23:17:58 2012 +0200
@@ -126,7 +126,7 @@
     val (proppss, asms_ctxt) = prep_propp (map snd raw_asms) fix_ctxt;
     val ((_, bind_ctxt), _) = Proof_Context.bind_propp_i proppss asms_ctxt;
     val asm_props = maps (map fst) proppss;
-    val asms = map fst (Attrib.map_specs (map (prep_att thy)) raw_asms) ~~ proppss;
+    val asms = map fst (Attrib.map_specs (map (prep_att ctxt)) raw_asms) ~~ proppss;
 
     (*obtain parms*)
     val (Ts, parms_ctxt) = fold_map Proof_Context.inferred_param xs' asms_ctxt;
@@ -168,7 +168,7 @@
 in
 
 val obtain = gen_obtain (K I) Proof_Context.cert_vars Proof_Context.cert_propp;
-val obtain_cmd = gen_obtain Attrib.attribute Proof_Context.read_vars Proof_Context.read_propp;
+val obtain_cmd = gen_obtain Attrib.attribute_cmd Proof_Context.read_vars Proof_Context.read_propp;
 
 end;
 
--- a/src/Pure/Isar/proof.ML	Fri Apr 27 22:36:27 2012 +0200
+++ b/src/Pure/Isar/proof.ML	Fri Apr 27 23:17:58 2012 +0200
@@ -83,7 +83,7 @@
   val apply: Method.text -> state -> state Seq.seq
   val apply_end: Method.text -> state -> state Seq.seq
   val local_goal: (context -> ((string * string) * (string * thm list) list) -> unit) ->
-    (theory -> 'a -> attribute) ->
+    (Proof.context -> 'a -> attribute) ->
     ('b list -> context -> (term list list * (context -> context)) * context) ->
     string -> Method.text option -> (thm list list -> state -> state) ->
     ((binding * 'a list) * 'b) list -> state -> state
@@ -400,7 +400,8 @@
 fun no_goal_cases st = map (rpair NONE) (goals st);
 
 fun goal_cases st =
-  Rule_Cases.make_common (Thm.theory_of_thm st, Thm.prop_of st) (map (rpair [] o rpair []) (goals st));
+  Rule_Cases.make_common
+    (Thm.theory_of_thm st, Thm.prop_of st) (map (rpair [] o rpair []) (goals st));
 
 fun apply_method current_context meth state =
   let
@@ -612,13 +613,13 @@
 fun gen_assume asm prep_att exp args state =
   state
   |> assert_forward
-  |> map_context_result (asm exp (Attrib.map_specs (map (prep_att (theory_of state))) args))
+  |> map_context_result (asm exp (Attrib.map_specs (map (prep_att (context_of state))) args))
   |> these_factss [] |> #2;
 
 in
 
 val assm = gen_assume Proof_Context.add_assms_i (K I);
-val assm_cmd = gen_assume Proof_Context.add_assms Attrib.attribute;
+val assm_cmd = gen_assume Proof_Context.add_assms Attrib.attribute_cmd;
 val assume = assm Assumption.assume_export;
 val assume_cmd = assm_cmd Assumption.assume_export;
 val presume = assm Assumption.presume_export;
@@ -634,10 +635,8 @@
 fun gen_def prep_att prep_vars prep_binds args state =
   let
     val _ = assert_forward state;
-    val thy = theory_of state;
-
     val (raw_name_atts, (raw_vars, raw_rhss)) = args |> split_list ||> split_list;
-    val name_atts = map (apsnd (map (prep_att thy))) raw_name_atts;
+    val name_atts = map (apsnd (map (prep_att (context_of state)))) raw_name_atts;
   in
     state
     |> map_context_result (prep_vars (map (fn (x, mx) => (x, NONE, mx)) raw_vars))
@@ -651,7 +650,7 @@
 in
 
 val def = gen_def (K I) Proof_Context.cert_vars Proof_Context.match_bind_i;
-val def_cmd = gen_def Attrib.attribute Proof_Context.read_vars Proof_Context.match_bind;
+val def_cmd = gen_def Attrib.attribute_cmd Proof_Context.read_vars Proof_Context.match_bind;
 
 end;
 
@@ -683,10 +682,8 @@
 fun gen_thmss more_facts opt_chain opt_result prep_atts prep_fact args state =
   state
   |> assert_forward
-  |> map_context_result (Proof_Context.note_thmss ""
-    (Attrib.map_facts_refs
-      (map (prep_atts (theory_of state)))
-      (prep_fact (context_of state)) args))
+  |> map_context_result (fn ctxt => ctxt |> Proof_Context.note_thmss ""
+    (Attrib.map_facts_refs (map (prep_atts ctxt)) (prep_fact ctxt) args))
   |> these_factss (more_facts state)
   ||> opt_chain
   |> opt_result;
@@ -694,13 +691,15 @@
 in
 
 val note_thmss = gen_thmss (K []) I #2 (K I) (K I);
-val note_thmss_cmd = gen_thmss (K []) I #2 Attrib.attribute Proof_Context.get_fact;
+val note_thmss_cmd = gen_thmss (K []) I #2 Attrib.attribute_cmd Proof_Context.get_fact;
 
 val from_thmss = gen_thmss (K []) chain #2 (K I) (K I) o no_binding;
-val from_thmss_cmd = gen_thmss (K []) chain #2 Attrib.attribute Proof_Context.get_fact o no_binding;
+val from_thmss_cmd =
+  gen_thmss (K []) chain #2 Attrib.attribute_cmd Proof_Context.get_fact o no_binding;
 
 val with_thmss = gen_thmss the_facts chain #2 (K I) (K I) o no_binding;
-val with_thmss_cmd = gen_thmss the_facts chain #2 Attrib.attribute Proof_Context.get_fact o no_binding;
+val with_thmss_cmd =
+  gen_thmss the_facts chain #2 Attrib.attribute_cmd Proof_Context.get_fact o no_binding;
 
 val local_results = gen_thmss (K []) I I (K I) (K I) o map (apsnd Thm.simple_fact);
 
@@ -715,9 +714,8 @@
   state
   |> assert_backward
   |> map_context_result
-    (Proof_Context.note_thmss ""
-      (Attrib.map_facts_refs (map (prep_att (theory_of state))) (prep_fact (context_of state))
-        (no_binding args)))
+    (fn ctxt => ctxt |> Proof_Context.note_thmss ""
+      (Attrib.map_facts_refs (map (prep_att ctxt)) (prep_fact ctxt) (no_binding args)))
   |> (fn (named_facts, state') =>
     state' |> map_goal I (fn (statement, _, using, goal, before_qed, after_qed) =>
       let
@@ -732,9 +730,9 @@
 in
 
 val using = gen_using append_using (K (K I)) (K I) (K I);
-val using_cmd = gen_using append_using (K (K I)) Attrib.attribute Proof_Context.get_fact;
+val using_cmd = gen_using append_using (K (K I)) Attrib.attribute_cmd Proof_Context.get_fact;
 val unfolding = gen_using unfold_using unfold_goals (K I) (K I);
-val unfolding_cmd = gen_using unfold_using unfold_goals Attrib.attribute Proof_Context.get_fact;
+val unfolding_cmd = gen_using unfold_using unfold_goals Attrib.attribute_cmd Proof_Context.get_fact;
 
 end;
 
@@ -748,7 +746,7 @@
 
 fun gen_invoke_case prep_att (name, xs, raw_atts) state =
   let
-    val atts = map (prep_att (theory_of state)) raw_atts;
+    val atts = map (prep_att (context_of state)) raw_atts;
     val (asms, state') = state |> map_context_result (fn ctxt =>
       ctxt |> Proof_Context.apply_case (Proof_Context.get_case ctxt name xs));
     val assumptions = asms |> map (fn (a, ts) => ((qualified_binding a, atts), map (rpair []) ts));
@@ -762,7 +760,7 @@
 in
 
 val invoke_case = gen_invoke_case (K I);
-val invoke_case_cmd = gen_invoke_case Attrib.attribute;
+val invoke_case_cmd = gen_invoke_case Attrib.attribute_cmd;
 
 end;
 
@@ -935,9 +933,8 @@
 
 fun local_goal print_results prep_att prepp kind before_qed after_qed stmt state =
   let
-    val thy = theory_of state;
     val ((names, attss), propp) =
-      Attrib.map_specs (map (prep_att thy)) stmt |> split_list |>> split_list;
+      Attrib.map_specs (map (prep_att (context_of state))) stmt |> split_list |>> split_list;
 
     fun after_qed' results =
       local_results ((names ~~ attss) ~~ results)
@@ -1044,9 +1041,9 @@
 in
 
 val have = gen_have (K I) Proof_Context.bind_propp_i;
-val have_cmd = gen_have Attrib.attribute Proof_Context.bind_propp;
+val have_cmd = gen_have Attrib.attribute_cmd Proof_Context.bind_propp;
 val show = gen_show (K I) Proof_Context.bind_propp_i;
-val show_cmd = gen_show Attrib.attribute Proof_Context.bind_propp;
+val show_cmd = gen_show Attrib.attribute_cmd Proof_Context.bind_propp;
 
 end;
 
--- a/src/Pure/ML/ml_antiquote.ML	Fri Apr 27 22:36:27 2012 +0200
+++ b/src/Pure/ML/ml_antiquote.ML	Fri Apr 27 23:17:58 2012 +0200
@@ -88,8 +88,7 @@
   macro (Binding.name "note")
     (Args.context :|-- (fn ctxt =>
       Parse.and_list1' (Scan.lift (Args.opt_thm_name I "=") -- Attrib.thms
-        >> (fn ((a, srcs), ths) =>
-          ((a, map (Attrib.attribute (Proof_Context.theory_of ctxt)) srcs), [(ths, [])])))
+        >> (fn ((a, srcs), ths) => ((a, map (Attrib.attribute_cmd ctxt) srcs), [(ths, [])])))
       >> (fn args => #2 (Proof_Context.note_thmss "" args ctxt)))) #>
 
   value (Binding.name "ctyp") (Args.typ >> (fn T =>
--- a/src/Pure/ML/ml_thms.ML	Fri Apr 27 22:36:27 2012 +0200
+++ b/src/Pure/ML/ml_thms.ML	Fri Apr 27 23:17:58 2012 +0200
@@ -42,7 +42,7 @@
 
           val i = serial ();
           val srcs = map (Attrib.intern_src thy) raw_srcs;
-          val _ = map (Attrib.attribute_i thy) srcs;
+          val _ = map (Attrib.attribute background) srcs;
           val (a, background') = background
             |> ML_Antiquote.variant "attributes" ||> put_attributes (i, srcs);
           val ml =
--- a/src/Pure/ROOT.ML	Fri Apr 27 22:36:27 2012 +0200
+++ b/src/Pure/ROOT.ML	Fri Apr 27 23:17:58 2012 +0200
@@ -101,8 +101,8 @@
 use "name.ML";
 use "term.ML";
 use "context.ML";
+use "context_position.ML";
 use "config.ML";
-use "context_position.ML";
 
 
 (* inner syntax *)
--- a/src/Pure/config.ML	Fri Apr 27 22:36:27 2012 +0200
+++ b/src/Pure/config.ML	Fri Apr 27 23:17:58 2012 +0200
@@ -121,12 +121,15 @@
     fun update_value f context =
       Value.map (Inttab.update (id, type_check name f (get_value context))) context;
 
-    fun map_value f (context as Context.Proof _) =
+    fun map_value f (context as Context.Proof ctxt) =
           let val context' = update_value f context in
             if global andalso
+              Context_Position.is_visible ctxt andalso
               print_value (get_value (Context.Theory (Context.theory_of context'))) <>
                 print_value (get_value context')
-            then (warning ("Ignoring local change of global option " ^ quote name); context)
+            then
+              (Context_Position.if_visible ctxt warning
+                ("Ignoring local change of global option " ^ quote name); context)
             else context'
           end
       | map_value f context = update_value f context;
--- a/src/Pure/context_position.ML	Fri Apr 27 22:36:27 2012 +0200
+++ b/src/Pure/context_position.ML	Fri Apr 27 23:17:58 2012 +0200
@@ -22,9 +22,17 @@
 structure Context_Position: CONTEXT_POSITION =
 struct
 
-val visible = Config.bool (Config.declare "Context_Position.visible" (K (Config.Bool true)));
-fun is_visible ctxt = Config.get ctxt visible;
-val set_visible = Config.put visible;
+structure Data = Generic_Data
+(
+  type T = bool option;
+  val empty: T = NONE;
+  val extend = I;
+  fun merge (x, y): T = if is_some x then x else y;
+);
+
+val is_visible_generic = the_default true o Data.get;
+val is_visible = is_visible_generic o Context.Proof;
+val set_visible = Context.proof_map o Data.put o SOME;
 val restore_visible = set_visible o is_visible;
 
 fun if_visible ctxt f x = if is_visible ctxt then f x else ();
@@ -35,7 +43,7 @@
 fun if_visible_proof context f x = if is_visible_proof context then f x else ();
 
 fun report_generic context pos markup =
-  if Config.get_generic context visible then
+  if is_visible_generic context then
     Output.report (Position.reported_text pos markup "")
   else ();
 
--- a/src/ZF/Tools/ind_cases.ML	Fri Apr 27 22:36:27 2012 +0200
+++ b/src/ZF/Tools/ind_cases.ML	Fri Apr 27 23:17:58 2012 +0200
@@ -48,7 +48,7 @@
   let
     val ctxt = Proof_Context.init_global thy;
     val facts = args |> map (fn ((name, srcs), props) =>
-      ((name, map (Attrib.attribute thy) srcs),
+      ((name, map (Attrib.attribute_cmd_global thy) srcs),
         map (Thm.no_attributes o single o smart_cases ctxt) props));
   in thy |> Global_Theory.note_thmss "" facts |> snd end;
 
--- a/src/ZF/Tools/inductive_package.ML	Fri Apr 27 22:36:27 2012 +0200
+++ b/src/ZF/Tools/inductive_package.ML	Fri Apr 27 23:17:58 2012 +0200
@@ -558,7 +558,7 @@
     val read_terms = map (Syntax.parse_term ctxt #> Type.constraint Ind_Syntax.iT)
       #> Syntax.check_terms ctxt;
 
-    val intr_atts = map (map (Attrib.attribute thy) o snd) intr_srcs;
+    val intr_atts = map (map (Attrib.attribute_cmd_global thy) o snd) intr_srcs;
     val sintrs = map fst intr_srcs ~~ intr_atts;
     val rec_tms = read_terms srec_tms;
     val dom_sum = singleton read_terms sdom_sum;
--- a/src/ZF/Tools/primrec_package.ML	Fri Apr 27 22:36:27 2012 +0200
+++ b/src/ZF/Tools/primrec_package.ML	Fri Apr 27 23:17:58 2012 +0200
@@ -189,7 +189,7 @@
 
 fun add_primrec args thy =
   add_primrec_i (map (fn ((name, s), srcs) =>
-    ((name, Syntax.read_prop_global thy s), map (Attrib.attribute thy) srcs))
+    ((name, Syntax.read_prop_global thy s), map (Attrib.attribute_cmd_global thy) srcs))
     args) thy;