dogecoin/depends
Carl Dong 043ce9a2c2
depends: Fully determine path for darwin_{CC,CXX}
Instead of doing the awkward /bin path prepending at config.site
creation time, set darwin_{CC,CXX} in a way that fully determines the
program's path (clang/clang++)

Also see the added comment block in depends/Makefile for more context on
determining $PATH for our config.site.

Cherry-picked from: 880660ac

Conflicts: cherry-picked from a Bitcoin Core build system that is
           optimized for supporting system-provided clang builds
           which Dogecoin Core does not have at this time. I have
           removed all code regarding that functionality and only
           kept the code relevant to Dogecoin Core for this
           major version (1.14), i.e. those lines that use the
           pinned clang from the depends system.
2021-09-23 20:14:03 +02:00
..
builders [depends] Add -stdlib=libc++ to darwin CXX flags 2016-05-04 19:03:59 +08:00
hosts depends: Fully determine path for darwin_{CC,CXX} 2021-09-23 20:14:03 +02:00
packages depends: Remove export of glibc 2.17 secure_getenv 2021-09-23 20:13:43 +02:00
patches depends: Remove export of glibc 2.17 secure_getenv 2021-09-23 20:13:43 +02:00
.gitignore [trivial] Add aarch64 to depends .gitignore 2016-06-24 15:01:45 +08:00
config.guess [depends] Latest config.guess and config.sub 2017-01-11 08:44:01 +08:00
config.site.in [depends] Remove OBJCXX define from config.site.in 2017-01-14 14:26:00 +08:00
config.sub [depends] Latest config.guess and config.sub 2017-01-11 08:44:01 +08:00
description.md doc: Documentation in Markdown for Depends Dir 2015-05-15 12:35:20 +02:00
funcs.mk depends: fix fallback downloads 2016-04-04 19:26:44 -04:00
Makefile depends: Fully determine path for darwin_{CC,CXX} 2021-09-23 20:14:03 +02:00
packages.md doc: Documentation in Markdown for Depends Dir 2015-05-15 12:35:20 +02:00
README.md depends: Add required packages to build 2021-07-20 20:55:16 +02:00

Prerequisites

The depends system is maintained and tested using Ubuntu Trusty. Both generic apt packages, and packages specific to the target architecture are required to successfully compile all dependencies. Listed packages are tested and known to work.

Generic packages

sudo apt-get install autoconf automake binutils-gold ca-certificates curl \
                     faketime git-core libtool pkg-config python

Generic linux: i686-pc-linux-gnu and x86_64-linux-gnu

sudo apt-get install g++-4.8-multilib gcc-4.8-multilib

ARM7 32bit: arm-linux-gnueabihf

sudo apt-get install g++-arm-linux-gnueabihf g++-4.8-arm-linux-gnueabihf \
                     gcc-4.8-arm-linux-gnueabihf binutils-arm-linux-gnueabihf

ARM 64bit: aarch64-linux-gnu

sudo apt-get install g++-aarch64-linux-gnu g++-4.8-aarch64-linux-gnu \
                     gcc-4.8-aarch64-linux-gnu binutils-aarch64-linux-gnu

Windows: i686-w64-mingw32 and x86_64-w64-mingw32

sudo apt-get install g++ g++-mingw-w64 mingw-w64 nsis zip

macOS (Intel): x86_64-apple-darwin11

sudo apt-get install g++ cmake imagemagick fonts-tuffy libz-dev libbz2-dev \
                     libcap-dev librsvg2-bin libtiff-tools python python-dev \
                     python-setuptools

Usage

To build dependencies for the current arch+OS:

make

To build for another arch/OS:

make HOST=host-platform-triplet

For example:

make HOST=x86_64-w64-mingw32 -j4

A prefix will be generated that's suitable for plugging into Bitcoin's configure. In the above example, a dir named x86_64-w64-mingw32 will be created. To use it for Bitcoin:

./configure --prefix=`pwd`/depends/x86_64-w64-mingw32

Common host-platform-triplets for cross compilation are:

  • i686-w64-mingw32 for Win32
  • x86_64-w64-mingw32 for Win64
  • x86_64-apple-darwin11 for MacOSX
  • arm-linux-gnueabihf for Linux ARM 32 bit
  • aarch64-linux-gnu for Linux ARM 64 bit

No other options are needed, the paths are automatically configured.

Dependency Options: The following can be set when running make: make FOO=bar

SOURCES_PATH: downloaded sources will be placed here
BASE_CACHE: built packages will be placed here
SDK_PATH: Path where sdk's can be found (used by OSX)
FALLBACK_DOWNLOAD_PATH: If a source file can't be fetched, try here before giving up
NO_QT: Don't download/build/cache qt and its dependencies
NO_WALLET: Don't download/build/cache libs needed to enable the wallet
NO_UPNP: Don't download/build/cache packages needed for enabling upnp
DEBUG: disable some optimizations and enable more runtime checking
HOST_ID_SALT: Optional salt to use when generating host package ids
BUILD_ID_SALT: Optional salt to use when generating build package ids

If some packages are not built, for example make NO_WALLET=1, the appropriate options will be passed to bitcoin's configure. In this case, --disable-wallet.

Additional targets:

download: run 'make download' to fetch all sources without building them
download-osx: run 'make download-osx' to fetch all sources needed for osx builds
download-win: run 'make download-win' to fetch all sources needed for win builds
download-linux: run 'make download-linux' to fetch all sources needed for linux builds

Other documentation