Skip to content

a (nearly) full qt build environment as a docker image, small footprint, lots of versions

License

Notifications You must be signed in to change notification settings

kp-miguel-galindo/qt-build

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

qt-build

Warning: Unmaintained

As the build infrastructure provided by travis ci has entirely stopped working for open source projects. New auto builds aren't done anymore. The base images on dockerhub are not updated regularly. As I still cannot fully understand how to easily transfer the travis-ci workflow to github actions, I cannot provide automated builds. Automating the builds of the images is a key feature for me. But I am simply not able to get that done at the moment. So I declare this project unmaintained because I have no interest anymore to put additional effort into it.

I am still willing to accept pull requests though. However, no ones that do not perform an auto build using actions. If someone is able to fix the ci/cd for me, I am willing to add at least the missing Qt 5 versions.

The recipe to build the images by yourself is well documented in here, so that for any present qt version configured, you simply should be able to get working images by building them the way I do.

Build Status Image Size information Image Layers information Image version information Dockerhub pulls Dockerhub stars

A (nearly) full qt build environment using docker. Using multi-stage build to decouple build from actual image. Can build a qmake project with one single command.

Find the images on Dockerhub. Find the sources on Github

Automated builds will run weekly, thus changes in the underlying base images will reach the registry within that time.

What about Qt 6?

When I started this project in 2018, I had no Idea, that it would be useful for so many of you. The Qt company released Qt 6.0.0 on December 08, 2020. A lot of changes have been introduced in the code base and mainly Qt decided to finally get rid of qmake as build system. Since this is a siginificant change, I do not plan to provide build images for Qt 6 in this very repository. Instead, I am currently working to provide those images via a separate repository, which I do not want to include more clutter than necessary. Qt 6 is the perfect starting point for this. However, since the user base for the images I provide through this very repository has grown in size, I will for sure not abandon this repository and keep maintaining it at least as long as Qt 5 is officially supported. Most probably even longer. Right now, my focus however is to provide good and well usable docker images for Qt 6, which is what currently requires a bit more attention than this Qt 5 based repo. Once I feel ready, I will put a corresponding link here to make readers aware of it.

What is missing

Due to a build time limitation of 3 hours with travis ci, I unfortunately am not able to provide qtwebengine with my builds. Once I either get help with transferring the build pipeline to another platform, where the time limitation is not that strict, or once travis give their VMs more cores for build jobs so that the build fits in 3 hours, I can include qtwebengine in my builds. Until then, you have to build the image locally with the provided script (description below) and adjust the build config if you absolutely need it.

Usage (short)

Download qt-build from dockerhub:

docker pull darkmattercoder/qt-build:latest

Provide your qmake project that you want to build in a separate directory and build it with qt-build:

docker run --rm -u $UID -v /path/to/your/project/directory:/var/build darkmattercoder/qt-build:latest build

You will find your built project in a new sub directory named build in your project directory. You can safely omit the -u $UID part in most environments, where your user has the standard UID=1000.

Usage (detailed)

The latest-tag will give you the latest released qt version for your build environment. For different versions available, refer to the available tags-section.

Generally you will find full version tags like 5.11.3 as well as minor version tags that refer to the last patch release for the given minor release like 5.11 or 5.12. There will be some tags listed that are named like builder-x.y.z, where x,y,z represent qt version numbers. Those images are used for ci builds of the images and contain the whole qt source overhead. They are used as caches in the ci environment. You normally do not want to use them for any production stuff, because they are fairly large.

The build command for docker run will build any qmake project that is mounted to /var/build. However, you can get an interactive session as well for manual adjustments or examinations:

docker run --rm -it -u $UID -v /path/to/your/project/directory:/var/build darkmattercoder/qt-build:latest bash

If you pass additional arguments to build they will be taken into account as arguments to qmake which allows you to modify your build if needed.

Building it yourself

git clone https://github.com/darkmattercoder/qt-build.git
cd qt-build
docker build --build-arg QT_VERSION_MAJOR=X --build-arg QT_VERSION_MINOR=Y --build-arg QT_VERSION_PATCH=Z --build-arg CORE_COUNT=N --target=qt -t qt-build:X.Y.Z

Replace X,Y,Z according to your desired qt version. You have to provide a build configuration as a very simple configure-script in the buildconfig directory to make the build succeed. The script has to be named after your desired QT version, e.g. configure-5.11.3.sh. Example content:

#!/bin/sh
../configure -prefix $QT_PREFIX -opensource -confirm-license -nomake examples -nomake tests

Build arguments

