2010-12-13 16:26:14 +00:00
|
|
|
Copyright (c) 2010 Laszlo Hanyecz
|
2011-06-27 20:11:35 +00:00
|
|
|
Portions Copyright (c) 2011 Douglas Huff
|
|
|
|
Distributed under the MIT/X11 software license, see the accompanying file
|
|
|
|
license.txt or http://www.opensource.org/licenses/mit-license.php. This
|
|
|
|
product includes software developed by the OpenSSL Project for use in the
|
|
|
|
OpenSSL Toolkit (http://www.openssl.org/). This product includes cryptographic
|
|
|
|
software written by Eric Young (eay@cryptsoft.com) and UPnP software written by
|
|
|
|
Thomas Bernard.
|
2010-08-29 16:58:15 +00:00
|
|
|
|
|
|
|
|
|
|
|
Mac OS X build instructions
|
2011-06-27 20:11:35 +00:00
|
|
|
Laszlo Hanyecz <solar@heliacal.net>
|
|
|
|
Douglas Huff <dhuff@jrbobdobbs.org>
|
2010-08-29 16:58:15 +00:00
|
|
|
|
|
|
|
|
|
|
|
Tested on 10.5 and 10.6 intel. PPC is not supported because it's big-endian.
|
|
|
|
|
|
|
|
All of the commands should be executed in Terminal.app.. it's in
|
|
|
|
/Applications/Utilities
|
|
|
|
|
2011-06-27 20:11:35 +00:00
|
|
|
You need to install XCode with all the options checked so that the compiler and
|
|
|
|
everything is available in /usr not just /Developer I think it comes on the DVD
|
|
|
|
but you can get the current version from http://developer.apple.com
|
2010-08-29 16:58:15 +00:00
|
|
|
|
|
|
|
|
|
|
|
1. Pick a directory to work inside.. something like ~/bitcoin works. The
|
|
|
|
structure I use looks like this:
|
2011-06-27 20:11:35 +00:00
|
|
|
|
2010-08-29 16:58:15 +00:00
|
|
|
(~ is your home directory)
|
|
|
|
|
|
|
|
~/bitcoin
|
2011-06-27 20:11:35 +00:00
|
|
|
~/bitcoin/bitcoin # Upstream source tree
|
|
|
|
~/bitcoin/src # source code (symlink to ~/bitcoin/bitcoin/src)
|
2010-08-29 16:58:15 +00:00
|
|
|
~/bitcoin/deps # dependencies.. like libraries and headers needed to compile
|
|
|
|
~/bitcoin/Bitcoin.app # the application bundle where you can run the app
|
|
|
|
|
|
|
|
Just execute: mkdir ~/bitcoin
|
|
|
|
This will create the top dir for you..
|
|
|
|
|
|
|
|
WARNING: do not use the ~ notation with the configure scripts.. use the full
|
|
|
|
name of the directory, for example /Users/james/bitcoin/deps for a user named
|
|
|
|
'james'. In my examples I am using 'macosuser' so make sure you change that.
|
|
|
|
|
2011-06-27 20:11:35 +00:00
|
|
|
2. Check out the bitcoin code from github:
|
2010-08-29 16:58:15 +00:00
|
|
|
|
|
|
|
cd ~/bitcoin
|
2011-06-27 20:11:35 +00:00
|
|
|
git clone https://github.com/bitcoin/bitcoin.git
|
|
|
|
ln -s bitcoin/src src
|
2010-08-29 16:58:15 +00:00
|
|
|
|
2011-06-27 20:11:35 +00:00
|
|
|
This will make ~/bitcoin/bitcoin for you with all the files from git. This puts
|
|
|
|
the actual sources in ~/bitcoin/bitcoin/src and create a symlink src in
|
|
|
|
~/bitcoin to this location.
|
2010-08-29 16:58:15 +00:00
|
|
|
|
|
|
|
3. Get and build the dependencies
|
|
|
|
|
|
|
|
|
|
|
|
Boost
|
|
|
|
-----
|
|
|
|
|
|
|
|
Download from http://www.boost.org/users/download/
|
|
|
|
I'm assuming it ended up in ~/Downloads..
|
|
|
|
|
|
|
|
mkdir ~/bitcoin/deps
|
|
|
|
cd ~/bitcoin/deps
|
|
|
|
tar xvjf ~/Downloads/boost_1_42_0.tar.bz2
|
|
|
|
cd boost_1_42_0
|
|
|
|
./bootstrap.sh
|
2011-04-13 20:38:22 +00:00
|
|
|
./bjam architecture=combined address-model=32_64 macosx-version=10.5 macosx-version-min=10.5 link=static runtime-link=static --toolset=darwin --prefix=/Users/macosuser/bitcoin/deps install
|
|
|
|
|
|
|
|
If you're using Snow Leopard, you will need to specify 10.6 as your Mac OS X
|
|
|
|
version instead of 10.5.
|
2010-08-29 16:58:15 +00:00
|
|
|
|
|
|
|
This part takes a while.. use your judgement and fix it if something doesn't
|
|
|
|
build for some reason.
|
|
|
|
|
|
|
|
Change the prefix to whatever your directory is (my username in this example
|
|
|
|
is macosuser). I'm also running on 10.6 so i have macosx-version=10.6 change
|
|
|
|
to 10.5 if you're using leopard.
|
|
|
|
|
|
|
|
This is what my output looked like at the end:
|
|
|
|
...failed updating 2 targets...
|
|
|
|
...skipped 144 targets...
|
|
|
|
...updated 8074 targets...
|
|
|
|
|
|
|
|
|
|
|
|
OpenSSL
|
|
|
|
-------
|
|
|
|
|
2011-06-27 20:11:35 +00:00
|
|
|
(System or MacPorts openssl will work fine. Optional.)
|
|
|
|
|
2010-08-29 16:58:15 +00:00
|
|
|
Download from http://www.openssl.org/source/
|
|
|
|
|
|
|
|
We would like to build this as a 32 bit/64 bit library so we actually build it
|
|
|
|
2 times and join it together here.. If you downloaded with safari it already
|
|
|
|
uncompressed it so it will just be a tar not a tar.gz
|
|
|
|
|
|
|
|
cd ~/bitcoin/deps
|
|
|
|
tar xvf ~/Downloads/openssl-1.0.0.tar
|
|
|
|
mv openssl-1.0.0 openssl-1.0.0-i386
|
|
|
|
tar xvf ~/Downloads/openssl-1.0.0.tar
|
|
|
|
mv openssl-1.0.0 openssl-1.0.0-x86_64
|
|
|
|
# build i386 (32 bit intel) binary
|
|
|
|
cd openssl-1.0.0-i386
|
2011-04-13 20:38:22 +00:00
|
|
|
./Configure --prefix=/Users/macosuser/bitcoin/deps --openssldir=/Users/macosuser/bitcoin/deps/openssl darwin-i386-cc && make
|
2010-08-29 16:58:15 +00:00
|
|
|
make install # only do this on one of the architectures, to install the headers
|
|
|
|
cd ..
|
|
|
|
# build x86_64 (64 bit intel) binary
|
|
|
|
cd openssl-1.0.0-x86_64
|
2011-04-13 20:38:22 +00:00
|
|
|
./Configure --prefix=/Users/macosuser/bitcoin/deps --openssldir=/Users/macosuser/bitcoin/deps/openssl darwin64-x86_64-cc && make
|
2010-08-29 16:58:15 +00:00
|
|
|
cd ..
|
|
|
|
|
|
|
|
# combine the libs
|
|
|
|
cd ~/bitcoin/deps
|
|
|
|
lipo -arch i386 openssl-1.0.0-i386/libcrypto.a -arch x86_64 openssl-1.0.0-x86_64/libcrypto.a -o lib/libcrypto.a -create
|
|
|
|
lipo -arch i386 openssl-1.0.0-i386/libssl.a -arch x86_64 openssl-1.0.0-x86_64/libssl.a -o lib/libssl.a -create
|
|
|
|
|
|
|
|
Verify your binaries
|
|
|
|
|
|
|
|
file lib/libcrypto.a
|
|
|
|
|
|
|
|
output should look like this:
|
|
|
|
|
2011-03-26 12:01:27 +00:00
|
|
|
lib/libcrypto.a: Mach-O universal binary with 2 architectures
|
2011-06-27 20:11:35 +00:00
|
|
|
lib/libcrypto.a (for architecture i386): current ar archive random library
|
|
|
|
lib/libcrypto.a (for architecture x86_64): current ar archive random library
|
2010-08-29 16:58:15 +00:00
|
|
|
|
|
|
|
|
2011-03-26 12:01:27 +00:00
|
|
|
miniupnpc
|
|
|
|
---------
|
|
|
|
|
2011-06-27 20:11:35 +00:00
|
|
|
(MacPorts miniupnpc package works fine. You will need to modify makefile.)
|
|
|
|
|
2011-03-26 12:01:27 +00:00
|
|
|
The process for miniupnpc (optional) is similar to that of OpenSSL.
|
|
|
|
|
|
|
|
Download from http://miniupnp.tuxfamily.org/files/.
|
|
|
|
|
|
|
|
cd ~/bitcoin/deps
|
|
|
|
tar xvf ~/Downloads/miniupnpc-1.5.tar
|
|
|
|
mv miniupnpc-1.5 miniupnpc-1.5-x86_64
|
|
|
|
tar xvf ~/Downloads/miniupnpc-1.5.tar
|
|
|
|
mv miniupnpc-1.5 miniupnpc-1.5-i386
|
|
|
|
# build x86_64 (64 bit intel) binary
|
|
|
|
cd miniupnpc-1.5-x86_64
|
|
|
|
export CFLAGS="-arch x86_64"
|
|
|
|
export LDFLAGS="-arch x86_64"
|
|
|
|
export PREFIX="/Users/macuser/bitcoin/deps"
|
|
|
|
make && make install
|
|
|
|
# build i386 (32 bit intel) binary
|
|
|
|
cd miniupnpc-1.5-i386
|
|
|
|
export CFLAGS="-arch i386"
|
|
|
|
export LDFLAGS="-arch i386"
|
|
|
|
export PREFIX="/Users/macuser/bitcoin/deps"
|
|
|
|
make
|
|
|
|
|
|
|
|
# combine the libs
|
|
|
|
cd ~/bitcoin/deps
|
|
|
|
lipo -arch i386 miniupnpc-1.5-i386/libminiupnpc.a -arch x86_64 miniupnpc-1.5-x86_64/libminiupnpc.a -o lib/libminiupnpc.a -create
|
|
|
|
|
|
|
|
Verify your binaries
|
|
|
|
|
|
|
|
file lib/libminiupnpc.a
|
|
|
|
|
|
|
|
output should look like this:
|
|
|
|
|
|
|
|
lib/libminiupnpc.a: Mach-O universal binary with 2 architectures
|
2011-06-27 20:11:35 +00:00
|
|
|
lib/libminiupnpc.a (for architecture i386): current ar archive random library
|
|
|
|
lib/libminiupnpc.a (for architecture x86_64): current ar archive random library
|
2011-03-26 12:01:27 +00:00
|
|
|
|
|
|
|
|
2010-08-29 16:58:15 +00:00
|
|
|
Berkeley DB
|
|
|
|
-----------
|
|
|
|
|
2011-06-27 20:11:35 +00:00
|
|
|
(System or MacPorts version work fine.)
|
|
|
|
|
2010-08-29 16:58:15 +00:00
|
|
|
Download from http://freshmeat.net/projects/berkeleydb/
|
|
|
|
|
|
|
|
cd ~/bitcoin/deps
|
|
|
|
tar xvf ~/Downloads/db-4.8.26.tar
|
|
|
|
cd db-4.8.26/build_unix
|
|
|
|
../dist/configure --prefix=/Users/macosuser/bitcoin/deps --enable-cxx && make && make install
|
|
|
|
|
|
|
|
|
|
|
|
wxWidgets
|
|
|
|
---------
|
|
|
|
|
2011-06-27 20:11:35 +00:00
|
|
|
(The wxWidgets-devel MacPorts package will work but will throw annoying assertion dialogs.)
|
|
|
|
|
2010-08-29 16:58:15 +00:00
|
|
|
This is the big one..
|
|
|
|
|
|
|
|
Check it out from svn
|
|
|
|
|
|
|
|
cd ~/bitcoin/deps
|
|
|
|
svn checkout http://svn.wxwidgets.org/svn/wx/wxWidgets/trunk wxWidgets-trunk
|
|
|
|
|
|
|
|
This will make a wxWidgets-trunk directory in deps.
|
|
|
|
|
|
|
|
Use this script snippet, change your prefix to whatever your dir is:
|
|
|
|
|
|
|
|
PREFIX=~/bitcoin/deps
|
|
|
|
SRCDIR="$PREFIX/wxWidgets-trunk"
|
|
|
|
BUILDDIR="$SRCDIR/macbuild"
|
|
|
|
|
|
|
|
cd "$PREFIX" &&
|
|
|
|
#svn checkout http://svn.wxwidgets.org/svn/wx/wxWidgets/trunk wxWidgets-trunk &&
|
|
|
|
cd "$SRCDIR" &&
|
|
|
|
|
|
|
|
[ -f include/wx/hashmap.h.orig ] || cp include/wx/hashmap.h include/wx/hashmap.h.orig &&
|
|
|
|
sed 's/if wxUSE_STL/if 0 \&\& wxUSE_STL/g' < include/wx/hashmap.h.orig > include/wx/hashmap.h &&
|
|
|
|
|
|
|
|
[ -f include/wx/hashset.h.orig ] || cp include/wx/hashset.h include/wx/hashset.h.orig &&
|
|
|
|
sed 's/if wxUSE_STL/if 0 \&\& wxUSE_STL/g' < include/wx/hashset.h.orig > include/wx/hashset.h &&
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
rm -vrf "$BUILDDIR" &&
|
|
|
|
mkdir "$BUILDDIR" &&
|
|
|
|
cd "$BUILDDIR" &&
|
|
|
|
|
|
|
|
../configure --prefix="$PREFIX" \
|
|
|
|
--with-osx_cocoa \
|
|
|
|
--disable-shared \
|
|
|
|
--disable-debug_flag \
|
|
|
|
--with-macosx-version-min=10.5 \
|
|
|
|
--enable-stl \
|
|
|
|
--enable-utf8 \
|
|
|
|
--enable-universal_binary \
|
|
|
|
--with-libjpeg=builtin \
|
|
|
|
--with-libpng=builtin \
|
|
|
|
--with-regex=builtin \
|
|
|
|
--with-libtiff=builtin \
|
|
|
|
--with-zlib=builtin \
|
|
|
|
--with-expat=builtin \
|
|
|
|
--with-macosx-sdk=/Developer/SDKs/MacOSX10.5.sdk &&
|
|
|
|
|
|
|
|
|
|
|
|
find . -name Makefile |
|
|
|
|
while read i; do
|
|
|
|
echo $i;
|
|
|
|
sed 's/-arch i386/-arch i386 -arch x86_64/g' < "$i" > "$i".new &&
|
|
|
|
mv "$i" "$i".old &&
|
|
|
|
mv "$i".new "$i";
|
|
|
|
done
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
make &&
|
|
|
|
make install
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Now you should be able to build bitcoin
|
|
|
|
|
2011-06-27 20:11:35 +00:00
|
|
|
cd ~/bitcoin/src
|
2010-08-29 16:58:15 +00:00
|
|
|
make -f makefile.osx bitcoin
|
|
|
|
|
|
|
|
Before you can run it, you need to create an application bundle for Mac OS.
|
2011-06-27 20:11:35 +00:00
|
|
|
|
|
|
|
A bundle is provided in contrib/Bitcoin.app.
|
|
|
|
|
|
|
|
Copy the bitcoin binary in to it like this:
|
|
|
|
cp -pR ~/bitcoin/bitcoin/contrib/Bitcoin.app ~/bitcoin/
|
|
|
|
cp ~/bitcoin/src/bitcoin ~/bitcoin/Bitcoin.app/Contents/MacOS/
|
|
|
|
|
|
|
|
To run it you can just click the Bitcoin.app in Finder, or just do:
|
|
|
|
open ~/bitcoin/Bitcoin.app
|
|
|
|
|
2010-08-29 16:58:15 +00:00
|
|
|
If you want to run it with arguments you can just run it without backgrounding
|
|
|
|
by specifying the full name in terminal:
|
2011-06-27 20:11:35 +00:00
|
|
|
|
2010-08-29 16:58:15 +00:00
|
|
|
~/bitcoin/Bitcoin.app/Contents/MacOS/bitcoin -addnode=192.75.207.66
|
2011-06-27 20:11:35 +00:00
|
|
|
|
|
|
|
You can also run it with arguments in the background with output going to the
|
|
|
|
normal places for apps (Console) like this:
|
|
|
|
|
|
|
|
open ~/bitcoin/Bitcoin.app --args -connect=192.75.207.66
|
|
|
|
|
|
|
|
It is advisable to relocate Bitcoin.app to /Applications or $HOME/Applications.
|
|
|
|
|