lbrycrd/depends
lbrynaut 1b5d21056d Fix Windows ICU build by making sure the cross compiled ICU exists before building boost.
Add some additional logging during ICU configuration and build process.

Resolve ICU on windows link issues.

Add /tmp/icu_install (cross-compile staging build) to the travis
directory cache for future windows builds.
2019-02-09 12:02:59 -07:00
..
builders [depends] builders: No need to set -L and --location for curl 2016-02-26 09:50:29 +01:00
hosts osx: bump build sdk to 10.9 2015-01-20 01:49:20 -05:00
packages Fix Windows ICU build by making sure the cross compiled ICU exists before building boost. 2019-02-09 12:02:59 -07:00
patches [depends] Delete unused patches 2016-03-01 13:03:42 +01:00
.gitignore Add x86_64* i686* mips* and arm* to depends .gitignore 2015-04-20 13:29:20 +02:00
config.guess [Depends] Latest config.guess & config.sub 2016-03-18 09:06:08 +08:00
config.site.in Fix Windows ICU build by making sure the cross compiled ICU exists before building boost. 2019-02-09 12:02:59 -07:00
config.sub [Depends] Latest config.guess & config.sub 2016-03-18 09:06:08 +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 Fix Windows ICU build by making sure the cross compiled ICU exists before building boost. 2019-02-09 12:02:59 -07:00
packages.md doc: Documentation in Markdown for Depends Dir 2015-05-15 12:35:20 +02:00
README.md depends: create a hostid and buildid and add option for salts 2016-04-04 19:26:44 -04:00

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

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