aboutsummaryrefslogtreecommitdiffstats
path: root/Library/Homebrew/cask/lib
diff options
context:
space:
mode:
authorJosh Hagins2016-10-24 01:11:48 -0400
committerGitHub2016-10-24 01:11:48 -0400
commit606a7623442924b9c828f3f3fbd227dd3122bf3c (patch)
tree984a4d34c6cbe23151e4a95da35c9e8e420ff264 /Library/Homebrew/cask/lib
parent512a0c950e828fe07e629a629ba4d7b2fb8c2a6d (diff)
parent0b8af5771f590bfb5cea7bccd4bd0fc77a973113 (diff)
downloadbrew-606a7623442924b9c828f3f3fbd227dd3122bf3c.tar.bz2
Merge pull request #1248 from Git-Jiro/add_reinstall_cmd_to_cask
add cask reinstall command
Diffstat (limited to 'Library/Homebrew/cask/lib')
-rw-r--r--Library/Homebrew/cask/lib/hbc/cli.rb1
-rw-r--r--Library/Homebrew/cask/lib/hbc/cli/reinstall.rb49
2 files changed, 50 insertions, 0 deletions
diff --git a/Library/Homebrew/cask/lib/hbc/cli.rb b/Library/Homebrew/cask/lib/hbc/cli.rb
index d062c6a7d..c9625c7e2 100644
--- a/Library/Homebrew/cask/lib/hbc/cli.rb
+++ b/Library/Homebrew/cask/lib/hbc/cli.rb
@@ -15,6 +15,7 @@ require "hbc/cli/home"
require "hbc/cli/info"
require "hbc/cli/install"
require "hbc/cli/list"
+require "hbc/cli/reinstall"
require "hbc/cli/search"
require "hbc/cli/style"
require "hbc/cli/uninstall"
diff --git a/Library/Homebrew/cask/lib/hbc/cli/reinstall.rb b/Library/Homebrew/cask/lib/hbc/cli/reinstall.rb
new file mode 100644
index 000000000..ac514bd50
--- /dev/null
+++ b/Library/Homebrew/cask/lib/hbc/cli/reinstall.rb
@@ -0,0 +1,49 @@
+module Hbc
+ class CLI
+ class Reinstall < Install
+ def self.install_casks(cask_tokens, force, skip_cask_deps, require_sha)
+ count = 0
+ cask_tokens.each do |cask_token|
+ begin
+ cask = Hbc.load(cask_token)
+
+ if cask.installed?
+ # use copy of cask for uninstallation to avoid 'No such file or directory' bug
+ installed_cask = cask
+ latest_installed_version = installed_cask.timestamped_versions.last
+
+ unless latest_installed_version.nil?
+ latest_installed_cask_file = installed_cask.metadata_master_container_path
+ .join(latest_installed_version
+ .join(File::Separator),
+ "Casks", "#{cask_token}.rb")
+
+ # use the same cask file that was used for installation, if possible
+ installed_cask = Hbc.load(latest_installed_cask_file) if latest_installed_cask_file.exist?
+ end
+
+ # Always force uninstallation, ignore method parameter
+ Installer.new(installed_cask, force: true).uninstall
+ end
+
+ Installer.new(cask,
+ force: force,
+ skip_cask_deps: skip_cask_deps,
+ require_sha: require_sha).install
+ count += 1
+ rescue CaskUnavailableError => e
+ warn_unavailable_with_suggestion cask_token, e
+ rescue CaskNoShasumError => e
+ opoo e.message
+ count += 1
+ end
+ end
+ count.zero? ? nil : count == cask_tokens.length
+ end
+
+ def self.help
+ "reinstalls the given Cask"
+ end
+ end
+ end
+end