X-Git-Url: http://git.megacz.com/?p=coq-hetmet.git;a=blobdiff_plain;f=Makefile;h=37512bf7e791ad2c6e562b9913b3f46c73dd4c0b;hp=826866b4132b3789aa00e353241c5233ec4564c9;hb=bb5ad91dc2d9cf1e35895e293b4e3e1478b4af00;hpb=112daf37524662d6d2267d3f7e50ff3522683b8f diff --git a/Makefile b/Makefile index 826866b..37512bf 100644 --- a/Makefile +++ b/Makefile @@ -1,24 +1,93 @@ -coqc := coqc -noglob -coqfiles := $(shell find src -name \*.v) -allfiles := $(coqfiles) $(shell find src -name \*.hs) +coqc := coqc -noglob -opt +coqfiles := $(shell find src -name \*.v | grep -v \\\#) +allfiles := $(coqfiles) $(shell find src -name \*.hs | grep -v \\\#) +coq_version := 8.3pl2-tracer -default: build/CoqPass.hs +default: all -build/CoqPass.hs: build/Makefile.coq $(allfiles) +all: $(allfiles) + $(MAKE) build/Makefile.coq + cd build; $(MAKE) -f Makefile.coq OPT="-opt -dont-load-proofs" All.vo - # first we build with -dont-load-proofs, since that runs very quickly - cd build; make -f Makefile.coq OPT="-dont-load-proofs" Main.vo +build/CoqPass.hs: $(allfiles) + $(coqc) -v | grep 'version $(coq_version)' || (echo;echo "You need Coq version $(coq_version) to proceed";echo; false) + make build/Makefile.coq + cd build; $(MAKE) -f Makefile.coq OPT="-opt -dont-load-proofs" ExtractionMain.vo + cd build; $(MAKE) -f Makefile.coq Extraction.vo + cat src/Extraction-prefix.hs > build/CoqPass.hs + cat build/Extraction.hs | grep -v '^module' | grep -v '^import' >> build/CoqPass.hs - # however the final extraction must be done without -dont-load-proofs - cd build; make -f Makefile.coq Extraction.vo - cat src/Extraction-prefix.hs build/Extraction.hs > build/CoqPass.hs - -build/Makefile.coq: $(coqfiles) +build/Makefile.coq: $(coqfiles) src/categories/src mkdir -p build rm -f build/*.v rm -f build/*.d - cd build; ln -s ../src/*.v . + cd build; ln -fs `find ../src -name \*.v` . cd build; coq_makefile *.v > Makefile.coq +src/categories/src: + git submodule update --init src/categories + cd src/categories; git checkout master + clean: - rm -rf build \ No newline at end of file + rm -rf build + +examples/test.pdf: + ../../../inplace/bin/ghc-stage2 GArrowTikZ.hs + ./GArrowTikZ > test.tex + pdflatex test.tex + open test.pdf + +examples/doc/index.html: + mkdir -p examples/doc + haddock --html Unify.hs + open Unify.html + + +merged: + mkdir -p .temp + cd src; for A in *.v; do cat $$A | grep -v '^Require Import' > ../.temp/`echo $$A | sed s_\\\\.v_._`; done + cd src/categories/src; for A in *.v; do cat $$A | \ + grep -v '^Require Import' > ../../../.temp/`echo $$A | sed s_\\\\.v_._`; done + cp src/Banner.v .temp/GArrows.v + cd .temp; grep '^Require Import ' ../src/All.v | sed 's_Require Import _echo;echo;echo;echo;echo;cat _' | bash >> GArrows.v + cd .temp; time $(coqc) -dont-load-proofs -verbose GArrows.v + echo + echo COMPILATION OK + echo + +pushcheck: + ssh megacz.com -- 'rm -rf /tmp/pushcheck; mkdir /tmp/pushcheck; cd /tmp/pushcheck; git clone http://git.megacz.com/ghc-hetmet.git && git clone http://git.megacz.com/coq-hetmet.git ghc-hetmet/compiler/hetmet' + rsync -are ssh --progress --verbose --exclude .git --exclude src/categories/build/ --exclude build/ ./ megacz.com:/tmp/pushcheck/ghc-hetmet/compiler/hetmet/ + ssh megacz.com -- '/vol/megacz/pushcheck2.sh' + + +# this is for Adam's use only! +push: build/CoqPass.hs + git push http://git.megacz.com/coq-hetmet.git master + git add -f build/CoqPass.hs; \ + git commit -m 'update baked-in CoqPass.hs' && \ + (git push -f http://git.megacz.com/coq-hetmet.git master:coq-extraction-baked-in; \ + git reset HEAD^) + rm -rf .temp + mkdir .temp + cd .temp; ln -s ../src/*.v . + cd .temp; for A in *.v; do \ + echo Latexing $$A ... ;\ + echo '\\documentclass[9pt,landscape]{article}' > $$A.tex; \ + echo '\\usepackage[landscape]{geometry}' >> $$A.tex; \ + echo '\\usepackage[cm]{fullpage}' >> $$A.tex; \ + echo '\\usepackage{amsmath}' >> $$A.tex; \ + echo '\\usepackage{amssymb}' >> $$A.tex; \ + echo '\\usepackage{stmaryrd}' >> $$A.tex; \ + echo '\\usepackage{upgreek}' >> $$A.tex; \ + echo '\\usepackage{parskip}' >> $$A.tex; \ + echo '\\begin{document}' >> $$A.tex; \ + echo '{{\\tt{' >> $$A.tex; \ + echo '' >> $$A.tex; \ + java -jar ~/bin/unicode2tex.jar < ../src/$$A >> $$A.tex;\ + echo '}}}' >> $$A.tex; \ + echo '\\end{document}' >> $$A.tex; \ + pdflatex $$A.tex < /dev/null; done + ssh login.eecs.berkeley.edu -- 'rm public_html/coq-in-ghc/pdfs/*.pdf' ; true + scp .temp/*.pdf login.eecs.berkeley.edu:public_html/coq-in-ghc/pdfs/ + rm -rf .temp