summaryrefslogtreecommitdiff
path: root/lib/prism/translation/ripper.rb
diff options
context:
space:
mode:
authorKevin Newton <kddnewton@gmail.com>2024-03-06 01:40:07 -0500
committergit <svn-admin@ruby-lang.org>2024-03-06 16:43:02 +0000
commit507ffc9686a2fbf796fb5401323f613ba373a3f6 (patch)
treed281224bf5a721b449b96ce3e418d76398c7a4d6 /lib/prism/translation/ripper.rb
parent8528e765b7c62dc3e7f10f1a9df319bda37ac509 (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.rb16
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