Homebrew nasıl temiz bir şekilde kaldırılır


26

Homebrew'i nasıl temiz bir şekilde çıkarabilirim. Daha eski hatalı bir kurulumum olabilir ve yeni bir başlangıç ​​yapmak istiyorum.


1
Ayrıca bkz. Superuser.com/questions/203707/… , homebrew'i kaldırmanın "şimdi kurallı" bir yolunu tanımlayan yanıtları var
rogerdpack

@rogerdpack Yorumlar herhangi bir zamanda silinebilir, lütfen yeni yöntemi tanımlayan bir cevap gönderebilir misiniz?
yokuş yukarı

Yanıtlar:


17

Bu rm -rf, ne zaman sildiğinizden emin olup olmadığınızı sormaz, bu nedenle cdkomutun / tmp'den çıkabilmesi için çalıştığından emin olun ( cd /tmpbir seferde her şeyi kopyalayıp / yapıştırmanız durumunda sizi güvenli bir yere götürür, böylece dosyaları silmezsiniz) geçerli dizinden)

Terminalinizde bunu deneyin:

cd /tmp
cd `brew --prefix`
rm -rf Cellar
brew prune
rm `git ls-files`
rm -r Library/Homebrew Library/Aliases Library/Formula Library/Contributions
rm -rf .git
rm -rf ~/Library/Caches/Homebrew

Bu konu hakkında daha fazla bilgi Homebrew SSS bölümünde bulunabilir .


1
cd `brew --prefix`Eski / hatalı çalışan bir kurulumun başarısız olabileceği ve silme git ls-filesişleminin kalıntısından başka bir şeyi silebileceğinden , normal check-in işlemlerinin yapılmadığı bir klasöre gittiğini kontrol ediyorum .
bmike

Belgeleri okudum, sadece ileride referans almak için yararlı bir soru olabileceğini düşündüm. Bununla birlikte, ayrı bir soru olarak gönderdiğim talimatlarla ilgili problemlerim var: apple.stackexchange.com/questions/82863/…
ipavlic

Homebrew SSS link güncellenebilen gerektiğini unutmayın github.com/mxcl/homebrew/wiki/FAQ/... için github.com/Homebrew/homebrew/blob/master/share/doc/homebrew/... Yapamam ( yorumları düzenle veya ekle).
cloudnthings

1
Şimdi bunun için bir senaryo var: github.com/Homebrew/brew/blob/master/docs/FAQ.md
larkey

5

HomeBrew'un kurulumu ön sayfasında belirgin bir şekilde yer alırken, ayrıntılar yok. https://brew.sh/ /usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)" Uzun süredir güvenilir bir kaldırma bulmak çok zordu. Şimdi, birkaç dokümanda bir kaç tıklama uzakta, artık resmi bir yöntem var: https://docs.brew.sh/FAQ Homebrew'i kaldırmak için aşağıdaki komutu bir terminal istemine yapıştırın. ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/uninstall)"


3

Homebrew'i kaldırmak için daha iyi bir çözüm: https://gist.github.com/SteveBenner/11254428

#!/usr/bin/env ruby
#
# Locates and removes Homebrew installation
# http://brew.sh/
#
# Author: Stephen Benner
# https://github.com/SteveBenner
#
require 'optparse'
require 'fileutils'
require 'open3'

$stdout.sync = true

# Default options
options = {
  :quiet     => false,
  :verbose   => true,
  :dry_run   => false,
  :force     => false,
  :find_path => false
}

optparser = OptionParser.new do |opts|
  opts.on('-q', '--quiet', 'Quiet mode - suppress output.') do |setting|
    options[:quiet]   = setting
    options[:verbose] = false
  end
  opts.on('-v', '--verbose', 'Verbose mode - print all operations.') { |setting| options[:verbose] = setting }
  opts.on('-d', '--dry', 'Dry run - print results, but perform no actual operations.') do |setting|
    options[:dry_run] = setting
  end
  opts.on('-f', '--force', 'Forces removal of files, bypassing prompt. USE WITH CAUTION.') do |setting|
    options[:force] = setting
  end
  opts.on('-p', '--find-path', 'Output homebrew location if found, then exit.') do |setting|
    options[:find_path] = setting
    options[:quiet]     = true
  end
  opts.on('-h', '--help', '--usage', 'Display usage info and quit.') { puts opts; exit }
end
optparser.parse!
$quiet = options[:quiet] # provides access to option value within methods

# Files installed into the Homebrew repository
BREW_LOCAL_FILES = %w[
  .git
  Cellar
  Library/brew.rb
  Library/Homebrew
  Library/Aliases
  Library/Formula
  Library/Contributions
  Library/LinkedKegs
]
# Files that Homebrew installs into other system locations
BREW_SYSTEM_FILES = %W[
  #{ENV['HOME']}/Library/Caches/Homebrew
  #{ENV['HOME']}/Library/Logs/Homebrew
  /Library/Caches/Homebrew
]
$files = []

