From 36afce97523566cd84ec64b74ceedcae9732d723 Mon Sep 17 00:00:00 2001 From: Gonzalo Matheu Date: Wed, 27 May 2020 19:33:10 -0300 Subject: [PATCH 1/2] Adding Python 3.8 dockerfile --- Dockerfile-py3.8-win64 | 84 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 84 insertions(+) create mode 100644 Dockerfile-py3.8-win64 diff --git a/Dockerfile-py3.8-win64 b/Dockerfile-py3.8-win64 new file mode 100644 index 0000000..6ff7421 --- /dev/null +++ b/Dockerfile-py3.8-win64 @@ -0,0 +1,84 @@ +FROM ubuntu:16.04 + +ENV DEBIAN_FRONTEND noninteractive + +ARG WINE_VERSION=winehq-staging +ARG PYTHON_VERSION=3.8.3 +ARG PYINSTALLER_VERSION=3.6 + +# we need wine for this all to work, so we'll use the PPA +RUN set -x \ + && dpkg --add-architecture i386 \ + && apt-get update -qy \ + && apt-get install --no-install-recommends -qfy apt-transport-https software-properties-common wget \ + && wget -nv https://dl.winehq.org/wine-builds/winehq.key \ + && apt-key add winehq.key \ + && add-apt-repository 'https://dl.winehq.org/wine-builds/ubuntu/' \ + && apt-get update -qy \ + && apt-get install --no-install-recommends -qfy $WINE_VERSION winbind cabextract \ + && apt-get clean \ + && wget -nv https://raw.githubusercontent.com/Winetricks/winetricks/master/src/winetricks \ + && chmod +x winetricks \ + && mv winetricks /usr/local/bin + +# wine settings +ENV WINEARCH win64 +ENV WINEDEBUG fixme-all +ENV WINEPREFIX /wine + +# PYPI repository location +ENV PYPI_URL=https://pypi.python.org/ +# PYPI index location +ENV PYPI_INDEX_URL=https://pypi.python.org/simple + +# install python in wine, using the msi packages to install, extracting +# the files directly, since installing isn't running correctly. +RUN set -x \ + && winetricks win7 \ + && for msifile in `echo core dev exe lib path pip tcltk tools`; do \ + wget -nv "https://www.python.org/ftp/python/$PYTHON_VERSION/amd64/${msifile}.msi"; \ + wine msiexec /i "${msifile}.msi" /qb TARGETDIR=C:/Python38; \ + rm ${msifile}.msi; \ + done \ + && cd /wine/drive_c/Python38 \ + && echo 'wine '\''C:\Python38\python.exe'\'' "$@"' > /usr/bin/python \ + && echo 'wine '\''C:\Python38\Scripts\easy_install.exe'\'' "$@"' > /usr/bin/easy_install \ + && echo 'wine '\''C:\Python38\Scripts\pip.exe'\'' "$@"' > /usr/bin/pip \ + && echo 'wine '\''C:\Python38\Scripts\pyinstaller.exe'\'' "$@"' > /usr/bin/pyinstaller \ + && echo 'wine '\''C:\Python38\Scripts\pyupdater.exe'\'' "$@"' > /usr/bin/pyupdater \ + && echo 'assoc .py=PythonScript' | wine cmd \ + && echo 'ftype PythonScript=c:\Python37\python.exe "%1" %*' | wine cmd \ + && while pgrep wineserver >/dev/null; do echo "Waiting for wineserver"; sleep 1; done \ + && chmod +x /usr/bin/python /usr/bin/easy_install /usr/bin/pip /usr/bin/pyinstaller /usr/bin/pyupdater \ + && (pip install -U pip || true) \ + && rm -rf /tmp/.wine-* + +ENV W_DRIVE_C=/wine/drive_c +ENV W_WINDIR_UNIX="$W_DRIVE_C/windows" +ENV W_SYSTEM64_DLLS="$W_WINDIR_UNIX/system32" +ENV W_TMP="$W_DRIVE_C/windows/temp/_$0" + +# install Microsoft Visual C++ Redistributable for Visual Studio 2017 dll files +RUN set -x \ + && rm -f "$W_TMP"/* \ + && wget -P "$W_TMP" https://download.visualstudio.microsoft.com/download/pr/11100230/15ccb3f02745c7b206ad10373cbca89b/VC_redist.x64.exe \ + && cabextract -q --directory="$W_TMP" "$W_TMP"/VC_redist.x64.exe \ + && cabextract -q --directory="$W_TMP" "$W_TMP/a10" \ + && cabextract -q --directory="$W_TMP" "$W_TMP/a11" \ + && cd "$W_TMP" \ + && rename 's/_/\-/g' *.dll \ + && cp "$W_TMP"/*.dll "$W_SYSTEM64_DLLS"/ + +# install pyinstaller +RUN /usr/bin/pip install pyinstaller==$PYINSTALLER_VERSION + +# put the src folder inside wine +RUN mkdir /src/ && ln -s /src /wine/drive_c/src +VOLUME /src/ +WORKDIR /wine/drive_c/src/ +RUN mkdir -p /wine/drive_c/tmp + +COPY entrypoint-windows.sh /entrypoint.sh +RUN chmod +x /entrypoint.sh + +ENTRYPOINT ["/entrypoint.sh"] From 7c6df497741133c4e43906b0790be783a9030a53 Mon Sep 17 00:00:00 2001 From: Gonzalo Matheu Date: Tue, 1 Sep 2020 14:24:54 -0300 Subject: [PATCH 2/2] Upgrading to python 3.8.5 and pyinstaller 4.0.0 --- Dockerfile-py3.8-win64 | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/Dockerfile-py3.8-win64 b/Dockerfile-py3.8-win64 index 6ff7421..ef32924 100644 --- a/Dockerfile-py3.8-win64 +++ b/Dockerfile-py3.8-win64 @@ -3,8 +3,8 @@ FROM ubuntu:16.04 ENV DEBIAN_FRONTEND noninteractive ARG WINE_VERSION=winehq-staging -ARG PYTHON_VERSION=3.8.3 -ARG PYINSTALLER_VERSION=3.6 +ARG PYTHON_VERSION=3.8.5 +ARG PYINSTALLER_VERSION=4.0 # we need wine for this all to work, so we'll use the PPA RUN set -x \