2024-09-12 12:42:13 +02:00
|
|
|
# openSUSE Tumbleweed BCI GNU Compiler Collection container image (GCC)
|
|
|
|
![Redistributable](https://img.shields.io/badge/Redistributable-Yes-green)
|
|
|
|
|
|
|
|
# Description
|
|
|
|
The GNU Compiler Collection (GCC) is an optimizing compiler for various
|
|
|
|
architectures and operating systems. It is the default compiler in the GNU
|
|
|
|
project and most Linux distributions, including SUSE Linux Enterprise and
|
|
|
|
openSUSE.
|
|
|
|
|
|
|
|
|
|
|
|
## Usage
|
|
|
|
|
|
|
|
### Compile an application with a `Dockerfile`
|
|
|
|
|
|
|
|
Normally, you'd want to compile an application and distribute it as part of a
|
|
|
|
custom container image. To do this, create a `Dockerfile` similar to the one
|
|
|
|
below. The `Dockerfile` uses this image to build a custom container image,
|
|
|
|
copies the sources to a working directory, and compiles the application:
|
|
|
|
|
|
|
|
```Dockerfile
|
|
|
|
FROM registry.opensuse.org/opensuse/bci/gcc:14
|
|
|
|
WORKDIR /src/
|
|
|
|
COPY . /src/
|
|
|
|
RUN gcc main.c src1.c src2.c
|
|
|
|
CMD ["./a.out"]
|
|
|
|
```
|
|
|
|
|
|
|
|
It is also possible to compile a static binary with gcc as part of a multistage
|
|
|
|
build:
|
|
|
|
|
|
|
|
```Dockerfile
|
|
|
|
FROM registry.opensuse.org/opensuse/bci/gcc:14 as builder
|
|
|
|
WORKDIR /src/
|
|
|
|
COPY . /src/
|
|
|
|
RUN gcc -o app main.c src1.c src2.c
|
|
|
|
|
2024-09-28 10:18:02 +02:00
|
|
|
FROM registry.opensuse.org/opensuse/bci/bci-micro:latest
|
2024-09-12 12:42:13 +02:00
|
|
|
WORKDIR /build/
|
|
|
|
COPY --from=builder /src/app /build/
|
|
|
|
CMD ["/build/app"]
|
|
|
|
```
|
|
|
|
|
|
|
|
Note that you must build a static binary to deploy it into bci-micro; otherwise
|
|
|
|
shared libraries might be missing. You cannot deploy such an app into a
|
|
|
|
`scratch` image, as it is not possible to statically link glibc.
|
|
|
|
|
|
|
|
|
|
|
|
### Available build systems
|
|
|
|
|
|
|
|
The container image comes with `make` by default. Other build systems and
|
|
|
|
related utilities are available in the repository, and they can be installed
|
|
|
|
using `zypper`. This includes the following:
|
|
|
|
- `meson`
|
|
|
|
- `cmake`
|
|
|
|
- `ninja`
|
|
|
|
- `autoconf` & `automake`
|
|
|
|
|
|
|
|
|
|
|
|
### Available compiler frontends
|
|
|
|
|
|
|
|
The GNU Compiler Collections supports a wide range of frontends. The container
|
2024-10-29 16:32:13 +01:00
|
|
|
image ships the C, C++ and fortran frontends available as `gcc`, `g++` and `gfortran`
|
2024-09-12 12:42:13 +02:00
|
|
|
respectively. The following additional frontends can be installed from the
|
|
|
|
repository:
|
|
|
|
- `gcc14-ada` for the Ada frontend (GNAT)
|
|
|
|
- `gcc14-go` for the Go frontend
|
|
|
|
- `gcc14-objc` and `gcc14-obj-c++` for the Objective C and Objective C++
|
|
|
|
- `gcc14-d` for the frontend to the D Language
|
|
|
|
- `gcc14-m2` for the Modula 2 compiler frontend
|
|
|
|
- `gcc14-rust` for the GNU Rust compiler
|
|
|
|
|
|
|
|
|
|
|
|
### Using the container image interactively
|
|
|
|
|
|
|
|
You can use the image to create ephemeral containers that execute only gcc. This
|
|
|
|
can be useful in situations, where building a full container image is not
|
|
|
|
practical. One way to do this is to mount the working directory of an
|
|
|
|
application into the launched container and compile the application there:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
podman run --rm -it -v $(pwd):/src/:Z registry.opensuse.org/opensuse/bci/gcc:14 \
|
|
|
|
gcc -o /src/app.out /src/*.c
|
|
|
|
```
|
|
|
|
or by invoking `make`
|
|
|
|
```bash
|
|
|
|
podman run --rm -it -v $(pwd):/src/:Z --workdir /src/ \
|
|
|
|
registry.opensuse.org/opensuse/bci/gcc:14 \
|
|
|
|
make
|
|
|
|
```
|
|
|
|
|
|
|
|
Note that the binary built using this approach are unlikely to work on a local
|
|
|
|
machine. They only work on operating systems that are binary-compatible to
|
|
|
|
openSUSE Tumbleweed.
|
|
|
|
|
|
|
|
## Licensing
|
|
|
|
|
2024-11-07 15:12:22 +01:00
|
|
|
`SPDX-License-Identifier: GPL-3.0-or-later`
|
2024-09-12 12:42:13 +02:00
|
|
|
|
2024-11-07 15:12:22 +01:00
|
|
|
This documentation and the build recipe are licensed as GPL-3.0-or-later.
|
2024-09-12 12:42:13 +02:00
|
|
|
The container itself contains various software components under various open source licenses listed in the associated
|
|
|
|
Software Bill of Materials (SBOM).
|
|
|
|
|
|
|
|
This image is based on [openSUSE Tumbleweed](https://get.opensuse.org/tumbleweed/).
|