Merge pull request #11214 from hyuraku/utils_repair_style
Utils repair style
This commit is contained in:
		
						commit
						5d67709cb6
					
				@ -1,43 +1,46 @@
 | 
			
		||||
# Migrate analytics UUID to its new home in Homebrew repo's git config and
 | 
			
		||||
# remove the legacy UUID file if detected.
 | 
			
		||||
# HOMEBREW_LINUX, HOMEBREW_REPOSITORY is set by bin/brew
 | 
			
		||||
# HOMEBREW_NO_ANALYTICS is from the user environment.
 | 
			
		||||
# shellcheck disable=SC2154
 | 
			
		||||
migrate-legacy-uuid-file() {
 | 
			
		||||
  local legacy_uuid_file analytics_uuid
 | 
			
		||||
 | 
			
		||||
  legacy_uuid_file="$HOME/.homebrew_analytics_user_uuid"
 | 
			
		||||
  legacy_uuid_file="${HOME}/.homebrew_analytics_user_uuid"
 | 
			
		||||
 | 
			
		||||
  if [[ -f "$legacy_uuid_file" ]]
 | 
			
		||||
  if [[ -f "${legacy_uuid_file}" ]]
 | 
			
		||||
  then
 | 
			
		||||
    analytics_uuid="$(<"$legacy_uuid_file")"
 | 
			
		||||
    if [[ -n "$analytics_uuid" ]]
 | 
			
		||||
    analytics_uuid="$(<"${legacy_uuid_file}")"
 | 
			
		||||
    if [[ -n "${analytics_uuid}" ]]
 | 
			
		||||
    then
 | 
			
		||||
      git config --file="$HOMEBREW_REPOSITORY/.git/config" --replace-all homebrew.analyticsuuid "$analytics_uuid" 2>/dev/null
 | 
			
		||||
      git config --file="${HOMEBREW_REPOSITORY}/.git/config" --replace-all homebrew.analyticsuuid "${analytics_uuid}" 2>/dev/null
 | 
			
		||||
    fi
 | 
			
		||||
    rm -f "$legacy_uuid_file"
 | 
			
		||||
    rm -f "${legacy_uuid_file}"
 | 
			
		||||
  fi
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
setup-analytics() {
 | 
			
		||||
  local git_config_file="$HOMEBREW_REPOSITORY/.git/config"
 | 
			
		||||
  local git_config_file="${HOMEBREW_REPOSITORY}/.git/config"
 | 
			
		||||
 | 
			
		||||
  migrate-legacy-uuid-file
 | 
			
		||||
 | 
			
		||||
  if [[ -n "$HOMEBREW_NO_ANALYTICS" ]]
 | 
			
		||||
  if [[ -n "${HOMEBREW_NO_ANALYTICS}" ]]
 | 
			
		||||
  then
 | 
			
		||||
    return
 | 
			
		||||
  fi
 | 
			
		||||
 | 
			
		||||
  local message_seen analytics_disabled
 | 
			
		||||
  message_seen="$(git config --file="$git_config_file" --get homebrew.analyticsmessage 2>/dev/null)"
 | 
			
		||||
  analytics_disabled="$(git config --file="$git_config_file" --get homebrew.analyticsdisabled 2>/dev/null)"
 | 
			
		||||
  if [[ "$message_seen" != "true" || "$analytics_disabled" = "true" ]]
 | 
			
		||||
  message_seen="$(git config --file="${git_config_file}" --get homebrew.analyticsmessage 2>/dev/null)"
 | 
			
		||||
  analytics_disabled="$(git config --file="${git_config_file}" --get homebrew.analyticsdisabled 2>/dev/null)"
 | 
			
		||||
  if [[ "${message_seen}" != "true" || "${analytics_disabled}" = "true" ]]
 | 
			
		||||
  then
 | 
			
		||||
    # Internal variable for brew's use, to differentiate from user-supplied setting
 | 
			
		||||
    export HOMEBREW_NO_ANALYTICS_THIS_RUN="1"
 | 
			
		||||
    return
 | 
			
		||||
  fi
 | 
			
		||||
 | 
			
		||||
  HOMEBREW_ANALYTICS_USER_UUID="$(git config --file="$git_config_file" --get homebrew.analyticsuuid 2>/dev/null)"
 | 
			
		||||
  if [[ -z "$HOMEBREW_ANALYTICS_USER_UUID" ]]
 | 
			
		||||
  HOMEBREW_ANALYTICS_USER_UUID="$(git config --file="${git_config_file}" --get homebrew.analyticsuuid 2>/dev/null)"
 | 
			
		||||
  if [[ -z "${HOMEBREW_ANALYTICS_USER_UUID}" ]]
 | 
			
		||||
  then
 | 
			
		||||
    if [[ -x /usr/bin/uuidgen ]]
 | 
			
		||||
    then
 | 
			
		||||
@ -49,16 +52,16 @@ setup-analytics() {
 | 
			
		||||
      HOMEBREW_ANALYTICS_USER_UUID="$(uuidgen)"
 | 
			
		||||
    fi
 | 
			
		||||
 | 
			
		||||
    if [[ -z "$HOMEBREW_ANALYTICS_USER_UUID" ]]
 | 
			
		||||
    if [[ -z "${HOMEBREW_ANALYTICS_USER_UUID}" ]]
 | 
			
		||||
    then
 | 
			
		||||
      # Avoid sending bogus analytics if no UUID could be generated.
 | 
			
		||||
      export HOMEBREW_NO_ANALYTICS_THIS_RUN="1"
 | 
			
		||||
      return
 | 
			
		||||
    fi
 | 
			
		||||
    git config --file="$git_config_file" --replace-all homebrew.analyticsuuid "$HOMEBREW_ANALYTICS_USER_UUID" 2>/dev/null
 | 
			
		||||
    git config --file="${git_config_file}" --replace-all homebrew.analyticsuuid "${HOMEBREW_ANALYTICS_USER_UUID}" 2>/dev/null
 | 
			
		||||
  fi
 | 
			
		||||
 | 
			
		||||
  if [[ -n "$HOMEBREW_LINUX" ]]
 | 
			
		||||
  if [[ -n "${HOMEBREW_LINUX}" ]]
 | 
			
		||||
  then
 | 
			
		||||
    # For Homebrew on Linux's analytics.
 | 
			
		||||
    HOMEBREW_ANALYTICS_ID="UA-76492262-1"
 | 
			
		||||
 | 
			
		||||
@ -1,17 +1,19 @@
 | 
			
		||||
# create a lock using `flock(2)`. A name is required as first argument.
 | 
			
		||||
# the lock will be automatically unlocked when the shell process quits.
 | 
			
		||||
# Noted due to the fixed FD, a shell process can only create one lock.
 | 
			
		||||
# HOMEBREW_PREFIX is set by extend/ENV/super.rb
 | 
			
		||||
# shellcheck disable=SC2154
 | 
			
		||||
lock() {
 | 
			
		||||
  local name="$1"
 | 
			
		||||
  local lock_dir="$HOMEBREW_PREFIX/var/homebrew/locks"
 | 
			
		||||
  local lock_file="$lock_dir/$name"
 | 
			
		||||
  [[ -d "$lock_dir" ]] || mkdir -p "$lock_dir"
 | 
			
		||||
  if ! [[ -w "$lock_dir" ]]
 | 
			
		||||
  local lock_dir="${HOMEBREW_PREFIX}/var/homebrew/locks"
 | 
			
		||||
  local lock_file="${lock_dir}/${name}"
 | 
			
		||||
  [[ -d "${lock_dir}" ]] || mkdir -p "${lock_dir}"
 | 
			
		||||
  if ! [[ -w "${lock_dir}" ]]
 | 
			
		||||
  then
 | 
			
		||||
    odie <<EOS
 | 
			
		||||
Can't create $name lock in $lock_dir!
 | 
			
		||||
Can't create ${name} lock in ${lock_dir}!
 | 
			
		||||
Fix permissions by running:
 | 
			
		||||
  sudo chown -R \$(whoami) $HOMEBREW_PREFIX/var/homebrew
 | 
			
		||||
  sudo chown -R \$(whoami) ${HOMEBREW_PREFIX}/var/homebrew
 | 
			
		||||
EOS
 | 
			
		||||
  fi
 | 
			
		||||
  # 200 is the file descriptor used in the lock.
 | 
			
		||||
@ -24,11 +26,11 @@ EOS
 | 
			
		||||
  # close FD first, this is required if parent process holds a different lock.
 | 
			
		||||
  exec 200>&-
 | 
			
		||||
  # open the lock file to FD, so the shell process can hold the lock.
 | 
			
		||||
  exec 200>"$lock_file"
 | 
			
		||||
  if ! _create_lock 200 "$name"
 | 
			
		||||
  exec 200>"${lock_file}"
 | 
			
		||||
  if ! _create_lock 200 "${name}"
 | 
			
		||||
  then
 | 
			
		||||
    odie <<EOS
 | 
			
		||||
Another active Homebrew $name process is already in progress.
 | 
			
		||||
Another active Homebrew ${name} process is already in progress.
 | 
			
		||||
Please wait for it to finish or terminate it to continue.
 | 
			
		||||
EOS
 | 
			
		||||
  fi
 | 
			
		||||
@ -39,19 +41,19 @@ _create_lock() {
 | 
			
		||||
  local name="$2"
 | 
			
		||||
  local ruby="/usr/bin/ruby"
 | 
			
		||||
  local python="/usr/bin/python"
 | 
			
		||||
  [[ -x "$ruby" ]] || ruby="$(type -P ruby)"
 | 
			
		||||
  [[ -x "$python" ]] || python="$(type -P python)"
 | 
			
		||||
  [[ -x "${ruby}" ]] || ruby="$(type -P ruby)"
 | 
			
		||||
  [[ -x "${python}" ]] || python="$(type -P python)"
 | 
			
		||||
 | 
			
		||||
  if [[ -x "$ruby" ]] && "$ruby" -e "exit(RUBY_VERSION >= '1.8.7')"
 | 
			
		||||
  if [[ -x "${ruby}" ]] && "${ruby}" -e "exit(RUBY_VERSION >= '1.8.7')"
 | 
			
		||||
  then
 | 
			
		||||
    "$ruby" -e "File.new($lock_fd).flock(File::LOCK_EX | File::LOCK_NB) || exit(1)"
 | 
			
		||||
  elif [[ -x "$python" ]]
 | 
			
		||||
    "${ruby}" -e "File.new(${lock_fd}).flock(File::LOCK_EX | File::LOCK_NB) || exit(1)"
 | 
			
		||||
  elif [[ -x "${python}" ]]
 | 
			
		||||
  then
 | 
			
		||||
    "$python" -c "import fcntl; fcntl.flock($lock_fd, fcntl.LOCK_EX | fcntl.LOCK_NB)"
 | 
			
		||||
    "${python}" -c "import fcntl; fcntl.flock(${lock_fd}, fcntl.LOCK_EX | fcntl.LOCK_NB)"
 | 
			
		||||
  elif [[ -x "$(type -P flock)" ]]
 | 
			
		||||
  then
 | 
			
		||||
    flock -n "$lock_fd"
 | 
			
		||||
    flock -n "${lock_fd}"
 | 
			
		||||
  else
 | 
			
		||||
    onoe "Cannot create $name lock, please avoid running Homebrew in parallel."
 | 
			
		||||
    onoe "Cannot create ${name} lock, please avoid running Homebrew in parallel."
 | 
			
		||||
  fi
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
@ -1,5 +1,7 @@
 | 
			
		||||
export HOMEBREW_REQUIRED_RUBY_VERSION=2.6.3
 | 
			
		||||
 | 
			
		||||
# HOMEBREW_LIBRARY is from the user environment
 | 
			
		||||
# shellcheck disable=SC2154
 | 
			
		||||
test_ruby() {
 | 
			
		||||
  if [[ ! -x $1 ]]
 | 
			
		||||
  then
 | 
			
		||||
@ -7,20 +9,23 @@ test_ruby() {
 | 
			
		||||
  fi
 | 
			
		||||
 | 
			
		||||
  "$1" --enable-frozen-string-literal --disable=gems,did_you_mean,rubyopt \
 | 
			
		||||
    "$HOMEBREW_LIBRARY/Homebrew/utils/ruby_check_version_script.rb" \
 | 
			
		||||
    "$HOMEBREW_REQUIRED_RUBY_VERSION" 2>/dev/null
 | 
			
		||||
    "${HOMEBREW_LIBRARY}/Homebrew/utils/ruby_check_version_script.rb" \
 | 
			
		||||
    "${HOMEBREW_REQUIRED_RUBY_VERSION}" 2>/dev/null
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
# HOMEBREW_MACOS is set by brew.sh
 | 
			
		||||
# HOMEBREW_PATH is set by global.rb
 | 
			
		||||
# shellcheck disable=SC2154
 | 
			
		||||
find_ruby() {
 | 
			
		||||
  if [[ -n "$HOMEBREW_MACOS" ]]
 | 
			
		||||
  if [[ -n "${HOMEBREW_MACOS}" ]]
 | 
			
		||||
  then
 | 
			
		||||
    echo "/System/Library/Frameworks/Ruby.framework/Versions/Current/usr/bin/ruby"
 | 
			
		||||
  else
 | 
			
		||||
    IFS=$'\n' # Do word splitting on new lines only
 | 
			
		||||
    for ruby_exec in $(which -a ruby 2>/dev/null) $(PATH=$HOMEBREW_PATH which -a ruby 2>/dev/null)
 | 
			
		||||
    for ruby_exec in $(command -v -a ruby 2>/dev/null) $(PATH=${HOMEBREW_PATH} command -v -a ruby 2>/dev/null)
 | 
			
		||||
    do
 | 
			
		||||
      if test_ruby "$ruby_exec"; then
 | 
			
		||||
        echo "$ruby_exec"
 | 
			
		||||
      if test_ruby "${ruby_exec}"; then
 | 
			
		||||
        echo "${ruby_exec}"
 | 
			
		||||
        break
 | 
			
		||||
      fi
 | 
			
		||||
    done
 | 
			
		||||
@ -28,14 +33,17 @@ find_ruby() {
 | 
			
		||||
  fi
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
# HOMEBREW_FORCE_VENDOR_RUBY is from the user environment
 | 
			
		||||
# HOMEBREW_MACOS_SYSTEM_RUBY_NEW_ENOUGH are set by brew.sh
 | 
			
		||||
# shellcheck disable=SC2154
 | 
			
		||||
need_vendored_ruby() {
 | 
			
		||||
  if [[ -n "$HOMEBREW_FORCE_VENDOR_RUBY" ]]
 | 
			
		||||
  if [[ -n "${HOMEBREW_FORCE_VENDOR_RUBY}" ]]
 | 
			
		||||
  then
 | 
			
		||||
    return 0
 | 
			
		||||
  elif [[ -n "$HOMEBREW_MACOS_SYSTEM_RUBY_NEW_ENOUGH" ]]
 | 
			
		||||
  elif [[ -n "${HOMEBREW_MACOS_SYSTEM_RUBY_NEW_ENOUGH}" ]]
 | 
			
		||||
  then
 | 
			
		||||
    return 1
 | 
			
		||||
  elif [[ -z "$HOMEBREW_MACOS" ]] && test_ruby "$HOMEBREW_RUBY_PATH"
 | 
			
		||||
  elif [[ -z "${HOMEBREW_MACOS}" ]] && test_ruby "${HOMEBREW_RUBY_PATH}"
 | 
			
		||||
  then
 | 
			
		||||
    return 1
 | 
			
		||||
  else
 | 
			
		||||
@ -43,6 +51,8 @@ need_vendored_ruby() {
 | 
			
		||||
  fi
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
# HOMEBREW_LINUX is set by brew.sh
 | 
			
		||||
# shellcheck disable=SC2154
 | 
			
		||||
setup-ruby-path() {
 | 
			
		||||
  local vendor_dir
 | 
			
		||||
  local vendor_ruby_root
 | 
			
		||||
@ -56,53 +66,53 @@ setup-ruby-path() {
 | 
			
		||||
  local upgrade_fail
 | 
			
		||||
  local install_fail
 | 
			
		||||
 | 
			
		||||
  if [[ -n $HOMEBREW_MACOS ]]
 | 
			
		||||
  if [[ -n ${HOMEBREW_MACOS} ]]
 | 
			
		||||
  then
 | 
			
		||||
    upgrade_fail="Failed to upgrade Homebrew Portable Ruby!"
 | 
			
		||||
    install_fail="Failed to install Homebrew Portable Ruby (and your system version is too old)!"
 | 
			
		||||
  else
 | 
			
		||||
    local advice="
 | 
			
		||||
If there's no Homebrew Portable Ruby available for your processor:
 | 
			
		||||
- install Ruby $HOMEBREW_REQUIRED_RUBY_VERSION with your system package manager (or rbenv/ruby-build)
 | 
			
		||||
- install Ruby ${HOMEBREW_REQUIRED_RUBY_VERSION} with your system package manager (or rbenv/ruby-build)
 | 
			
		||||
- make it first in your PATH
 | 
			
		||||
- try again
 | 
			
		||||
"
 | 
			
		||||
    upgrade_fail="Failed to upgrade Homebrew Portable Ruby!$advice"
 | 
			
		||||
    install_fail="Failed to install Homebrew Portable Ruby and cannot find another Ruby $HOMEBREW_REQUIRED_RUBY_VERSION!$advice"
 | 
			
		||||
    upgrade_fail="Failed to upgrade Homebrew Portable Ruby!${advice}"
 | 
			
		||||
    install_fail="Failed to install Homebrew Portable Ruby and cannot find another Ruby ${HOMEBREW_REQUIRED_RUBY_VERSION}!${advice}"
 | 
			
		||||
  fi
 | 
			
		||||
 | 
			
		||||
  vendor_dir="$HOMEBREW_LIBRARY/Homebrew/vendor"
 | 
			
		||||
  vendor_ruby_root="$vendor_dir/portable-ruby/current"
 | 
			
		||||
  vendor_ruby_path="$vendor_ruby_root/bin/ruby"
 | 
			
		||||
  vendor_ruby_terminfo="$vendor_ruby_root/share/terminfo"
 | 
			
		||||
  vendor_ruby_latest_version=$(<"$vendor_dir/portable-ruby-version")
 | 
			
		||||
  vendor_ruby_current_version=$(readlink "$vendor_ruby_root")
 | 
			
		||||
  vendor_dir="${HOMEBREW_LIBRARY}/Homebrew/vendor"
 | 
			
		||||
  vendor_ruby_root="${vendor_dir}/portable-ruby/current"
 | 
			
		||||
  vendor_ruby_path="${vendor_ruby_root}/bin/ruby"
 | 
			
		||||
  vendor_ruby_terminfo="${vendor_ruby_root}/share/terminfo"
 | 
			
		||||
  vendor_ruby_latest_version=$(<"${vendor_dir}/portable-ruby-version")
 | 
			
		||||
  vendor_ruby_current_version=$(readlink "${vendor_ruby_root}")
 | 
			
		||||
 | 
			
		||||
  unset HOMEBREW_RUBY_PATH
 | 
			
		||||
 | 
			
		||||
  if [[ "$HOMEBREW_COMMAND" == "vendor-install" ]]
 | 
			
		||||
  if [[ "${HOMEBREW_COMMAND}" == "vendor-install" ]]
 | 
			
		||||
  then
 | 
			
		||||
    return 0
 | 
			
		||||
  fi
 | 
			
		||||
 | 
			
		||||
  if [[ -x "$vendor_ruby_path" ]]
 | 
			
		||||
  if [[ -x "${vendor_ruby_path}" ]]
 | 
			
		||||
  then
 | 
			
		||||
    HOMEBREW_RUBY_PATH="$vendor_ruby_path"
 | 
			
		||||
    TERMINFO_DIRS="$vendor_ruby_terminfo"
 | 
			
		||||
    if [[ $vendor_ruby_current_version != "$vendor_ruby_latest_version" ]]
 | 
			
		||||
    HOMEBREW_RUBY_PATH="${vendor_ruby_path}"
 | 
			
		||||
    TERMINFO_DIRS="${vendor_ruby_terminfo}"
 | 
			
		||||
    if [[ ${vendor_ruby_current_version} != "${vendor_ruby_latest_version}" ]]
 | 
			
		||||
    then
 | 
			
		||||
      brew vendor-install ruby || odie "$upgrade_fail"
 | 
			
		||||
      brew vendor-install ruby || odie "${upgrade_fail}"
 | 
			
		||||
    fi
 | 
			
		||||
  else
 | 
			
		||||
    HOMEBREW_RUBY_PATH=$(find_ruby)
 | 
			
		||||
    if need_vendored_ruby
 | 
			
		||||
    then
 | 
			
		||||
      brew vendor-install ruby || odie "$install_fail"
 | 
			
		||||
      HOMEBREW_RUBY_PATH="$vendor_ruby_path"
 | 
			
		||||
      TERMINFO_DIRS="$vendor_ruby_terminfo"
 | 
			
		||||
      brew vendor-install ruby || odie "${install_fail}"
 | 
			
		||||
      HOMEBREW_RUBY_PATH="${vendor_ruby_path}"
 | 
			
		||||
      TERMINFO_DIRS="${vendor_ruby_terminfo}"
 | 
			
		||||
    fi
 | 
			
		||||
  fi
 | 
			
		||||
 | 
			
		||||
  export HOMEBREW_RUBY_PATH
 | 
			
		||||
  [[ -n "$HOMEBREW_LINUX" && -n "$TERMINFO_DIRS" ]] && export TERMINFO_DIRS
 | 
			
		||||
  [[ -n "${HOMEBREW_LINUX}" && -n "${TERMINFO_DIRS}" ]] && export TERMINFO_DIRS
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user