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