Remove duplicate locale activation code; performance improvement.
authorballarin
Thu, 05 Aug 2010 22:29:43 +0200
changeset 38211 8ed3a5fb4d25
parent 38210 7f4755c5e77b
child 38216 17d9808ed626
Remove duplicate locale activation code; performance improvement.
src/Pure/Isar/expression.ML
src/Pure/Isar/locale.ML
--- a/src/Pure/Isar/expression.ML	Thu Aug 05 21:56:22 2010 +0200
+++ b/src/Pure/Isar/expression.ML	Thu Aug 05 22:29:43 2010 +0200
@@ -451,7 +451,7 @@
     (* Declare parameters and imported facts *)
     val context' = context |>
       fix_params fixed |>
-      fold (Context.proof_map o Locale.activate_facts) deps;
+      fold Locale.activate_declarations deps;
     val (elems', _) = context' |>
       ProofContext.set_stmt true |>
       fold_map activate elems;
--- a/src/Pure/Isar/locale.ML	Thu Aug 05 21:56:22 2010 +0200
+++ b/src/Pure/Isar/locale.ML	Thu Aug 05 22:29:43 2010 +0200
@@ -53,7 +53,7 @@
 
   (* Activation *)
   val activate_declarations: string * morphism -> Proof.context -> Proof.context
-  val activate_facts: string * morphism -> Context.generic -> Context.generic
+  val activate_facts: morphism -> string * morphism -> Context.generic -> Context.generic
   val init: string -> theory -> Proof.context
 
   (* Reasoning about locales *)
@@ -89,7 +89,7 @@
 datatype ctxt = datatype Element.ctxt;
 
 
-(*** Theory data ***)
+(*** Locales ***)
 
 datatype locale = Loc of {
   (** static part **)
@@ -155,7 +155,7 @@
   Locales.map o apsnd o Symtab.map_entry name o map_locale o apsnd;
 
 
-(*** Primitive operations ***)
+(** Primitive operations **)
 
 fun params_of thy = snd o #parameters o the_locale thy;
 
@@ -197,9 +197,7 @@
   end;
 
 
-(*** Activate context elements of locale ***)
-
-(** Identifiers: activated locales in theory or proof context **)
+(*** Identifiers: activated locales in theory or proof context ***)
 
 (* subsumption *)
 fun ident_le thy ((n: string, ts), (m, ss)) = (m = n) andalso Pattern.matchess thy (ss, ts);
@@ -285,67 +283,7 @@
 end;
 
 
-(* Declarations, facts and entire locale content *)
-
-fun activate_syntax_decls (name, morph) context =
-  let
-    val thy = Context.theory_of context;
-    val {syntax_decls, ...} = the_locale thy name;
-  in
-    context
-    |> fold_rev (fn (decl, _) => decl morph) syntax_decls
-  end;
-
-fun activate_notes activ_elem transfer thy (name, morph) input =
-  let
-    val {notes, ...} = the_locale thy name;
-    fun activate ((kind, facts), _) input =
-      let
-        val facts' = facts |> Element.facts_map (Element.morph_ctxt (transfer input $> morph))
-      in activ_elem (Notes (kind, facts')) input end;
-  in
-    fold_rev activate notes input
-  end;
-
-fun activate_all name thy activ_elem transfer (marked, input) =
-  let
-    val {parameters = (_, params), spec = (asm, defs), ...} = the_locale thy name;
-    val input' = input |>
-      (not (null params) ?
-        activ_elem (Fixes (map (fn ((x, T), mx) => (Binding.name x, SOME T, mx)) params))) |>
-      (* FIXME type parameters *)
-      (case asm of SOME A => activ_elem (Assumes [(Attrib.empty_binding, [(A, [])])]) | _ => I) |>
-      (if not (null defs)
-        then activ_elem (Defines (map (fn def => (Attrib.empty_binding, (def, []))) defs))
-        else I);
-    val activate = activate_notes activ_elem transfer thy;
-  in
-    roundup thy activate Morphism.identity (name, Morphism.identity) (marked, input')
-  end;
-
-
-(** Public activation functions **)
-
-fun activate_declarations dep = Context.proof_map (fn context =>
-  let
-    val thy = Context.theory_of context;
-  in
-    roundup thy activate_syntax_decls Morphism.identity dep (get_idents context, context)
-    |-> put_idents
-  end);
-
-fun activate_facts dep context =
-  let
-    val thy = Context.theory_of context;
-    val activate = activate_notes Element.init (Element.transfer_morphism o Context.theory_of) thy;
-  in roundup thy activate Morphism.identity dep (get_idents context, context) |-> put_idents end;
-
-fun init name thy =
-  activate_all name thy Element.init (Element.transfer_morphism o Context.theory_of)
-    ([], Context.Proof (ProofContext.init_global thy)) |-> put_idents |> Context.proof_of;
-
-
-(*** Registrations: interpretations in theories ***)
+(*** Registrations: interpretations in theories or proof contexts ***)
 
 structure Idtab = Table(type key = string * term list val ord = ident_ord);
 
@@ -426,27 +364,73 @@
 
 fun all_registrations context = get_registrations context I;
 
-fun activate_notes' activ_elem transfer context export (name, morph) input =
+
+(*** Activate context elements of locale ***)
+
+(* Declarations, facts and entire locale content *)
+
+fun activate_syntax_decls (name, morph) context =
+  let
+    val thy = Context.theory_of context;
+    val {syntax_decls, ...} = the_locale thy name;
+  in
+    context
+    |> fold_rev (fn (decl, _) => decl morph) syntax_decls
+  end;
+
+fun activate_notes activ_elem transfer context export' (name, morph) input =
   let
     val thy = Context.theory_of context;
     val {notes, ...} = the_locale thy name;
     fun activate ((kind, facts), _) input =
       let
-        val mixin = collect_mixins context (name, morph $> export);
-        val facts' = facts |> Element.facts_map (Element.morph_ctxt (transfer input $> morph $> mixin $> export))
+        val mixin = case export' of NONE => Morphism.identity
+         | SOME export => collect_mixins context (name, morph $> export) $> export;
+        val facts' = facts |> Element.facts_map (Element.morph_ctxt (transfer input $> morph $> mixin))
       in activ_elem (Notes (kind, facts')) input end;
   in
     fold_rev activate notes input
   end;
 
-fun activate_facts' export dep context =
+fun activate_all name thy activ_elem transfer (marked, input) =
+  let
+    val {parameters = (_, params), spec = (asm, defs), ...} = the_locale thy name;
+    val input' = input |>
+      (not (null params) ?
+        activ_elem (Fixes (map (fn ((x, T), mx) => (Binding.name x, SOME T, mx)) params))) |>
+      (* FIXME type parameters *)
+      (case asm of SOME A => activ_elem (Assumes [(Attrib.empty_binding, [(A, [])])]) | _ => I) |>
+      (if not (null defs)
+        then activ_elem (Defines (map (fn def => (Attrib.empty_binding, (def, []))) defs))
+        else I);
+    val activate = activate_notes activ_elem transfer (Context.Theory thy) NONE;
+  in
+    roundup thy activate Morphism.identity (name, Morphism.identity) (marked, input')
+  end;
+
+
+(** Public activation functions **)
+
+fun activate_declarations dep = Context.proof_map (fn context =>
   let
     val thy = Context.theory_of context;
-    val activate = activate_notes' Element.init (Element.transfer_morphism o Context.theory_of) context export;
+  in
+    roundup thy activate_syntax_decls Morphism.identity dep (get_idents context, context)
+    |-> put_idents
+  end);
+
+fun activate_facts export dep context =
+  let
+    val thy = Context.theory_of context;
+    val activate = activate_notes Element.init (Element.transfer_morphism o Context.theory_of) context (SOME export);
   in roundup thy activate export dep (get_idents context, context) |-> put_idents end;
 
+fun init name thy =
+  activate_all name thy Element.init (Element.transfer_morphism o Context.theory_of)
+    ([], Context.Proof (ProofContext.init_global thy)) |-> put_idents |> Context.proof_of;
 
-(* Add and extend registrations *)
+
+(*** Add and extend registrations ***)
 
 fun amend_registration (name, morph) mixin export context =
   let
@@ -484,7 +468,7 @@
       |> (case mixin of NONE => I
            | SOME mixin => amend_registration (name, morph) mixin export)
       (* activate import hierarchy as far as not already active *)
-      |> activate_facts' export (name, morph)
+      |> activate_facts export (name, morph)
   end;