tools: more top-level build fixes; remove chart/vty rules
This commit is contained in:
		
							parent
							
								
									f03b020e2f
								
							
						
					
					
						commit
						3e28f6001f
					
				
							
								
								
									
										76
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										76
									
								
								Makefile
									
									
									
									
									
								
							| @ -17,7 +17,7 @@ COVCMD=test | ||||
| # or in the current directory. hledger executables for benchmarking should
 | ||||
| # generally be the standard optimised cabal build, constrained to parsec 2.
 | ||||
| BENCHEXES=hledger-0.12.1 hledger-0.13 hledger-0.14 hledger-0.15 hledger-0.16 hledger-0.17 hledger-0.18 hledgeropt ledger | ||||
| #BENCHEXES=hledger
 | ||||
| BENCHEXES=hledger-0.18 hledger ledger | ||||
| 
 | ||||
| # misc. tools
 | ||||
| BROWSE=google-chrome | ||||
| @ -30,16 +30,12 @@ PRINT=lpr | ||||
| PACKAGES=\
 | ||||
| 	hledger-lib \
 | ||||
| 	hledger \
 | ||||
| 	hledger-web \
 | ||||
| #	hledger-vty \
 | ||||
| #	hledger-chart
 | ||||
| 	hledger-web | ||||
| INCLUDEPATHS=\
 | ||||
| 	-i../hledger-lib \
 | ||||
| 	-i../hledger \
 | ||||
| 	-i../hledger-web \
 | ||||
| #	-i../hledger-vty \
 | ||||
| #	-i../hledger-chart
 | ||||
| MAIN=hledger-cli.hs | ||||
| 	-ihledger-lib \
 | ||||
| 	-ihledger \
 | ||||
| 	-ihledger-web | ||||
| MAIN=hledger/hledger-cli.hs | ||||
| 
 | ||||
| # all source files in the project (plus a few strays like Setup.hs & hlint.hs)
 | ||||
| SOURCEFILES:= \
 | ||||
| @ -60,11 +56,7 @@ HADDOCKSOURCEFILES:= \ | ||||
| 	hledger/Hledger/*/*hs \
 | ||||
| 	hledger-web/Hledger/*hs \
 | ||||
| 	hledger-web/Hledger/*/*hs \
 | ||||
| 	hledger-web/Hledger/Web/Settings/*hs \
 | ||||
| #	hledger-vty/Hledger/*hs \
 | ||||
| #	hledger-vty/Hledger/*/*hs
 | ||||
| #	hledger-chart/Hledger/*hs
 | ||||
| #	hledger-chart/Hledger/*/*hs
 | ||||
