diff --git a/Library/Homebrew/cmd/outdated.rb b/Library/Homebrew/cmd/outdated.rb index a318b65f63..7e93644161 100644 --- a/Library/Homebrew/cmd/outdated.rb +++ b/Library/Homebrew/cmd/outdated.rb @@ -32,10 +32,19 @@ module Homebrew def print_outdated(formulae) verbose = ($stdout.tty? || ARGV.verbose?) && !ARGV.flag?("--quiet") + fetch_head = ARGV.fetch_head? - formulae.select(&:outdated?).each do |f| + outdated_formulae = formulae.select { |f| f.outdated?(:fetch_head => fetch_head) } + + outdated_formulae.each do |f| if verbose - puts "#{f.full_name} (#{f.outdated_versions*", "} < #{f.pkg_version})" + outdated_versions = f.outdated_versions(:fetch_head => fetch_head) + current_version = if f.head? && outdated_versions.any? { |v| v.to_s == f.pkg_version.to_s } + "latest HEAD" + else + f.pkg_version.to_s + end + puts "#{f.full_name} (#{outdated_versions.join(", ")}) < #{current_version}" else puts f.full_name end @@ -44,11 +53,20 @@ module Homebrew def print_outdated_json(formulae) json = [] - outdated = formulae.select(&:outdated?).each do |f| + fetch_head = ARGV.fetch_head? + outdated_formulae = formulae.select { |f| f.outdated?(:fetch_head => fetch_head) } + + outdated = outdated_formulae.each do |f| + outdated_versions = f.outdated_versions(:fetch_head => fetch_head) + current_version = if f.head? && outdated_versions.any? { |v| v.to_s == f.pkg_version.to_s } + "HEAD" + else + f.pkg_version.to_s + end json << { :name => f.full_name, - :installed_versions => f.outdated_versions.collect(&:to_s), - :current_version => f.pkg_version.to_s } + :installed_versions => outdated_versions.collect(&:to_s), + :current_version => current_version } end puts Utils::JSON.dump(json) diff --git a/Library/Homebrew/cmd/upgrade.rb b/Library/Homebrew/cmd/upgrade.rb index c96d2b1f54..1933c05010 100644 --- a/Library/Homebrew/cmd/upgrade.rb +++ b/Library/Homebrew/cmd/upgrade.rb @@ -19,10 +19,15 @@ module Homebrew Homebrew.perform_preinstall_checks if ARGV.named.empty? - outdated = Formula.installed.select(&:outdated?) + outdated = Formula.installed.select do |f| + f.outdated?(:fetch_head => ARGV.fetch_head?) + end + exit 0 if outdated.empty? else - outdated = ARGV.resolved_formulae.select(&:outdated?) + outdated = ARGV.resolved_formulae.select do |f| + f.outdated?(:fetch_head => ARGV.fetch_head?) + end (ARGV.resolved_formulae - outdated).each do |f| versions = f.installed_kegs.map { |keg| keg.version } diff --git a/Library/Homebrew/extend/ARGV.rb b/Library/Homebrew/extend/ARGV.rb index 4a497957b3..adceee275a 100644 --- a/Library/Homebrew/extend/ARGV.rb +++ b/Library/Homebrew/extend/ARGV.rb @@ -223,6 +223,10 @@ module HomebrewArgvExtension include? "--force-bottle" end + def fetch_head? + include? "--fetch-HEAD" + end + # eg. `foo -ns -i --bar` has three switches, n, s and i def switch?(char) return false if char.length > 1