From 0bea6c990d048a4567c9b39e328fabe99c84bb71 Mon Sep 17 00:00:00 2001 From: DeeDeeG Date: Sat, 21 Sep 2019 13:37:59 -0400 Subject: [PATCH] bin/nvh: Add "forced on" state for xz Skips node version checks, which would otherwise gate xz usage. In other words: Overrides any checks that would normally be run, so that nvh always attempts to use xz. --- Also updates "--use-xz" to not set the "xz forced on" state. (This matches the flag's description in the help messages.) --- Partly adapted from this comment (with liberties taken on implementation): https://github.com/shadowspawn/nvh/issues/8#issuecomment-533034644 Co-authored-by: John Gee --- bin/nvh | 16 +++++++++++----- 1 file changed, 11 insertions(+), 5 deletions(-) diff --git a/bin/nvh b/bin/nvh index 033f88f..98db794 100755 --- a/bin/nvh +++ b/bin/nvh @@ -22,12 +22,16 @@ NVH_NODE_DOWNLOAD_MIRROR=${NVH_NODE_DOWNLOAD_MIRROR:-https://nodejs.org/download NVH_NODE_DOWNLOAD_MIRROR=${NVH_NODE_DOWNLOAD_MIRROR%/} readonly NVH_NODE_DOWNLOAD_MIRROR -# Enabled by default. User may set NVH_USE_XZ to 0 to disable. -# Normalise to true/false. +# Using xz instead of gzip is enabled by default, if xz compatibility checks pass. +# User may set NVH_USE_XZ to 0 to disable, or set to anything else to force-enable. # May be overridden by command line flags. +g_xz_force_enabled="false" if [[ "${NVH_USE_XZ}" = "0" ]]; then NVH_USE_XZ="false" +elif [[ -n "${NVH_USE_XZ+defined}" ]]; then + NVH_USE_XZ="true" + g_xz_force_enabled="true" else NVH_USE_XZ="true" fi @@ -686,12 +690,14 @@ function install() { fi fi - [[ "${NVH_USE_XZ}" = "true" ]] && can_use_xz || NVH_USE_XZ="false" + if [[ "${NVH_USE_XZ}" = true ]] && [[ "S{g_xz_force_enabled}" = "false" ]]; then + can_use_xz || NVH_USE_XZ="false" + fi echo install_log "installing" "${g_mirror_folder_name}/${resolved_version}" - if [[ "${NVH_USE_XZ}" = "true" ]]; then + if [[ "${NVH_USE_XZ}" = "true" ]] && [[ "${g_xz_force_enabled}" = "false" ]]; then local resolved_major_version resolved_major_version="$(echo ${resolved_version#v} | cut -d '.' -f '1')" if [[ "${resolved_major_version}" -lt 4 ]]; then @@ -1193,7 +1199,7 @@ function main() { --insecure) set_insecure ;; -p|--preserve) NVH_PRESERVE_NPM="true" ;; --no-preserve) NVH_PRESERVE_NPM="" ;; - --use-xz) NVH_USE_XZ="true" ;; + --use-xz) NVH_USE_XZ="true"; g_xz_force_enabled="false" ;; --no-use-xz) NVH_USE_XZ="false" ;; -V|--version) echo "${VERSION}"; exit ;; -*) abort "unrecognised option '$1'"; exit 1 ;;