| 	hledger-web/Hledger/Web/Settings/*hs | ||||
| 
 | ||||
| CABALFILES:= \
 | ||||
| 	hledger/hledger.cabal \
 | ||||
| @ -73,7 +65,6 @@ CABALFILES:= \ | ||||
| WEBFILES:= \
 | ||||
| 	hledger-web/static/*.js \
 | ||||
| 	hledger-web/static/*.css | ||||
| #	hledger-web/templates/* \
 | ||||
| 
 | ||||
| DOCFILES:= \
 | ||||
| 	*.md | ||||
| @ -151,23 +142,17 @@ autotest-%: sp | ||||
| 	$(AUTOBUILD) $(MAIN) -o bin/hledger $(AUTOBUILDFLAGS) --run test $* | ||||
| 
 | ||||
| autoweb: sp | ||||
| 	cd hledger-web; $(AUTOBUILD) hledger-web.hs -o bin/hledger-web $(AUTOBUILDFLAGS) -DDEVELOPMENT --run -B --port 5001 --base-url http://localhost:5001 -f test.journal | ||||
| 
 | ||||
| autovty: sp | ||||
| 	cd hledger-vty; $(AUTOBUILD) hledger-vty.hs -o bin/hledger-vty $(AUTOBUILDFLAGS) --run --help | ||||
| 
 | ||||
| autochart: sp | ||||
| 	cd hledger-chart; $(AUTOBUILD) hledger-chart.hs -o bin/hledger-chart $(AUTOBUILDFLAGS) --run --help | ||||
| 	$(AUTOBUILD) hledger-web/hledger-web.hs -o bin/hledger-web $(AUTOBUILDFLAGS) -DDEVELOPMENT --run -B --port 5001 --base-url http://localhost:5001 -f test.journal | ||||
| 
 | ||||
| # check for sp and explain how to get it if not found.
 | ||||
| sp: | ||||
| 	@/usr/bin/env which sp >/dev/null || \
 | ||||
| 	  (echo '"sp" is required for auto-compilation. darcs get http://joyful.com/darcsden/simon/searchpath, make it (cabal install-ing any needed packages) and add it to your PATH'; exit 1) | ||||
| 
 | ||||
| hledgerall: bin/hledger hledger-web hledger-vty hledger-chart | ||||
| hledgerall: bin/hledger hledger-web | ||||
| 
 | ||||
| # force a compile even if binary exists, since we don't specify dependencies
 | ||||
| .PHONY: bin/hledger hledger-web hledger-vty hledger-chart | ||||
| .PHONY: bin/hledger hledger-web | ||||
| 
 | ||||
| # build hledger binary as quickly as possible
 | ||||
| bin/hledger: | ||||
| @ -201,36 +186,22 @@ hledgerhpc: | ||||
| # build other executables quickly
 | ||||
| 
 | ||||
| bin/hledger-web: | ||||
| 	cd hledger-web; ghc --make hledger-web.hs -o bin/hledger-web $(BUILDFLAGS) | ||||
| 	ghc --make -o $@ $(BUILDFLAGS) hledger-web/hledger-web.hs | ||||
| 
 | ||||
| bin/hledger-web-production: | ||||
| 	cd hledger-web; ghc --make hledger-web.hs -o $@ $(BUILDFLAGS) | ||||
| 
 | ||||
| bin/hledger-vty: | ||||
| 	cd hledger-vty; ghc --make hledger-vty.hs -o bin/hledger-vty $(BUILDFLAGS) | ||||
| 
 | ||||
| bin/hledger-chart: | ||||
| 	cd hledger-chart; ghc --make hledger-chart.hs -o bin/hledger-chart $(BUILDFLAGS) | ||||
| 	ghc --make -o $@ $(BUILDFLAGS) hledger-web/hledger-web.hs | ||||
| 
 | ||||
| # build portable releaseable binaries for gnu/linux
 | ||||
| linuxbinaries: 	linuxbinary-hledger \ | ||||
| 		linuxbinary-hledger-web \
 | ||||
| 		linuxbinary-hledger-vty \
 | ||||
| 		linuxbinary-hledger-chart | ||||
| 		linuxbinary-hledger-web | ||||
| 	@echo 'Please check the binaries look portable, then make compressbinaries:' | ||||
| 	-file bin/*`arch` | ||||
| 
 | ||||
| linuxbinary-%: | ||||
| 	ghc --make $*/$*.hs -o bin/$*$(RELEASEBINARYSUFFIX) $(LINUXRELEASEBUILDFLAGS) | ||||
| 
 | ||||
| # XXX link errors
 | ||||
| linuxbinary-hledger-chart: | ||||
| 	ghc --make hledger-chart/hledger-chart.hs -o bin/hledger-chart$(RELEASEBINARYSUFFIX) $(LINUXRELEASEBUILDFLAGS) -lpixman-1 -v | ||||
| 
 | ||||
| macbinaries:    macbinary-hledger \ | ||||
| 		macbinary-hledger-vty \
 | ||||
| 		macbinary-hledger-web \
 | ||||
| 		macbinary-hledger-chart | ||||
| 		macbinary-hledger-web | ||||
| 	@echo 'Please check the binaries are portable, then make compressbinaries' | ||||
| 	otool -L bin/*`arch` | ||||
| 
 | ||||
| @ -240,7 +211,7 @@ macbinaries:    macbinary-hledger \ | ||||
| # Clunky, does the link twice.
 | ||||
| macbinary-%: | ||||
| 	BINARY=`echo $(BINARYFILENAME) | sed -e 's/hledger/$*/'` ; \
 | ||||
| 	LINKCMD=`cd $* && ghc -v --make $*.hs $(MACRELEASEBUILDFLAGS) -o bin/$$BINARY 2>&1 | egrep "bin/gcc.*bin/$$BINARY"` ; \
 | ||||
