Terror
Terror is a terrible solution to the non-problem of creating custom error classes in Ruby. Terror provides a DSL to define custom error classes with support for custom messages, parent classes, and custom behavior. If that still seems like too much work, Terror will automagically create error classes for you at runtime if the class name ends with "Error".
Terror was written years ago before I knew how terrible of an idea it was. I'm only updating it now because the older version was even more awful. Don't be lazy. Don't write code like this.
Installation
Add this line to your application's Gemfile:
gem "terror"
And then execute:
$ bundle
Or install it yourself as:
$ gem install terror
Usage
require "terror"
class MyClass
extend Terror
# Error base class can be specified in the keyword argument `from`.
errors from: RuntimeError do
# Errors can use the `message` keyword to set a custom error message.
MyError message: "just another error"
# Override the top-level base class for this error.
SpecialError from: StandardError
end
def raise_error
# This error does not exist before it is raised here.
raise TooLazyToDefineThisError, "error gets defined at runtime"
end
end
Development
After checking out the repo, run bin/setup
to install dependencies. Then, run rake test
to run the tests. You can also run bin/console
for an interactive prompt that will allow you to experiment.
To install this gem onto your local machine, run bundle exec rake install
. To release a new version, update the version number in version.rb
, and then run bundle exec rake release
, which will create a git tag for the version, push git commits and tags, and push the .gem
file to rubygems.org.
Contributing
Bug reports and pull requests are welcome on GitHub at https://github.com/adamtanner/terror.
License
The gem is available as open source under the terms of the MIT License.