Skip to main content

Building From Sources

Linux

Install prerequisites

sudo apt-get install -y build-essential g++ python-dev autotools-dev libicu-dev libbz2-dev cmake git screen checkinstall zlib1g-dev

Download and build Boost

(Assuming you have cloned Zano into zano folder. If used different location for Zano, edit line 4 correspondingly)

curl -OL https://boostorg.jfrog.io/artifactory/main/release/1.70.0/source/boost_1_70_0.tar.bz2
echo "430ae8354789de4fd19ee52f3b1f739e1fba576f0aded0897c3c2bc00fb38778 boost_1_70_0.tar.bz2" | shasum -c && tar -xjf boost_1_70_0.tar.bz2
rm boost_1_70_0.tar.bz2 && cd boost_1_70_0
patch -p0 < ../zano/utils/boost_1.70_gcc_8.patch || cd ..
./bootstrap.sh --with-libraries=system,filesystem,thread,date_time,chrono,regex,serialization,atomic,program_options,locale,timer,log
./b2

Make sure that you see "The Boost C++ Libraries were successfully built!" message at the end.

Install OpenSSL

Please, make sure the paths correspond to your environment (`/home/user/')

curl -OL https://www.openssl.org/source/openssl-1.1.1t.tar.gz
echo "a06b067b7e3bd6a2cb52a06f087ff13346ce7360 openssl-1.1.1t.tar.gz" | shasum -c && tar xzf openssl-1.1.1t.tar.gz
cd openssl-1.1.1t/
./config --prefix=/home/user/openssl --openssldir=/home/user/openssl shared zlib
make
make test
make install

Checkout Zano from github

git clone --recursive https://github.com/hyle-team/zano.git

Set environment variables

For instance, by adding the following lines to ~/.bashrc

Server version

export BOOST_ROOT=/home/user/boost_1_70_0
export OPENSSL_ROOT_DIR=/home/user/openssl

GUI version

export BOOST_ROOT=/home/user/boost_1_70_0
export OPENSSL_ROOT_DIR=/home/user/openssl
export QT_PREFIX_PATH=/home/user/Qt5.11.2/5.11.2/gcc_64

Build the binaries

Mainnet:

cd zano && mkdir build && cd build
cmake
make -j1 daemon simplewallet

Testnet:

cd zano && mkdir build && cd build
cmake -D TESTNET=TRUE ..
make -j1 daemon simplewallet

Build GUI

cd zano
utils/build_script_linux.sh

Windows

Install required prerequisites (Boost, Qt, CMake, OpenSSL)
Rename utils/configure_local_paths.cmd.example to utils/configure_local_paths.cmd and edit paths in this file so they correspond to your environment.

Mainnet: Run one of utils/configure_win64_msvsNNNN_gui.cmd according to your MSVC version.

Testnet: Run one of utils/configure_win64_msvsNNNN_testnet.cmd according to your MSVC version.

Go to the build folder and open generated Zano.sln in MSVC and build it.

Build GUI

In order to correctly deploy Qt GUI application, you also need to do the following:

Copy Zano.exe to a folder (e.g. depoy). Run PATH_TO_QT\bin\windeployqt.exe deploy\Zano.exe. Copy folder \src\gui\qt-daemon\html to deploy\html. Now you can run Zano.exe

MacOS

Install required prerequisites.
Set environment variables as stated in utils/macosx_build_config.command

mkdir build
cd build
cmake -D TESTNET=TRUE ..
make

Build GUI

Create self-signing certificate via Keychain Access:

Run Keychain Access

Choose Keychain Access > Certificate Assistant > Create a Certificate

Use “Zano” (without quotes) as certificate name

Choose “Code Signing” in “Certificate Type” field

Press “Create”, then “Done”

Make sure the certificate was added to keychain "System". If not—move it to "System"

Double click the certificate you've just added, enter the trust section and under "When using this certificate" select "Always trust"

Unfold the certificate in Keychain Access window and double click the underlying private key "Zano". Select "Access Control" tab, then select "Allow all applications to access this item". Click "Save Changes"

Revise building script, comment out unwanted steps and run it: utils/build_script_mac_osx.sh

The application should be here: /buid_mac_osx_64/release/src