-
Notifications
You must be signed in to change notification settings - Fork 805
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge remote-tracking branch 'origin/master' into ghc-9.2
- Loading branch information
Showing
3 changed files
with
649 additions
and
607 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -4,7 +4,7 @@ on: | |
push: | ||
branches: | ||
- nightly | ||
- lts18 | ||
- lts19 | ||
|
||
jobs: | ||
push: | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,90 @@ | ||
FROM ubuntu:18.04 | ||
|
||
LABEL maintainer="[email protected]" | ||
|
||
ARG GHC_VERSION=9.0.2 | ||
ARG LTS_SLUG=lts-19.0 | ||
ARG PID1_VERSION=0.1.2.0 | ||
ARG STACK_VERSION=2.7.3 | ||
ARG CUDA_VERSION=10.0 | ||
ARG JVM_PATH=/usr/lib/jvm/java-8-openjdk-amd64 | ||
ARG LLVM_PATH=/usr/lib/llvm-9 | ||
ARG BOOTSTRAP_COMMIT=70317ea1c42e6caae625059980575157cf9525ed | ||
|
||
ARG DEBIAN_FRONTEND=noninteractive | ||
ARG VARIANT=build | ||
ARG STACK_ROOT=/home/stackage/.stack | ||
|
||
# | ||
# Set encoding to UTF-8 and PATH to find GHC and cabal/stack-installed binaries. | ||
# | ||
|
||
ENV LANG=C.UTF-8 \ | ||
LC_ALL=C.UTF-8 \ | ||
PATH=/root/.local/bin:/usr/local/cuda-$CUDA_VERSION/bin:$STACK_ROOT/programs/x86_64-linux/ghc-$GHC_VERSION/bin:$PATH \ | ||
CUDA_PATH=/usr/local/cuda-$CUDA_VERSION \ | ||
CPATH=$JVM_PATH/include:$JVM_PATH/include/linux:$LLVM_PATH/include | ||
|
||
# | ||
# Install pre-requisites | ||
# | ||
|
||
RUN apt-get update && \ | ||
apt-get install -y --no-install-recommends \ | ||
wget netbase ca-certificates g++ gcc libc6-dev libffi-dev libgmp-dev \ | ||
make xz-utils zlib1g-dev git gnupg libtinfo-dev jq && \ | ||
rm -rf /var/lib/apt/lists/* | ||
|
||
# | ||
# Use Stackage's debian-bootstrap.sh script to install system libraries and | ||
# tools required to build any Stackage package. | ||
# Re-installs 'stack' *after* running debian-bootstrap.sh since that may have | ||
# installed a different version. | ||
# In the case of 'small' image, just install Stack and GHC. | ||
# | ||
|
||
RUN if [ "$VARIANT" != "small" ]; then \ | ||
wget -qO- https://raw.githubusercontent.com/fpco/stackage/$BOOTSTRAP_COMMIT/debian-bootstrap.sh | sed "s/^GHCVER=9.0.1$/GHCVER=$GHC_VERSION/" | GHCVER=$GHC_VERSION bash; \ | ||
fi && \ | ||
wget -qO- https://github.com/commercialhaskell/stack/releases/download/v$STACK_VERSION/stack-$STACK_VERSION-linux-x86_64.tar.gz | tar xz --wildcards --strip-components=1 -C /usr/bin '*/stack' && \ | ||
if [ "$VARIANT" = "small" ]; then \ | ||
stack setup --resolver ghc-$GHC_VERSION; \ | ||
fi && \ | ||
rm -rf /var/lib/apt/lists/* && \ | ||
cd $STACK_ROOT && \ | ||
find . -type f -not -path "./programs/x86_64-linux/ghc-$GHC_VERSION/*" -exec rm '{}' \; && \ | ||
find . -type d -print0 |sort -rz |xargs -0 rmdir 2>/dev/null || true | ||
|
||
# | ||
# Configure Stack to use the GHC installed in the Docker image rather than installing its own | ||
# | ||
|
||
RUN mkdir /etc/stack/ && \ | ||
echo "system-ghc: true" >/etc/stack/config.yaml | ||
|
||
# | ||
# Use 'stack' to install basic Haskell tools like alex, happy, and cpphs. We | ||
# remove most of the STACK_ROOT afterward to save space, but keep the 'share' | ||
# files that some of these tools require. | ||
# | ||
|
||
RUN stack --resolver=$LTS_SLUG --local-bin-path=/usr/bin install \ | ||
happy alex cpphs gtk2hs-buildtools hscolour hlint hindent && \ | ||
cd $STACK_ROOT && \ | ||
find . -type f -not -path './snapshots/*/share/*' -and -not -path "./programs/x86_64-linux/ghc-$GHC_VERSION/*" -exec rm '{}' \; && \ | ||
find . -type d -print0 |sort -rz |xargs -0 rmdir 2>/dev/null || true | ||
|
||
# | ||
# Install 'pid1' init daemon | ||
# | ||
|
||
RUN wget -O- "https://github.com/fpco/pid1/releases/download/v$PID1_VERSION/pid1-$PID1_VERSION-linux-x86_64.tar.gz" | tar xzf - -C /usr/local && \ | ||
chown root:root /usr/local/sbin && \ | ||
chown root:root /usr/local/sbin/pid1 | ||
|
||
# | ||
# Set up pid1 entrypoint and default command | ||
# | ||
|
||
ENTRYPOINT ["/usr/local/sbin/pid1"] | ||
CMD ["bash"] |
Oops, something went wrong.