| 	LINKCMD=`ghc -v --make $*/$*.hs $(MACRELEASEBUILDFLAGS) -o bin/$$BINARY 2>&1 | egrep "bin/gcc.*bin/$$BINARY"` ; \
 | ||||
| 	PORTABLELINKCMD=`echo $$LINKCMD | sed -e 's/ -framework GMP//'` ; \
 | ||||
| 	echo $$PORTABLELINKCMD; $$PORTABLELINKCMD | ||||
| 
 | ||||
| @ -252,8 +223,6 @@ macbinary-%: | ||||
| windowsbinaries: install | ||||
| 	cp ~/.cabal/bin/hledger.exe bin/`echo $(BINARYFILENAME) | dos2unix` | ||||
| 	-cp ~/.cabal/bin/hledger-web.exe bin/`echo $(BINARYFILENAME) | sed -e 's/hledger/hledger-web/' | dos2unix` | ||||
| 	-cp ~/.cabal/bin/hledger-vty.exe bin/`echo $(BINARYFILENAME) | sed -e 's/hledger/hledger-vty/' | dos2unix` | ||||
| 	-cp ~/.cabal/bin/hledger-chart.exe bin/`echo $(BINARYFILENAME) | sed -e 's/hledger/hledger-chart/' | dos2unix` | ||||
| 	@echo 'Please check the binaries are portable, then make compressbinaries' | ||||
| 	ls -l bin/*`arch` | ||||
| 
 | ||||
| @ -485,9 +454,6 @@ viewcoverage: | ||||
| ghci: | ||||
| 	ghci $(INCLUDEPATHS) $(MAIN) | ||||
| 
 | ||||
| ghci-vty: | ||||
| 	ghci $(INCLUDEPATHS) hledger-vty/Hledger/Vty/Main.hs | ||||
| 
 | ||||
| # generate standard sample journals
 | ||||
| samplejournals: data/sample.journal data/100x100x10.journal data/1000x1000x10.journal data/10000x1000x10.journal data/100000x1000x10.journal | ||||
| 
 | ||||
| @ -580,7 +546,7 @@ pushdocs: push | ||||
| 	ssh simon@joyful.com 'make -C/repos/hledger docs' | ||||
| 
 | ||||
| # dump all executables' command line help into files for review
 | ||||
| EXES=hledger hledger-vty hledger-web hledger-chart | ||||
| EXES=hledger hledger-vty hledger-web | ||||
| savehelp: | ||||
| 	for e in $(EXES); do $$e --help >.HELP_$$e; done | ||||
| 
 | ||||
| @ -755,16 +721,6 @@ hledger/hledger.cabal: $(VERSIONFILE) | ||||
| 	perl -p -e "s/(^ *version:) *.*/\1 $(VERSION)/" -i $@ | ||||
| 	perl -p -e "s/(^[ ,]*hledger-lib *[>=]=) *.*/\1 $(VERSION)/" -i $@ | ||||
| 
 | ||||
| hledger-chart/hledger-chart.cabal: $(VERSIONFILE) | ||||
| 	perl -p -e "s/(^ *version:) *.*/\1 $(VERSION)/" -i $@ | ||||
| 	perl -p -e "s/(^[ ,]*hledger *[>=]=) *.*/\1 $(VERSION)/" -i $@ | ||||
| 	perl -p -e "s/(^[ ,]*hledger-lib *[>=]=) *.*/\1 $(VERSION)/" -i $@ | ||||
| 
 | ||||
| hledger-vty/hledger-vty.cabal: $(VERSIONFILE) | ||||
| 	perl -p -e "s/(^ *version:) *.*/\1 $(VERSION)/" -i $@ | ||||
| 	perl -p -e "s/(^[ ,]*hledger *[>=]=) *.*/\1 $(VERSION)/" -i $@ | ||||
| 	perl -p -e "s/(^[ ,]*hledger-lib *[>=]=) *.*/\1 $(VERSION)/" -i $@ | ||||
| 
 | ||||
| hledger-web/hledger-web.cabal: $(VERSIONFILE) | ||||
| 	perl -p -e "s/(^ *version:) *.*/\1 $(VERSION)/" -i $@ | ||||
| 	perl -p -e "s/(^[ ,]*hledger *[>=]=) *.*/\1 $(VERSION)/" -i $@ | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user