X-Git-Url: http://matita.cs.unibo.it/gitweb/?p=helm.git;a=blobdiff_plain;f=helm%2Fsoftware%2Fhelena%2FMakefile;h=38dab9e6b1d929f8d26cb76b11f385e30c2ff0c3;hp=6194e6c4c0ace7eb89cb4398ad21977c68841c92;hb=88977b2d546e547e23b046792fe2ad8f6ff192a4;hpb=fdb80b08af83b86759833142456ce3c4f84cd80e diff --git a/helm/software/helena/Makefile b/helm/software/helena/Makefile index 6194e6c4c..38dab9e6b 100644 --- a/helm/software/helena/Makefile +++ b/helm/software/helena/Makefile @@ -1,21 +1,33 @@ -MAIN = helena - SRC = src +DIRECTORIES = $(shell find $(SRC) -type d) + +ALL_FEATURES = LEXER PARSER TRACE SUMMARY EXPAND MANAGER OBJECTS PREPROCESS QUOTE STAGE TYPE + +FF = $(F:ALL=$(ALL_FEATURES)) + +EXEC = helena + REQUIRES = unix str helm-ng_kernel OCAMLOPTIONS = -rectypes +CAMLPOPTIONS = $(FF:%=-D%) + +BUILDOPTIONS = -Is "$(DIRECTORIES)" + KEEP = README CLEAN = etc/log.txt etc/profile.txt -TAGS = test-si-fast test-si test2-opt test2-byte test3 test6 \ - profile-fast profile profile-coq profile-coq-byte \ - xml-si xml-si-v3 xml xml-v3 \ - export-coq export-matita \ - export-lp1 export-lp2 export-tj2 export-tj3 \ - matita matitac +TARGETS = test-si-fast test-si test2-opt test2-byte test3 test6 \ + profile-fast profile profile-coq profile-coq-byte \ + xml-si xml-si-v3 xml xml-v3 \ + export-coq export-matita \ + export-lp1 export-lp2 export-tj2 export-tj3 export-lyp \ + matita matitac + +include Makefile.common TIME = `which time` -p -a -o etc/log.txt @@ -41,130 +53,128 @@ LP1 = grundlagen_21.elpi LP2 = grundlagen_22.elpi TJ2 = grundlagen_22.mod TJ3 = grundlagen_23.mod +CC0 = grundlagen_20.elpi +LYP = grundlagen_2b_lyp.elpi PREAMBLE_MA = ../matita/matita.ma.templ PREAMBLE_V = $(OUTPUT)/coq/grundlagen.template PREAMBLE_LP = $(OUTPUT)/lp/lp.template -ALL_FEATURES = LEXER PARSER TRACE SUMMARY EXPAND MANAGER OBJECTS PREPROCESS QUOTE STAGE TYPE - TEST1 = -T 1 -l -u -1 $(O) $(INPUT) TEST2 = -X -T 2 -l -1 $(O) $(INPUT) -all: .depend.opt .depend.byte - @$(CALLMAKE) $(MAIN).opt F="$(ALL_FEATURES)" - @$(CALLMAKE) $(MAIN).byte F="$(ALL_FEATURES)" - -opt: .depend.opt - @$(CALLMAKE) F="$(ALL_FEATURES)" $(MAIN).opt - -byte: .depend.byte - @$(CALLMAKE) F="$(ALL_FEATURES)" $(MAIN).byte - -test-si-fast: $(MAIN).opt etc +test-si-fast: $(EXEC).native etc @echo " HELENA -u -x -y -1 $(INPUTFAST)" - $(H)./$(MAIN).opt -T 1 -u -x -y -1 $(O) $(INPUTFAST) > etc/log.txt + $(H)./$(EXEC).native -T 1 -u -x -y -1 $(O) $(INPUTFAST) > etc/log.txt -test-si: $(MAIN).opt etc +test-si: $(EXEC).native etc @echo " HELENA -d -l -u -0 $(INPUT)" - $(H)./$(MAIN).opt -T 2 -d -l -u -0 $(O) $(INPUT) > etc/log.txt + $(H)./$(EXEC).native -T 2 -d -l -u -0 $(O) $(INPUT) > etc/log.txt -test1: $(MAIN).opt etc +test1: $(EXEC).native etc @echo " HELENA -l -u -1 $(INPUT)" - $(H)./$(MAIN).opt $(TEST1) > etc/log.txt + $(H)./$(EXEC).native $(TEST1) > etc/log.txt -test2-opt: $(MAIN).opt etc +test2-opt: $(EXEC).native etc @echo " HELENA -l -1 $(INPUT)" - $(H)./$(MAIN).opt $(TEST1) $(TEST2) > etc/log.txt + $(H)./$(EXEC).native $(TEST1) $(TEST2) > etc/log.txt -test2-byte: $(MAIN).byte etc +test2-byte: $(EXEC).byte etc @echo " HELENA -l -1 $(INPUT)" - $(H)./$(MAIN).byte $(TEST1) $(TEST2) > etc/log.txt + $(H)./$(EXEC).byte $(TEST1) $(TEST2) > etc/log.txt -test3: $(MAIN).opt etc +test3: $(EXEC).native etc @echo " HELENA -T 3 -l $(INPUT)" - $(H)./$(MAIN).opt -l -u $(O) $(INPUT) -X -T 3 -l $(O) $(INPUT) > etc/log.txt + $(H)./$(EXEC).native -l -u $(O) $(INPUT) -X -T 3 -l $(O) $(INPUT) > etc/log.txt -test6: $(MAIN).opt etc +test6: $(EXEC).native etc @echo " HELENA -T 6 -l $(INPUT)" - $(H)./$(MAIN).opt -l -u $(O) $(INPUT) -X -T 6 -l $(O) $(INPUT) > etc/log.txt + $(H)./$(EXEC).native -l -u $(O) $(INPUT) -X -T 6 -l $(O) $(INPUT) > etc/log.txt -profile-fast: $(MAIN).opt etc +profile-fast: $(EXEC).native etc @echo " HELENA -u -x -y -1 $(INPUTFAST) (31 TIMES)" $(H)rm -f etc/log.txt - $(H)for T in `seq 31`; do ./$(MAIN).opt -T 1 -u -x -y -1 $(O) $(INPUTFAST) >> etc/log.txt; done + $(H)for T in `seq 31`; do ./$(EXEC).native -T 1 -u -x -y -1 $(O) $(INPUTFAST) >> etc/log.txt; done $(H)grep "at exit" etc/log.txt | sort | uniq > etc/profile.txt -profile: $(MAIN).opt etc +profile: $(EXEC).native etc @echo " HELENA -l -u -1 $(INPUT) (31 TIMES)" $(H)rm -f etc/log.txt - $(H)for _ in `seq 31`; do ./$(MAIN).opt $(TEST1) >> etc/log.txt; done + $(H)for _ in `seq 31`; do ./$(EXEC).native $(TEST1) >> etc/log.txt; done $(H)grep "at exit" etc/log.txt | sort | uniq > etc/profile.txt -profile-opt: $(MAIN).opt etc +profile-opt: $(EXEC).native etc @echo " HELENA -l -1 $(INPUT) (31 TIMES)" $(H)rm -f etc/log.txt - $(H)for _ in `seq 31`; do ./$(MAIN).opt $(TEST1) $(TEST2) >> etc/log.txt; done + $(H)for _ in `seq 31`; do ./$(EXEC).native $(TEST1) $(TEST2) >> etc/log.txt; done $(H)grep "processed" etc/log.txt | sort -k 6 | uniq > etc/profile.txt -profile-byte: $(MAIN).byte etc +profile-byte: $(EXEC).byte etc @echo " HELENA -l -1 $(INPUT) (31 TIMES)" $(H)rm -f etc/log.txt - $(H)for _ in `seq 31`; do ./$(MAIN).byte $(TEST1) $(TEST2) >> etc/log.txt; done + $(H)for _ in `seq 31`; do ./$(EXEC).byte $(TEST1) $(TEST2) >> etc/log.txt; done $(H)grep "processed" etc/log.txt | sort -k 6 | uniq > etc/profile.txt -profile-coq: $(MAIN).opt etc +profile-coq: etc @echo " COQTOP $(V) (31 TIMES)" $(H)rm -f etc/log.txt $(H)for _ in `seq 31`; do echo Load \"$(OUTPUT)/coq/$(V)\". | $(TIME) $(COQTOP) -q $(NULL); done $(H)grep -h user etc/log.txt | sort | uniq > etc/profile.txt -profile-coq-byte: $(MAIN).opt etc +profile-coq-byte: etc @echo " COQTOP $(V) (31 TIMES)" $(H)rm -f etc/log.txt $(H)for _ in `seq 31`; do echo Load \"$(OUTPUT)/coq/$(V)\". | $(TIME) $(COQTOP).byte -q $(NULL); done $(H)grep -h user etc/log.txt | sort | uniq > etc/profile.txt -xml-si: $(MAIN).opt etc +xml-si: $(EXEC).native etc @echo " HELENA -l -o -q -s 1 -u -y $(INPUT)" - $(H)./$(MAIN).opt -O $(XMLDIR) -T 1 -l -o -q -s 1 -u -y $(O) $(INPUT) > etc/log.txt + $(H)./$(EXEC).native -O $(XMLDIR) -T 1 -l -o -q -s 1 -u -y $(O) $(INPUT) > etc/log.txt -xml-si-v3: $(MAIN).opt etc +xml-si-v3: $(EXEC).native etc @echo " HELENA -l -o -q -s 2 -u -y $(INPUT)" - $(H)./$(MAIN).opt -O $(XMLDIR) -T 1 -l -o -q -s 2 -u -y $(O) $(INPUT) > etc/log.txt + $(H)./$(EXEC).native -O $(XMLDIR) -T 1 -l -o -q -s 2 -u -y $(O) $(INPUT) > etc/log.txt -xml: $(MAIN).opt etc +xml: $(EXEC).native etc @echo " HELENA -l -o -q -s 1 -y $(INPUT)" - $(H)./$(MAIN).opt -l -u $(O) $(INPUT) -X -O $(XMLDIR) -T 1 -l -o -q -s 1 -y $(O) $(INPUT) > etc/log.txt + $(H)./$(EXEC).native -l -u $(O) $(INPUT) -X -O $(XMLDIR) -T 1 -l -o -q -s 1 -y $(O) $(INPUT) > etc/log.txt -xml-v3: $(MAIN).opt etc +xml-v3: $(EXEC).native etc @echo " HELENA -l -o -q -s 2 -y $(INPUT)" - $(H)./$(MAIN).opt -l -u $(O) $(INPUT) -X -O $(XMLDIR) -T 1 -l -o -q -s 2 -y $(O) $(INPUT) > etc/log.txt + $(H)./$(EXEC).native -l -u $(O) $(INPUT) -X -O $(XMLDIR) -T 1 -l -o -q -s 2 -y $(O) $(INPUT) > etc/log.txt -export-coq $(OUTPUT)/coq/$(V): $(MAIN).opt etc +export-coq $(OUTPUT)/coq/$(V): $(EXEC).native etc @echo " HELENA -m V8 -q $(INPUT)" - $(H)./$(MAIN).opt -M $(OUTPUT) -a n -m V8 -p $(PREAMBLE_V) -q $(TEST1) > etc/log.txt + $(H)./$(EXEC).native -M $(OUTPUT) -a n -m V8 -p $(PREAMBLE_V) -q $(TEST1) > etc/log.txt -export-matita $(OUTPUT)/matita/$(MA): $(MAIN).opt etc +export-matita $(OUTPUT)/matita/$(MA): $(EXEC).native etc @echo " HELENA -m MA2 -q $(INPUT)" - $(H)./$(MAIN).opt -M $(OUTPUT) -a n -m MA2 -p $(PREAMBLE_MA) -q $(TEST1) > etc/log.txt + $(H)./$(EXEC).native -M $(OUTPUT) -a n -m MA2 -p $(PREAMBLE_MA) -q $(TEST1) > etc/log.txt -export-lp1 $(OUTPUT)/lp/$(LP1): $(MAIN).opt etc +export-lp1 $(OUTPUT)/lp/$(LP1): $(EXEC).native etc @echo " HELENA -m LP1 -q $(INPUT)" - $(H)./$(MAIN).opt -M $(OUTPUT) -a n -m LP1 -p $(PREAMBLE_LP) -q $(TEST1) > etc/log.txt + $(H)./$(EXEC).native -M $(OUTPUT) -a n -m LP1 -p $(PREAMBLE_LP) -q $(TEST1) > etc/log.txt -export-lp2 $(OUTPUT)/lp/$(LP2): $(MAIN).opt etc +export-lp2 $(OUTPUT)/lp/$(LP2): $(EXEC).native etc @echo " HELENA -m LP2 -q $(INPUT)" - $(H)./$(MAIN).opt -M $(OUTPUT) -a n -m LP2 -p $(PREAMBLE_LP) -q $(TEST1) > etc/log.txt + $(H)./$(EXEC).native -M $(OUTPUT) -a n -m LP2 -p $(PREAMBLE_LP) -q $(TEST1) > etc/log.txt -export-tj2 $(OUTPUT)/lp/$(TJ2): $(MAIN).opt etc +export-tj2 $(OUTPUT)/lp/$(TJ2): $(EXEC).native etc @echo " HELENA -m TJ2 -q $(INPUT)" - $(H)./$(MAIN).opt -M $(OUTPUT) -a n -m TJ2 -p $(PREAMBLE_LP) -q $(TEST1) > etc/log.txt + $(H)./$(EXEC).native -M $(OUTPUT) -a n -m TJ2 -p $(PREAMBLE_LP) -q $(TEST1) > etc/log.txt -export-tj3 $(OUTPUT)/lp/$(TJ3): $(MAIN).opt etc +export-tj3 $(OUTPUT)/lp/$(TJ3): $(EXEC).native etc @echo " HELENA -m TJ3 -q $(INPUT)" - $(H)./$(MAIN).opt -M $(OUTPUT) -a n -m TJ3 -p $(PREAMBLE_LP) -q $(TEST1) > etc/log.txt + $(H)./$(EXEC).native -M $(OUTPUT) -a n -m TJ3 -p $(PREAMBLE_LP) -q $(TEST1) > etc/log.txt + +export-cc0 $(OUTPUT)/cc/$(CC0): $(EXEC).native etc + @echo " HELENA -m CC0 -q $(INPUT)" + $(H)./$(EXEC).native -M $(OUTPUT) -a n -m CC0 -p $(PREAMBLE_LP) -q $(TEST1) > etc/log.txt + +export-lyp $(OUTPUT)/lp/$(LYP): $(EXEC).native etc + @echo " HELENA -m lyp -q $(INPUT)" + $(H)./$(EXEC).native -M $(OUTPUT) -a n -m lyp -p $(PREAMBLE_LP) -c -q $(O) $(TEST1) > etc/log.txt matita: $(OUTPUT)/matita/$(MA) @echo " MATITA $(MA)" @@ -174,10 +184,8 @@ matitac: $(OUTPUT)/matita/$(MA) @echo " MATITAC $(MA)" $(H)cd matita && $(MATITAC) $(MA) -#profile-matita: $(MAIN).opt etc +#profile-matita: $(EXEC).native etc # @echo " HELENA -u $(INPUT) (1 TIMES)" # $(H)rm -f etc/log.txt -# $(H)for T in `seq 1`; do ./$(MAIN).opt -T 1 -M $(OUTPUT) -a n -l -m $(PREAMBLE) -o -u $(INPUT) >> etc/log.txt; done +# $(H)for T in `seq 1`; do ./$(EXEC).native -T 1 -M $(OUTPUT) -a n -l -m $(PREAMBLE) -o -u $(INPUT) >> etc/log.txt; done # $(H)grep "at exit" etc/log.txt | sort | uniq > etc/profile-new.txt - -include Makefile.common