Actions
Bug #21378
closedvariable pinning does not look for method arguments
    Bug #21378:
    variable pinning does not look for method arguments
  
ruby -v:
ruby 3.5.0dev (2025-01-23T15:24:35Z origin/7ed08c4fd31.. 7ed08c4fd3) +PRISM [wasm32-wasi]
Description
Is this intentional?
irb(main):001> def x?(y, z) = y in { x: ^z }
<internal:kernel>:168:in 'Kernel#loop': (irb):1: syntax error found (SyntaxError)
> 1 | def x?(y, z) = y in { x: ^z }
    |                           ^ z: no such local variable
        from eval_async:132:in '<main>'
        from /bundle/gems/js-2.7.1/lib/js.rb:109:in 'Kernel.eval'
        from /bundle/gems/js-2.7.1/lib/js.rb:109:in 'block in JS.__eval_async_rb'
        from /bundle/gems/js-2.7.1/lib/js.rb:120:in 'block in JS.__async'
        
           Updated by nobu (Nobuyoshi Nakada) 5 months ago
          Updated by nobu (Nobuyoshi Nakada) 5 months ago
          
          
        
        
      
      It is parsed as (def x?(y, z) = y) in { x: ^z }.
        
           Updated by hsbt (Hiroshi SHIBATA) 5 months ago
          Updated by hsbt (Hiroshi SHIBATA) 5 months ago
          
          
        
        
      
      - Status changed from Open to Assigned
        
           Updated by Eregon (Benoit Daloze) 5 months ago
          Updated by Eregon (Benoit Daloze) 5 months ago
          
          
        
        
      
      - Assignee changed from prism to matz (Yukihiro Matsumoto)
It's the same with parse.y:
$ ruby -v --parser=parse.y -e 'def x?(y, z) = y in { x: ^z }'
ruby 3.5.0dev (2025-05-28T04:34:40Z master d064fd067b) [x86_64-linux]
-e:1: z: no such local variable
ruby: compile error (SyntaxError)
So I think we should assign matz and not prism.
I guess it's a pitfall of the weird precedence of def =, which has already been reported many times in various variants.
def x?(y, z); y in { x: ^z }; end works fine of course.
        
           Updated by mame (Yusuke Endoh) 5 months ago
          Updated by mame (Yusuke Endoh) 5 months ago
          
          
        
        
      
      - Status changed from Assigned to Feedback
@yui-knk (Kaneko Yuichiro) Do you think this is possible to implement?
        
           Updated by yui-knk (Kaneko Yuichiro) about 2 months ago
          Updated by yui-knk (Kaneko Yuichiro) about 2 months ago
          
          
        
        
      
      - Related to Bug #21097: `x = a rescue b in c` and `def f = a rescue b in c` parsed differently between parse.y and prism added
        
           Updated by yui-knk (Kaneko Yuichiro) about 1 month ago
          Updated by yui-knk (Kaneko Yuichiro) about 1 month ago
          
          
        
        
      
      
    
Actions