[#54738] [ruby-trunk - Bug #8358][Open] TestSprintf#test_float test failuer on mingw32 — "phasis68 (Heesob Park)" <phasis@...>

36 messages 2013/05/02

[#54749] [ruby-trunk - Feature #8361][Open] Alternative syntax for block parameter — "alexeymuranov (Alexey Muranov)" <redmine@...>

12 messages 2013/05/02

[#54798] [ruby-trunk - Bug #8370][Open] Constants MAX_MULTIPART_LENGTH in cgi\core.rb — "xibbar (Takeyuki FUJIOKA)" <xibbar@...>

17 messages 2013/05/05

[#54850] [ruby-trunk - Feature #8377][Open] Deprecate :: for method calls in 2.1 — "charliesome (Charlie Somerville)" <charliesome@...>

27 messages 2013/05/07

[#54881] [ruby-trunk - Bug #8384][Open] Cannot build ruby against OpenSSL build with "no-ec2m" — "vo.x (Vit Ondruch)" <v.ondruch@...>

16 messages 2013/05/09

[#54921] [ruby-trunk - Bug #8393][Open] A class who's parent class is in a module can go wrong if files are required in the wrong order — "eLobato (Daniel Lobato Garcia)" <elobatocs@...>

15 messages 2013/05/12

[#54939] [ruby-trunk - Bug #8399][Open] Remove usage of RARRAY_PTR in C extensions when not needed — "dbussink (Dirkjan Bussink)" <d.bussink@...>

32 messages 2013/05/12

[#55053] [ruby-trunk - Feature #8426][Open] Implement class hierarchy method caching — "charliesome (Charlie Somerville)" <charliesome@...>

21 messages 2013/05/19

[#55096] [ruby-trunk - Feature #8430][Open] Rational number literal — "mrkn (Kenta Murata)" <muraken@...>

28 messages 2013/05/21

[#55197] [ruby-trunk - Feature #8461][Open] Easy way to disable certificate checking in XMLRPC::Client — "herwinw (Herwin Weststrate)" <herwin@...>

11 messages 2013/05/29

[ruby-core:54940] [ruby-trunk - Bug #8398] case/when shouldn't try to evaluate all AND joined conditions if one of preceding was falsy

From: "jeremyevans0 (Jeremy Evans)" <merch-redmine@...>
Date: 2013-05-12 21:42:21 UTC
List: ruby-core #54940
Issue #8398 has been updated by jeremyevans0 (Jeremy Evans).


You probably think your case statement is translated to:

case
when (String === 1) && (proc { |x| x.blah } === 1)
  :something
else
  :no
end

I believe ruby actually translates it to:

case
when (String && proc { |x| x.blah }) === 1
  :something
else
  :no
end

As String is not false or nil, it's fairly obvious why proc is evaluated.  As you can see, using && in case expressions with values doesn't generally make sense.

Note that if you don't provide a value for case, the short circuiting works as you expect:

case
when (String === 1) && proc{|x| p x} === 1
 :yes
else
 :no
end

I suppose ruby could be modified to do what you want, but it could break existing code.  Note that for || expressions, there is already special case syntax for short circuiting:

case 1
when String, proc { |x| x.blah } # String === 1 || proc { |x| x.blah } === 1
  :something
else
  :no
end
----------------------------------------
Bug #8398: case/when shouldn't try to evaluate all AND joined conditions if one of preceding was falsy 
https://bugs.ruby-lang.org/issues/8398#change-39282

Author: goshakkk (Gosha Arinich)
Status: Open
Priority: Normal
Assignee: 
Category: 
Target version: 
ruby -v: 1.9.3, 2.0.0
Backport: 1.9.3: UNKNOWN, 2.0.0: UNKNOWN


=begin

Steps to reproduce:

 case 1
 when String && proc { |x| x.blah }
   :something
 else
   :no
 end

Here is how I thought it works: goes to the first 'when', evals the first condition ((({1 === String}))), sees it's false and proceeds to the next (({when})) (or (({else}))) and happily returns (({:no})).

As it turns out, even if one of AND joined conditions was false, ruby would still try to eval other conditions, and as soon as it calls the block with 1, (({NoMethodError})) gets thrown as there is no (({#blah})) on Integer.

I believe this is incorrect behavior and conditions with AND in case/when should behave like everywhere else.

=end



-- 
http://bugs.ruby-lang.org/

In This Thread