Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ruby/error_highlight
The gem enhances Exception#message by adding a short explanation where the exception is raised
https://github.com/ruby/error_highlight
ruby
Last synced: 2 days ago
JSON representation
The gem enhances Exception#message by adding a short explanation where the exception is raised
- Host: GitHub
- URL: https://github.com/ruby/error_highlight
- Owner: ruby
- License: mit
- Created: 2021-06-29T08:44:01.000Z (over 3 years ago)
- Default Branch: master
- Last Pushed: 2024-12-03T03:11:32.000Z (about 1 month ago)
- Last Synced: 2024-12-26T13:06:51.528Z (9 days ago)
- Topics: ruby
- Language: Ruby
- Homepage:
- Size: 78.1 KB
- Stars: 149
- Watchers: 32
- Forks: 23
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
Awesome Lists containing this project
README
# ErrorHighlight
## Installation
Ruby 3.1 will ship with this gem and it will automatically be `require`d when a Ruby process starts up. No special setup is required.
Note: This gem works only on MRI and requires Ruby 3.1 or later because it depends on MRI's internal APIs that are available since 3.1.
## Examples
```ruby
1.time {}
``````
$ ruby test.rb
test.rb:1:in `': undefined method `time' for 1:Integer (NoMethodError)1.time {}
^^^^^
Did you mean? times
```## More example
```ruby
def extract_value(data)
data[:results].first[:value]
end
```When `data` is `{ :results => [] }`, the following error message is shown:
```
$ ruby test.rb
test.rb:2:in `extract_value': undefined method `[]' for nil:NilClass (NoMethodError)data[:results].first[:value]
^^^^^^^^
from test.rb:5:in `'
```When `data` is `nil`, it prints:
```
$ ruby test.rb
test.rb:2:in `extract_value': undefined method `[]' for nil:NilClass (NoMethodError)data[:results].first[:value]
^^^^^^^^^^
from test.rb:5:in `'
```## Using the `ErrorHighlight.spot`
*Note: This API is experimental, may change in future.*
You can use the `ErrorHighlight.spot` method to get the snippet data.
Note that the argument must be a RubyVM::AbstractSyntaxTree::Node object that is created with `keep_script_lines: true` option (which is available since Ruby 3.1).```ruby
class Dummy
def test(_dummy_arg)
node = RubyVM::AbstractSyntaxTree.of(caller_locations.first, keep_script_lines: true)
ErrorHighlight.spot(node)
end
endpp Dummy.new.test(42) # <- Line 8
# ^^^^^ <- Column 12--17#=> {:first_lineno=>8,
# :first_column=>12,
# :last_lineno=>8,
# :last_column=>17,
# :snippet=>"pp Dummy.new.test(42) # <- Line 8\n"}
```## Custom Formatter
If you want to customize the message format for code snippet, use `ErrorHighlight.formatter=` to set your custom object that responds to `message_for` method.
```ruby
formatter = Object.new
def formatter.message_for(spot)
marker = " " * spot[:first_column] + "^" + "~" * (spot[:last_column] - spot[:first_column] - 1)"\n\n#{ spot[:snippet] }#{ marker }"
endErrorHighlight.formatter = formatter
1.time {}
#=>
#
# test.rb:10:in `': undefined method `time' for 1:Integer (NoMethodError)
#
# 1.time {}
# ^~~~~
# Did you mean? times
```## Disabling `error_highlight`
Occasionally, you may want to disable the `error_highlight` gem for e.g. debugging issues in the error object itself. You
can disable it entirely by specifying `--disable-error_highlight` option to the `ruby` command:```bash
$ ruby --disable-error_highlight -e '1.time {}'
-e:1:in `': undefined method `time' for 1:Integer (NoMethodError)
Did you mean? times
```## Contributing
Bug reports and pull requests are welcome on GitHub at https://github.com/ruby/error_highlight.
## License
The gem is available as open source under the terms of the [MIT License](https://opensource.org/licenses/MIT).