only conceal primitive definition theorems, not predicate names
authorhaftmann
Thu, 09 Sep 2010 09:11:13 +0200
changeset 39248 4a3747517552
parent 39247 3a15ee47c610
child 39249 9c866b248cb1
only conceal primitive definition theorems, not predicate names
src/HOL/Tools/inductive.ML
--- a/src/HOL/Tools/inductive.ML	Wed Sep 08 19:23:23 2010 +0200
+++ b/src/HOL/Tools/inductive.ML	Thu Sep 09 09:11:13 2010 +0200
@@ -789,14 +789,12 @@
             val xs = map Free (Variable.variant_frees lthy intr_ts
               (mk_names "x" (length Ts) ~~ Ts))
           in
-            (name_mx, (Attrib.empty_binding, fold_rev lambda (params @ xs)
+            (name_mx, (apfst Binding.conceal Attrib.empty_binding, fold_rev lambda (params @ xs)
               (list_comb (rec_const, params @ make_bool_args' bs i @
                 make_args argTs (xs ~~ Ts)))))
           end) (cnames_syn ~~ cs);
     val (consts_defs, lthy'') = lthy'
-      |> Local_Theory.conceal
-      |> fold_map Local_Theory.define specs
-      ||> Local_Theory.restore_naming lthy';
+      |> fold_map Local_Theory.define specs;
     val preds = (case cs of [_] => [rec_const] | _ => map #1 consts_defs);
 
     val (_, lthy''') = Variable.add_fixes (map (fst o dest_Free) params) lthy'';