dogecoin/depends/README.md

107 lines
3.4 KiB
Markdown

### Prerequisites
The depends system is maintained and tested using Ubuntu Bionic. 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 bison
```
#### Generic linux: i686-pc-linux-gnu and x86_64-linux-gnu
```
sudo apt-get install g++-7-multilib gcc-7-multilib
```
#### ARM7 32bit: arm-linux-gnueabihf
```
sudo apt-get install g++-arm-linux-gnueabihf g++-7-arm-linux-gnueabihf \
gcc-7-arm-linux-gnueabihf binutils-arm-linux-gnueabihf
```
#### ARM 64bit: aarch64-linux-gnu
```
sudo apt-get install g++-aarch64-linux-gnu g++-7-aarch64-linux-gnu \
gcc-7-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
- [description.md](description.md): General description of the depends system
- [packages.md](packages.md): Steps for adding packages