src/Pure/term.ML
changeset 6033 c8c69a4a7762
parent 5986 6ebbc9e7cc20
child 6548 9b108dd75c25
--- a/src/Pure/term.ML	Fri Dec 18 11:00:46 1998 +0100
+++ b/src/Pure/term.ML	Fri Dec 18 11:01:25 1998 +0100
@@ -40,6 +40,7 @@
   val is_Const: term -> bool
   val is_Free: term -> bool
   val is_Var: term -> bool
+  val dest_Type: typ -> string * typ list
   val dest_Const: term -> string * typ
   val dest_Free: term -> string * typ
   val dest_Var: term -> indexname * typ
@@ -188,13 +189,7 @@
              | TFree of string * sort
 	     | TVar  of indexname * sort;
 
-fun S --> T = Type("fun",[S,T]);
-
-(*handy for multiple args: [T1,...,Tn]--->T  gives  T1-->(T2--> ... -->T)*)
-val op ---> = foldr (op -->);
-
-
-(*terms.  Bound variables are indicated by depth number.
+(*Terms.  Bound variables are indicated by depth number.
   Free variables, (scheme) variables and constants have names.
   An term is "closed" if every bound variable of level "lev"
   is enclosed by at least "lev" abstractions. 
@@ -232,6 +227,17 @@
 *)
 
 
+(** Types **)
+
+fun S --> T = Type("fun",[S,T]);
+
+(*handy for multiple args: [T1,...,Tn]--->T  gives  T1-->(T2--> ... -->T)*)
+val op ---> = foldr (op -->);
+
+fun dest_Type (Type x) = x
+  | dest_Type T = raise TYPE ("dest_Type", [T], []);
+
+
 (** Discriminators **)
 
 fun is_Const (Const _) = true