aboutsummaryrefslogtreecommitdiffstats
path: root/Library/Homebrew/cmd/upgrade.rb
diff options
context:
space:
mode:
authorCharlie Sharpsteen2012-12-18 14:59:12 -0800
committerCharlie Sharpsteen2012-12-18 15:12:10 -0800
commit78e7cc32e889fd1f83a1d811c75cb97795d8b5bd (patch)
tree2c2a748085f4e77e1585854ff822f9eeaf9898de /Library/Homebrew/cmd/upgrade.rb
parent05f0ea712c44054b136d5244c11c8bfa0c54bab8 (diff)
downloadhomebrew-78e7cc32e889fd1f83a1d811c75cb97795d8b5bd.tar.bz2
upgrade.rb: Generate Tab from Keg not Formula
Two issues were preventing `brew upgrade` from functioning properly: - `Tab.for_formula` was used to recover options from prior installs. The problem is that during an upgrade `for_formula` will be directed to a non-existant install of the newer version and thus returns a forged tab claiming no options were invoked. - The assignment to `installer.install_bottle` requires parenthesis in order to function properly.
Diffstat (limited to 'Library/Homebrew/cmd/upgrade.rb')
-rw-r--r--Library/Homebrew/cmd/upgrade.rb7
1 files changed, 5 insertions, 2 deletions
diff --git a/Library/Homebrew/cmd/upgrade.rb b/Library/Homebrew/cmd/upgrade.rb
index 7ec02a0b5..06dfb8732 100644
--- a/Library/Homebrew/cmd/upgrade.rb
+++ b/Library/Homebrew/cmd/upgrade.rb
@@ -53,12 +53,15 @@ module Homebrew extend self
end
def upgrade_formula f
- tab = Tab.for_formula(f)
+ # Generate using `for_keg` since the formula object points to a newer version
+ # that doesn't exist yet. Use `opt_prefix` to guard against keg-only installs.
+ # Also, guard against old installs that may not have an `opt_prefix` symlink.
+ tab = (f.opt_prefix.exist? ? Tab.for_keg(f.opt_prefix) : Tab.dummy_tab(f))
outdated_keg = Keg.new(f.linked_keg.realpath) rescue nil
installer = FormulaInstaller.new(f, tab)
installer.show_header = false
- installer.install_bottle = install_bottle?(f) and tab.used_options.empty?
+ installer.install_bottle = (install_bottle?(f) and tab.used_options.empty?)
oh1 "Upgrading #{f.name}"