aboutsummaryrefslogtreecommitdiffstats
path: root/Library/Homebrew/cask/lib/hbc/cli
diff options
context:
space:
mode:
authorMarkus Reiter2017-03-16 11:37:49 +0100
committerGitHub2017-03-16 11:37:49 +0100
commitc4d8b1696c90fa54f0e2f4bce3c734f7a657662b (patch)
tree58f3ad399870aca5329b7461d41cf8e12c885328 /Library/Homebrew/cask/lib/hbc/cli
parent6c180e500827f9513304c96bcb43db31a31c5ae0 (diff)
parent7532545140c1ce0da370b2b3124e488dbb11fc41 (diff)
downloadbrew-c4d8b1696c90fa54f0e2f4bce3c734f7a657662b.tar.bz2
Merge pull request #2309 from axiac/cask-outdated
add command 'cask outdated'
Diffstat (limited to 'Library/Homebrew/cask/lib/hbc/cli')
-rw-r--r--Library/Homebrew/cask/lib/hbc/cli/outdated.rb39
1 files changed, 39 insertions, 0 deletions
diff --git a/Library/Homebrew/cask/lib/hbc/cli/outdated.rb b/Library/Homebrew/cask/lib/hbc/cli/outdated.rb
new file mode 100644
index 000000000..d608beab5
--- /dev/null
+++ b/Library/Homebrew/cask/lib/hbc/cli/outdated.rb
@@ -0,0 +1,39 @@
+module Hbc
+ class CLI
+ class Outdated < Base
+ def self.run(*args)
+ greedy = args.include?("--greedy")
+ verbose = ($stdout.tty? || CLI.verbose?) && !args.include?("--quiet")
+
+ cask_tokens = cask_tokens_from(args)
+ casks_to_check = if cask_tokens.empty?
+ Hbc.installed
+ else
+ cask_tokens.map { |token| Hbc.load(token) }
+ end
+
+ casks_to_check.each do |cask|
+ odebug "Checking update info of Cask #{cask}"
+ list_if_outdated(cask, greedy, verbose)
+ end
+ end
+
+ def self.list_if_outdated(cask, greedy, verbose)
+ return unless cask.outdated?(greedy)
+
+ if verbose
+ outdated_versions = cask.outdated_versions(greedy)
+ outdated_info = "#{cask.token} (#{outdated_versions.join(", ")})"
+ current_version = cask.version.to_s
+ puts "#{outdated_info} != #{current_version}"
+ else
+ puts cask.token
+ end
+ end
+
+ def self.help
+ "list the outdated installed Casks"
+ end
+ end
+ end
+end