diff options
author | Kevin Newton <kddnewton@gmail.com> | 2024-03-06 01:40:07 -0500 |
---|---|---|
committer | git <svn-admin@ruby-lang.org> | 2024-03-06 16:43:02 +0000 |
commit | 507ffc9686a2fbf796fb5401323f613ba373a3f6 (patch) | |
tree | d281224bf5a721b449b96ce3e418d76398c7a4d6 /lib/prism/translation/ripper.rb | |
parent | 8528e765b7c62dc3e7f10f1a9df319bda37ac509 (diff) |
[ruby/prism] Better handle splats in MRHS in rescues in ripper translation
https://github.com/ruby/prism/commit/36a0b2e45a
Diffstat (limited to 'lib/prism/translation/ripper.rb')
-rw-r--r-- | lib/prism/translation/ripper.rb | 16 |
1 files changed, 13 insertions, 3 deletions
diff --git a/lib/prism/translation/ripper.rb b/lib/prism/translation/ripper.rb index be7157512b..08fd2d14b4 100644 --- a/lib/prism/translation/ripper.rb +++ b/lib/prism/translation/ripper.rb @@ -2318,12 +2318,22 @@ module Prism node.exceptions.each_with_index.inject(on_args_new) do |mrhs, (exception, index)| arg = visit(exception) + bounds(exception.location) + mrhs = on_mrhs_new_from_args(mrhs) if index == length - 1 - if index == length - 1 - on_mrhs_add(on_mrhs_new_from_args(mrhs), arg) + if exception.is_a?(SplatNode) + if index == length - 1 + on_mrhs_add_star(mrhs, arg) + else + on_args_add_star(mrhs, arg) + end else - on_args_add(mrhs, arg) + if index == length - 1 + on_mrhs_add(mrhs, arg) + else + on_args_add(mrhs, arg) + end end end end |