utils/git: various improvement
* Use `ENV/scm/git` to check whether git is installed. * Use `brew install git` to enforce pre-install checks such as sudo check.
This commit is contained in:
parent
8ca79a6df5
commit
e0e277ecde
@ -1,27 +1,20 @@
|
||||
module Utils
|
||||
def self.git_available?
|
||||
return @git if instance_variable_defined?(:@git)
|
||||
# check git in original path in case it's the wrapper script of Library/ENV/scm
|
||||
git = which("git", ORIGINAL_PATHS.join(File::PATH_SEPARATOR))
|
||||
# git isn't installed by older Xcodes
|
||||
return @git = false if git.nil?
|
||||
# /usr/bin/git is a popup stub when Xcode/CLT aren't installed, so bail out
|
||||
return @git = false if git == "/usr/bin/git" && !OS::Mac.has_apple_developer_tools?
|
||||
@git = true
|
||||
@git = quiet_system HOMEBREW_ENV_PATH/"scm/git", "--version"
|
||||
end
|
||||
|
||||
def self.ensure_git_installed!
|
||||
return if git_available?
|
||||
|
||||
require "cmd/install"
|
||||
begin
|
||||
oh1 "Installing git"
|
||||
Homebrew.perform_preinstall_checks
|
||||
Homebrew.install_formula(Formulary.factory("git"))
|
||||
safe_system HOMEBREW_BREW_FILE, "install", "git"
|
||||
rescue
|
||||
raise "Git is unavailable"
|
||||
end
|
||||
|
||||
clear_git_available_cache
|
||||
raise "Git is unavailable" unless git_available?
|
||||
end
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user