The build arguments can entirely be omitted, resulting in a build with some default values from the Dockerfile. However, I do not promise that those default values for the Qt-Version that are hardcoded in the Dockerfile will get updated on a regular basis, because I inject the desired versions all in my ci build matrix. Available build arguments are:

  • QT_VERSION_MAJOR
  • QT_VERSION_MINOR
  • QT_VERSION_PATCH
  • QT_DOWNLOAD_BRANCH -- gives you the possibility to address different versions for download. Should e.g. read official_releases or archive.
  • QT_TARBALL_NAMING_SCHEME -- gives you the possibility to alter the naming scheme. Qt changed that between 5.9and 5.10 ftom qt-everywhere-opensource-src to qt-everywhere-src. The qt- and -src parts are hardcoded, QT_TARBALL_NAMING_SCHEME is inserted between
  • CI_BUILD -- will suppress regular make output. If set to 2 it will stay silent, if set to 1 (or anything else) only warnings will show up. When the compiling fails, make is run again regularly to give you the whole output, skipping everything that has been built before, to give you the possibility to see the actual behaviour. When left undefined, all output is visible and the second run of make is not performed
  • CORE_COUNT -- determines the number of parallel make jobs. Adjust it to fit your machine

Convenience local build script

In case you want to do a quick, customised build like I do it in the automated build process. Have a look at the self-explanatory script build-dockerfile-local.sh.

Available and maintained tags

All currently supported versions of Qt should be available as tags. I added also versions that have been supported at the time adding them first, but are now archived. I'd like to add other archived versions, too, but I did not yet put any effort into thet. This is no hard work though, so might be a nice first contribution

Some images have been built and are available in the dockerhub registry, but due to missing sources on the qt download servers, they cannot be built automatically anymore and thus, its base layer image is not updated anymore. You should consider that when you want to use them. Find them in the second table below.

Tags Size Layers
imgVerInfo imgVerInfo imgVerInfo imgSizeInfo imgLayerInfo
imgVerInfo imgSizeInfo imgLayerInfo
imgVerInfo imgSizeInfo imgLayerInfo
imgVerInfo imgVerInfo imgSizeInfo imgLayerInfo
imgVerInfo imgSizeInfo imgLayerInfo
imgVerInfo imgSizeInfo imgLayerInfo
imgVerInfo imgVerInfo imgSizeInfo imgLayerInfo
imgVerInfo imgSizeInfo imgLayerInfo
imgVerInfo imgSizeInfo imgLayerInfo
imgVerInfo imgVerInfo imgSizeInfo imgLayerInfo
imgVerInfo imgSizeInfo imgLayerInfo
imgVerInfo imgSizeInfo imgLayerInfo
imgVerInfo imgSizeInfo imgLayerInfo
imgVerInfo imgSizeInfo imgLayerInfo
imgVerInfo imgSizeInfo imgLayerInfo
imgVerInfo imgSizeInfo imgLayerInfo
imgVerInfo imgSizeInfo imgLayerInfo
imgVerInfo imgSizeInfo imgLayerInfo
imgVerInfo imgSizeInfo imgLayerInfo
imgVerInfo imgSizeInfo imgLayerInfo
imgVerInfo imgVerInfo imgSizeInfo imgLayerInfo
imgVerInfo imgSizeInfo imgLayerInfo
imgVerInfo imgSizeInfo imgLayerInfo
imgVerInfo imgSizeInfo imgLayerInfo
imgVerInfo imgSizeInfo imgLayerInfo
imgVerInfo imgSizeInfo imgLayerInfo
imgVerInfo imgSizeInfo imgLayerInfo
imgVerInfo imgSizeInfo imgLayerInfo
imgVerInfo imgSizeInfo imgLayerInfo
imgVerInfo imgSizeInfo imgLayerInfo

Available but unmaintained tags

Tags Size Layers
imgVerInfo imgVerInfo imgSizeInfo imgLayerInfo
imgVerInfo imgSizeInfo imgLayerInfo
imgVerInfo imgSizeInfo imgLayerInfo
imgVerInfo imgSizeInfo imgLayerInfo
imgVerInfo imgVerInfo imgSizeInfo imgLayerInfo
imgVerInfo imgSizeInfo imgLayerInfo
imgVerInfo imgVerInfo imgSizeInfo imgLayerInfo
imgVerInfo imgSizeInfo imgLayerInfo
imgVerInfo imgVerInfo imgSizeInfo imgLayerInfo
imgVerInfo imgSizeInfo imgLayerInfo

Contributions

I highly appreciate any contributions to this project. I will add contribution guidelines later on. As a short summary here is what you could do:

  • Provide new or changed documentation
  • File issues against the project
  • Tinker nice badges to give a visual overview of the docker image structure or the build status for individual tags
  • Open pull requests, for example
    • add new qt version build configurations
    • add more qt features
    • add tests

For opening pull requests, please keep the following in mind:

  • Pull requests for the master branch will be rejected
  • Pull requests must be made for the deploy branch only
  • Pull requests that alter the build configuration or the dependencies in the base image to compile something that did not compile before have to provide a test that represents the changes. The test, when added without changes to build configs or docker file has to fail.
  • Pull requests should be made with the fact in mind, that we want to provide a general multi purpose build environment that should not get bloated more than necessary.

License

Any directly written content in this repo is licensed under the GPL v3. Software parts that are produced during the image build and resulting docker images are of course a composition of components that probably carry their own licenses.

About

a (nearly) full qt build environment as a docker image, small footprint, lots of versions

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Shell 71.3%
  • Dockerfile 14.9%
  • Python 8.9%
  • C++ 2.9%
  • QMake 2.0%