# This function runs given command in a sub-shell, expecting the output to be the
# path of a Homebrew installation. If given a block, it passes the shell output to
# the block for processing, using the return value of the block as the new path.
# Known Homebrew files are then scanned for and added to the file list. Then the
# directory is tested for a Homebrew installation, and the git index is added if
# a valid repo is found. The function won't run once a Homebrew installation is
# found, but it will accumulate untracked Homebrew files each invocation.
#
# @param  [String] cmd       a shell command to run
# @param  [String] error_msg message to print if command fails
#
def locate_brew_path(cmd, error_msg = 'check homebrew installation and PATH.')
  return if $brew_location # stop testing if we find a valid Homebrew installation
  puts "Searching for homewbrew installation using '#{cmd}'..." unless $quiet

  # Run given shell command along with any code passed-in via block
  path = `#{cmd}`.chomp
  path = yield(path) if block_given? # pass command output to your own fancy code block

  begin
    Dir.chdir(path) do
      # Search for known Homebrew files and folders, regardless of git presence
      $files += BREW_LOCAL_FILES.select { |file| File.exist? file }.map {|file| File.expand_path file }
      $files += Dir.glob('**/{man,bin}/**/brew*')
      # Test for Homebrew git repository (use popen3 so we can suppress git error output)
      repo_name = Open3.popen3('git remote -v') do |stdin, stdout, stderr|
        stderr.close
        stdout.read
      end
      if repo_name =~ /homebrew.git|Homebrew/
        $brew_location = path
      else
        return
      end
    end
  rescue StandardError # on normal errors, continue program
    return
  end
end

# Attempt to locate homebrew installation using a command and optional code block
# for processing the command results. Locating a valid path halts searching.
locate_brew_path 'brew --prefix'
locate_brew_path('which brew') { |output| File.expand_path('../..', output) }
locate_brew_path 'brew --prefix' do |output|
  output = output.split($/).first
  File.expand_path('../..', output)
end

# Found Homebrew installation
if $brew_location
  puts "Homebrew found at: #{$brew_location}" unless options[:quiet]
  if options[:find_path]
    puts $brew_location
    exit
  end
  # Collect files indexed by git
  begin
    Dir.chdir($brew_location) do
      # Update file list (use popen3 so we can suppress git error output)
      Open3.popen3('git checkout master') { |stdin, stdout, stderr| stderr.close }
      $files += `git ls-files`.split.map {|file| File.expand_path file }
    end
  rescue StandardError => e
    puts e # Report any errors, but continue the script and collect any last files
  end
end

# Collect any files Homebrew may have installed throughout our system
$files += BREW_SYSTEM_FILES.select { |file| File.exist? file }

abort 'Failed to locate any homebrew files!' if $files.empty?

# DESTROY! DESTROY! DESTROY!
unless options[:force]
  print "Delete #{$files.count} files? "
  abort unless gets.rstrip =~ /y|yes/i
end

rm =
  if options[:dry_run]
    lambda { |entry| puts "deleting #{entry}" unless options[:quiet] }
  else
    lambda { |entry| FileUtils.rm_rf(entry, :verbose => options[:verbose]) }
  end

puts 'Deleting files...' unless options[:quiet]
$files.each(&rm)

1
Farklı sormaya hoş geldiniz! Verdiğiniz bağlantı soruyu cevaplayabilse de, yanıtı buraya eklemek ve referans için bağlantıyı sağlamak daha iyidir. Bağlantılı sayfa değişirse, yalnızca bağlantı yanıtları geçersiz olabilir. Sorunuzu, atıfta bulunduğunuz çözüm olduğuna inandığım şeyi dahil etmek için düzenlemiştim, ancak lütfen ilgili bölümü alıntılamadıysanız. Ayrıca, çözümünüzün neden daha iyi olduğunu da genişletebilir misiniz ?
grg

1
Birkaç satırdan fazla, bu yüzden kodun dahil edilmesi çok zahmetli olur, ancak gelecekte bunu yapmaktan mutlu olurum. Bu daha iyi, çünkü komut dosyamın kaldıracağı yayınlanan cevapta yakalanmayan dosya ve dizinler var. Kullanıcıya CLI seçenekleri aracılığıyla yardımcı olur, demleme yerleri için daha ayrıntılı arama yapar ve komut dosyasını geliştirmek istediğinizde kolayca değiştirilebilmesi için kodlanır.
Steve Benner
Sitemizi kullandığınızda şunları okuyup anladığınızı kabul etmiş olursunuz: Çerez Politikası ve Gizlilik Politikası.
Licensed under cc by-sa 3.0 with attribution required.