Permalink
Browse files

autotools: switch to autotools buildsystem

  • Loading branch information...
1 parent 2fee100 commit 35b8af92265ed74de63c3818e5290c27b3f35df2 Cory Fields committed May 27, 2013
Showing with 3,527 additions and 1,508 deletions.
  1. +61 −1 .gitignore
  2. +159 −0 Makefile.am
  3. +2 −9 README.md
  4. +1 −0 autogen.sh
  5. +0 −453 bitcoin-qt.pro
  6. +714 −0 configure.ac
  7. +17 −0 contrib/bitcoin-qt.pro
  8. +7 −12 contrib/gitian-descriptors/boost-win32.yml
  9. +24 −14 contrib/gitian-descriptors/deps-win32.yml
  10. +32 −53 contrib/gitian-descriptors/gitian-win32.yml
  11. +23 −15 contrib/gitian-descriptors/gitian.yml
  12. +11 −9 contrib/gitian-descriptors/protobuf-win32.yml
  13. +6 −4 contrib/gitian-descriptors/qt-win32.yml
  14. +17 −0 contrib/macdeploy/macdeployqtplus
  15. +6 −18 contrib/macdeploy/notes.txt
  16. +21 −16 doc/build-unix.md
  17. +12 −39 doc/readme-qt.md
  18. +10 −27 doc/unit-tests.md
  19. +214 −0 pkg.m4
  20. +45 −0 qa/pull-tester/build-tests.sh.in
  21. +15 −0 qa/pull-tester/pull-tester.sh
  22. +27 −0 qa/pull-tester/run-bitcoind-for-test.sh.in
  23. +5 −3 share/genbuild.sh
  24. +3 −3 share/qt/{Info.plist → Info.plist.in}
  25. +162 −162 share/{setup.nsi → setup.nsi.in}
  26. +67 −0 src/Makefile.am
  27. +48 −0 src/Makefile.include
  28. +5 −0 src/clientversion.h
  29. +0 −1 src/compat.h
  30. +4 −0 src/init.cpp
  31. +258 −0 src/m4/ax_boost_base.m4
  32. +118 −0 src/m4/ax_boost_chrono.m4
  33. +118 −0 src/m4/ax_boost_filesystem.m4
  34. +108 −0 src/m4/ax_boost_program_options.m4
  35. +120 −0 src/m4/ax_boost_system.m4
  36. +153 −0 src/m4/ax_boost_thread.m4
  37. +137 −0 src/m4/ax_boost_unit_test_framework.m4
  38. +72 −0 src/m4/ax_check_compile_flag.m4
  39. +71 −0 src/m4/ax_check_link_flag.m4
  40. +72 −0 src/m4/ax_check_preproc_flag.m4
  41. +317 −0 src/m4/ax_pthread.m4
  42. +4 −0 src/main.h
  43. +0 −135 src/makefile.linux-mingw
  44. +0 −143 src/makefile.mingw
  45. +0 −181 src/makefile.osx
  46. +0 −206 src/makefile.unix
  47. +7 −0 src/net.cpp
  48. +4 −0 src/netbase.cpp
  49. +4 −0 src/netbase.h
  50. +160 −0 src/qt/Makefile.am
  51. +4 −0 src/qt/addressbookpage.cpp
  52. +4 −0 src/qt/notificator.h
  53. +4 −0 src/qt/optionsdialog.cpp
  54. +4 −0 src/qt/optionsmodel.cpp
  55. 0 src/qt/res/{bitcoin-qt.rc → bitcoin-qt-res.rc}
  56. +26 −0 src/qt/test/Makefile.am
  57. +1 −0 src/qt/test/paymentservertests.cpp
  58. +38 −0 src/test/Makefile.am
  59. +5 −4 src/util.h
