You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
40 lines
1.6 KiB
40 lines
1.6 KiB
#===- llvm/utils/docker/example/build/Dockerfile -------------------------===//
|
|
#
|
|
# Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
# See https://llvm.org/LICENSE.txt for license information.
|
|
# SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
#
|
|
#===----------------------------------------------------------------------===//
|
|
# This is an example Dockerfile to build an image that compiles clang.
|
|
# Replace FIXMEs to prepare your own image.
|
|
|
|
# Stage 1. Check out LLVM source code and run the build.
|
|
# FIXME: Replace 'ubuntu' with your base image
|
|
FROM ubuntu as builder
|
|
# FIXME: Change maintainer name
|
|
LABEL maintainer "Maintainer <maintainer@email>"
|
|
# FIXME: Install llvm/clang build dependencies here. Including compiler to
|
|
# build stage1, cmake, subversion, ninja, etc.
|
|
|
|
ADD checksums /tmp/checksums
|
|
ADD scripts /tmp/scripts
|
|
|
|
# Checkout the source code.
|
|
ARG checkout_args
|
|
RUN /tmp/scripts/checkout.sh ${checkout_args}
|
|
# Run the build. Results of the build will be available at /tmp/clang-install/.
|
|
ARG buildscript_args
|
|
RUN /tmp/scripts/build_install_llvm.sh --to /tmp/clang-install ${buildscript_args}
|
|
|
|
|
|
# Stage 2. Produce a minimal release image with build results.
|
|
# FIXME: Replace 'ubuntu' with your base image.
|
|
FROM ubuntu
|
|
# FIXME: Change maintainer name.
|
|
LABEL maintainer "Maintainer <maintainer@email>"
|
|
# FIXME: Install all packages you want to have in your release container.
|
|
# A minimal useful installation should include at least libstdc++ and binutils.
|
|
|
|
# Copy build results of stage 1 to /usr/local.
|
|
COPY --from=builder /tmp/clang-install/ /usr/local/
|