author | nipkow |
Thu, 22 May 1997 10:49:33 +0200 | |
changeset 3287 | 078be5581967 |
parent 3125 | 3f0ab2c306f7 |
child 3313 | b00902bb16ca |
permissions | -rw-r--r-- |
1296 | 1 |
# $Id$ |
923 | 2 |
######################################################################### |
3 |
# # |
|
2094 | 4 |
# Makefile for Isabelle (HOL) # |
923 | 5 |
# # |
6 |
######################################################################### |
|
7 |
||
8 |
#To make the system, cd to this directory and type |
|
1296 | 9 |
# make |
923 | 10 |
#To make the system and test it on standard examples, type |
1296 | 11 |
# make test |
12 |
#To generate HTML files for every theory, set the environment variable |
|
13 |
#MAKE_HTML or add the parameter "MAKE_HTML=". |
|
923 | 14 |
|
15 |
#Environment variable ISABELLECOMP specifies the compiler. |
|
16 |
#Environment variable ISABELLEBIN specifies the destination directory. |
|
17 |
#For Poly/ML, ISABELLEBIN must begin with a / |
|
18 |
||
19 |
#Makes pure Isabelle (Pure) if this file is ABSENT -- but not |
|
20 |
#if it is out of date, since this Makefile does not know its dependencies! |
|
21 |
||
22 |
BIN = $(ISABELLEBIN) |
|
23 |
COMP = $(ISABELLECOMP) |
|
1129 | 24 |
NAMES = HOL Ord Set Fun subset equalities Prod Relation Trancl Sum WF \ |
2094 | 25 |
mono Lfp Gfp Nat intr_elim indrule Inductive Finite Arith \ |
26 |
Sexp Univ List RelPow Option |
|
923 | 27 |
|
28 |
FILES = ROOT.ML add_ind_def.ML datatype.ML hologic.ML\ |
|
1981 | 29 |
ind_syntax.ML cladata.ML simpdata.ML\ |
1665 | 30 |
typedef.ML thy_syntax.ML thy_data.ML ../Pure/section_utils.ML\ |
2889 | 31 |
../Provers/hypsubst.ML ../Provers/classical.ML ../Provers/blast.ML \ |
2094 | 32 |
../Provers/simplifier.ML ../Provers/splitter.ML\ |
2921 | 33 |
../Provers/nat_transitive.ML \ |
2094 | 34 |
$(NAMES:%=%.thy) $(NAMES:%=%.ML) |
923 | 35 |
|
1164 | 36 |
$(BIN)/HOL: $(BIN)/Pure $(FILES) |
2117 | 37 |
@if [ -d $${ISABELLEBIN:?}/Pure ];\ |
2094 | 38 |
then echo Bad value for ISABELLEBIN: \ |
39 |
$(BIN) is the Isabelle source directory; \ |
|
40 |
exit 1; \ |
|
2117 | 41 |
fi |
2235
866dbb04816c
Makefile improvements by Thomas Santen and Stephan Herrmann
paulson
parents:
2117
diff
changeset
|
42 |
@case `basename "$(COMP)"` in \ |
1164 | 43 |
poly*) echo 'make_database"$(BIN)/HOL"; quit();' \ |
1296 | 44 |
| $(COMP) $(BIN)/Pure;\ |
2094 | 45 |
if [ "$${MAKE_HTML}" = "true" ]; \ |
46 |
then echo 'open PolyML; make_html := true; exit_use_dir".";' \ |
|
47 |
| $(COMP) $(BIN)/HOL;\ |
|
1491 | 48 |
elif [ "$${MAKE_HTML-undefined}" != "undefined" ]; \ |
2094 | 49 |
then echo 'open PolyML; make_html := true; exit_use_dir"."; make_html := false;' | $(COMP) $(BIN)/HOL;\ |
50 |
else echo 'open PolyML; exit_use_dir".";' \ |
|
51 |
| $(COMP) $(BIN)/HOL;\ |
|
52 |
fi;\ |
|
2023
aa25f20c5d8b
Calls discgarb -c to realize dramatic space savings!
paulson
parents:
2019
diff
changeset
|
53 |
discgarb -c $(BIN)/HOL;;\ |
1491 | 54 |
sml*) if [ "$${MAKE_HTML}" = "true" ]; \ |
2094 | 55 |
then echo 'make_html := true; exit_use_dir"."; xML"$(BIN)/HOL" banner;' | $(BIN)/Pure;\ |
56 |
elif [ "$${MAKE_HTML-undefined}" != "undefined" ];\ |
|
57 |
then echo 'make_html := true; exit_use_dir"."; make_html := false; xML"$(BIN)/HOL" banner;' \ |
|
58 |
| $(BIN)/Pure;\ |
|
59 |
else echo 'exit_use_dir"."; xML"$(BIN)/HOL" banner;' \ |
|
60 |
| $(BIN)/Pure;\ |
|
61 |
fi;;\ |
|
923 | 62 |
*) echo Bad value for ISABELLECOMP: \ |
2117 | 63 |
\"$(COMP)\" is not poly or sml; exit 1;;\ |
923 | 64 |
esac |
65 |
||
66 |
$(BIN)/Pure: |
|
67 |
cd ../Pure; $(MAKE) |
|
68 |
||
1164 | 69 |
#### Testing of HOL |
923 | 70 |
|
71 |
#A macro referring to the object-logic (depends on ML compiler) |
|
2235
866dbb04816c
Makefile improvements by Thomas Santen and Stephan Herrmann
paulson
parents:
2117
diff
changeset
|
72 |
# [Thanks to Thomas Santen and Stephan Herrmann from GMD First] |
866dbb04816c
Makefile improvements by Thomas Santen and Stephan Herrmann
paulson
parents:
2117
diff
changeset
|
73 |
LOGIC=`case \`basename "$(ISABELLECOMP)"\` in \ |
866dbb04816c
Makefile improvements by Thomas Santen and Stephan Herrmann
paulson
parents:
2117
diff
changeset
|
74 |
poly*) echo "$(ISABELLECOMP) $(ISABELLEBIN)/HOL" ;;\ |
866dbb04816c
Makefile improvements by Thomas Santen and Stephan Herrmann
paulson
parents:
2117
diff
changeset
|
75 |
sml*) echo "$(ISABELLEBIN)/HOL" ;;\ |
2117 | 76 |
*) echo "echo; echo Bad value for ISABELLECOMP: \ |
2235
866dbb04816c
Makefile improvements by Thomas Santen and Stephan Herrmann
paulson
parents:
2117
diff
changeset
|
77 |
$(ISABELLECOMP) is not poly or sml; exit 1" ;;\ |
866dbb04816c
Makefile improvements by Thomas Santen and Stephan Herrmann
paulson
parents:
2117
diff
changeset
|
78 |
esac` |
923 | 79 |
|
2371 | 80 |
##TFL (requires integration into HOL proper) |
81 |
TFL_NAMES = mask tfl thms thry usyntax utils |
|
82 |
TFL_FILES = ../TFL/ROOT.ML ../TFL/sys.sml \ |
|
83 |
$(TFL_NAMES:%=../TFL/%.sig) $(TFL_NAMES:%=../TFL/%.sml) |
|
84 |
||
85 |
TFL: $(BIN)/HOL $(TFL_FILES) |
|
86 |
@if [ "$${MAKE_HTML-undefined}" != "undefined" ]; \ |
|
87 |
then echo 'make_html:= true; exit_use_dir"../TFL";quit();' | $(LOGIC);\ |
|
88 |
else echo 'exit_use_dir"../TFL";quit();' | $(LOGIC); \ |
|
89 |
fi |
|
90 |
||
3125 | 91 |
|
92 |
## Inductive definitions: simple examples |
|
93 |
||
94 |
INDUCT_FILES = Perm Comb Mutil SList LList LFilter Acc PropLog Term Simult |
|
95 |
||
96 |
INDUCT_FILES = Induct/ROOT.ML \ |
|
97 |
$(INDUCT_NAMES:%=Induct/%.thy) $(INDUCT_NAMES:%=Induct/%.ML) |
|
98 |
||
99 |
Induct: $(BIN)/HOL $(INDUCT_FILES) |
|
100 |
@if [ "$${MAKE_HTML-undefined}" != "undefined" ]; \ |
|
101 |
then echo 'make_html := true; exit_use_dir"Induct";quit();' | $(LOGIC); \ |
|
102 |
else echo 'exit_use_dir"Induct";quit();' | $(LOGIC); \ |
|
103 |
fi |
|
104 |
||
105 |
||
923 | 106 |
##IMP-semantics example |
1699 | 107 |
IMP_NAMES = Expr Com Natural Transition Denotation Hoare VC |
1044 | 108 |
IMP_FILES = IMP/ROOT.ML $(IMP_NAMES:%=IMP/%.thy) $(IMP_NAMES:%=IMP/%.ML) |
923 | 109 |
|
2094 | 110 |
IMP: $(BIN)/HOL $(IMP_FILES) |
2117 | 111 |
@if [ "$${MAKE_HTML-undefined}" != "undefined" ]; \ |
2094 | 112 |
then echo 'make_html := true; exit_use_dir"IMP";quit();' | $(LOGIC); \ |
113 |
else echo 'exit_use_dir"IMP";quit();' | $(LOGIC); \ |
|
114 |
fi |
|
923 | 115 |
|
1336 | 116 |
##Hoare logic |
117 |
Hoare_NAMES = Hoare Arith2 Examples |
|
1491 | 118 |
Hoare_FILES = Hoare/ROOT.ML $(Hoare_NAMES:%=Hoare/%.thy) \ |
2094 | 119 |
$(Hoare_NAMES:%=Hoare/%.ML) |
1336 | 120 |
|
2094 | 121 |
Hoare: $(BIN)/HOL $(Hoare_FILES) |
2117 | 122 |
@if [ "$${MAKE_HTML-undefined}" != "undefined" ]; \ |
2094 | 123 |
then echo 'make_html := true; exit_use_dir"Hoare";quit();' | $(LOGIC);\ |
124 |
else echo 'exit_use_dir"Hoare";quit();' | $(LOGIC); \ |
|
125 |
fi |
|
1336 | 126 |
|
1164 | 127 |
##The integers in HOL |
2279 | 128 |
INTEG_NAMES = Equiv Integ Group Ring Lagrange IntRingDefs IntRing |
923 | 129 |
|
1044 | 130 |
INTEG_FILES = Integ/ROOT.ML \ |
2094 | 131 |
$(INTEG_NAMES:%=Integ/%.thy) $(INTEG_NAMES:%=Integ/%.ML) |
923 | 132 |
|
2094 | 133 |
Integ: $(BIN)/HOL $(INTEG_FILES) |
2117 | 134 |
@if [ "$${MAKE_HTML-undefined}" != "undefined" ]; \ |
2094 | 135 |
then echo 'make_html := true; exit_use_dir"Integ";quit();' | $(LOGIC);\ |
136 |
else echo 'exit_use_dir"Integ";quit();' | $(LOGIC); \ |
|
137 |
fi |
|
923 | 138 |
|
1972 | 139 |
|
140 |
##Authentication & Security Protocols |
|
2117 | 141 |
Auth_NAMES = Message Shared NS_Shared OtwayRees OtwayRees_AN OtwayRees_Bad \ |
2450 | 142 |
Recur WooLam Yahalom Yahalom2 Public NS_Public_Bad NS_Public |
1972 | 143 |
|
144 |
AUTH_FILES = Auth/ROOT.ML $(AUTH_NAMES:%=Auth/%.thy) $(AUTH_NAMES:%=Auth/%.ML) |
|
145 |
||
2094 | 146 |
Auth: $(BIN)/HOL $(AUTH_FILES) |
2117 | 147 |
@if [ "$${MAKE_HTML-undefined}" != "undefined" ]; \ |
2094 | 148 |
then echo 'make_html := true; exit_use_dir"Auth";quit();' | $(LOGIC);\ |
149 |
else echo 'exit_use_dir"Auth";quit();' | $(LOGIC); \ |
|
150 |
fi |
|
1972 | 151 |
|
152 |
||
923 | 153 |
##Properties of substitutions |
1044 | 154 |
SUBST_NAMES = AList Setplus Subst Unifier UTerm UTLemmas |
923 | 155 |
|
1044 | 156 |
SUBST_FILES = Subst/ROOT.ML \ |
2094 | 157 |
$(SUBST_NAMES:%=Subst/%.thy) $(SUBST_NAMES:%=Subst/%.ML) |
923 | 158 |
|
2094 | 159 |
Subst: $(BIN)/HOL $(SUBST_FILES) |
2117 | 160 |
@if [ "$${MAKE_HTML-undefined}" != "undefined" ]; \ |
2094 | 161 |
then echo 'make_html := true; exit_use_dir"Subst";quit();' | $(LOGIC);\ |
162 |
else echo 'exit_use_dir"Subst";quit();' | $(LOGIC); \ |
|
163 |
fi |
|
923 | 164 |
|
1125 | 165 |
##Confluence of Lambda-calculus |
1270 | 166 |
LAMBDA_NAMES = Lambda ParRed Commutation Eta |
1125 | 167 |
|
168 |
LAMBDA_FILES = Lambda/ROOT.ML \ |
|
2094 | 169 |
$(LAMBDA_NAMES:%=Lambda/%.thy) $(LAMBDA_NAMES:%=Lambda/%.ML) |
1125 | 170 |
|
2094 | 171 |
Lambda: $(BIN)/HOL $(LAMBDA_FILES) |
2117 | 172 |
@if [ "$${MAKE_HTML-undefined}" != "undefined" ]; \ |
2094 | 173 |
then echo 'make_html := true; exit_use_dir"Lambda";quit();' \ |
174 |
| $(LOGIC);\ |
|
175 |
else echo 'exit_use_dir"Lambda";quit();' | $(LOGIC); \ |
|
176 |
fi |
|
1125 | 177 |
|
2534 | 178 |
## Type inference without let |
179 |
||
180 |
W0_NAMES = I Maybe MiniML Type W |
|
181 |
||
182 |
W0_FILES = W0/ROOT.ML \ |
|
183 |
$(W0_NAMES:%=W0/%.thy) $(W0_NAMES:%=W0/%.ML) |
|
184 |
||
185 |
W0: $(BIN)/HOL $(W0_FILES) |
|
186 |
@if [ "$${MAKE_HTML-undefined}" != "undefined" ]; \ |
|
187 |
then echo 'make_html := true; exit_use_dir"W0";quit();' \ |
|
188 |
| $(LOGIC);\ |
|
189 |
else echo 'exit_use_dir"W0";quit();' | $(LOGIC); \ |
|
190 |
fi |
|
191 |
||
192 |
## Type inference with let |
|
193 |
||
194 |
MINIML_NAMES = Generalize Instance Maybe MiniML Type W |
|
1301 | 195 |
|
1343 | 196 |
MINIML_FILES = MiniML/ROOT.ML \ |
2094 | 197 |
$(MINIML_NAMES:%=MiniML/%.thy) $(MINIML_NAMES:%=MiniML/%.ML) |
1301 | 198 |
|
1350
5bf4a54ba25f
replaced exit_use by exit_use_dir for subdirectories
clasohm
parents:
1343
diff
changeset
|
199 |
MiniML: $(BIN)/HOL $(MINIML_FILES) |
2117 | 200 |
@if [ "$${MAKE_HTML-undefined}" != "undefined" ]; \ |
2094 | 201 |
then echo 'make_html := true; exit_use_dir"MiniML";quit();' \ |
202 |
| $(LOGIC);\ |
|
203 |
else echo 'exit_use_dir"MiniML";quit();' | $(LOGIC); \ |
|
204 |
fi |
|
1301 | 205 |
|
1343 | 206 |
##Lexical analysis |
207 |
LEX_FILES = Auto AutoChopper Chopper Prefix |
|
208 |
||
209 |
LEX_FILES = Lex/ROOT.ML \ |
|
2094 | 210 |
$(LEX_NAMES:%=Lex/%.thy) $(LEX_NAMES:%=Lex/%.ML) |
1343 | 211 |
|
212 |
Lex: $(BIN)/HOL $(LEX_FILES) |
|
2117 | 213 |
@if [ "$${MAKE_HTML-undefined}" != "undefined" ]; \ |
2094 | 214 |
then echo 'make_html := true; exit_use_dir"Lex";quit();' | $(LOGIC);\ |
215 |
else echo 'exit_use_dir"Lex";quit();' | $(LOGIC); \ |
|
216 |
fi |
|
1343 | 217 |
|
923 | 218 |
##Miscellaneous examples |
3125 | 219 |
EX_NAMES = String BT InSort Qsort LexProd Puzzle Primes NatSum MT |
923 | 220 |
|
221 |
EX_FILES = ex/ROOT.ML ex/cla.ML ex/meson.ML ex/mesontest.ML ex/rel.ML \ |
|
2094 | 222 |
ex/set.ML $(EX_NAMES:%=ex/%.thy) $(EX_NAMES:%=ex/%.ML) |
923 | 223 |
|
2094 | 224 |
ex: $(BIN)/HOL $(EX_FILES) |
2117 | 225 |
@if [ "$${MAKE_HTML-undefined}" != "undefined" ]; \ |
2094 | 226 |
then echo 'make_html := true; exit_use_dir"ex";quit();' | $(LOGIC);\ |
227 |
else echo 'exit_use_dir"ex";quit();' | $(LOGIC); \ |
|
228 |
fi |
|
923 | 229 |
|
1343 | 230 |
#Full test. |
3125 | 231 |
test: $(BIN)/HOL \ |
232 |
TFL Induct IMP Hoare Lex Integ Auth Subst Lambda \ |
|
233 |
W0 MiniML IOA AxClasses Quot ex |
|
923 | 234 |
echo 'Test examples ran successfully' > test |
235 |
||
1164 | 236 |
.PRECIOUS: $(BIN)/Pure $(BIN)/HOL |