diff options
| author | Martin Afanasjew | 2016-04-19 08:11:17 +0200 |
|---|---|---|
| committer | Martin Afanasjew | 2016-04-20 13:46:10 +0200 |
| commit | d9363a15590ddb8aad3e8e5444a972eaa79fd05e (patch) | |
| tree | 5c3a8ee063a8c314b4e9c6989025e94295ec6cd7 /Library | |
| parent | cf3486f98a5ddc8eae3c511f759471eff79cfcf8 (diff) | |
| download | brew-d9363a15590ddb8aad3e8e5444a972eaa79fd05e.tar.bz2 | |
exceptions: add reason to 'UsageError' exception
Use the `reason` attribute to be able to handle `UsageError` subclasses
more uniformly and simplify logic in `brew.rb` to handle them together.
Diffstat (limited to 'Library')
| -rw-r--r-- | Library/Homebrew/exceptions.rb | 28 | ||||
| -rw-r--r-- | Library/brew.rb | 8 |
2 files changed, 27 insertions, 9 deletions
diff --git a/Library/Homebrew/exceptions.rb b/Library/Homebrew/exceptions.rb index 130d3f505..144f70768 100644 --- a/Library/Homebrew/exceptions.rb +++ b/Library/Homebrew/exceptions.rb @@ -1,6 +1,28 @@ -class UsageError < RuntimeError; end -class FormulaUnspecifiedError < UsageError; end -class KegUnspecifiedError < UsageError; end +class UsageError < RuntimeError + attr_reader :reason + + def initialize(reason = nil) + @reason = reason + end + + def to_s + s = "Invalid usage" + s += ": #{reason}" if reason + s + end +end + +class FormulaUnspecifiedError < UsageError + def initialize + super "This command requires a formula argument" + end +end + +class KegUnspecifiedError < UsageError + def initialize + super "This command requires a keg argument" + end +end class MultipleVersionsInstalledError < RuntimeError attr_reader :name diff --git a/Library/brew.rb b/Library/brew.rb index 222b432ac..ebb144792 100644 --- a/Library/brew.rb +++ b/Library/brew.rb @@ -113,13 +113,9 @@ begin end end -rescue FormulaUnspecifiedError - abort "This command requires a formula argument" -rescue KegUnspecifiedError - abort "This command requires a keg argument" -rescue UsageError +rescue UsageError => e require "cmd/help" - Homebrew.help cmd, :usage_error => "Invalid usage" + Homebrew.help cmd, :usage_error => e.message rescue SystemExit => e onoe "Kernel.exit" if ARGV.verbose? && !e.success? $stderr.puts e.backtrace if ARGV.debug? |
