Includes type:sort constraints in its code to collect predicates in axiom clauses.
authorpaulson
Thu, 16 Nov 2006 17:06:24 +0100
changeset 21398 11996e938dfe
parent 21397 2134b81a0b37
child 21399 700ae58d2273
Includes type:sort constraints in its code to collect predicates in axiom clauses.
src/HOL/Tools/res_hol_clause.ML
--- a/src/HOL/Tools/res_hol_clause.ML	Thu Nov 16 17:05:23 2006 +0100
+++ b/src/HOL/Tools/res_hol_clause.ML	Thu Nov 16 17:06:24 2006 +0100
@@ -696,15 +696,22 @@
                        (foldl add_clause_funcs (init_funcs_tab Symtab.empty) clauses)
                        arity_clauses)
 
-fun preds_of clsrel_clauses arity_clauses = 
+fun add_clause_preds (Clause {ctypes_sorts, ...}, preds) =
+  foldl ResClause.add_type_sort_preds preds ctypes_sorts
+  handle Symtab.DUP a => raise ERROR ("predicate " ^ a ^ " has multiple arities")
+
+(*Higher-order clauses have only the predicates hBOOL and type classes.*)
+fun preds_of_clauses clauses clsrel_clauses arity_clauses = 
     Symtab.dest
 	(foldl ResClause.add_classrelClause_preds 
 	       (foldl ResClause.add_arityClause_preds
-		      (Symtab.update ("hBOOL",1) Symtab.empty)
+		      (Symtab.update ("hBOOL",1) 
+		        (foldl add_clause_preds Symtab.empty clauses))
 		      arity_clauses)
 	       clsrel_clauses)
 
 
+
 (**********************************************************************)
 (* write clauses to files                                             *)
 (**********************************************************************)
@@ -781,7 +788,7 @@
 	val helper_clauses = (#2 o ListPair.unzip o get_helper_clauses) ()
 	val helper_clauses_strs = (#1 o ListPair.unzip o (map clause2dfg)) helper_clauses
 	val funcs = funcs_of_clauses (helper_clauses @ conjectures @ axclauses') arity_clauses
-	and preds = preds_of classrel_clauses arity_clauses
+	and preds = preds_of_clauses axclauses' classrel_clauses arity_clauses
     in
 	TextIO.output (out, ResClause.string_of_start probname); 
 	TextIO.output (out, ResClause.string_of_descrip probname);