Skip to content

Latest commit

 

History

History
71 lines (53 loc) · 4.26 KB

README.md

File metadata and controls

71 lines (53 loc) · 4.26 KB

Docker containers for CI/CD of C/C++ projects

Adapted from embedded-guidelines.

This repository contains Dockerfiles that can build common CI/CD utilities for C/C++ projects. The utilities are divided in 2 categories:

Note: If no version is given for an utility/SW, it means the latest version is retrieved from the package manager or github.

Directories and files

<This repository >/
├───Common/                 - Common Docker files to build the images
│   ├───Compilers.dock      - Dockerfile to install the embedded compilers
│   ├───StaticAnalysis.dock - Dockerfile to install the static analysis tools
├───Embedded/               - Dockerfile to build the Embedded Image
└───README.md               - this file    

By looking at the repository you will notice that there are Dockerfiles with .dock extension. The reason is two-fold:

  1. Not all of the tools are always required to be installed for a specific environment. For example if your project is desktop based, you wouldnt need the embedded compilers. This allows to only select the tools that you need to use.
  2. Better organization. Its easier to organize how the Docker images are built if they are organized based on their purpose.

By default Docker does not have a syntax to include other Dockerfiles. For this reason to include these files you can either manually copy their contents to the Dockerfile you want to build or like in this repository, use the Dockerfile-plus syntax extension. This extension allows to easily include other dockerfiles to your main Dockerfile (see directory Embedded and ROS for examples).To use this extension you need to add the following env. variables before building with docker:

  • DOCKER_BUILDKIT=1
  • COMPOSE_DOCKER_CLI_BUILD=1

How To Use

As mentioned in the last section, the dockerfiles for the installation of the tools are located in the Common directory. If you need to use any of the tools for a specific project you can manually copy the contents or use the Dockerfile-plus to include them.

This repository builds automatically the following images based on the docker files in the Common directory.

  • Embedded: Image for embedded projects that includes all of the .dock files located in the Common dir. The image is hosted in this gitlab repository under the following url:

    registry.git.fh-aachen.de/embeddedtools/embedded-tools-image:core
    

    The image can also be built from Docker as follows:

    export DOCKER_BUILDKIT=1
    export COMPOSE_DOCKER_CLI_BUILD=1
    docker build -f Embedded/Dockerfile -t embedded-tools-image:core .