mirror of
https://gitee.com/ineo6/homebrew-install.git
synced 2025-04-06 03:58:05 +08:00
feat: update scripts
This commit is contained in:
parent
213082e79e
commit
775dcd6727
110
install.sh
110
install.sh
@ -45,6 +45,7 @@ if [[ -z "${HOMEBREW_ON_LINUX-}" ]]; then
|
|||||||
HOMEBREW_CORE_DEFAULT_GIT_REMOTE="https://mirrors.ustc.edu.cn/homebrew-core.git"
|
HOMEBREW_CORE_DEFAULT_GIT_REMOTE="https://mirrors.ustc.edu.cn/homebrew-core.git"
|
||||||
|
|
||||||
STAT="stat -f"
|
STAT="stat -f"
|
||||||
|
PERMISSION_FORMAT="%A"
|
||||||
CHOWN="/usr/sbin/chown"
|
CHOWN="/usr/sbin/chown"
|
||||||
CHGRP="/usr/bin/chgrp"
|
CHGRP="/usr/bin/chgrp"
|
||||||
GROUP="admin"
|
GROUP="admin"
|
||||||
@ -61,6 +62,7 @@ else
|
|||||||
HOMEBREW_CORE_DEFAULT_GIT_REMOTE="https://mirrors.ustc.edu.cn/linuxbrew-core.git"
|
HOMEBREW_CORE_DEFAULT_GIT_REMOTE="https://mirrors.ustc.edu.cn/linuxbrew-core.git"
|
||||||
|
|
||||||
STAT="stat --printf"
|
STAT="stat --printf"
|
||||||
|
PERMISSION_FORMAT="%a"
|
||||||
CHOWN="/bin/chown"
|
CHOWN="/bin/chown"
|
||||||
CHGRP="/bin/chgrp"
|
CHGRP="/bin/chgrp"
|
||||||
GROUP="$(id -gn)"
|
GROUP="$(id -gn)"
|
||||||
@ -90,6 +92,8 @@ MACOS_OLDEST_SUPPORTED="10.14"
|
|||||||
# For Homebrew on Linux
|
# For Homebrew on Linux
|
||||||
REQUIRED_RUBY_VERSION=2.6 # https://github.com/Homebrew/brew/pull/6556
|
REQUIRED_RUBY_VERSION=2.6 # https://github.com/Homebrew/brew/pull/6556
|
||||||
REQUIRED_GLIBC_VERSION=2.13 # https://docs.brew.sh/Homebrew-on-Linux#requirements
|
REQUIRED_GLIBC_VERSION=2.13 # https://docs.brew.sh/Homebrew-on-Linux#requirements
|
||||||
|
REQUIRED_CURL_VERSION=7.41.0 # HOMEBREW_MINIMUM_CURL_VERSION in brew.sh in Homebrew/brew
|
||||||
|
REQUIRED_GIT_VERSION=2.7.0 # HOMEBREW_MINIMUM_GIT_VERSION in brew.sh in Homebrew/brew
|
||||||
|
|
||||||
# no analytics during installation
|
# no analytics during installation
|
||||||
export HOMEBREW_NO_ANALYTICS_THIS_RUN=1
|
export HOMEBREW_NO_ANALYTICS_THIS_RUN=1
|
||||||
@ -109,6 +113,10 @@ tty_bold="$(tty_mkbold 39)"
|
|||||||
tty_reset="$(tty_escape 0)"
|
tty_reset="$(tty_escape 0)"
|
||||||
|
|
||||||
have_sudo_access() {
|
have_sudo_access() {
|
||||||
|
if [[ ! -x "/usr/bin/sudo" ]]; then
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
local -a args
|
local -a args
|
||||||
if [[ -n "${SUDO_ASKPASS-}" ]]; then
|
if [[ -n "${SUDO_ASKPASS-}" ]]; then
|
||||||
args=("-A")
|
args=("-A")
|
||||||
@ -233,11 +241,11 @@ should_install_command_line_tools() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
get_permission() {
|
get_permission() {
|
||||||
$STAT "%A" "$1"
|
$STAT "${PERMISSION_FORMAT}" "$1"
|
||||||
}
|
}
|
||||||
|
|
||||||
user_only_chmod() {
|
user_only_chmod() {
|
||||||
[[ -d "$1" ]] && [[ "$(get_permission "$1")" != "755" ]]
|
[[ -d "$1" ]] && [[ "$(get_permission "$1")" != 75[0145] ]]
|
||||||
}
|
}
|
||||||
|
|
||||||
exists_but_not_writable() {
|
exists_but_not_writable() {
|
||||||
@ -257,7 +265,7 @@ get_group() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
file_not_grpowned() {
|
file_not_grpowned() {
|
||||||
[[ " $(id -G "$USER") " != *" $(get_group "$1") "* ]]
|
[[ " $(id -G "$USER") " != *" $(get_group "$1") "* ]]
|
||||||
}
|
}
|
||||||
|
|
||||||
# Please sync with 'test_ruby()' in 'Library/Homebrew/utils/ruby.sh' from Homebrew/brew repository.
|
# Please sync with 'test_ruby()' in 'Library/Homebrew/utils/ruby.sh' from Homebrew/brew repository.
|
||||||
@ -272,17 +280,46 @@ test_ruby() {
|
|||||||
Gem::Version.new('$REQUIRED_RUBY_VERSION').to_s.split('.').first(2)" 2>/dev/null
|
Gem::Version.new('$REQUIRED_RUBY_VERSION').to_s.split('.').first(2)" 2>/dev/null
|
||||||
}
|
}
|
||||||
|
|
||||||
no_usable_ruby() {
|
test_curl() {
|
||||||
local ruby_exec
|
if [[ ! -x $1 ]]; then
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
local curl_version_output curl_name_and_version
|
||||||
|
curl_version_output=$("$1" --version 2>/dev/null)
|
||||||
|
curl_name_and_version="${curl_version_output%% (*}"
|
||||||
|
version_ge "$(major_minor "${curl_name_and_version##* }")" "$(major_minor "$REQUIRED_CURL_VERSION")"
|
||||||
|
}
|
||||||
|
|
||||||
|
test_git() {
|
||||||
|
if [[ ! -x $1 ]]; then
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
local git_version_output
|
||||||
|
git_version_output=$("$1" --version 2>/dev/null)
|
||||||
|
version_ge "$(major_minor "${git_version_output##* }")" "$(major_minor "$REQUIRED_GIT_VERSION")"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Search PATH for the specified program that satisfies Homebrew requirements
|
||||||
|
find_tool() {
|
||||||
|
if [[ $# -ne 1 ]]; then
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
local executable
|
||||||
IFS=$'\n' # Do word splitting on new lines only
|
IFS=$'\n' # Do word splitting on new lines only
|
||||||
for ruby_exec in $(which -a ruby 2>/dev/null); do
|
for executable in $(which -a "$1" 2>/dev/null); do
|
||||||
if test_ruby "$ruby_exec"; then
|
if "test_$1" "$executable"; then
|
||||||
IFS=$' \t\n' # Restore IFS to its default value
|
echo "$executable"
|
||||||
return 1
|
break
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
IFS=$' \t\n' # Restore IFS to its default value
|
IFS=$' \t\n' # Restore IFS to its default value
|
||||||
return 0
|
}
|
||||||
|
|
||||||
|
no_usable_ruby() {
|
||||||
|
[[ -z $(find_tool ruby) ]]
|
||||||
}
|
}
|
||||||
|
|
||||||
outdated_glibc() {
|
outdated_glibc() {
|
||||||
@ -310,7 +347,7 @@ if [[ -z "${USER-}" ]]; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
# Invalidate sudo timestamp before exiting (if it wasn't active before).
|
# Invalidate sudo timestamp before exiting (if it wasn't active before).
|
||||||
if ! /usr/bin/sudo -n -v 2>/dev/null; then
|
if [[ -x /usr/bin/sudo ]] && ! /usr/bin/sudo -n -v 2>/dev/null; then
|
||||||
trap '/usr/bin/sudo -k' EXIT
|
trap '/usr/bin/sudo -k' EXIT
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@ -325,6 +362,18 @@ You must install Git before installing Homebrew. See:
|
|||||||
${tty_underline}https://docs.brew.sh/Installation${tty_reset}
|
${tty_underline}https://docs.brew.sh/Installation${tty_reset}
|
||||||
EOABORT
|
EOABORT
|
||||||
)"
|
)"
|
||||||
|
elif [[ -n "${HOMEBREW_ON_LINUX-}" ]]; then
|
||||||
|
USABLE_GIT=$(find_tool git)
|
||||||
|
if [[ -z "$USABLE_GIT" ]]; then
|
||||||
|
abort "$(cat <<-EOABORT
|
||||||
|
Git that is available on your system does not satisfy Homebrew requirements.
|
||||||
|
Please install Git $REQUIRED_GIT_VERSION or newer and add it to your PATH.
|
||||||
|
EOABORT
|
||||||
|
)"
|
||||||
|
elif [[ "$USABLE_GIT" != /usr/bin/git ]]; then
|
||||||
|
export HOMEBREW_GIT_PATH=$USABLE_GIT
|
||||||
|
ohai "Found Git: $HOMEBREW_GIT_PATH"
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if ! command -v curl >/dev/null; then
|
if ! command -v curl >/dev/null; then
|
||||||
@ -333,6 +382,25 @@ You must install cURL before installing Homebrew. See:
|
|||||||
${tty_underline}https://docs.brew.sh/Installation${tty_reset}
|
${tty_underline}https://docs.brew.sh/Installation${tty_reset}
|
||||||
EOABORT
|
EOABORT
|
||||||
)"
|
)"
|
||||||
|
elif [[ -n "${HOMEBREW_ON_LINUX-}" ]]; then
|
||||||
|
USABLE_CURL=$(find_tool curl)
|
||||||
|
if [[ -z "$USABLE_CURL" ]]; then
|
||||||
|
abort "$(cat <<-EOABORT
|
||||||
|
cURL that is available on your system does not satisfy Homebrew requirements.
|
||||||
|
Please install cURL $REQUIRED_CURL_VERSION or newer and add it to your PATH.
|
||||||
|
EOABORT
|
||||||
|
)"
|
||||||
|
elif [[ "$USABLE_CURL" != /usr/bin/curl ]]; then
|
||||||
|
export HOMEBREW_CURL_PATH=$USABLE_CURL
|
||||||
|
ohai "Found cURL: $HOMEBREW_CURL_PATH"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Set HOMEBREW_DEVELOPER on Linux systems where usable Git/cURL is not in /usr/bin
|
||||||
|
if [[ "${HOMEBREW_ON_LINUX-}" && ( -n "${HOMEBREW_CURL_PATH-}" || -n "${HOMEBREW_GIT_PATH-}" ) ]]
|
||||||
|
then
|
||||||
|
ohai "Setting HOMEBREW_DEVELOPER to use Git/cURL not in /usr/bin"
|
||||||
|
export HOMEBREW_DEVELOPER=1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# shellcheck disable=SC2016
|
# shellcheck disable=SC2016
|
||||||
@ -481,9 +549,12 @@ for dir in "${directories[@]}"; do
|
|||||||
done
|
done
|
||||||
|
|
||||||
user_chmods=()
|
user_chmods=()
|
||||||
|
mkdirs_user_only=()
|
||||||
if [[ "${#zsh_dirs[@]}" -gt 0 ]]; then
|
if [[ "${#zsh_dirs[@]}" -gt 0 ]]; then
|
||||||
for dir in "${zsh_dirs[@]}"; do
|
for dir in "${zsh_dirs[@]}"; do
|
||||||
if user_only_chmod "${dir}"; then
|
if [[ ! -d "${dir}" ]]; then
|
||||||
|
mkdirs_user_only+=("${dir}")
|
||||||
|
elif user_only_chmod "${dir}"; then
|
||||||
user_chmods+=("${dir}")
|
user_chmods+=("${dir}")
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
@ -598,7 +669,7 @@ if [[ -d "${HOMEBREW_PREFIX}" ]]; then
|
|||||||
execute_sudo "/bin/chmod" "g+rwx" "${group_chmods[@]}"
|
execute_sudo "/bin/chmod" "g+rwx" "${group_chmods[@]}"
|
||||||
fi
|
fi
|
||||||
if [[ "${#user_chmods[@]}" -gt 0 ]]; then
|
if [[ "${#user_chmods[@]}" -gt 0 ]]; then
|
||||||
execute_sudo "/bin/chmod" "755" "${user_chmods[@]}"
|
execute_sudo "/bin/chmod" "g-w,o-w" "${user_chmods[@]}"
|
||||||
fi
|
fi
|
||||||
if [[ "${#chowns[@]}" -gt 0 ]]; then
|
if [[ "${#chowns[@]}" -gt 0 ]]; then
|
||||||
execute_sudo "$CHOWN" "$USER" "${chowns[@]}"
|
execute_sudo "$CHOWN" "$USER" "${chowns[@]}"
|
||||||
@ -617,7 +688,10 @@ fi
|
|||||||
|
|
||||||
if [[ "${#mkdirs[@]}" -gt 0 ]]; then
|
if [[ "${#mkdirs[@]}" -gt 0 ]]; then
|
||||||
execute_sudo "/bin/mkdir" "-p" "${mkdirs[@]}"
|
execute_sudo "/bin/mkdir" "-p" "${mkdirs[@]}"
|
||||||
execute_sudo "/bin/chmod" "g+rwx" "${mkdirs[@]}"
|
execute_sudo "/bin/chmod" "u=rwx,g=rwx" "${mkdirs[@]}"
|
||||||
|
if [[ "${#mkdirs_user_only[@]}" -gt 0 ]]; then
|
||||||
|
execute_sudo "/bin/chmod" "g-w,o-w" "${mkdirs_user_only[@]}"
|
||||||
|
fi
|
||||||
execute_sudo "$CHOWN" "$USER" "${mkdirs[@]}"
|
execute_sudo "$CHOWN" "$USER" "${mkdirs[@]}"
|
||||||
execute_sudo "$CHGRP" "$GROUP" "${mkdirs[@]}"
|
execute_sudo "$CHGRP" "$GROUP" "${mkdirs[@]}"
|
||||||
fi
|
fi
|
||||||
@ -708,7 +782,11 @@ ohai "Downloading and installing Homebrew..."
|
|||||||
execute "git" "reset" "--hard" "origin/master"
|
execute "git" "reset" "--hard" "origin/master"
|
||||||
|
|
||||||
if [[ "${HOMEBREW_REPOSITORY}" != "${HOMEBREW_PREFIX}" ]]; then
|
if [[ "${HOMEBREW_REPOSITORY}" != "${HOMEBREW_PREFIX}" ]]; then
|
||||||
execute "ln" "-sf" "${HOMEBREW_REPOSITORY}/bin/brew" "${HOMEBREW_PREFIX}/bin/brew"
|
if [[ "${HOMEBREW_REPOSITORY}" == "${HOMEBREW_PREFIX}/Homebrew" ]]; then
|
||||||
|
execute "ln" "-sf" "../Homebrew/bin/brew" "${HOMEBREW_PREFIX}/bin/brew"
|
||||||
|
else
|
||||||
|
abort "The Homebrew/brew repository should be placed in the Homebrew prefix directory."
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ ! -d "${HOMEBREW_CORE}" ]]; then
|
if [[ ! -d "${HOMEBREW_CORE}" ]]; then
|
||||||
@ -797,7 +875,7 @@ if [[ -n "${non_default_repos}" ]]; then
|
|||||||
if [[ "${#additional_shellenv_commands[@]}" -gt 1 ]]; then
|
if [[ "${#additional_shellenv_commands[@]}" -gt 1 ]]; then
|
||||||
s="s"
|
s="s"
|
||||||
fi
|
fi
|
||||||
echo "- Add the non-default Git remote${s} for ${non_default_repos} in ${tty_underline}${shell_profile}${tty_reset}:"
|
echo "- Run these commands in your terminal to add the non-default Git remote${s} for ${non_default_repos}:"
|
||||||
printf " echo '%s' >> ${shell_profile}\n" "${additional_shellenv_commands[@]}"
|
printf " echo '%s' >> ${shell_profile}\n" "${additional_shellenv_commands[@]}"
|
||||||
printf " %s\n" "${additional_shellenv_commands[@]}"
|
printf " %s\n" "${additional_shellenv_commands[@]}"
|
||||||
fi
|
fi
|
||||||
|
@ -169,7 +169,7 @@ usage() {
|
|||||||
cat <<EOS
|
cat <<EOS
|
||||||
Homebrew Uninstaller
|
Homebrew Uninstaller
|
||||||
Usage: $0 [options]
|
Usage: $0 [options]
|
||||||
-p, --path=PATH Sets Homebrew prefix. Defaults to /usr/local.
|
-p, --path=PATH Sets Homebrew prefix. Defaults to ${homebrew_prefix_default}.
|
||||||
--skip-cache-and-logs
|
--skip-cache-and-logs
|
||||||
Skips removal of HOMEBREW_CACHE and HOMEBREW_LOGS.
|
Skips removal of HOMEBREW_CACHE and HOMEBREW_LOGS.
|
||||||
-f, --force Uninstall without prompting.
|
-f, --force Uninstall without prompting.
|
||||||
|
Loading…
x
Reference in New Issue
Block a user