src/ZF/ROOT.ML
author lcp
Fri Dec 16 18:07:12 1994 +0100 (1994-12-16)
changeset 803 4c8333ab3eae
parent 578 efc648d29dd0
child 1069 66efd8f90fbd
permissions -rw-r--r--
changed useless "qed" calls for lemmas back to uses of "result",
and/or used "bind_thm" to declare the real results.
     1 (*  Title: 	ZF/ROOT
     2     ID:         $Id$
     3     Author: 	Lawrence C Paulson, Cambridge University Computer Laboratory
     4     Copyright   1993  University of Cambridge
     5 
     6 Adds Zermelo-Fraenkel Set Theory to a database containing First-Order Logic.
     7 
     8 This theory is the work of Martin Coen, Philippe Noel and Lawrence Paulson.
     9 *)
    10 
    11 val banner = "ZF Set Theory (in FOL)";
    12 writeln banner;
    13 
    14 (*For Pure/tactic??  A crude way of adding structure to rules*)
    15 fun CHECK_SOLVED (Tactic tf) = 
    16   Tactic (fn state => 
    17     case Sequence.pull (tf state) of
    18 	None => error"DO_GOAL: tactic list failed"
    19       | Some(x,_) => 
    20 		if has_fewer_prems 1 x then
    21 		    Sequence.cons(x, Sequence.null)
    22 		else (writeln"DO_GOAL: unsolved goals!!";
    23 		      writeln"Final proof state was ...";
    24 		      print_goals (!goals_limit) x;
    25 		      raise ERROR));
    26 
    27 fun DO_GOAL tfs = SELECT_GOAL (CHECK_SOLVED (EVERY1 tfs));
    28 
    29 print_depth 1;
    30 
    31 (*Add user sections for inductive/datatype definitions*)
    32 use     "../Pure/section_utils.ML";
    33 use     "thy_syntax.ML";
    34 
    35 use_thy "InfDatatype";
    36 use_thy "List";
    37 use_thy "EquivClass";
    38 
    39 (*printing functions are inherited from FOL*)
    40 print_depth 8;
    41 
    42 val ZF_build_completed = ();	(*indicate successful build*)