File: Dockerfile

package info (click to toggle)
cmake 4.2.3-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 152,456 kB
  • sloc: ansic: 403,896; cpp: 303,920; sh: 4,105; python: 3,583; yacc: 3,106; lex: 1,279; f90: 538; asm: 471; lisp: 375; cs: 270; java: 266; fortran: 239; objc: 215; perl: 213; xml: 198; makefile: 111; javascript: 83; pascal: 63; tcl: 55; php: 25; ruby: 22
file content (53 lines) | stat: -rw-r--r-- 2,442 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
# syntax=docker/dockerfile:1

ARG BASE_IMAGE=debian:12

FROM ${BASE_IMAGE} AS apt-cache
# Populate APT cache w/ the fresh metadata and prefetch packages.
# Use an empty `docker-clean` file to "hide" the image-provided
# file to disallow removing packages after `apt-get` operations.
RUN --mount=type=tmpfs,target=/var/log \
    --mount=type=bind,source=docker-clean,target=/etc/apt/apt.conf.d/docker-clean \
    --mount=type=bind,source=base.lst,target=/root/base.lst \
    --mount=type=bind,source=openssl.lst,target=/root/openssl.lst \
    apt-get update \
 && apt-get --download-only -y install $(grep -h '^[^#]\+$' /root/*.lst)

FROM ${BASE_IMAGE} AS base
ARG ARCH=sparc64
RUN --mount=type=bind,source=base.lst,target=/root/base.lst \
    --mount=type=bind,source=docker-clean,target=/etc/apt/apt.conf.d/docker-clean \
    --mount=type=cache,from=apt-cache,source=/var/lib/apt/lists,target=/var/lib/apt/lists \
    --mount=type=cache,from=apt-cache,source=/var/cache/apt,target=/var/cache/apt,sharing=private \
    --mount=type=tmpfs,target=/var/log \
    --mount=type=tmpfs,target=/tmp \
    apt-get install -y $(grep '^[^#]\+$' /root/base.lst)
RUN --mount=type=bind,source=base.bash,target=/root/base.bash \
    --mount=type=tmpfs,target=/tmp \
    /root/base.bash $ARCH

FROM base AS sysroot
ARG SYSROOT_URL
ARG SYSROOT_SHA256SUM
RUN --mount=type=bind,source=sysroot.bash,target=/root/sysroot.bash \
    --mount=type=tmpfs,target=/tmp \
    /root/sysroot.bash $ARCH

FROM sysroot AS openssl
RUN --mount=type=bind,source=openssl.lst,target=/root/openssl.lst \
    --mount=type=bind,source=docker-clean,target=/etc/apt/apt.conf.d/docker-clean \
    --mount=type=cache,from=apt-cache,source=/var/lib/apt/lists,target=/var/lib/apt/lists \
    --mount=type=cache,from=apt-cache,source=/var/cache/apt,target=/var/cache/apt,sharing=private \
    --mount=type=tmpfs,target=/var/log \
    --mount=type=tmpfs,target=/tmp \
    apt-get install -y $(grep '^[^#]\+$' /root/openssl.lst)
RUN --mount=type=bind,source=openssl.bash,target=/root/openssl.bash \
    --mount=type=bind,source=openssl.patch,target=/root/openssl.patch \
    --mount=type=bind,from=sysroot,source=/opt/cross/sysroot,target=/opt/cross/sysroot \
    --mount=type=tmpfs,target=/tmp \
    /root/openssl.bash $ARCH

FROM base
LABEL maintainer="Brad King <brad.king@kitware.com>"
RUN --mount=type=bind,from=openssl,source=/root,target=/root \
    tar xzf /root/openssl.tar.gz -C /