From d53f33041334a1dfa015fa9a5ba3121fd70e8d9a Mon Sep 17 00:00:00 2001 From: Yury Shvedov Date: Sun, 11 Feb 2024 15:11:59 +0300 Subject: [PATCH] Add option to disable patches Additionally try to fix bash regex issues. Change-Id: I529ae66c323ba1ee489f8cca5af96cc9ffc61cbc --- repack.sh | 34 +++++++++++++++++++++------------- 1 file changed, 21 insertions(+), 13 deletions(-) diff --git a/repack.sh b/repack.sh index ff8c9c7..f30f912 100755 --- a/repack.sh +++ b/repack.sh @@ -8,16 +8,19 @@ usage() { echo " Options:" echo " -o DIR Path to destination folder" echo " -x Extract and fix only to destination folder" + echo " -p Do not apply patches" echo " -h Show this help and exit" } exe_location= dst="$PWD/app" SCRIPT_DIR=$( cd -- "$( dirname -- "${BASH_SOURCE[0]}" )" &> /dev/null && pwd ) -while getopts :xo:h name; do +nopatch=0 +while getopts :xo:ph name; do case $name in x) extract_only=1 ;; o) dst="$OPTARG" ;; + p) nopatch=1 ;; h) usage exit 0 @@ -81,19 +84,25 @@ done echo "Title Fixed" # applying patches + +# This function accepts patch file. If it names starts with `XXXX-optional`, +# then this function check is there the variable with tail name of patch and +# prefix patch_ defined to 1 and apply conditionally the patch. So, if the passed +# file has name `0003-optional-some-magic-feature.patch` the function will apply +# it only when the variable `patch_some_magic_feature` defined to `1`. apply_patch() { - local patchfile patchname + local patchfile patchname re patchfile="$(realpath "$1")" patchname="$(basename "$patchfile")" patchname="${patchname,,}" - - if [[ $patchname =~ [[:digit:]]+\-optional\-(.+).patch ]]; then + re='[[:digit:]]+\-optional\-(.+).patch ]]' + if [[ $patchname =~ $re ]]; then patchname="${BASH_REMATCH[1]}" patchname="${patchname//[- ]/_}" if eval [ \"\$"patch_$patchname"\" != 1 ]; then - echo "Shipping patch '$patchfile'" + echo "Skipping patch '$patchfile'" return 0 fi fi @@ -101,20 +110,19 @@ apply_patch() (cd "$TEMPDIR/app" && patch -p1 < "$patchfile") } -for f in $(eval echo "$SCRIPT_DIR"/patches/*); do - apply_patch "$f" -done +if [ "$nopatch" != "1" ]; then + for f in $(eval echo "$SCRIPT_DIR"/patches/*.patch); do + apply_patch "$f" + done +fi + +mkdir -p "$dst" if [ -n "$extract_only" ]; then - mkdir -p "$dst" eval cp -r "$TEMPDIR/app/*" "$dst" exit 0 fi - - -mkdir -p "$dst" - echo "Packing" cd "$curdir" asar pack "$TEMPDIR/app" "$dst/yandexmusic.asar"