From 8a7245ab7ee8f867f02a3fecdd3222af6087607e Mon Sep 17 00:00:00 2001 From: Daniel Trugman Date: Mon, 19 Sep 2022 00:57:25 +0100 Subject: [PATCH] Add docker images for easier compilation and evaluation Create a number of Docker spec files that allow users to develop, test and evaluate pfs on a range of Linux distros with minimal fuss. --- docker/Dockerfile-redhat | 11 +++++++ docker/Dockerfile-ubuntu | 11 +++++++ docker/docker-pfs | 68 ++++++++++++++++++++++++++++++++++++++++ 3 files changed, 90 insertions(+) create mode 100644 docker/Dockerfile-redhat create mode 100644 docker/Dockerfile-ubuntu create mode 100755 docker/docker-pfs diff --git a/docker/Dockerfile-redhat b/docker/Dockerfile-redhat new file mode 100644 index 0000000..4d4b5be --- /dev/null +++ b/docker/Dockerfile-redhat @@ -0,0 +1,11 @@ +FROM redhat/ubi8:latest + +WORKDIR /pfs + +RUN yum update && \ + yum install -y cmake gcc-c++ + +ENV CXX=g++ +ENV CC=gcc + +CMD /bin/bash diff --git a/docker/Dockerfile-ubuntu b/docker/Dockerfile-ubuntu new file mode 100644 index 0000000..3e58451 --- /dev/null +++ b/docker/Dockerfile-ubuntu @@ -0,0 +1,11 @@ +FROM ubuntu:jammy + +WORKDIR /pfs + +RUN apt-get update && \ + apt-get install -y cmake g++ build-essential + +ENV CXX=g++ +ENV CC=gcc + +CMD /bin/bash diff --git a/docker/docker-pfs b/docker/docker-pfs new file mode 100755 index 0000000..8733dd6 --- /dev/null +++ b/docker/docker-pfs @@ -0,0 +1,68 @@ +#!/bin/bash + +lowercase() { + echo "$1" | tr '[:upper:]' '[:lower:]' +} + +usage() { + echo "$0 [build|run] platform" + echo "" + echo "Build and/or run a docker image that can build pfs." + echo "There is a Dockerfile for each supported platform family." + echo "" + echo " build build docker image for specified platform" + echo " will be tagged as pfs:" + echo "" + echo " run run an already built image for a specified platform" + echo "" + + return 2 +} + +build() { + declare -r platform="$(lowercase "$1")" + + declare -r tag="$project:$platform" + + declare -r file="Dockerfile-$platform" + if [[ ! -f "$file" ]]; then + echo "Platform probably not supported, cannot find $file" + return 1 + fi + + docker build \ + --tag "$tag" \ + --file "$file" \ + "$root" +} + +run() { + declare -r platform="$(lowercase "$1")" + + declare -r tag="$project:$platform" + + docker run --rm --interactive --tty \ + --volume "$root:/$project" \ + "$tag" +} + +main() { + if [[ $# -ne 2 ]]; then + usage + return $? + fi + + declare -r action="$1" + declare -r platform="$2" + + declare -r project="pfs" + declare -r root="$(git rev-parse --show-toplevel)" + + case "$action" in + build) build "$platform";; + run) run "$platform";; + *) usage; return $?;; + esac +} + +main "$@"