Merge pull request #3560
fe14e8d
build: Change package name to Bitcoin Core (Wladimir J. van der Laan)6c980c7
build: Package docs/ and don't package source. (Wladimir J. van der Laan)39db27c
build: Add bitcoin-cli.exe to installer (Wladimir J. van der Laan)2f87b38
Adapt Windows installer for 64 bit (Wladimir J. van der Laan)f622232
gitian: Windows 64 bit support (Wladimir J. van der Laan)
This commit is contained in:
commit
6746787a0c
23
Makefile.am
23
Makefile.am
@ -6,7 +6,8 @@ GZIP_ENV="-9n"
|
|||||||
|
|
||||||
BITCOIND_BIN=$(top_builddir)/src/bitcoind$(EXEEXT)
|
BITCOIND_BIN=$(top_builddir)/src/bitcoind$(EXEEXT)
|
||||||
BITCOIN_QT_BIN=$(top_builddir)/src/qt/bitcoin-qt$(EXEEXT)
|
BITCOIN_QT_BIN=$(top_builddir)/src/qt/bitcoin-qt$(EXEEXT)
|
||||||
BITCOIN_WIN_INSTALLER=$(PACKAGE)-$(PACKAGE_VERSION)-win32-setup$(EXEEXT)
|
BITCOIN_CLI_BIN=$(top_builddir)/src/bitcoin-cli$(EXEEXT)
|
||||||
|
BITCOIN_WIN_INSTALLER=$(PACKAGE)-$(PACKAGE_VERSION)-win$(WINDOWS_BITS)-setup$(EXEEXT)
|
||||||
|
|
||||||
OSX_APP=Bitcoin-Qt.app
|
OSX_APP=Bitcoin-Qt.app
|
||||||
OSX_DMG=Bitcoin-Qt.dmg
|
OSX_DMG=Bitcoin-Qt.dmg
|
||||||
@ -15,6 +16,8 @@ OSX_FANCY_PLIST=$(top_srcdir)/contrib/macdeploy/fancy.plist
|
|||||||
OSX_INSTALLER_ICONS=$(top_srcdir)/src/qt/res/icons/bitcoin.icns
|
OSX_INSTALLER_ICONS=$(top_srcdir)/src/qt/res/icons/bitcoin.icns
|
||||||
OSX_PLIST=$(top_srcdir)/share/qt/Info.plist #not installed
|
OSX_PLIST=$(top_srcdir)/share/qt/Info.plist #not installed
|
||||||
|
|
||||||
|
DIST_DOCS = $(wildcard doc/*.md)
|
||||||
|
|
||||||
WINDOWS_PACKAGING = $(top_srcdir)/share/pixmaps/bitcoin.ico \
|
WINDOWS_PACKAGING = $(top_srcdir)/share/pixmaps/bitcoin.ico \
|
||||||
$(top_srcdir)/share/pixmaps/nsis-header.bmp \
|
$(top_srcdir)/share/pixmaps/nsis-header.bmp \
|
||||||
$(top_srcdir)/share/pixmaps/nsis-wizard.bmp \
|
$(top_srcdir)/share/pixmaps/nsis-wizard.bmp \
|
||||||
@ -40,20 +43,16 @@ distcheck-hook:
|
|||||||
distcleancheck:
|
distcleancheck:
|
||||||
@:
|
@:
|
||||||
|
|
||||||
$(BITCOIN_WIN_INSTALLER): $(BITCOIND_BIN) $(BITCOIN_QT_BIN)
|
$(BITCOIN_WIN_INSTALLER): $(BITCOIND_BIN) $(BITCOIN_QT_BIN) $(BITCOIN_CLI_BIN)
|
||||||
$(MAKE) distdir
|
|
||||||
$(MKDIR_P) $(top_builddir)/release
|
$(MKDIR_P) $(top_builddir)/release
|
||||||
$(INSTALL_STRIP_PROGRAM) $(top_builddir)/src/bitcoind$(EXEEXT) $(top_builddir)/release
|
$(INSTALL_STRIP_PROGRAM) $(BITCOIND_BIN) $(top_builddir)/release
|
||||||
$(INSTALL_STRIP_PROGRAM) $(top_builddir)/src/qt/bitcoin-qt$(EXEEXT) $(top_builddir)/release
|
$(INSTALL_STRIP_PROGRAM) $(BITCOIN_QT_BIN) $(top_builddir)/release
|
||||||
|
$(INSTALL_STRIP_PROGRAM) $(BITCOIN_CLI_BIN) $(top_builddir)/release
|
||||||
@test -f $(MAKENSIS) && $(MAKENSIS) $(top_builddir)/share/setup.nsi || \
|
@test -f $(MAKENSIS) && $(MAKENSIS) $(top_builddir)/share/setup.nsi || \
|
||||||
echo error: could not build $@
|
echo error: could not build $@
|
||||||
|
|
||||||
$(BITCOIND_BIN):
|
$(BITCOIND_BIN) $(BITCOIN_QT_BIN) $(BITCOIN_CLI_BIN):
|
||||||
make -C $(top_srcdir)/src bitcoind$(EXEEXT)
|
make -C $(dir $@) $(notdir $@)
|
||||||
|
|
||||||
$(BITCOIN_QT_BIN):
|
|
||||||
make -C $(top_srcdir)/src/qt bitcoin-qt$(EXEEXT)
|
|
||||||
|
|
||||||
|
|
||||||
$(OSX_APP)/Contents/PkgInfo:
|
$(OSX_APP)/Contents/PkgInfo:
|
||||||
$(MKDIR_P) $(@D)
|
$(MKDIR_P) $(@D)
|
||||||
@ -151,7 +150,7 @@ check-local:
|
|||||||
@qa/pull-tester/run-bitcoind-for-test.sh $(JAVA) -jar $(JAVA_COMPARISON_TOOL) qa/tmp/compTool $(COMPARISON_TOOL_REORG_TESTS)
|
@qa/pull-tester/run-bitcoind-for-test.sh $(JAVA) -jar $(JAVA_COMPARISON_TOOL) qa/tmp/compTool $(COMPARISON_TOOL_REORG_TESTS)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
EXTRA_DIST = $(top_srcdir)/share/genbuild.sh qa/pull-tester/pull-tester.sh $(WINDOWS_PACKAGING) $(OSX_PACKAGING)
|
EXTRA_DIST = $(top_srcdir)/share/genbuild.sh qa/pull-tester/pull-tester.sh $(DIST_DOCS) $(WINDOWS_PACKAGING) $(OSX_PACKAGING)
|
||||||
|
|
||||||
CLEANFILES = $(OSX_DMG) $(OSX_APP) $(BITCOIN_WIN_INSTALLER)
|
CLEANFILES = $(OSX_DMG) $(OSX_APP) $(BITCOIN_WIN_INSTALLER)
|
||||||
|
|
||||||
|
@ -6,7 +6,7 @@ define(_CLIENT_VERSION_REVISION, 99)
|
|||||||
define(_CLIENT_VERSION_BUILD, 0)
|
define(_CLIENT_VERSION_BUILD, 0)
|
||||||
define(_CLIENT_VERSION_IS_RELEASE, false)
|
define(_CLIENT_VERSION_IS_RELEASE, false)
|
||||||
define(_COPYRIGHT_YEAR, 2014)
|
define(_COPYRIGHT_YEAR, 2014)
|
||||||
AC_INIT([Bitcoin],[_CLIENT_VERSION_MAJOR._CLIENT_VERSION_MINOR._CLIENT_VERSION_REVISION],[info@bitcoin.org],[bitcoin])
|
AC_INIT([Bitcoin Core],[_CLIENT_VERSION_MAJOR._CLIENT_VERSION_MINOR._CLIENT_VERSION_REVISION],[info@bitcoin.org],[bitcoin])
|
||||||
AC_CONFIG_AUX_DIR([src/build-aux])
|
AC_CONFIG_AUX_DIR([src/build-aux])
|
||||||
AC_CONFIG_MACRO_DIR([src/m4])
|
AC_CONFIG_MACRO_DIR([src/m4])
|
||||||
AC_CANONICAL_HOST
|
AC_CANONICAL_HOST
|
||||||
@ -194,6 +194,12 @@ case $host in
|
|||||||
if test "x$CXXFLAGS_overridden" = "xno"; then
|
if test "x$CXXFLAGS_overridden" = "xno"; then
|
||||||
CXXFLAGS="$CXXFLAGS -w"
|
CXXFLAGS="$CXXFLAGS -w"
|
||||||
fi
|
fi
|
||||||
|
case $host in
|
||||||
|
i?86-*) WINDOWS_BITS=32 ;;
|
||||||
|
x86_64-*) WINDOWS_BITS=64 ;;
|
||||||
|
*) AC_MSG_ERROR("Could not determine win32/win64 for installer") ;;
|
||||||
|
esac
|
||||||
|
AC_SUBST(WINDOWS_BITS)
|
||||||
;;
|
;;
|
||||||
*darwin*)
|
*darwin*)
|
||||||
TARGET_OS=darwin
|
TARGET_OS=darwin
|
||||||
|
79
contrib/gitian-descriptors/boost-win.yml
Normal file
79
contrib/gitian-descriptors/boost-win.yml
Normal file
@ -0,0 +1,79 @@
|
|||||||
|
---
|
||||||
|
name: "boost"
|
||||||
|
suites:
|
||||||
|
- "precise"
|
||||||
|
architectures:
|
||||||
|
- "amd64"
|
||||||
|
packages:
|
||||||
|
- "mingw-w64"
|
||||||
|
- "g++-mingw-w64"
|
||||||
|
- "faketime"
|
||||||
|
- "zip"
|
||||||
|
reference_datetime: "2011-01-30 00:00:00"
|
||||||
|
remotes: []
|
||||||
|
files:
|
||||||
|
- "boost_1_55_0.tar.bz2"
|
||||||
|
- "boost-mingw-gas-cross-compile-2013-03-03.patch"
|
||||||
|
script: |
|
||||||
|
# Defines
|
||||||
|
export TZ=UTC
|
||||||
|
INDIR=$HOME/build
|
||||||
|
# Input Integrity Check
|
||||||
|
echo "fff00023dd79486d444c8e29922f4072e1d451fc5a4d2b6075852ead7f2b7b52 boost_1_55_0.tar.bz2" | shasum -c
|
||||||
|
echo "d2b7f6a1d7051faef3c9cf41a92fa3671d905ef1e1da920d07651a43299f6268 boost-mingw-gas-cross-compile-2013-03-03.patch" | shasum -c
|
||||||
|
|
||||||
|
for BITS in 32 64; do # for architectures
|
||||||
|
#
|
||||||
|
INSTALLPREFIX=$HOME/staging${BITS}
|
||||||
|
BUILDDIR=$HOME/build${BITS}
|
||||||
|
if [ "$BITS" == "32" ]; then
|
||||||
|
HOST=i686-w64-mingw32
|
||||||
|
else
|
||||||
|
HOST=x86_64-w64-mingw32
|
||||||
|
fi
|
||||||
|
#
|
||||||
|
mkdir -p $INSTALLPREFIX $BUILDDIR
|
||||||
|
cd $BUILDDIR
|
||||||
|
#
|
||||||
|
tar xjf $INDIR/boost_1_55_0.tar.bz2
|
||||||
|
cd boost_1_55_0
|
||||||
|
GCCVERSION=$($HOST-g++ -E -dM $(mktemp --suffix=.h) | grep __VERSION__ | cut -d ' ' -f 3 | cut -d '"' -f 2)
|
||||||
|
echo "using gcc : $GCCVERSION : $HOST-g++
|
||||||
|
:
|
||||||
|
<rc>$HOST-windres
|
||||||
|
<archiver>$HOST-ar
|
||||||
|
<cxxflags>-frandom-seed=boost1
|
||||||
|
<ranlib>$HOST-ranlib
|
||||||
|
;" > user-config.jam
|
||||||
|
./bootstrap.sh --without-icu
|
||||||
|
|
||||||
|
# Workaround: Upstream boost dev refuses to include patch that would allow Free Software cross-compile toolchain to work
|
||||||
|
# This patch was authored by the Fedora package developer and ships in Fedora's mingw32-boost.
|
||||||
|
# Please obtain the exact patch that matches the above sha256sum from one of the following mirrors.
|
||||||
|
#
|
||||||
|
# Read History: https://svn.boost.org/trac/boost/ticket/7262
|
||||||
|
# History Mirror: http://rose.makesad.us/~paulproteus/mirrors/7262%20Boost.Context%20fails%20to%20build%20using%20MinGW.html
|
||||||
|
#
|
||||||
|
# Patch: https://svn.boost.org/trac/boost/raw-attachment/ticket/7262/boost-mingw.patch
|
||||||
|
# Patch Mirror: http://wtogami.fedorapeople.org/boost-mingw-gas-cross-compile-2013-03-03.patch
|
||||||
|
# Patch Mirror: http://mindstalk.net/host/boost-mingw-gas-cross-compile-2013-03-03.patch
|
||||||
|
# Patch Mirror: http://rose.makesad.us/~paulproteus/mirrors/boost-mingw-gas-cross-compile-2013-03-03.patch
|
||||||
|
patch -p0 < $INDIR/boost-mingw-gas-cross-compile-2013-03-03.patch
|
||||||
|
|
||||||
|
# Bug Workaround: boost-1.54.0 broke the ability to disable zlib, still broken in 1.55
|
||||||
|
# https://svn.boost.org/trac/boost/ticket/9156
|
||||||
|
sed -i 's^\[ ac.check-library /zlib//zlib : <library>/zlib//zlib^^' libs/iostreams/build/Jamfile.v2
|
||||||
|
sed -i 's^<source>zlib.cpp <source>gzip.cpp \]^^' libs/iostreams/build/Jamfile.v2
|
||||||
|
|
||||||
|
# http://statmt.org/~s0565741/software/boost_1_52_0/libs/context/doc/html/context/requirements.html
|
||||||
|
# "For cross-compiling the lib you must specify certain additional properties at bjam command line: target-os, abi, binary-format, architecture and address-model."
|
||||||
|
./bjam toolset=gcc binary-format=pe target-os=windows threadapi=win32 address-model=$BITS threading=multi variant=release link=static runtime-link=static --user-config=user-config.jam --without-mpi --without-python -sNO_BZIP2=1 -sNO_ZLIB=1 --layout=tagged --build-type=complete --prefix="$INSTALLPREFIX" $MAKEOPTS install
|
||||||
|
#
|
||||||
|
cd "$INSTALLPREFIX"
|
||||||
|
export LD_PRELOAD=/usr/lib/faketime/libfaketime.so.1
|
||||||
|
export FAKETIME=$REFERENCE_DATETIME
|
||||||
|
zip -r $OUTDIR/boost-win$BITS-1.55.0-gitian-r6.zip *
|
||||||
|
unset LD_PRELOAD
|
||||||
|
unset FAKETIME
|
||||||
|
done # for BITS in
|
||||||
|
|
@ -1,65 +0,0 @@
|
|||||||
---
|
|
||||||
name: "boost"
|
|
||||||
suites:
|
|
||||||
- "precise"
|
|
||||||
architectures:
|
|
||||||
- "amd64"
|
|
||||||
packages:
|
|
||||||
- "mingw-w64"
|
|
||||||
- "g++-mingw-w64"
|
|
||||||
- "faketime"
|
|
||||||
- "zip"
|
|
||||||
reference_datetime: "2011-01-30 00:00:00"
|
|
||||||
remotes: []
|
|
||||||
files:
|
|
||||||
- "boost_1_55_0.tar.bz2"
|
|
||||||
- "boost-mingw-gas-cross-compile-2013-03-03.patch"
|
|
||||||
script: |
|
|
||||||
# Defines
|
|
||||||
INSTALLPREFIX="$HOME/install"
|
|
||||||
HOST=i686-w64-mingw32
|
|
||||||
# Input Integrity Check
|
|
||||||
echo "fff00023dd79486d444c8e29922f4072e1d451fc5a4d2b6075852ead7f2b7b52 boost_1_55_0.tar.bz2" | shasum -c
|
|
||||||
echo "d2b7f6a1d7051faef3c9cf41a92fa3671d905ef1e1da920d07651a43299f6268 boost-mingw-gas-cross-compile-2013-03-03.patch" | shasum -c
|
|
||||||
|
|
||||||
mkdir -p "$INSTALLPREFIX"
|
|
||||||
tar xjf boost_1_55_0.tar.bz2
|
|
||||||
cd boost_1_55_0
|
|
||||||
GCCVERSION=$($HOST-g++ -E -dM $(mktemp --suffix=.h) | grep __VERSION__ | cut -d ' ' -f 3 | cut -d '"' -f 2)
|
|
||||||
echo "using gcc : $GCCVERSION : $HOST-g++
|
|
||||||
:
|
|
||||||
<rc>$HOST-windres
|
|
||||||
<archiver>$HOST-ar
|
|
||||||
<cxxflags>-frandom-seed=boost1
|
|
||||||
<ranlib>$HOST-ranlib
|
|
||||||
;" > user-config.jam
|
|
||||||
./bootstrap.sh --without-icu
|
|
||||||
|
|
||||||
# Workaround: Upstream boost dev refuses to include patch that would allow Free Software cross-compile toolchain to work
|
|
||||||
# This patch was authored by the Fedora package developer and ships in Fedora's mingw32-boost.
|
|
||||||
# Please obtain the exact patch that matches the above sha256sum from one of the following mirrors.
|
|
||||||
#
|
|
||||||
# Read History: https://svn.boost.org/trac/boost/ticket/7262
|
|
||||||
# History Mirror: http://rose.makesad.us/~paulproteus/mirrors/7262%20Boost.Context%20fails%20to%20build%20using%20MinGW.html
|
|
||||||
#
|
|
||||||
# Patch: https://svn.boost.org/trac/boost/raw-attachment/ticket/7262/boost-mingw.patch
|
|
||||||
# Patch Mirror: http://wtogami.fedorapeople.org/boost-mingw-gas-cross-compile-2013-03-03.patch
|
|
||||||
# Patch Mirror: http://mindstalk.net/host/boost-mingw-gas-cross-compile-2013-03-03.patch
|
|
||||||
# Patch Mirror: http://rose.makesad.us/~paulproteus/mirrors/boost-mingw-gas-cross-compile-2013-03-03.patch
|
|
||||||
patch -p0 < ../boost-mingw-gas-cross-compile-2013-03-03.patch
|
|
||||||
|
|
||||||
# Bug Workaround: boost-1.54.0 broke the ability to disable zlib, still broken in 1.55
|
|
||||||
# https://svn.boost.org/trac/boost/ticket/9156
|
|
||||||
sed -i 's^\[ ac.check-library /zlib//zlib : <library>/zlib//zlib^^' libs/iostreams/build/Jamfile.v2
|
|
||||||
sed -i 's^<source>zlib.cpp <source>gzip.cpp \]^^' libs/iostreams/build/Jamfile.v2
|
|
||||||
|
|
||||||
# http://statmt.org/~s0565741/software/boost_1_52_0/libs/context/doc/html/context/requirements.html
|
|
||||||
# Note: Might need these options in the future for 64bit builds.
|
|
||||||
# "Please note that address-model=64 must be given to bjam command line on 64bit Windows for 64bit build; otherwise 32bit code will be generated."
|
|
||||||
# "For cross-compiling the lib you must specify certain additional properties at bjam command line: target-os, abi, binary-format, architecture and address-model."
|
|
||||||
./bjam toolset=gcc binary-format=pe target-os=windows threadapi=win32 threading=multi variant=release link=static runtime-link=static --user-config=user-config.jam --without-mpi --without-python -sNO_BZIP2=1 -sNO_ZLIB=1 --layout=tagged --build-type=complete --prefix="$INSTALLPREFIX" $MAKEOPTS install
|
|
||||||
|
|
||||||
cd "$INSTALLPREFIX"
|
|
||||||
export LD_PRELOAD=/usr/lib/faketime/libfaketime.so.1
|
|
||||||
export FAKETIME=$REFERENCE_DATETIME
|
|
||||||
zip -r $OUTDIR/boost-win32-1.55.0-gitian-r6.zip *
|
|
117
contrib/gitian-descriptors/deps-win.yml
Normal file
117
contrib/gitian-descriptors/deps-win.yml
Normal file
@ -0,0 +1,117 @@
|
|||||||
|
---
|
||||||
|
name: "bitcoin-deps"
|
||||||
|
suites:
|
||||||
|
- "precise"
|
||||||
|
architectures:
|
||||||
|
- "amd64"
|
||||||
|
packages:
|
||||||
|
- "mingw-w64"
|
||||||
|
- "g++-mingw-w64"
|
||||||
|
- "git-core"
|
||||||
|
- "zip"
|
||||||
|
- "faketime"
|
||||||
|
- "psmisc"
|
||||||
|
reference_datetime: "2011-01-30 00:00:00"
|
||||||
|
remotes: []
|
||||||
|
files:
|
||||||
|
- "openssl-1.0.1e.tar.gz"
|
||||||
|
- "db-4.8.30.NC.tar.gz"
|
||||||
|
- "miniupnpc-1.8.tar.gz"
|
||||||
|
- "zlib-1.2.8.tar.gz"
|
||||||
|
- "libpng-1.6.8.tar.gz"
|
||||||
|
- "qrencode-3.4.3.tar.bz2"
|
||||||
|
script: |
|
||||||
|
#
|
||||||
|
export LD_PRELOAD=/usr/lib/faketime/libfaketime.so.1
|
||||||
|
export FAKETIME=$REFERENCE_DATETIME
|
||||||
|
export TZ=UTC
|
||||||
|
INDIR=$HOME/build
|
||||||
|
# Input Integrity Check
|
||||||
|
echo "f74f15e8c8ff11aa3d5bb5f276d202ec18d7246e95f961db76054199c69c1ae3 openssl-1.0.1e.tar.gz" | sha256sum -c
|
||||||
|
echo "12edc0df75bf9abd7f82f821795bcee50f42cb2e5f76a6a281b85732798364ef db-4.8.30.NC.tar.gz" | sha256sum -c
|
||||||
|
echo "bc5f73c7b0056252c1888a80e6075787a1e1e9112b808f863a245483ff79859c miniupnpc-1.8.tar.gz" | sha256sum -c
|
||||||
|
echo "36658cb768a54c1d4dec43c3116c27ed893e88b02ecfcb44f2166f9c0b7f2a0d zlib-1.2.8.tar.gz" | sha256sum -c
|
||||||
|
echo "32c7acf1608b9c8b71b743b9780adb7a7b347563dbfb4a5263761056da44cc96 libpng-1.6.8.tar.gz" | sha256sum -c
|
||||||
|
echo "dfd71487513c871bad485806bfd1fdb304dedc84d2b01a8fb8e0940b50597a98 qrencode-3.4.3.tar.bz2" | sha256sum -c
|
||||||
|
|
||||||
|
for BITS in 32 64; do # for architectures
|
||||||
|
#
|
||||||
|
INSTALLPREFIX=$HOME/staging${BITS}
|
||||||
|
BUILDDIR=$HOME/build${BITS}
|
||||||
|
if [ "$BITS" == "32" ]; then
|
||||||
|
HOST=i686-w64-mingw32
|
||||||
|
else
|
||||||
|
HOST=x86_64-w64-mingw32
|
||||||
|
fi
|
||||||
|
#
|
||||||
|
mkdir -p $INSTALLPREFIX $BUILDDIR
|
||||||
|
cd $BUILDDIR
|
||||||
|
#
|
||||||
|
tar xzf $INDIR/openssl-1.0.1e.tar.gz
|
||||||
|
cd openssl-1.0.1e
|
||||||
|
if [ "$BITS" == "32" ]; then
|
||||||
|
OPENSSL_TGT=mingw
|
||||||
|
else
|
||||||
|
OPENSSL_TGT=mingw64
|
||||||
|
fi
|
||||||
|
./Configure --cross-compile-prefix=$HOST- ${OPENSSL_TGT} no-shared no-dso --openssldir=$INSTALLPREFIX
|
||||||
|
make
|
||||||
|
make install_sw
|
||||||
|
cd ..
|
||||||
|
#
|
||||||
|
tar xzf $INDIR/db-4.8.30.NC.tar.gz
|
||||||
|
cd db-4.8.30.NC/build_unix
|
||||||
|
../dist/configure --prefix=$INSTALLPREFIX --enable-mingw --enable-cxx --host=$HOST --disable-shared
|
||||||
|
make $MAKEOPTS library_build
|
||||||
|
make install_lib install_include
|
||||||
|
cd ../..
|
||||||
|
#
|
||||||
|
tar xzf $INDIR/miniupnpc-1.8.tar.gz
|
||||||
|
cd miniupnpc-1.8
|
||||||
|
echo "
|
||||||
|
--- miniupnpc-1.8/Makefile.mingw.orig 2013-09-29 18:52:51.014087958 -1000
|
||||||
|
+++ miniupnpc-1.8/Makefile.mingw 2013-09-29 19:09:29.663318691 -1000
|
||||||
|
@@ -67,8 +67,8 @@
|
||||||
|
|
||||||
|
wingenminiupnpcstrings.o: wingenminiupnpcstrings.c
|
||||||
|
|
||||||
|
-miniupnpcstrings.h: miniupnpcstrings.h.in wingenminiupnpcstrings
|
||||||
|
- wingenminiupnpcstrings \$< \$@
|
||||||
|
+miniupnpcstrings.h: miniupnpcstrings.h.in
|
||||||
|
+ sed -e 's|OS/version|MSWindows/5.1.2600|' -e 's|MINIUPNPC_VERSION_STRING \"version\"|MINIUPNPC_VERSION_STRING \"VERSIONHERE\"|' \$< > \$@
|
||||||
|
|
||||||
|
minixml.o: minixml.c minixml.h miniupnpcstrings.h
|
||||||
|
|
||||||
|
" | sed "s/VERSIONHERE/$(cat VERSION)/" | patch -p1
|
||||||
|
mkdir -p dll
|
||||||
|
make -f Makefile.mingw CC=$HOST-gcc AR=$HOST-ar libminiupnpc.a
|
||||||
|
install -d $INSTALLPREFIX/include/miniupnpc
|
||||||
|
install *.h $INSTALLPREFIX/include/miniupnpc
|
||||||
|
install libminiupnpc.a $INSTALLPREFIX/lib
|
||||||
|
cd ..
|
||||||
|
#
|
||||||
|
tar xzf $INDIR/zlib-1.2.8.tar.gz
|
||||||
|
cd zlib-1.2.8
|
||||||
|
CROSS_PREFIX=$HOST- ./configure --prefix=$INSTALLPREFIX --static
|
||||||
|
make
|
||||||
|
make install
|
||||||
|
cd ..
|
||||||
|
#
|
||||||
|
tar xzf $INDIR/libpng-1.6.8.tar.gz
|
||||||
|
cd libpng-1.6.8
|
||||||
|
OPT="-O2"
|
||||||
|
CPPFLAGS="${OPT} -I$INSTALLPREFIX/include" CFLAGS="${OPT} -I$INSTALLPREFIX/include" LDFLAGS="${OPT} -L$INSTALLPREFIX/lib" ./configure --disable-shared --prefix=$INSTALLPREFIX --host=$HOST
|
||||||
|
make $MAKEOPTS
|
||||||
|
make install
|
||||||
|
cd ..
|
||||||
|
#
|
||||||
|
tar xjf $INDIR/qrencode-3.4.3.tar.bz2
|
||||||
|
cd qrencode-3.4.3
|
||||||
|
png_CFLAGS="-I$INSTALLPREFIX/include" png_LIBS="-L$INSTALLPREFIX/lib -lpng" ./configure --prefix=$INSTALLPREFIX --host=$HOST
|
||||||
|
make
|
||||||
|
make install
|
||||||
|
cd ..
|
||||||
|
#
|
||||||
|
cd $INSTALLPREFIX
|
||||||
|
zip -r $OUTDIR/bitcoin-deps-win$BITS-gitian-r10.zip include lib
|
||||||
|
done # for BITS in
|
@ -1,101 +0,0 @@
|
|||||||
---
|
|
||||||
name: "bitcoin-deps"
|
|
||||||
suites:
|
|
||||||
- "precise"
|
|
||||||
architectures:
|
|
||||||
- "amd64"
|
|
||||||
packages:
|
|
||||||
- "mingw-w64"
|
|
||||||
- "g++-mingw-w64"
|
|
||||||
- "git-core"
|
|
||||||
- "zip"
|
|
||||||
- "faketime"
|
|
||||||
- "psmisc"
|
|
||||||
reference_datetime: "2011-01-30 00:00:00"
|
|
||||||
remotes: []
|
|
||||||
files:
|
|
||||||
- "openssl-1.0.1e.tar.gz"
|
|
||||||
- "db-4.8.30.NC.tar.gz"
|
|
||||||
- "miniupnpc-1.8.tar.gz"
|
|
||||||
- "zlib-1.2.8.tar.gz"
|
|
||||||
- "libpng-1.6.8.tar.gz"
|
|
||||||
- "qrencode-3.4.3.tar.bz2"
|
|
||||||
script: |
|
|
||||||
#
|
|
||||||
export LD_PRELOAD=/usr/lib/faketime/libfaketime.so.1
|
|
||||||
export FAKETIME=$REFERENCE_DATETIME
|
|
||||||
export TZ=UTC
|
|
||||||
export INSTALLPREFIX=$OUTDIR/staging/deps
|
|
||||||
export HOST=i686-w64-mingw32
|
|
||||||
# Input Integrity Check
|
|
||||||
echo "f74f15e8c8ff11aa3d5bb5f276d202ec18d7246e95f961db76054199c69c1ae3 openssl-1.0.1e.tar.gz" | sha256sum -c
|
|
||||||
echo "12edc0df75bf9abd7f82f821795bcee50f42cb2e5f76a6a281b85732798364ef db-4.8.30.NC.tar.gz" | sha256sum -c
|
|
||||||
echo "bc5f73c7b0056252c1888a80e6075787a1e1e9112b808f863a245483ff79859c miniupnpc-1.8.tar.gz" | sha256sum -c
|
|
||||||
echo "36658cb768a54c1d4dec43c3116c27ed893e88b02ecfcb44f2166f9c0b7f2a0d zlib-1.2.8.tar.gz" | sha256sum -c
|
|
||||||
echo "32c7acf1608b9c8b71b743b9780adb7a7b347563dbfb4a5263761056da44cc96 libpng-1.6.8.tar.gz" | sha256sum -c
|
|
||||||
echo "dfd71487513c871bad485806bfd1fdb304dedc84d2b01a8fb8e0940b50597a98 qrencode-3.4.3.tar.bz2" | sha256sum -c
|
|
||||||
|
|
||||||
mkdir -p $INSTALLPREFIX
|
|
||||||
|
|
||||||
tar xzf openssl-1.0.1e.tar.gz
|
|
||||||
cd openssl-1.0.1e
|
|
||||||
./Configure --cross-compile-prefix=$HOST- mingw --openssldir=$INSTALLPREFIX
|
|
||||||
make
|
|
||||||
make install_sw
|
|
||||||
cd ..
|
|
||||||
#
|
|
||||||
tar xzf db-4.8.30.NC.tar.gz
|
|
||||||
cd db-4.8.30.NC/build_unix
|
|
||||||
../dist/configure --prefix=$INSTALLPREFIX --enable-mingw --enable-cxx --host=$HOST --disable-shared
|
|
||||||
make $MAKEOPTS library_build
|
|
||||||
make install_lib install_include
|
|
||||||
cd ../..
|
|
||||||
#
|
|
||||||
tar xzf miniupnpc-1.8.tar.gz
|
|
||||||
cd miniupnpc-1.8
|
|
||||||
echo "
|
|
||||||
--- miniupnpc-1.8/Makefile.mingw.orig 2013-09-29 18:52:51.014087958 -1000
|
|
||||||
+++ miniupnpc-1.8/Makefile.mingw 2013-09-29 19:09:29.663318691 -1000
|
|
||||||
@@ -67,8 +67,8 @@
|
|
||||||
|
|
||||||
wingenminiupnpcstrings.o: wingenminiupnpcstrings.c
|
|
||||||
|
|
||||||
-miniupnpcstrings.h: miniupnpcstrings.h.in wingenminiupnpcstrings
|
|
||||||
- wingenminiupnpcstrings \$< \$@
|
|
||||||
+miniupnpcstrings.h: miniupnpcstrings.h.in
|
|
||||||
+ sed -e 's|OS/version|MSWindows/5.1.2600|' -e 's|MINIUPNPC_VERSION_STRING \"version\"|MINIUPNPC_VERSION_STRING \"VERSIONHERE\"|' \$< > \$@
|
|
||||||
|
|
||||||
minixml.o: minixml.c minixml.h miniupnpcstrings.h
|
|
||||||
|
|
||||||
" | sed "s/VERSIONHERE/$(cat VERSION)/" | patch -p1
|
|
||||||
mkdir -p dll
|
|
||||||
make -f Makefile.mingw CC=$HOST-gcc AR=$HOST-ar libminiupnpc.a
|
|
||||||
install -d $INSTALLPREFIX/include/miniupnpc
|
|
||||||
install *.h $INSTALLPREFIX/include/miniupnpc
|
|
||||||
install libminiupnpc.a $INSTALLPREFIX/lib
|
|
||||||
cd ..
|
|
||||||
#
|
|
||||||
tar xzf zlib-1.2.8.tar.gz
|
|
||||||
cd zlib-1.2.8
|
|
||||||
CROSS_PREFIX=$HOST- ./configure --prefix=$INSTALLPREFIX --static
|
|
||||||
make
|
|
||||||
make install
|
|
||||||
cd ..
|
|
||||||
#
|
|
||||||
tar xzf libpng-1.6.8.tar.gz
|
|
||||||
cd libpng-1.6.8
|
|
||||||
OPT="-O2"
|
|
||||||
CPPFLAGS="${OPT} -I$INSTALLPREFIX/include" CFLAGS="${OPT} -I$INSTALLPREFIX/include" LDFLAGS="${OPT} -L$INSTALLPREFIX/lib" ./configure --disable-shared --prefix=$INSTALLPREFIX --host=$HOST
|
|
||||||
make $MAKEOPTS
|
|
||||||
make install
|
|
||||||
cd ..
|
|
||||||
#
|
|
||||||
tar xjf qrencode-3.4.3.tar.bz2
|
|
||||||
cd qrencode-3.4.3
|
|
||||||
png_CFLAGS="-I$INSTALLPREFIX/include" png_LIBS="-L$INSTALLPREFIX/lib -lpng" ./configure --prefix=$INSTALLPREFIX --host=$HOST
|
|
||||||
make
|
|
||||||
make install
|
|
||||||
cd ..
|
|
||||||
#
|
|
||||||
cd $INSTALLPREFIX
|
|
||||||
zip -r $OUTDIR/bitcoin-deps-win32-gitian-r10.zip include lib
|
|
84
contrib/gitian-descriptors/gitian-win.yml
Normal file
84
contrib/gitian-descriptors/gitian-win.yml
Normal file
@ -0,0 +1,84 @@
|
|||||||
|
---
|
||||||
|
name: "bitcoin"
|
||||||
|
suites:
|
||||||
|
- "precise"
|
||||||
|
architectures:
|
||||||
|
- "amd64"
|
||||||
|
packages:
|
||||||
|
- "mingw-w64"
|
||||||
|
- "g++-mingw-w64"
|
||||||
|
- "git-core"
|
||||||
|
- "unzip"
|
||||||
|
- "nsis"
|
||||||
|
- "faketime"
|
||||||
|
- "autoconf2.13"
|
||||||
|
- "libtool"
|
||||||
|
- "automake"
|
||||||
|
- "pkg-config"
|
||||||
|
- "bsdmainutils"
|
||||||
|
|
||||||
|
reference_datetime: "2013-06-01 00:00:00"
|
||||||
|
remotes:
|
||||||
|
- "url": "https://github.com/bitcoin/bitcoin.git"
|
||||||
|
"dir": "bitcoin"
|
||||||
|
files:
|
||||||
|
- "qt-win32-5.2.0-gitian-r1.zip"
|
||||||
|
- "qt-win64-5.2.0-gitian-r1.zip"
|
||||||
|
- "boost-win32-1.55.0-gitian-r6.zip"
|
||||||
|
- "boost-win64-1.55.0-gitian-r6.zip"
|
||||||
|
- "bitcoin-deps-win32-gitian-r10.zip"
|
||||||
|
- "bitcoin-deps-win64-gitian-r10.zip"
|
||||||
|
- "protobuf-win32-2.5.0-gitian-r4.zip"
|
||||||
|
- "protobuf-win64-2.5.0-gitian-r4.zip"
|
||||||
|
script: |
|
||||||
|
# Defines
|
||||||
|
export TZ=UTC
|
||||||
|
INDIR=$HOME/build
|
||||||
|
OPTFLAGS='-O2'
|
||||||
|
NEEDDIST=1
|
||||||
|
for BITS in 32 64; do # for architectures
|
||||||
|
#
|
||||||
|
STAGING=$HOME/staging${BITS}
|
||||||
|
BUILDDIR=$HOME/build${BITS}
|
||||||
|
BINDIR=$OUTDIR/$BITS
|
||||||
|
if [ "$BITS" == "32" ]; then
|
||||||
|
HOST=i686-w64-mingw32
|
||||||
|
else
|
||||||
|
HOST=x86_64-w64-mingw32
|
||||||
|
fi
|
||||||
|
mkdir -p $STAGING $BUILDDIR $BINDIR
|
||||||
|
#
|
||||||
|
cd $STAGING
|
||||||
|
unzip $INDIR/qt-win${BITS}-5.2.0-gitian-r1.zip
|
||||||
|
unzip $INDIR/boost-win${BITS}-1.55.0-gitian-r6.zip
|
||||||
|
unzip $INDIR/bitcoin-deps-win${BITS}-gitian-r10.zip
|
||||||
|
unzip $INDIR/protobuf-win${BITS}-2.5.0-gitian-r4.zip
|
||||||
|
if [ "$NEEDDIST" == "1" ]; then
|
||||||
|
# Make source code archive which is architecture independent so it only needs to be done once
|
||||||
|
cd $HOME/build/
|
||||||
|
cd bitcoin
|
||||||
|
export PATH=$STAGING/host/bin:$PATH
|
||||||
|
export TAR_OPTIONS=--mtime=`echo $REFERENCE_DATETIME | awk '{ print $1 }'`
|
||||||
|
./autogen.sh
|
||||||
|
./configure --bindir=$OUTDIR --prefix=$STAGING --host=$HOST --with-qt-plugindir=$STAGING/plugins --with-qt-incdir=$STAGING/include --with-qt-bindir=$STAGING/host/bin --with-boost=$STAGING --disable-maintainer-mode --with-protoc-bindir=$STAGING/host/bin --disable-dependency-tracking CPPFLAGS="-I$STAGING/include ${OPTFLAGS}" LDFLAGS="-L$STAGING/lib ${OPTFLAGS}" CXXFLAGS="-frandom-seed=bitcoin ${OPTFLAGS}"
|
||||||
|
make dist
|
||||||
|
mkdir -p $OUTDIR/src
|
||||||
|
cp -f bitcoin-*.tar.* $OUTDIR/src
|
||||||
|
NEEDDIST=0
|
||||||
|
fi
|
||||||
|
# Build platform-dependent executables from source archive
|
||||||
|
cd $BUILDDIR
|
||||||
|
mkdir -p distsrc
|
||||||
|
cd distsrc
|
||||||
|
tar --strip-components=1 -xf $HOME/build/bitcoin/bitcoin-*.tar.*
|
||||||
|
./configure --bindir=$BINDIR --prefix=$STAGING --host=$HOST --with-qt-plugindir=$STAGING/plugins --with-qt-incdir=$STAGING/include --with-qt-bindir=$STAGING/host/bin --with-boost=$STAGING --disable-maintainer-mode --with-protoc-bindir=$STAGING/host/bin --disable-dependency-tracking CPPFLAGS="-I$STAGING/include ${OPTFLAGS}" LDFLAGS="-L$STAGING/lib ${OPTFLAGS}" CXXFLAGS="-frandom-seed=bitcoin ${OPTFLAGS}"
|
||||||
|
export LD_PRELOAD=/usr/lib/faketime/libfaketime.so.1
|
||||||
|
export FAKETIME=$REFERENCE_DATETIME
|
||||||
|
make $MAKEOPTS
|
||||||
|
make deploy
|
||||||
|
make install-strip
|
||||||
|
cp -f bitcoin-*setup*.exe $BINDIR/
|
||||||
|
unset LD_PRELOAD
|
||||||
|
unset FAKETIME
|
||||||
|
done # for BITS in
|
||||||
|
|
@ -1,62 +0,0 @@
|
|||||||
---
|
|
||||||
name: "bitcoin"
|
|
||||||
suites:
|
|
||||||
- "precise"
|
|
||||||
architectures:
|
|
||||||
- "amd64"
|
|
||||||
packages:
|
|
||||||
- "mingw-w64"
|
|
||||||
- "g++-mingw-w64"
|
|
||||||
- "git-core"
|
|
||||||
- "unzip"
|
|
||||||
- "nsis"
|
|
||||||
- "faketime"
|
|
||||||
- "autoconf2.13"
|
|
||||||
- "libtool"
|
|
||||||
- "automake"
|
|
||||||
- "pkg-config"
|
|
||||||
- "bsdmainutils"
|
|
||||||
|
|
||||||
reference_datetime: "2013-06-01 00:00:00"
|
|
||||||
remotes:
|
|
||||||
- "url": "https://github.com/bitcoin/bitcoin.git"
|
|
||||||
"dir": "bitcoin"
|
|
||||||
files:
|
|
||||||
- "qt-win32-5.2.0-gitian-r1.zip"
|
|
||||||
- "boost-win32-1.55.0-gitian-r6.zip"
|
|
||||||
- "bitcoin-deps-win32-gitian-r10.zip"
|
|
||||||
- "protobuf-win32-2.5.0-gitian-r4.zip"
|
|
||||||
script: |
|
|
||||||
#
|
|
||||||
STAGING=$HOME/staging
|
|
||||||
HOST=i686-w64-mingw32
|
|
||||||
OPTFLAGS='-O2'
|
|
||||||
#
|
|
||||||
mkdir -p $STAGING
|
|
||||||
cd $STAGING
|
|
||||||
unzip ../build/qt-win32-5.2.0-gitian-r1.zip
|
|
||||||
unzip ../build/boost-win32-1.55.0-gitian-r6.zip
|
|
||||||
unzip ../build/bitcoin-deps-win32-gitian-r10.zip
|
|
||||||
unzip ../build/protobuf-win32-2.5.0-gitian-r4.zip
|
|
||||||
cd $HOME/build/
|
|
||||||
#
|
|
||||||
cd bitcoin
|
|
||||||
export PATH=$STAGING/host/bin:$PATH
|
|
||||||
export TAR_OPTIONS=--mtime=`echo $REFERENCE_DATETIME | awk '{ print $1 }'`
|
|
||||||
./autogen.sh
|
|
||||||
./configure --bindir=$OUTDIR --prefix=$STAGING --host=$HOST --with-qt-plugindir=$STAGING/plugins --with-qt-incdir=$STAGING/include --with-qt-bindir=$STAGING/host/bin --with-boost=$STAGING --disable-maintainer-mode --with-protoc-bindir=$STAGING/host/bin --disable-dependency-tracking CPPFLAGS="-I$STAGING/include ${OPTFLAGS}" LDFLAGS="-L$STAGING/lib ${OPTFLAGS}" CXXFLAGS="-frandom-seed=bitcoin ${OPTFLAGS}"
|
|
||||||
make dist
|
|
||||||
mkdir -p distsrc
|
|
||||||
cd distsrc
|
|
||||||
tar --strip-components=1 -xf ../bitcoin-*.tar.*
|
|
||||||
./configure --bindir=$OUTDIR --prefix=$STAGING --host=i686-w64-mingw32 --with-qt-plugindir=$STAGING/plugins --with-qt-incdir=$STAGING/include --with-qt-bindir=$STAGING/host/bin --with-boost=$STAGING --disable-maintainer-mode --with-protoc-bindir=$STAGING/host/bin --disable-dependency-tracking CPPFLAGS="-I$STAGING/include ${OPTFLAGS}" LDFLAGS="-L$STAGING/lib ${OPTFLAGS}" CXXFLAGS="-frandom-seed=bitcoin ${OPTFLAGS}"
|
|
||||||
export LD_PRELOAD=/usr/lib/faketime/libfaketime.so.1
|
|
||||||
export FAKETIME=$REFERENCE_DATETIME
|
|
||||||
export TZ=UTC
|
|
||||||
make $MAKEOPTS
|
|
||||||
make deploy
|
|
||||||
make install-strip
|
|
||||||
cp -f bitcoin-*setup*.exe $OUTDIR/
|
|
||||||
|
|
||||||
mkdir -p $OUTDIR/src
|
|
||||||
cp -f ../bitcoin-*.tar.* $OUTDIR/src
|
|
56
contrib/gitian-descriptors/protobuf-win.yml
Normal file
56
contrib/gitian-descriptors/protobuf-win.yml
Normal file
@ -0,0 +1,56 @@
|
|||||||
|
---
|
||||||
|
name: "protobuf-win32"
|
||||||
|
suites:
|
||||||
|
- "precise"
|
||||||
|
architectures:
|
||||||
|
- "amd64"
|
||||||
|
packages:
|
||||||
|
- "mingw-w64"
|
||||||
|
- "g++-mingw-w64"
|
||||||
|
- "zip"
|
||||||
|
- "faketime"
|
||||||
|
reference_datetime: "2013-04-15 00:00:00"
|
||||||
|
remotes: []
|
||||||
|
files:
|
||||||
|
- "protobuf-2.5.0.tar.bz2"
|
||||||
|
script: |
|
||||||
|
#
|
||||||
|
export TZ=UTC
|
||||||
|
INDIR=$HOME/build
|
||||||
|
OPTFLAGS="-O2"
|
||||||
|
# Integrity Check
|
||||||
|
echo "13bfc5ae543cf3aa180ac2485c0bc89495e3ae711fc6fab4f8ffe90dfb4bb677 protobuf-2.5.0.tar.bz2" | sha256sum -c
|
||||||
|
|
||||||
|
for BITS in 32 64; do # for architectures
|
||||||
|
#
|
||||||
|
INSTALLPREFIX=$HOME/staging${BITS}
|
||||||
|
BUILDDIR=$HOME/build${BITS}
|
||||||
|
if [ "$BITS" == "32" ]; then
|
||||||
|
HOST=i686-w64-mingw32
|
||||||
|
else
|
||||||
|
HOST=x86_64-w64-mingw32
|
||||||
|
fi
|
||||||
|
#
|
||||||
|
mkdir -p $INSTALLPREFIX $BUILDDIR
|
||||||
|
cd $BUILDDIR
|
||||||
|
#
|
||||||
|
tar xjf $INDIR/protobuf-2.5.0.tar.bz2
|
||||||
|
cd protobuf-2.5.0
|
||||||
|
# First: build a native (linux) protoc
|
||||||
|
./configure --enable-shared=no --disable-dependency-tracking
|
||||||
|
make
|
||||||
|
mkdir -p $INSTALLPREFIX/host/bin
|
||||||
|
cp src/protoc $INSTALLPREFIX/host/bin
|
||||||
|
# Now recompile with the mingw cross-compiler:
|
||||||
|
make distclean
|
||||||
|
./configure --prefix=$INSTALLPREFIX --enable-shared=no --disable-dependency-tracking --with-protoc=$INSTALLPREFIX/host/bin/protoc --host=$HOST CXXFLAGS="-frandom-seed=11 ${OPTFLAGS}"
|
||||||
|
make
|
||||||
|
make install
|
||||||
|
#
|
||||||
|
cd $INSTALLPREFIX
|
||||||
|
export LD_PRELOAD=/usr/lib/faketime/libfaketime.so.1
|
||||||
|
export FAKETIME=$REFERENCE_DATETIME
|
||||||
|
zip -r $OUTDIR/protobuf-win$BITS-2.5.0-gitian-r4.zip include lib host
|
||||||
|
unset LD_PRELOAD
|
||||||
|
unset FAKETIME
|
||||||
|
done # for BITS in
|
@ -1,45 +0,0 @@
|
|||||||
---
|
|
||||||
name: "protobuf-win32"
|
|
||||||
suites:
|
|
||||||
- "precise"
|
|
||||||
architectures:
|
|
||||||
- "amd64"
|
|
||||||
packages:
|
|
||||||
- "mingw-w64"
|
|
||||||
- "g++-mingw-w64"
|
|
||||||
- "zip"
|
|
||||||
- "faketime"
|
|
||||||
reference_datetime: "2013-04-15 00:00:00"
|
|
||||||
remotes: []
|
|
||||||
files:
|
|
||||||
- "protobuf-2.5.0.tar.bz2"
|
|
||||||
script: |
|
|
||||||
#
|
|
||||||
export TZ=UTC
|
|
||||||
export INSTALLPREFIX=$OUTDIR/staging/deps
|
|
||||||
export HOST=i686-w64-mingw32
|
|
||||||
OPTFLAGS="-O2"
|
|
||||||
# Integrity Check
|
|
||||||
echo "13bfc5ae543cf3aa180ac2485c0bc89495e3ae711fc6fab4f8ffe90dfb4bb677 protobuf-2.5.0.tar.bz2" | sha256sum -c
|
|
||||||
|
|
||||||
#
|
|
||||||
mkdir -p $INSTALLPREFIX
|
|
||||||
|
|
||||||
tar xjf protobuf-2.5.0.tar.bz2
|
|
||||||
cd protobuf-2.5.0
|
|
||||||
# First: build a native (linux) protoc
|
|
||||||
./configure --enable-shared=no --disable-dependency-tracking
|
|
||||||
make
|
|
||||||
mkdir -p $INSTALLPREFIX/host/bin
|
|
||||||
cp src/protoc $INSTALLPREFIX/host/bin
|
|
||||||
# Now recompile with the mingw cross-compiler:
|
|
||||||
make distclean
|
|
||||||
./configure --prefix=$INSTALLPREFIX --enable-shared=no --disable-dependency-tracking --with-protoc=$INSTALLPREFIX/host/bin/protoc --host=$HOST CXXFLAGS="-frandom-seed=11 ${OPTFLAGS}"
|
|
||||||
make
|
|
||||||
make install
|
|
||||||
cd $INSTALLPREFIX
|
|
||||||
export LD_PRELOAD=/usr/lib/faketime/libfaketime.so.1
|
|
||||||
export FAKETIME=$REFERENCE_DATETIME
|
|
||||||
zip -r $OUTDIR/protobuf-win32-2.5.0-gitian-r4.zip include lib host
|
|
||||||
unset LD_PRELOAD
|
|
||||||
unset FAKETIME
|
|
77
contrib/gitian-descriptors/qt-win.yml
Normal file
77
contrib/gitian-descriptors/qt-win.yml
Normal file
@ -0,0 +1,77 @@
|
|||||||
|
---
|
||||||
|
name: "qt"
|
||||||
|
suites:
|
||||||
|
- "precise"
|
||||||
|
architectures:
|
||||||
|
- "amd64"
|
||||||
|
packages:
|
||||||
|
- "mingw-w64"
|
||||||
|
- "g++-mingw-w64"
|
||||||
|
- "zip"
|
||||||
|
- "unzip"
|
||||||
|
- "faketime"
|
||||||
|
- "libz-dev"
|
||||||
|
reference_datetime: "2011-01-30 00:00:00"
|
||||||
|
remotes: []
|
||||||
|
files:
|
||||||
|
- "qt-everywhere-opensource-src-5.2.0.tar.gz"
|
||||||
|
- "bitcoin-deps-win32-gitian-r10.zip"
|
||||||
|
- "bitcoin-deps-win64-gitian-r10.zip"
|
||||||
|
script: |
|
||||||
|
# Defines
|
||||||
|
export TZ=UTC
|
||||||
|
INDIR=$HOME/build
|
||||||
|
# Integrity Check
|
||||||
|
echo "395ec72277c5786c65b8163ef5817fd03d0a1f524a6d47f53624baf8056f1081 qt-everywhere-opensource-src-5.2.0.tar.gz" | sha256sum -c
|
||||||
|
|
||||||
|
for BITS in 32 64; do # for architectures
|
||||||
|
#
|
||||||
|
INSTALLPREFIX=$HOME/staging${BITS}
|
||||||
|
BUILDDIR=$HOME/build${BITS}
|
||||||
|
DEPSDIR=$HOME/deps${BITS}
|
||||||
|
if [ "$BITS" == "32" ]; then
|
||||||
|
HOST=i686-w64-mingw32
|
||||||
|
else
|
||||||
|
HOST=x86_64-w64-mingw32
|
||||||
|
fi
|
||||||
|
#
|
||||||
|
mkdir -p $INSTALLPREFIX $INSTALLPREFIX/host/bin $DEPSDIR $BUILDDIR
|
||||||
|
#
|
||||||
|
# Need mingw-compiled openssl from bitcoin-deps:
|
||||||
|
cd $DEPSDIR
|
||||||
|
unzip $INDIR/bitcoin-deps-win${BITS}-gitian-r10.zip
|
||||||
|
#
|
||||||
|
cd $BUILDDIR
|
||||||
|
#
|
||||||
|
tar xzf $INDIR/qt-everywhere-opensource-src-5.2.0.tar.gz
|
||||||
|
cd qt-everywhere-opensource-src-5.2.0
|
||||||
|
SPECNAME="win32-g++"
|
||||||
|
SPECFILE="qtbase/mkspecs/${SPECNAME}/qmake.conf"
|
||||||
|
sed 's/$TODAY/2011-01-30/' -i configure
|
||||||
|
sed --posix "s|QMAKE_CFLAGS = -pipe -fno-keep-inline-dllexport|QMAKE_CFLAGS\t\t= -pipe -fno-keep-inline-dllexport -isystem /usr/$HOST/include/ -frandom-seed=qtbuild -I$DEPSDIR/include|" -i ${SPECFILE}
|
||||||
|
sed --posix "s|QMAKE_LFLAGS =|QMAKE_LFLAGS\t\t= -L$DEPSDIR/lib|" -i ${SPECFILE}
|
||||||
|
# ar adds timestamps to every object file included in the static library
|
||||||
|
# providing -D as ar argument is supposed to solve it, but doesn't work as qmake strips off the arguments and adds -M to pass a script...
|
||||||
|
# which somehow cannot be combined with other flags.
|
||||||
|
# use faketime only for ar, as it confuses make/qmake into hanging sometimes
|
||||||
|
sed --posix "s|QMAKE_LIB = \\\$\\\${CROSS_COMPILE}ar -ru|QMAKE_LIB\t\t= $HOME/ar -Dr|" -i ${SPECFILE}
|
||||||
|
echo '#!/bin/bash' > $HOME/ar
|
||||||
|
echo 'export LD_PRELOAD=/usr/lib/faketime/libfaketime.so.1' >> $HOME/ar
|
||||||
|
echo "$HOST-ar \"\$@\"" >> $HOME/ar
|
||||||
|
chmod +x $HOME/ar
|
||||||
|
# Don't load faketime while compiling Qt, qmake will get stuck in nearly infinite loops
|
||||||
|
#export LD_PRELOAD=/usr/lib/faketime/libfaketime.so.1
|
||||||
|
export FAKETIME=$REFERENCE_DATETIME
|
||||||
|
#
|
||||||
|
# Compile static libraries, and use statically linked openssl (-openssl-linked):
|
||||||
|
OPENSSL_LIBS="-L$DEPSDIR/lib -lssl -lcrypto -lgdi32" ./configure -prefix $INSTALLPREFIX -bindir $INSTALLPREFIX/host/bin -confirm-license -release -opensource -static -xplatform $SPECNAME -device-option CROSS_COMPILE="$HOST-" -no-audio-backend -no-javascript-jit -no-sql-sqlite -no-sql-odbc -no-nis -no-cups -no-iconv -no-dbus -no-gif -no-opengl -no-compile-examples -no-feature-style-windowsce -no-feature-style-windowsmobile -no-qml-debug -openssl-linked -skip qtsvg -skip qtwebkit -skip qtwebkit-examples -skip qtserialport -skip qtdeclarative -skip qtmultimedia -skip qtimageformats -skip qtlocation -skip qtsensors -skip qtquick1 -skip qtquickcontrols -skip qtactiveqt -skip qtconnectivity -skip qtwinextras -skip qtxmlpatterns -skip qtscript -skip qtdoc -system-libpng -system-zlib
|
||||||
|
make $MAKEOPTS install
|
||||||
|
#
|
||||||
|
cd $INSTALLPREFIX
|
||||||
|
|
||||||
|
# as zip stores file timestamps, use faketime to intercept stat calls to set dates for all files to reference date
|
||||||
|
export LD_PRELOAD=/usr/lib/faketime/libfaketime.so.1
|
||||||
|
zip -r $OUTDIR/qt-win${BITS}-5.2.0-gitian-r1.zip *
|
||||||
|
unset LD_PRELOAD
|
||||||
|
unset FAKETIME
|
||||||
|
done # for BITS in
|
@ -1,60 +0,0 @@
|
|||||||
---
|
|
||||||
name: "qt"
|
|
||||||
suites:
|
|
||||||
- "precise"
|
|
||||||
architectures:
|
|
||||||
- "amd64"
|
|
||||||
packages:
|
|
||||||
- "mingw-w64"
|
|
||||||
- "g++-mingw-w64"
|
|
||||||
- "zip"
|
|
||||||
- "unzip"
|
|
||||||
- "faketime"
|
|
||||||
- "libz-dev"
|
|
||||||
reference_datetime: "2011-01-30 00:00:00"
|
|
||||||
remotes: []
|
|
||||||
files:
|
|
||||||
- "qt-everywhere-opensource-src-5.2.0.tar.gz"
|
|
||||||
- "bitcoin-deps-win32-gitian-r10.zip"
|
|
||||||
script: |
|
|
||||||
#
|
|
||||||
HOST=i686-w64-mingw32
|
|
||||||
INSTDIR="$HOME/qt/"
|
|
||||||
# Integrity Check
|
|
||||||
echo "395ec72277c5786c65b8163ef5817fd03d0a1f524a6d47f53624baf8056f1081 qt-everywhere-opensource-src-5.2.0.tar.gz" | sha256sum -c
|
|
||||||
|
|
||||||
mkdir $INSTDIR
|
|
||||||
mkdir -p $INSTDIR/host/bin
|
|
||||||
#
|
|
||||||
# Need mingw-compiled openssl from bitcoin-deps:
|
|
||||||
unzip bitcoin-deps-win32-gitian-r10.zip
|
|
||||||
DEPSDIR=`pwd`
|
|
||||||
#
|
|
||||||
tar xzf qt-everywhere-opensource-src-5.2.0.tar.gz
|
|
||||||
cd qt-everywhere-opensource-src-5.2.0
|
|
||||||
SPECNAME="win32-g++"
|
|
||||||
SPECFILE="qtbase/mkspecs/${SPECNAME}/qmake.conf"
|
|
||||||
sed 's/$TODAY/2011-01-30/' -i configure
|
|
||||||
sed --posix "s|QMAKE_CFLAGS = -pipe -fno-keep-inline-dllexport|QMAKE_CFLAGS\t\t= -pipe -fno-keep-inline-dllexport -isystem /usr/$HOST/include/ -frandom-seed=qtbuild -I$DEPSDIR/include|" -i ${SPECFILE}
|
|
||||||
sed --posix "s|QMAKE_LFLAGS =|QMAKE_LFLAGS\t\t= -L$DEPSDIR/lib|" -i ${SPECFILE}
|
|
||||||
# ar adds timestamps to every object file included in the static library
|
|
||||||
# providing -D as ar argument is supposed to solve it, but doesn't work as qmake strips off the arguments and adds -M to pass a script...
|
|
||||||
# which somehow cannot be combined with other flags.
|
|
||||||
# use faketime only for ar, as it confuses make/qmake into hanging sometimes
|
|
||||||
sed --posix "s|QMAKE_LIB = \\\$\\\${CROSS_COMPILE}ar -ru|QMAKE_LIB\t\t= $HOME/ar -Dr|" -i ${SPECFILE}
|
|
||||||
echo '#!/bin/bash' > $HOME/ar
|
|
||||||
echo 'export LD_PRELOAD=/usr/lib/faketime/libfaketime.so.1' >> $HOME/ar
|
|
||||||
echo "$HOST-ar \"\$@\"" >> $HOME/ar
|
|
||||||
chmod +x $HOME/ar
|
|
||||||
#export LD_PRELOAD=/usr/lib/faketime/libfaketime.so.1
|
|
||||||
export FAKETIME=$REFERENCE_DATETIME
|
|
||||||
export TZ=UTC
|
|
||||||
#
|
|
||||||
# Compile static libraries, and use statically linked openssl (-openssl-linked):
|
|
||||||
OPENSSL_LIBS="-L$DEPSDIR/lib -lssl -lcrypto -lgdi32" ./configure -prefix $INSTDIR -bindir $INSTDIR/host/bin -confirm-license -release -opensource -static -xplatform $SPECNAME -device-option CROSS_COMPILE="$HOST-" -no-audio-backend -no-javascript-jit -no-sql-sqlite -no-sql-odbc -no-nis -no-cups -no-iconv -no-dbus -no-gif -no-opengl -no-compile-examples -no-feature-style-windowsce -no-feature-style-windowsmobile -no-qml-debug -openssl-linked -skip qtsvg -skip qtwebkit -skip qtwebkit-examples -skip qtserialport -skip qtdeclarative -skip qtmultimedia -skip qtimageformats -skip qtlocation -skip qtsensors -skip qtquick1 -skip qtquickcontrols -skip qtactiveqt -skip qtconnectivity -skip qtwinextras -skip qtxmlpatterns -skip qtscript -skip qtdoc -system-libpng -system-zlib
|
|
||||||
make $MAKEOPTS install
|
|
||||||
cd $INSTDIR
|
|
||||||
|
|
||||||
# as zip stores file timestamps, use faketime to intercept stat calls to set dates for all files to reference date
|
|
||||||
export LD_PRELOAD=/usr/lib/faketime/libfaketime.so.1
|
|
||||||
zip -r $OUTDIR/qt-win32-5.2.0-gitian-r1.zip *
|
|
@ -51,18 +51,18 @@ Release Process
|
|||||||
wget 'https://download.qt-project.org/official_releases/qt/5.2/5.2.0/single/qt-everywhere-opensource-src-5.2.0.tar.gz'
|
wget 'https://download.qt-project.org/official_releases/qt/5.2/5.2.0/single/qt-everywhere-opensource-src-5.2.0.tar.gz'
|
||||||
wget 'https://protobuf.googlecode.com/files/protobuf-2.5.0.tar.bz2'
|
wget 'https://protobuf.googlecode.com/files/protobuf-2.5.0.tar.bz2'
|
||||||
cd ..
|
cd ..
|
||||||
|
./bin/gbuild ../bitcoin/contrib/gitian-descriptors/boost-linux.yml
|
||||||
|
mv build/out/boost-*.zip inputs/
|
||||||
./bin/gbuild ../bitcoin/contrib/gitian-descriptors/deps-linux.yml
|
./bin/gbuild ../bitcoin/contrib/gitian-descriptors/deps-linux.yml
|
||||||
mv build/out/bitcoin-deps-*.zip inputs/
|
mv build/out/bitcoin-deps-*.zip inputs/
|
||||||
./bin/gbuild ../bitcoin/contrib/gitian-descriptors/boost-linux.yml
|
./bin/gbuild ../bitcoin/contrib/gitian-descriptors/boost-win.yml
|
||||||
mv build/out/boost-linux-*.zip inputs/
|
mv build/out/boost-*.zip inputs/
|
||||||
./bin/gbuild ../bitcoin/contrib/gitian-descriptors/boost-win32.yml
|
./bin/gbuild ../bitcoin/contrib/gitian-descriptors/deps-win.yml
|
||||||
mv build/out/boost-win32-*.zip inputs/
|
|
||||||
./bin/gbuild ../bitcoin/contrib/gitian-descriptors/deps-win32.yml
|
|
||||||
mv build/out/bitcoin-deps-*.zip inputs/
|
mv build/out/bitcoin-deps-*.zip inputs/
|
||||||
./bin/gbuild ../bitcoin/contrib/gitian-descriptors/qt-win32.yml
|
./bin/gbuild ../bitcoin/contrib/gitian-descriptors/qt-win.yml
|
||||||
mv build/out/qt-win32-*.zip inputs/
|
mv build/out/qt-*.zip inputs/
|
||||||
./bin/gbuild ../bitcoin/contrib/gitian-descriptors/protobuf-win32.yml
|
./bin/gbuild ../bitcoin/contrib/gitian-descriptors/protobuf-win.yml
|
||||||
mv build/out/protobuf-win32-*.zip inputs/
|
mv build/out/protobuf-*.zip inputs/
|
||||||
|
|
||||||
Build bitcoind and bitcoin-qt on Linux32, Linux64, and Win32:
|
Build bitcoind and bitcoin-qt on Linux32, Linux64, and Win32:
|
||||||
|
|
||||||
@ -72,19 +72,19 @@ Release Process
|
|||||||
zip -r bitcoin-${VERSION}-linux-gitian.zip *
|
zip -r bitcoin-${VERSION}-linux-gitian.zip *
|
||||||
mv bitcoin-${VERSION}-linux-gitian.zip ../../../
|
mv bitcoin-${VERSION}-linux-gitian.zip ../../../
|
||||||
popd
|
popd
|
||||||
./bin/gbuild --commit bitcoin=v${VERSION} ../bitcoin/contrib/gitian-descriptors/gitian-win32.yml
|
./bin/gbuild --commit bitcoin=v${VERSION} ../bitcoin/contrib/gitian-descriptors/gitian-win.yml
|
||||||
./bin/gsign --signer $SIGNER --release ${VERSION}-win32 --destination ../gitian.sigs/ ../bitcoin/contrib/gitian-descriptors/gitian-win32.yml
|
./bin/gsign --signer $SIGNER --release ${VERSION}-win --destination ../gitian.sigs/ ../bitcoin/contrib/gitian-descriptors/gitian-win.yml
|
||||||
pushd build/out
|
pushd build/out
|
||||||
zip -r bitcoin-${VERSION}-win32-gitian.zip *
|
zip -r bitcoin-${VERSION}-win-gitian.zip *
|
||||||
mv bitcoin-${VERSION}-win32-gitian.zip ../../../
|
mv bitcoin-${VERSION}-win-gitian.zip ../../../
|
||||||
popd
|
popd
|
||||||
popd
|
popd
|
||||||
|
|
||||||
Build output expected:
|
Build output expected:
|
||||||
|
|
||||||
1. linux 32-bit and 64-bit binaries + source (bitcoin-${VERSION}-linux-gitian.zip)
|
1. linux 32-bit and 64-bit binaries + source (bitcoin-${VERSION}-linux-gitian.zip)
|
||||||
2. windows 32-bit binary, installer + source (bitcoin-${VERSION}-win32-gitian.zip)
|
2. windows 32-bit and 64-bit binaries + installer + source (bitcoin-${VERSION}-win-gitian.zip)
|
||||||
3. Gitian signatures (in gitian.sigs/${VERSION}[-win32]/(your gitian key)/
|
3. Gitian signatures (in gitian.sigs/${VERSION}[-win]/(your gitian key)/
|
||||||
|
|
||||||
repackage gitian builds for release as stand-alone zip/tar/installer exe
|
repackage gitian builds for release as stand-alone zip/tar/installer exe
|
||||||
|
|
||||||
@ -96,10 +96,10 @@ repackage gitian builds for release as stand-alone zip/tar/installer exe
|
|||||||
|
|
||||||
**Windows .zip and setup.exe:**
|
**Windows .zip and setup.exe:**
|
||||||
|
|
||||||
unzip bitcoin-${VERSION}-win32-gitian.zip -d bitcoin-${VERSION}-win32
|
unzip bitcoin-${VERSION}-win-gitian.zip -d bitcoin-${VERSION}-win
|
||||||
mv bitcoin-${VERSION}-win32/bitcoin-*-setup.exe .
|
mv bitcoin-${VERSION}-win/bitcoin-*-setup.exe .
|
||||||
zip -r bitcoin-${VERSION}-win32.zip bitcoin-${VERSION}-win32
|
zip -r bitcoin-${VERSION}-win.zip bitcoin-${VERSION}-win
|
||||||
rm -rf bitcoin-${VERSION}-win32
|
rm -rf bitcoin-${VERSION}-win
|
||||||
|
|
||||||
**Perform Mac build:**
|
**Perform Mac build:**
|
||||||
|
|
||||||
@ -138,7 +138,7 @@ Commit your signature to gitian.sigs:
|
|||||||
|
|
||||||
pushd gitian.sigs
|
pushd gitian.sigs
|
||||||
git add ${VERSION}/${SIGNER}
|
git add ${VERSION}/${SIGNER}
|
||||||
git add ${VERSION}-win32/${SIGNER}
|
git add ${VERSION}-win/${SIGNER}
|
||||||
git commit -a
|
git commit -a
|
||||||
git push # Assuming you can push to the gitian.sigs tree
|
git push # Assuming you can push to the gitian.sigs tree
|
||||||
popd
|
popd
|
||||||
@ -162,17 +162,17 @@ From a directory containing bitcoin source, gitian.sigs and gitian zips
|
|||||||
zip -r bitcoin-${VERSION}-linux-gitian.zip *
|
zip -r bitcoin-${VERSION}-linux-gitian.zip *
|
||||||
cp bitcoin-${VERSION}-linux-gitian.zip ../
|
cp bitcoin-${VERSION}-linux-gitian.zip ../
|
||||||
popd
|
popd
|
||||||
mkdir bitcoin-${VERSION}-win32-gitian
|
mkdir bitcoin-${VERSION}-win-gitian
|
||||||
pushd bitcoin-${VERSION}-win32-gitian
|
pushd bitcoin-${VERSION}-win-gitian
|
||||||
unzip ../bitcoin-${VERSION}-win32-gitian.zip
|
unzip ../bitcoin-${VERSION}-win-gitian.zip
|
||||||
mkdir gitian
|
mkdir gitian
|
||||||
cp ../bitcoin/contrib/gitian-downloader/*.pgp ./gitian/
|
cp ../bitcoin/contrib/gitian-downloader/*.pgp ./gitian/
|
||||||
for signer in $(ls ../gitian.sigs/${VERSION}-win32/); do
|
for signer in $(ls ../gitian.sigs/${VERSION}-win/); do
|
||||||
cp ../gitian.sigs/${VERSION}-win32/${signer}/bitcoin-build.assert ./gitian/${signer}-build.assert
|
cp ../gitian.sigs/${VERSION}-win/${signer}/bitcoin-build.assert ./gitian/${signer}-build.assert
|
||||||
cp ../gitian.sigs/${VERSION}-win32/${signer}/bitcoin-build.assert.sig ./gitian/${signer}-build.assert.sig
|
cp ../gitian.sigs/${VERSION}-win/${signer}/bitcoin-build.assert.sig ./gitian/${signer}-build.assert.sig
|
||||||
done
|
done
|
||||||
zip -r bitcoin-${VERSION}-win32-gitian.zip *
|
zip -r bitcoin-${VERSION}-win-gitian.zip *
|
||||||
cp bitcoin-${VERSION}-win32-gitian.zip ../
|
cp bitcoin-${VERSION}-win-gitian.zip ../
|
||||||
popd
|
popd
|
||||||
|
|
||||||
- Upload gitian zips to SourceForge
|
- Upload gitian zips to SourceForge
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
Name @PACKAGE_NAME@
|
Name "@PACKAGE_NAME@ (@WINDOWS_BITS@-bit)"
|
||||||
|
|
||||||
RequestExecutionLevel highest
|
RequestExecutionLevel highest
|
||||||
SetCompressor /SOLID lzma
|
SetCompressor /SOLID lzma
|
||||||
@ -6,7 +6,7 @@ SetCompressor /SOLID lzma
|
|||||||
# General Symbol Definitions
|
# General Symbol Definitions
|
||||||
!define REGKEY "SOFTWARE\$(^Name)"
|
!define REGKEY "SOFTWARE\$(^Name)"
|
||||||
!define VERSION @CLIENT_VERSION_MAJOR@.@CLIENT_VERSION_MINOR@.@CLIENT_VERSION_REVISION@
|
!define VERSION @CLIENT_VERSION_MAJOR@.@CLIENT_VERSION_MINOR@.@CLIENT_VERSION_REVISION@
|
||||||
!define COMPANY "Bitcoin project"
|
!define COMPANY "Bitcoin Core project"
|
||||||
!define URL http://www.bitcoin.org/
|
!define URL http://www.bitcoin.org/
|
||||||
|
|
||||||
# MUI Symbol Definitions
|
# MUI Symbol Definitions
|
||||||
@ -19,7 +19,7 @@ SetCompressor /SOLID lzma
|
|||||||
!define MUI_STARTMENUPAGE_REGISTRY_ROOT HKLM
|
!define MUI_STARTMENUPAGE_REGISTRY_ROOT HKLM
|
||||||
!define MUI_STARTMENUPAGE_REGISTRY_KEY ${REGKEY}
|
!define MUI_STARTMENUPAGE_REGISTRY_KEY ${REGKEY}
|
||||||
!define MUI_STARTMENUPAGE_REGISTRY_VALUENAME StartMenuGroup
|
!define MUI_STARTMENUPAGE_REGISTRY_VALUENAME StartMenuGroup
|
||||||
!define MUI_STARTMENUPAGE_DEFAULTFOLDER @PACKAGE_NAME@
|
!define MUI_STARTMENUPAGE_DEFAULTFOLDER "@PACKAGE_NAME@"
|
||||||
!define MUI_FINISHPAGE_RUN $INSTDIR\bitcoin-qt.exe
|
!define MUI_FINISHPAGE_RUN $INSTDIR\bitcoin-qt.exe
|
||||||
!define MUI_UNICON "${NSISDIR}\Contrib\Graphics\Icons\modern-uninstall.ico"
|
!define MUI_UNICON "${NSISDIR}\Contrib\Graphics\Icons\modern-uninstall.ico"
|
||||||
!define MUI_UNWELCOMEFINISHPAGE_BITMAP "@abs_top_srcdir@/share/pixmaps/nsis-wizard.bmp"
|
!define MUI_UNWELCOMEFINISHPAGE_BITMAP "@abs_top_srcdir@/share/pixmaps/nsis-wizard.bmp"
|
||||||
@ -28,6 +28,9 @@ SetCompressor /SOLID lzma
|
|||||||
# Included files
|
# Included files
|
||||||
!include Sections.nsh
|
!include Sections.nsh
|
||||||
!include MUI2.nsh
|
!include MUI2.nsh
|
||||||
|
!if "@WINDOWS_BITS@" == "64"
|
||||||
|
!include x64.nsh
|
||||||
|
!endif
|
||||||
|
|
||||||
# Variables
|
# Variables
|
||||||
Var StartMenuGroup
|
Var StartMenuGroup
|
||||||
@ -45,14 +48,18 @@ Var StartMenuGroup
|
|||||||
!insertmacro MUI_LANGUAGE English
|
!insertmacro MUI_LANGUAGE English
|
||||||
|
|
||||||
# Installer attributes
|
# Installer attributes
|
||||||
OutFile @abs_top_srcdir@/bitcoin-${VERSION}-win32-setup.exe
|
OutFile @abs_top_srcdir@/bitcoin-${VERSION}-win@WINDOWS_BITS@-setup.exe
|
||||||
|
!if "@WINDOWS_BITS@" == "64"
|
||||||
|
InstallDir $PROGRAMFILES64\Bitcoin
|
||||||
|
!else
|
||||||
InstallDir $PROGRAMFILES\Bitcoin
|
InstallDir $PROGRAMFILES\Bitcoin
|
||||||
|
!endif
|
||||||
CRCCheck on
|
CRCCheck on
|
||||||
XPStyle on
|
XPStyle on
|
||||||
BrandingText " "
|
BrandingText " "
|
||||||
ShowInstDetails show
|
ShowInstDetails show
|
||||||
VIProductVersion ${VERSION}.@CLIENT_VERSION_BUILD@
|
VIProductVersion ${VERSION}.@CLIENT_VERSION_BUILD@
|
||||||
VIAddVersionKey ProductName Bitcoin
|
VIAddVersionKey ProductName "Bitcoin Core"
|
||||||
VIAddVersionKey ProductVersion "${VERSION}"
|
VIAddVersionKey ProductVersion "${VERSION}"
|
||||||
VIAddVersionKey CompanyName "${COMPANY}"
|
VIAddVersionKey CompanyName "${COMPANY}"
|
||||||
VIAddVersionKey CompanyWebsite "${URL}"
|
VIAddVersionKey CompanyWebsite "${URL}"
|
||||||
@ -71,8 +78,9 @@ Section -Main SEC0000
|
|||||||
File /oname=readme.txt @abs_top_srcdir@/doc/README_windows.txt
|
File /oname=readme.txt @abs_top_srcdir@/doc/README_windows.txt
|
||||||
SetOutPath $INSTDIR\daemon
|
SetOutPath $INSTDIR\daemon
|
||||||
File @abs_top_srcdir@/release/bitcoind.exe
|
File @abs_top_srcdir@/release/bitcoind.exe
|
||||||
SetOutPath $INSTDIR\src
|
File @abs_top_srcdir@/release/bitcoin-cli.exe
|
||||||
File /r @abs_top_srcdir@/@PACKAGE@-@VERSION@/src\*.*
|
SetOutPath $INSTDIR\doc
|
||||||
|
File /r @abs_top_srcdir@/doc\*.*
|
||||||
SetOutPath $INSTDIR
|
SetOutPath $INSTDIR
|
||||||
WriteRegStr HKCU "${REGKEY}\Components" Main 1
|
WriteRegStr HKCU "${REGKEY}\Components" Main 1
|
||||||
|
|
||||||
@ -87,8 +95,8 @@ Section -post SEC0001
|
|||||||
WriteUninstaller $INSTDIR\uninstall.exe
|
WriteUninstaller $INSTDIR\uninstall.exe
|
||||||
!insertmacro MUI_STARTMENU_WRITE_BEGIN Application
|
!insertmacro MUI_STARTMENU_WRITE_BEGIN Application
|
||||||
CreateDirectory $SMPROGRAMS\$StartMenuGroup
|
CreateDirectory $SMPROGRAMS\$StartMenuGroup
|
||||||
CreateShortcut "$SMPROGRAMS\$StartMenuGroup\Bitcoin.lnk" $INSTDIR\bitcoin-qt.exe
|
CreateShortcut "$SMPROGRAMS\$StartMenuGroup\$(^Name).lnk" $INSTDIR\bitcoin-qt.exe
|
||||||
CreateShortcut "$SMPROGRAMS\$StartMenuGroup\Uninstall Bitcoin.lnk" $INSTDIR\uninstall.exe
|
CreateShortcut "$SMPROGRAMS\$StartMenuGroup\Uninstall $(^Name).lnk" $INSTDIR\uninstall.exe
|
||||||
!insertmacro MUI_STARTMENU_WRITE_END
|
!insertmacro MUI_STARTMENU_WRITE_END
|
||||||
WriteRegStr HKCU "SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall\$(^Name)" DisplayName "$(^Name)"
|
WriteRegStr HKCU "SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall\$(^Name)" DisplayName "$(^Name)"
|
||||||
WriteRegStr HKCU "SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall\$(^Name)" DisplayVersion "${VERSION}"
|
WriteRegStr HKCU "SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall\$(^Name)" DisplayVersion "${VERSION}"
|
||||||
@ -123,14 +131,14 @@ Section /o -un.Main UNSEC0000
|
|||||||
Delete /REBOOTOK $INSTDIR\COPYING.txt
|
Delete /REBOOTOK $INSTDIR\COPYING.txt
|
||||||
Delete /REBOOTOK $INSTDIR\readme.txt
|
Delete /REBOOTOK $INSTDIR\readme.txt
|
||||||
RMDir /r /REBOOTOK $INSTDIR\daemon
|
RMDir /r /REBOOTOK $INSTDIR\daemon
|
||||||
RMDir /r /REBOOTOK $INSTDIR\src
|
RMDir /r /REBOOTOK $INSTDIR\doc
|
||||||
DeleteRegValue HKCU "${REGKEY}\Components" Main
|
DeleteRegValue HKCU "${REGKEY}\Components" Main
|
||||||
SectionEnd
|
SectionEnd
|
||||||
|
|
||||||
Section -un.post UNSEC0001
|
Section -un.post UNSEC0001
|
||||||
DeleteRegKey HKCU "SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall\$(^Name)"
|
DeleteRegKey HKCU "SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall\$(^Name)"
|
||||||
Delete /REBOOTOK "$SMPROGRAMS\$StartMenuGroup\Uninstall Bitcoin.lnk"
|
Delete /REBOOTOK "$SMPROGRAMS\$StartMenuGroup\Uninstall $(^Name).lnk"
|
||||||
Delete /REBOOTOK "$SMPROGRAMS\$StartMenuGroup\Bitcoin.lnk"
|
Delete /REBOOTOK "$SMPROGRAMS\$StartMenuGroup\$(^Name).lnk"
|
||||||
Delete /REBOOTOK "$SMSTARTUP\Bitcoin.lnk"
|
Delete /REBOOTOK "$SMSTARTUP\Bitcoin.lnk"
|
||||||
Delete /REBOOTOK $INSTDIR\uninstall.exe
|
Delete /REBOOTOK $INSTDIR\uninstall.exe
|
||||||
Delete /REBOOTOK $INSTDIR\debug.log
|
Delete /REBOOTOK $INSTDIR\debug.log
|
||||||
@ -152,6 +160,15 @@ SectionEnd
|
|||||||
# Installer functions
|
# Installer functions
|
||||||
Function .onInit
|
Function .onInit
|
||||||
InitPluginsDir
|
InitPluginsDir
|
||||||
|
!if "@WINDOWS_BITS@" == "64"
|
||||||
|
${If} ${RunningX64}
|
||||||
|
; disable registry redirection (enable access to 64-bit portion of registry)
|
||||||
|
SetRegView 64
|
||||||
|
${Else}
|
||||||
|
MessageBox MB_OK|MB_ICONSTOP "Cannot install 64-bit version on a 32-bit system."
|
||||||
|
Abort
|
||||||
|
${EndIf}
|
||||||
|
!endif
|
||||||
FunctionEnd
|
FunctionEnd
|
||||||
|
|
||||||
# Uninstaller functions
|
# Uninstaller functions
|
||||||
|
@ -33,7 +33,16 @@ void AboutDialog::setModel(ClientModel *model)
|
|||||||
{
|
{
|
||||||
if(model)
|
if(model)
|
||||||
{
|
{
|
||||||
ui->versionLabel->setText(model->formatFullVersion());
|
QString version = model->formatFullVersion();
|
||||||
|
/* On x86 add a bit specifier to the version so that users can distinguish between
|
||||||
|
* 32 and 64 bit builds. On other architectures, 32/64 bit may be more ambigious.
|
||||||
|
*/
|
||||||
|
#if defined(__x86_64__)
|
||||||
|
version += " (64-bit)";
|
||||||
|
#elif defined(__i386__ )
|
||||||
|
version += " (32-bit)";
|
||||||
|
#endif
|
||||||
|
ui->versionLabel->setText(version);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user