52c4471a30
Updated so that it can build Haiku R1 Beta 4. The intention is to use this to create repeatable builds for Rust builds. The script has been tweaked to use the latest stable debian as base image, to include the (now-required) libzstd-devel package, and the g++-multilib package to support building 32 bit in a 64 bit host. It also moves to python 3.x. Additionally, the image now supports specifying custom git tags/branches for the buildtools and Haiku itself, so that specific hrevs or branches can be built Change-Id: Ia43089ff7271256fdb6603bd4400ee3b9228ea1b Reviewed-on: https://review.haiku-os.org/c/haiku/+/5965 Tested-by: Commit checker robot <no-reply+buildbot@haiku-os.org> Reviewed-by: Adrien Destugues <pulkomandy@pulkomandy.tk>
36 lines
1.8 KiB
Markdown
36 lines
1.8 KiB
Markdown
# A docker image suitable for cross-compiling Haiku applications
|
|
|
|
This docker image provides an environment suitable to build Haiku applications
|
|
inside a Linux compiler. It can be used by projects willing to integrate an
|
|
Haiku build inside their CI system, for example.
|
|
|
|
The docker build of this image prepares the environment by:
|
|
- Building our toolchain
|
|
- Building the haiku hpkg files and downloading dependencies
|
|
- Extracting headers and libraries from the hpkg files to generate a sysroot
|
|
directory
|
|
- Setting up environment variables for the toolchain to be usable
|
|
|
|
You can then use the $ARCH-unknown-haiku compiler (for example
|
|
arm-unknown-haiku-gcc) to build your application. All the required files are
|
|
installed in /tools/cross-tools-$ARCH.
|
|
|
|
## Building the image
|
|
|
|
The Dockerfile accepts four arguments when building the image:
|
|
|
|
* `BUILDTOOLS_REV` is the branch/tag of buildtools that should be built. It defaults to `master`.
|
|
* `HAIKU_REV` is the branch/tag of the haiku repository that should be built. It defaults to `master`.
|
|
* `ARCHITECTURE` is the primary architecture to build the tools and library for. It defaults to `x86_64`
|
|
* `SECONDARY_ARCHITECTURE` is the secondary architecture. Leave it empty in case it is not necessary.
|
|
|
|
For example, the r1beta4 images are build with the following commands:
|
|
|
|
```bash
|
|
# r1beta4 on x86 hybrid, with gcc2 as the primary architecture, and modern gcc as the secondary
|
|
podman build --build-arg BUILDTOOLS_REV=r1beta4 --build-arg HAIKU_REV=r1beta4 --build-arg ARCHITECTURE=x86_gcc2 --build-arg SECONDARY_ARCHITECTURE=x86 --tag docker.io/haiku/cross-compiler:x86_gcc2h-r1beta4 .
|
|
|
|
# r1beta4 on x86_64
|
|
podman build --build-arg BUILDTOOLS_REV=r1beta4 --build-arg HAIKU_REV=r1beta4 --build-arg ARCHITECTURE=x86_64 --tag docker.io/haiku/cross-compiler:x86_64-r1beta4 .
|
|
```
|