View
@@ -1,7 +1,46 @@
+*.tar.gz
+
+*.exe
src/*.exe
+src/*/*.exe
src/bitcoin
src/bitcoind
-src/test_bitcoin
+src/test/test_bitcoin
+src/qt/test/test_bitcoin-qt
+
+Makefile.in
+aclocal.m4
+autom4te.cache/
+config.log
+config.status
+configure
+src/.deps/
+src/Makefile.in
+src/bitcoin-config.h
+src/bitcoin-config.h.in
+src/build-aux/
+src/qt/Makefile.in
+src/stamp-h1
+share/setup.nsi
+share/qt/Info.plist
+
+src/leveldb/.deps/
+
+src/test/.deps
+src/test/.dirstamp
+
+src/qt/.deps/
+src/qt/.dirstamp
+src/qt/*.moc
+src/qt/moc_*.cpp
+src/qt/forms/ui_*.h
+
+src/qt/test/.deps/
+src/qt/test/.dirstamp
+src/qt/test/moc*.cpp
+src/qt/res/.deps/
+src/qt/res/.dirstamp
+
.*.swp
*.*~*
*.bak
@@ -10,6 +49,13 @@ src/test_bitcoin
*.o
*.patch
.bitcoin
+*.a
+*.pb.cc
+*.pb.h
+
+*.log
+*.trs
+*.dmg
# Compilation and Qt preprocessor part
*.qm
@@ -31,4 +77,18 @@ qrc_*.cpp
.DS_Store
build
+#lcov
+*.gcno
+/*.info
+test_bitcoin.coverage/
+total.coverage/
+coverage_percent.txt
+
+#build tests
+linux-coverage-build
+linux-build
+win32-build
+qa/pull-tester/run-bitcoind-for-test.sh
+qa/pull-tester/build-tests.sh
+
!src/leveldb-*/Makefile
View
@@ -0,0 +1,159 @@
+ACLOCAL_AMFLAGS = -I src/m4
+SUBDIRS = src
+.PHONY: deploy
+
+GZIP_ENV="-9n"
+
+BITCOIND_BIN=$(top_builddir)/src/bitcoind$(EXEEXT)
+BITCOIN_QT_BIN=$(top_builddir)/src/qt/bitcoin-qt$(EXEEXT)
+BITCOIN_WIN_INSTALLER=$(PACKAGE)-$(PACKAGE_VERSION)-win32-setup$(EXEEXT)
+
+OSX_APP=Bitcoin-Qt.app
+OSX_DMG=Bitcoin-Qt.dmg
+OSX_DEPLOY_SCRIPT=$(top_srcdir)/contrib/macdeploy/macdeployqtplus
+OSX_FANCY_PLIST=$(top_srcdir)/contrib/macdeploy/fancy.plist
+OSX_INSTALLER_ICONS=$(top_srcdir)/src/qt/res/icons/bitcoin.icns
+OSX_PLIST=$(top_srcdir)/share/qt/Info.plist #not installed
+
+WINDOWS_PACKAGING = $(top_srcdir)/share/pixmaps/bitcoin.ico \
+ $(top_srcdir)/share/pixmaps/nsis-header.bmp \
+ $(top_srcdir)/share/pixmaps/nsis-wizard.bmp \
+ $(top_srcdir)/doc/README_windows.txt
+
+OSX_PACKAGING = $(OSX_DEPLOY_SCRIPT) $(OSX_FANCY_PLIST) $(OSX_INSTALLER_ICONS) \
+ $(top_srcdir)/contrib/macdeploy/background.png
+
+COVERAGE_INFO = baseline_filtered_combined.info baseline.info block_test.info \
+ leveldb_baseline.info test_bitcoin_filtered.info total_coverage.info \
+ baseline_filtered.info block_test_filtered.info \
+ leveldb_baseline_filtered.info test_bitcoin_coverage.info test_bitcoin.info
+
+dist-hook:
+ -$(MAKE) -C $(top_distdir)/src/leveldb clean
+ -$(GIT) archive --format=tar HEAD -- src/version.cpp | $(AMTAR) -C $(top_distdir) -xf -
+
+distcheck-hook:
+ $(MKDIR_P) $(top_distdir)/_build/src/leveldb
+ cp -rf $(top_srcdir)/src/leveldb/* $(top_distdir)/_build/src/leveldb/
+ -$(MAKE) -C $(top_distdir)/_build/src/leveldb clean
+
+distcleancheck:
+ @:
+
+$(BITCOIN_WIN_INSTALLER): $(BITCOIND_BIN) $(BITCOIN_QT_BIN)
+ $(MAKE) distdir
+ $(MKDIR_P) $(top_builddir)/release
+ $(INSTALL_STRIP_PROGRAM) $(top_builddir)/src/bitcoind$(EXEEXT) $(top_builddir)/release
+ $(INSTALL_STRIP_PROGRAM) $(top_builddir)/src/qt/bitcoin-qt$(EXEEXT) $(top_builddir)/release
+ @test -f $(MAKENSIS) && $(MAKENSIS) $(top_builddir)/share/setup.nsi || \
+ echo error: could not build $@
+
+$(BITCOIND_BIN):
+ make -C $(top_srcdir)/src bitcoind$(EXEEXT)
+
+$(BITCOIN_QT_BIN):
+ make -C $(top_srcdir)/src/qt bitcoin-qt$(EXEEXT)
+
+
+$(OSX_APP)/Contents/PkgInfo:
+ $(MKDIR_P) $(@D)
+ @echo "APPL????" > $@
+
+$(OSX_APP)/Contents/Resources/empty.lproj:
+ $(MKDIR_P) $(@D)
+ @touch $@
+
+$(OSX_APP)/Contents/Info.plist: $(OSX_PLIST)
+ $(MKDIR_P) $(@D)
+ $(INSTALL) $< $@
+
+$(OSX_APP)/Contents/Resources/bitcoin.icns: $(OSX_INSTALLER_ICONS)
+ $(MKDIR_P) $(@D)
+ $(INSTALL) $< $@
+
+$(OSX_APP)/Contents/MacOS/Bitcoin-Qt: $(BITCOIN_QT_BIN)
+ $(MKDIR_P) $(@D)
+ $(INSTALL_STRIP_PROGRAM) $< $@
+
+OSX_APP_BUILT=$(OSX_APP)/Contents/PkgInfo $(OSX_APP)/Contents/Resources/empty.lproj \
+ $(OSX_APP)/Contents/Resources/bitcoin.icns $(OSX_APP)/Contents/Info.plist \
+ $(OSX_APP)/Contents/MacOS/Bitcoin-Qt
+
+$(OSX_DMG): $(OSX_APP_BUILT) $(OSX_PACKAGING)
+ $(OSX_DEPLOY_SCRIPT) $(OSX_APP) -add-qt-tr da,de,es,hu,ru,uk,zh_CN,zh_TW -dmg -fancy $(OSX_FANCY_PLIST) -verbose 2
+ rm -rf $(OSX_APP)
+
+
+if TARGET_DARWIN
+deploy: $(OSX_DMG)
+endif
+if TARGET_WINDOWS
+deploy: $(BITCOIN_WIN_INSTALLER)
+endif
+
+if USE_LCOV
+
+baseline.info:
+ $(LCOV) -c -i -d $(abs_builddir)/src -o $@
+
+baseline_filtered.info: baseline.info
+ $(LCOV) -r $< "/usr/include/*" -o $@
+
+leveldb_baseline.info: baseline_filtered.info
+ $(LCOV) -c -i -d $(abs_builddir)/src/leveldb -b $(abs_builddir)/src/leveldb -o $@
+
+leveldb_baseline_filtered.info: leveldb_baseline.info
+ $(LCOV) -r $< "/usr/include/*" -o $@
+
+baseline_filtered_combined.info: leveldb_baseline_filtered.info baseline_filtered.info
+ $(LCOV) -a leveldb_baseline_filtered.info -a baseline_filtered.info -o $@
+
+test_bitcoin.info: baseline_filtered_combined.info
+ $(MAKE) -C src/ check
+ $(LCOV) -c -d $(abs_builddir)/src -t test_bitcoin -o $@
+ $(LCOV) -z -d $(abs_builddir)/src
+ $(LCOV) -z -d $(abs_builddir)/src/leveldb
+
+test_bitcoin_filtered.info: test_bitcoin.info
+ $(LCOV) -r $< "/usr/include/*" -o $@
+
+block_test.info: test_bitcoin_filtered.info
+ -@TIMEOUT=15 qa/pull-tester/run-bitcoind-for-test.sh $(JAVA) -Xmx2G -jar $(JAVA_COMPARISON_TOOL) 1 18444
+ $(LCOV) -c -d $(abs_builddir)/src --t BitcoinJBlockTest -o $@
+ $(LCOV) -z -d $(abs_builddir)/src
+ $(LCOV) -z -d $(abs_builddir)/src/leveldb
+
+block_test_filtered.info: block_test.info
+ $(LCOV) -r $< "/usr/include/*" -o $@
+
+test_bitcoin_coverage.info: baseline_filtered_combined.info test_bitcoin_filtered.info
+ $(LCOV) -a baseline_filtered.info -a leveldb_baseline_filtered.info -a test_bitcoin_filtered.info -o $@
+
+total_coverage.info: baseline_filtered_combined.info test_bitcoin_filtered.info block_test_filtered.info
+ $(LCOV) -a baseline_filtered.info -a leveldb_baseline_filtered.info -a test_bitcoin_filtered.info -a block_test_filtered.info -o $@ | $(GREP) "\%" | $(AWK) '{ print substr($$3,2,50) "/" $$5 }' > coverage_percent.txt
+
+test_bitcoin.coverage/.dirstamp: test_bitcoin_coverage.info
+ $(GENHTML) -s $< -o $(@D)
+ @touch $@
+
+total.coverage/.dirstamp: total_coverage.info
+ $(GENHTML) -s $< -o $(@D)
+ @touch $@
+
+cov: test_bitcoin.coverage/.dirstamp total.coverage/.dirstamp
+
+endif
+
+if USE_COMPARISON_TOOL
+check-local:
+ @qa/pull-tester/run-bitcoind-for-test.sh $(JAVA) -Xmx2G -jar $(JAVA_COMPARISON_TOOL) 1 18444
+endif
+
+EXTRA_DIST = $(top_srcdir)/share/genbuild.sh qa/pull-tester/pull-tester.sh $(WINDOWS_PACKAGING) $(OSX_PACKAGING)
+
+CLEANFILES = $(OSX_DMG) $(BITCOIN_WIN_INSTALLER)
+
+.INTERMEDIATE: $(OSX_APP_BUILT) $(COVERAGE_INFO)
+
+clean-local:
+ rm -rf test_bitcoin.coverage/ total.coverage/
View
@@ -58,15 +58,8 @@ lots of money.
Developers are strongly encouraged to write unit tests for new code, and to
submit new unit tests for old code.
-Unit tests for the core code are in `src/test/`. To compile and run them:
-
- cd src; make -f makefile.unix test
-
-Unit tests for the GUI code are in `src/qt/test/`. To compile and run them:
-
- qmake BITCOIN_QT_TEST=1 -o Makefile.test bitcoin-qt.pro
- make -f Makefile.test
- ./bitcoin-qt_test
+Unit tests can be compiled and run (assuming they weren't disabled in configure) with:
+ make check
Every pull request is built for both Windows and Linux on a dedicated server,
and unit and sanity tests are automatically run. The binaries produced may be
View
@@ -0,0 +1 @@
+autoreconf -vif
Oops, something went wrong.

0 comments on commit 35b8af9

Please sign in to comment.