module Hbc class CLI class Install < AbstractCommand def initialize(*args) @cask_tokens = self.class.cask_tokens_from(args) raise CaskUnspecifiedError if @cask_tokens.empty? @force = args.include? "--force" @skip_cask_deps = args.include? "--skip-cask-deps" @require_sha = args.include? "--require-sha" end def run retval = install_casks # retval is ternary: true/false/nil raise CaskError, "nothing to install" if retval.nil? raise CaskError, "install incomplete" unless retval end def install_casks count = 0 @cask_tokens.each do |cask_token| begin cask = CaskLoader.load(cask_token) Installer.new(cask, binaries: CLI.binaries?, force: @force, skip_cask_deps: @skip_cask_deps, require_sha: @require_sha).install count += 1 rescue CaskAlreadyInstalledError => e opoo e.message count += 1 rescue CaskAlreadyInstalledAutoUpdatesError => e opoo e.message count += 1 rescue CaskUnavailableError => e self.class.warn_unavailable_with_suggestion cask_token, e rescue CaskNoShasumError => e opoo e.message count += 1 rescue CaskError => e onoe e.message end end count.zero? ? nil : count == @cask_tokens.length end def self.warn_unavailable_with_suggestion(cask_token, e) exact_match, partial_matches = Search.search(cask_token) error_message = e.message if exact_match error_message.concat(". Did you mean:\n#{exact_match}") elsif !partial_matches.empty? error_message.concat(". Did you mean one of:\n") .concat(Formatter.columns(partial_matches.take(20))) end onoe error_message end def self.help "installs the given Cask" end def self.needs_init? true end end end end