Project

General

Profile

Actions

Bug #21168

open

Prism doesn't require argument parentheses (in some cases) when a block is present but parse.y does

Added by Earlopain (Earlopain _) about 1 month ago. Updated 10 days ago.

Status:
Assigned
Assignee:
Target version:
-
ruby -v:
ruby 3.4.2 (2025-02-15 revision d2930f8e7a) +PRISM [x86_64-linux]
[ruby-core:121234]

Description

It's a bit more than that but explaining it in full would be a bit much. Instead, see this:

foo(
  bar baz do
  end
)
$ ruby -c --parser=prism test.rb
Syntax OK
$ ruby -c --parser=parse.y test.rb
ruby: test.rb:2: syntax error, unexpected 'do' for block, expecting ')' (SyntaxError)
  bar baz do
          ^~

OTOH, this is consistently rejected:

[
  foo bar do
  end,
]
# And also
foo || bar baz do
end

Updated by eileencodes (Eileen Uchitelle) 29 days ago

I took a look at this and I'm not sure any of these cases should fail - which would mean the consistently rejected cases are incorrect.

If the argument is wrapped in parenthesis it passes the syntax check (in all cases provided in this report). Prism can parse the first example without error, and if all the methods are defined it runs and produces correct results.

So I'd argue that parse.y is incorrect in all cases and Prism should be fixed for the last two.

Also for what it's worth, with parse.y the last two examples point to the passed argument as where the syntax error is occurring, whereas the first example points to the do keyword. If it's decided these should all error, I think the error should be consistent in which part of these examples are incorrect (ie is it the argument passes to bar or is it the do keyword that's unexpected?)

Syntax error at the 1 argument with parse.y.

[
  bar 1 do
  end 
]
=> ./miniruby: test.rb:2: syntax error, unexpected integer literal, expecting 'do' or '{' or '(' (SyntaxError)
  bar 1 do
      ^

Syntax error at the do keyword with parse.y:

foo(
  bar 1 do
  end
)
=> ./miniruby: test2.rb:2: syntax error, unexpected 'do' for block, expecting ')' (SyntaxError)
  bar 1 do
        ^~
Actions #3

Updated by hsbt (Hiroshi SHIBATA) 10 days ago

  • Status changed from Open to Assigned
Actions

Also available in: Atom PDF

Like0
Like0Like0Like0