From dded25f39874223b0d5d6c94ca9824542f4f4584 Mon Sep 17 00:00:00 2001 From: SomberNight Date: Sun, 7 Mar 2021 22:12:26 +0100 Subject: [PATCH] windows build: cache pip downloads --- contrib/build-linux/appimage/build.sh | 14 +++++++------- contrib/build-wine/build-electrum-git.sh | 11 ++++++++--- contrib/build-wine/build.sh | 3 ++- contrib/build-wine/prepare-wine.sh | 6 ++---- 4 files changed, 19 insertions(+), 15 deletions(-) diff --git a/contrib/build-linux/appimage/build.sh b/contrib/build-linux/appimage/build.sh index 86d90d563..c54b08c7e 100755 --- a/contrib/build-linux/appimage/build.sh +++ b/contrib/build-linux/appimage/build.sh @@ -9,6 +9,7 @@ DISTDIR="$PROJECT_ROOT/dist" BUILDDIR="$CONTRIB_APPIMAGE/build/appimage" APPDIR="$BUILDDIR/electrum.AppDir" CACHEDIR="$CONTRIB_APPIMAGE/.cache/appimage" +PIP_CACHE_DIR="$CACHEDIR/pip_cache" export GCC_STRIP_BINARIES="1" @@ -26,7 +27,7 @@ APPIMAGE="$DISTDIR/electrum-$VERSION-x86_64.AppImage" . "$CONTRIB"/build_tools_util.sh rm -rf "$BUILDDIR" -mkdir -p "$APPDIR" "$CACHEDIR" "$DISTDIR" +mkdir -p "$APPDIR" "$CACHEDIR" "$PIP_CACHE_DIR" "$DISTDIR" # potential leftover from setuptools that might make pip put garbage in binary rm -rf "$PROJECT_ROOT/build" @@ -118,9 +119,8 @@ info "preparing electrum-locale." info "Installing build dependencies." -mkdir -p "$CACHEDIR/pip_cache" "$python" -m pip install --no-dependencies --no-binary :all: --no-warn-script-location \ - --cache-dir "$CACHEDIR/pip_cache" -r "$CONTRIB/deterministic-build/requirements-build-appimage.txt" + --cache-dir "$PIP_CACHE_DIR" -r "$CONTRIB/deterministic-build/requirements-build-appimage.txt" info "installing electrum and its dependencies." # note: we prefer compiling C extensions ourselves, instead of using binary wheels, @@ -128,14 +128,14 @@ info "installing electrum and its dependencies." # - PyQt5, as it's harder to build from source # - cryptography, as building it would need openssl 1.1, not available on ubuntu 16.04 "$python" -m pip install --no-dependencies --no-binary :all: --no-warn-script-location \ - --cache-dir "$CACHEDIR/pip_cache" -r "$CONTRIB/deterministic-build/requirements.txt" + --cache-dir "$PIP_CACHE_DIR" -r "$CONTRIB/deterministic-build/requirements.txt" "$python" -m pip install --no-dependencies --no-binary :all: --only-binary pyqt5,cryptography --no-warn-script-location \ - --cache-dir "$CACHEDIR/pip_cache" -r "$CONTRIB/deterministic-build/requirements-binaries.txt" + --cache-dir "$PIP_CACHE_DIR" -r "$CONTRIB/deterministic-build/requirements-binaries.txt" "$python" -m pip install --no-dependencies --no-binary :all: --no-warn-script-location \ - --cache-dir "$CACHEDIR/pip_cache" -r "$CONTRIB/deterministic-build/requirements-hw.txt" + --cache-dir "$PIP_CACHE_DIR" -r "$CONTRIB/deterministic-build/requirements-hw.txt" "$python" -m pip install --no-dependencies --no-warn-script-location \ - --cache-dir "$CACHEDIR/pip_cache" "$PROJECT_ROOT" + --cache-dir "$PIP_CACHE_DIR" "$PROJECT_ROOT" # was only needed during build time, not runtime "$python" -m pip uninstall -y Cython diff --git a/contrib/build-wine/build-electrum-git.sh b/contrib/build-wine/build-electrum-git.sh index 54175c7f8..be2067661 100755 --- a/contrib/build-wine/build-electrum-git.sh +++ b/contrib/build-wine/build-electrum-git.sh @@ -7,7 +7,7 @@ export WINEPREFIX=/opt/wine64 export WINEDEBUG=-all export PYTHONDONTWRITEBYTECODE=1 -PYHOME=c:/python3 +PYHOME="c:/python3" PYTHON="wine $PYHOME/python.exe -OO -B" @@ -42,9 +42,14 @@ popd # Install frozen dependencies -$PYTHON -m pip install --no-dependencies --no-warn-script-location -r "$CONTRIB"/deterministic-build/requirements.txt +$PYTHON -m pip install --no-dependencies --no-warn-script-location \ + --cache-dir "$WINE_PIP_CACHE_DIR" -r "$CONTRIB"/deterministic-build/requirements.txt -$PYTHON -m pip install --no-dependencies --no-warn-script-location -r "$CONTRIB"/deterministic-build/requirements-hw.txt +$PYTHON -m pip install --no-dependencies --no-warn-script-location \ + --cache-dir "$WINE_PIP_CACHE_DIR" -r "$CONTRIB"/deterministic-build/requirements-binaries.txt + +$PYTHON -m pip install --no-dependencies --no-warn-script-location \ + --cache-dir "$WINE_PIP_CACHE_DIR" -r "$CONTRIB"/deterministic-build/requirements-hw.txt pushd $WINEPREFIX/drive_c/electrum # see https://github.com/pypa/pip/issues/2195 -- pip makes a copy of the entire directory diff --git a/contrib/build-wine/build.sh b/contrib/build-wine/build.sh index f8dc7d573..710319d3d 100755 --- a/contrib/build-wine/build.sh +++ b/contrib/build-wine/build.sh @@ -24,7 +24,8 @@ export GCC_STRIP_BINARIES="1" export CONTRIB="$here/.." export PROJECT_ROOT="$CONTRIB/.." export CACHEDIR="$here/.cache/$WIN_ARCH" -export PIP_CACHE_DIR="$CACHEDIR/pip_cache" +export PIP_CACHE_DIR="$CACHEDIR/wine_pip_cache" +export WINE_PIP_CACHE_DIR="c:/electrum/contrib/build-wine/.cache/$WIN_ARCH/wine_pip_cache" export DLL_TARGET_DIR="$CACHEDIR/dlls" . "$CONTRIB"/build_tools_util.sh diff --git a/contrib/build-wine/prepare-wine.sh b/contrib/build-wine/prepare-wine.sh index 5991b75c0..5f7fc5d10 100755 --- a/contrib/build-wine/prepare-wine.sh +++ b/contrib/build-wine/prepare-wine.sh @@ -63,10 +63,8 @@ done break_legacy_easy_install info "Installing build dependencies." -$PYTHON -m pip install --no-dependencies --no-warn-script-location -r "$CONTRIB"/deterministic-build/requirements-build-wine.txt - -info "Installing dependencies specific to binaries." -$PYTHON -m pip install --no-dependencies --no-warn-script-location -r "$CONTRIB"/deterministic-build/requirements-binaries.txt +$PYTHON -m pip install --no-dependencies --no-warn-script-location \ + --cache-dir "$WINE_PIP_CACHE_DIR" -r "$CONTRIB"/deterministic-build/requirements-build-wine.txt info "Installing NSIS." download_if_not_exist "$CACHEDIR/$NSIS_FILENAME" "$NSIS_URL"