Actions
Bug #21048
closed 
  [Prism] rescue in modifier form with condition behaves differently
    Bug #21048:
    [Prism] rescue in modifier form with condition behaves differently
  
Description
With the following code there is a discrepancy in how prism and parse.y consider precedence:
$called = false
def foo
  $called = true
end
foo rescue nil if false
puts "Called: #{$called}"
Prism interprets it as foo rescue (nil if false), calling the method. parse.y does (foo rescue nil) if false since at least Ruby 2.0
$ ruby -v
ruby 3.5.0dev (2025-01-19T12:44:20Z master f27ed98eff) +PRISM [x86_64-linux]
$ ruby code.rb
Called: true
$ ruby --parser=parse.y code.rb
Called: false
        
           Updated by Earlopain (Earlopain _) 9 months ago
          Updated by Earlopain (Earlopain _) 9 months ago
          
          
        
        
      
      - ruby -v changed from 3.4.1 to ruby 3.4.1 (2024-12-25 revision 48d4efcb85) +PRISM [x86_64-linux]
        
           Updated by nobu (Nobuyoshi Nakada) 9 months ago
          Updated by nobu (Nobuyoshi Nakada) 9 months ago
          
          
        
        
      
      Earlopain (Earlopain _) wrote:
Prism interprets it as
(foo rescue nil) if false, not calling the method.parse.ydoesfoo rescue (nil if false)since at least Ruby 2.0
Inverse?
$ ruby -v ruby 3.5.0dev (2025-01-19T12:44:20Z master f27ed98eff) +PRISM [x86_64-linux] $ ruby code.rb Called: true $ ruby --parser=parse.y code.rb Called: false
        
           Updated by Earlopain (Earlopain _) 9 months ago
          Updated by Earlopain (Earlopain _) 9 months ago
          
          
        
        
      
      Yes, I switched it up in the text. Fixed
        
           Updated by Earlopain (Earlopain _) 9 months ago
          Updated by Earlopain (Earlopain _) 9 months ago
          
          
        
        
      
      - Description updated (diff)
        
           Updated by tenderlovemaking (Aaron Patterson) 9 months ago
          Updated by tenderlovemaking (Aaron Patterson) 9 months ago
          
          
        
        
      
      - Assignee set to prism
        
           Updated by kddnewton (Kevin Newton) 9 months ago
          Updated by kddnewton (Kevin Newton) 9 months ago
          
          
        
        
      
      - Backport changed from 3.1: UNKNOWN, 3.2: UNKNOWN, 3.3: UNKNOWN, 3.4: UNKNOWN to 3.1: UNKNOWN, 3.2: UNKNOWN, 3.3: UNKNOWN, 3.4: REQUIRED
        
           Updated by kddnewton (Kevin Newton) 9 months ago
          Updated by kddnewton (Kevin Newton) 9 months ago
          
          
        
        
      
      - Status changed from Open to Closed
        
           Updated by hsbt (Hiroshi SHIBATA) 8 months ago
          Updated by hsbt (Hiroshi SHIBATA) 8 months ago
          
          
        
        
      
      - Has duplicate Bug #21132: Changed postposition `rescue` and `if` behavior since Ruby 3.4 added
        
           Updated by k0kubun (Takashi Kokubun) 8 months ago
          Updated by k0kubun (Takashi Kokubun) 8 months ago
          
          
        
        
      
      - Backport changed from 3.1: UNKNOWN, 3.2: UNKNOWN, 3.3: UNKNOWN, 3.4: REQUIRED to 3.1: UNKNOWN, 3.2: UNKNOWN, 3.3: UNKNOWN, 3.4: DONE
ruby_3_4 04298f2d158fa860293d2ed2779cba69bc47f404 merged revision(s) c2908613368b2ae404d094a15df61d830fc46dc9.
        
           Updated by nagachika (Tomoyuki Chikanaga) 7 months ago
          Updated by nagachika (Tomoyuki Chikanaga) 7 months ago
          
          
        
        
      
      - Backport changed from 3.1: UNKNOWN, 3.2: UNKNOWN, 3.3: UNKNOWN, 3.4: DONE to 3.1: DONTNEED, 3.2: DONTNEED, 3.3: REQUIRED, 3.4: DONE
        
           Updated by nagachika (Tomoyuki Chikanaga) 4 months ago
          Updated by nagachika (Tomoyuki Chikanaga) 4 months ago
          
          
        
        
      
      Backporting c2908613368b2ae404d094a15df61d830fc46dc9 depends on many changesets about prism in ruby_3_3. Please make a backport pull request.
Actions