diff options
| -rw-r--r-- | Library/Homebrew/cmd/outdated.rb | 24 | ||||
| -rw-r--r-- | Library/Homebrew/cmd/upgrade.rb | 2 |
2 files changed, 13 insertions, 13 deletions
diff --git a/Library/Homebrew/cmd/outdated.rb b/Library/Homebrew/cmd/outdated.rb index 40aa7a470..5f655b3a4 100644 --- a/Library/Homebrew/cmd/outdated.rb +++ b/Library/Homebrew/cmd/outdated.rb @@ -1,11 +1,12 @@ require 'formula' +require 'keg' module Homebrew extend self def outdated - outdated_brews.each do |f| + outdated_brews do |f| if $stdout.tty? and not ARGV.flag? '--quiet' - versions = f.rack.cd{ Dir['*'] }.join(', ') - puts "#{f.name} (#{versions} < #{f.version})" + versions = f.rack.subdirs.map { |d| Keg.new(d) }.map { |keg| keg.basename } + puts "#{f.name} (#{versions*', '} < #{f.version})" else puts f.name end @@ -13,16 +14,15 @@ module Homebrew extend self end def outdated_brews - HOMEBREW_CELLAR.subdirs.map do |rack| - # Skip kegs with no versions installed - next unless rack.subdirs + HOMEBREW_CELLAR.subdirs.reject { |d| d.subdirs.empty? }.map do |rack| + f = Formula.factory(rack.basename.to_s) rescue nil + next if f.nil? - # Skip HEAD formulae, consider them "evergreen" - next if rack.subdirs.map{ |keg| keg.basename.to_s }.include? "HEAD" - - name = rack.basename.to_s - f = Formula.factory name rescue nil - f if f and not f.installed? + kegs = rack.subdirs.map { |d| Keg.new(d) } + unless kegs.any? { |keg| keg.version >= f.version } + yield f if block_given? + f + end end.compact end end diff --git a/Library/Homebrew/cmd/upgrade.rb b/Library/Homebrew/cmd/upgrade.rb index 9a2448066..99954d91e 100644 --- a/Library/Homebrew/cmd/upgrade.rb +++ b/Library/Homebrew/cmd/upgrade.rb @@ -1,4 +1,3 @@ -require 'cmd/outdated' require 'cmd/install' class Fixnum @@ -18,6 +17,7 @@ module Homebrew extend self Homebrew.perform_preinstall_checks outdated = if ARGV.named.empty? + require 'cmd/outdated' Homebrew.outdated_brews else ARGV.formulae.select do |f| |
