added assert_judgment;
authorwenzelm
Wed, 10 Jul 2002 14:49:06 +0200
changeset 13334 27149d72bdff
parent 13333 1f5745b76fb8
child 13335 7995b3f4ca5e
added assert_judgment;
src/Pure/Isar/object_logic.ML
--- a/src/Pure/Isar/object_logic.ML	Wed Jul 10 14:48:08 2002 +0200
+++ b/src/Pure/Isar/object_logic.ML	Wed Jul 10 14:49:06 2002 +0200
@@ -13,6 +13,7 @@
   val judgment_name: Sign.sg -> string
   val is_judgment: Sign.sg -> term -> bool
   val drop_judgment: Sign.sg -> term -> term
+  val assert_judgment: Sign.sg -> term -> term
   val fixed_judgment: Sign.sg -> string -> term
   val declare_atomize: theory attribute
   val declare_rulify: theory attribute
@@ -95,6 +96,11 @@
       if (c = judgment_name sg handle TERM _ => false) then t else tm
   | drop_judgment _ tm = tm;
 
+fun assert_judgment sg (Abs (x, T, t)) = Abs (x, T, assert_judgment sg t)
+  | assert_judgment sg t =
+      if (is_judgment sg t handle TERM _ => true) then t
+      else Const (judgment_name sg, fastype_of t --> propT) $ t;
+
 fun fixed_judgment sg x =
   let  (*be robust wrt. low-level errors*)
     val c = judgment_name sg;