Merge branch 'master' into clifford/ids
[yosys.git] / Dockerfile
index 3a4358335c59e19f8bd04bf25a0f375c8552924b..549c73c97123252bd4ac5c69563865334fc59792 100644 (file)
@@ -1,47 +1,57 @@
-FROM ubuntu:16.04 as builder
-LABEL author="Abdelrahman Hosny <abdelrahman.hosny@hotmail.com>"
+ARG IMAGE="python:3-slim-buster"
 
-RUN apt-get update && apt-get install -y build-essential \
+#---
+
+FROM $IMAGE AS base
+
+RUN apt-get update -qq \
+ && DEBIAN_FRONTEND=noninteractive apt-get -y install --no-install-recommends \
+    ca-certificates \
     clang \
-    bison \
-    flex \
+    curl \
+    libffi-dev \
     libreadline-dev \
-    gawk \
     tcl-dev \
-    libffi-dev \
-    git \
     graphviz \
     xdot \
-    pkg-config \
-    python3
+ && apt-get autoclean && apt-get clean && apt-get -y autoremove \
+ && update-ca-certificates \
+ && rm -rf /var/lib/apt/lists
 
-COPY . /
-RUN make && \
-    make install
+#---
 
+FROM base AS build
 
-FROM ubuntu:16.04
-RUN apt-get update && apt-get install -y clang \
+RUN apt-get update -qq \
+ && DEBIAN_FRONTEND=noninteractive apt-get -y install --no-install-recommends \
     bison \
     flex \
-    libreadline-dev \
     gawk \
-    tcl-dev \
-    libffi-dev \
+    gcc \
     git \
-    graphviz \
-    xdot \
+    iverilog \
     pkg-config \
-    python3
-COPY --from=builder /yosys /build/yosys
-COPY --from=builder /yosys-abc /build/yosys-abc
-COPY --from=builder /yosys-config /build/yosys-config
-COPY --from=builder /yosys-filterlib /build/yosys-filterlib
-COPY --from=builder /yosys-smtbmc /build/yosys-smtbmc
+ && apt-get autoclean && apt-get clean && apt-get -y autoremove \
+ && rm -rf /var/lib/apt/lists
+
+COPY . /yosys
+
+ENV PREFIX /opt/yosys
+
+RUN cd /yosys \
+ && make \
+ && make install \
+ && make test
+
+#---
+
+FROM base
+
+COPY --from=build /opt/yosys /opt/yosys
 
-ENV PATH /build:$PATH
+ENV PATH /opt/yosys/bin:$PATH
 
-RUN mkdir /data
-WORKDIR /data
+RUN useradd -m yosys
+USER yosys
 
-ENTRYPOINT ["yosys"]
+CMD ["yosys"]