You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
feather/BUILDING.md

2.8 KiB

Buildbot builds

The docker build bins can be found here: https://build.featherwallet.org/files/

Docker static builds

Static builds via Docker are done in 3 steps:

  1. Cloning this repository (+submodules)
  2. Creating a base Docker image
  3. Using the base image to compile a build

Windows

The docker image for Windows static compiles uses Ubuntu 18.04 and installs mxe from our git, which comes with: OpenSSL 1.1.1g, Qt 5.15.0 (OpenGL via mesa). For more information, check the Dockerfile: Dockerfile_windows.

1. Clone

git clone --recursive https://git.wownero.com/feather/feather.git
cd feather

2. Base image

Warning: Building the MXE base image takes up to a hour, so go watch a movie.

docker build -f Dockerfile_windows --tag feather:win --build-arg THREADS=8 .

Note: You only need to build the base image once.

3. Build

docker run --rm -it -v /tmp/ccache:/root/.ccache -v /root/feather:/feather -w /feather feather:win /bin/bash -c 'PATH=/mxe/usr/bin/:$PATH make windows-mxe-release -j8'

Replace PATH_TO_FEATHER with the absolute path to Feather locally.

The resulting binary can be found in build/bin/feather.exe.

Linux

The docker image for Linux static compiles uses Ubuntu 18.04 and compiles the required libraries statically so that the resulting Feather binary is static. It comes with OpenSSL 1.1.1g, Qt 5.15.0 (OpenGL disabled). For more information, check the Dockerfile: Dockerfile.

1. Clone

git clone --recursive https://git.wownero.com/feather/feather.git
cd feather

2. Base image

Warning: Building the base image takes a while, go prepare some dinner.

docker build --tag feather:linux --build-arg THREADS=8 .

Note: You only need to build the base image once.

3. Build

docker run --env OPENSSL_ROOT_DIR=/usr/local/openssl/ --rm -it -v /tmp/ccache:/root/.ccache -v PATH_TO_FEATHER:/feather -w /feather feather:linux sh -c 'make release-static -j8'

Replace PATH_TO_FEATHER with the absolute path to Feather locally.

The resulting binary can be found in build/bin/feather.

macOS

For MacOS it's easiest to leverage brew to install the required dependencies.

HOMEBREW_OPTFLAGS="-march=core2" HOMEBREW_OPTIMIZATION_LEVEL="O0" \
    brew install boost zmq openssl libpgm miniupnpc libsodium expat libunwind-headers protobuf libgcrypt qrencode ccache cmake pkgconfig git

Clone the repository.

git clone --recursive https://git.wownero.com/feather/feather.git

Get the latest LTS from here: https://www.qt.io/offline-installers and install.

Build Feather.

CMAKE_PREFIX_PATH=~/Qt5.15.1/5.15.1/clang_64 make mac-release

The resulting Mac OS application can be found build/bin/feather.app.