From: merch-redmine@... Date: 2015-03-06T23:02:17+00:00 Subject: [ruby-core:68449] [Ruby trunk - Bug #10947] Multiline if statement returns unexpected value instead of raising a syntax error Issue #10947 has been updated by Jeremy Evans. Sam Davies wrote: > Here is an invalid multiline if statement > > if (false && > false && > false > true) This is valid syntax. ruby parses this as: ~~~ if (false && false && false; true) ~~~ This is expected behavior, and changing how ruby handles this would break working code. ---------------------------------------- Bug #10947: Multiline if statement returns unexpected value instead of raising a syntax error https://bugs.ruby-lang.org/issues/10947#change-51797 * Author: Sam Davies * Status: Open * Priority: Normal * Assignee: * ruby -v: 2.1.2 * Backport: 2.0.0: UNKNOWN, 2.1: UNKNOWN, 2.2: UNKNOWN ---------------------------------------- Here is an invalid multiline if statement if (false && false && false true) puts "I was expecting an exception but saw this message instead" end As far as I can tell this is and should never be interpreted as valid syntax. What actually happens is instead of raising an exception, ruby ignores all values except the last and only evaluates that. If you forget a && at the end of a line this can result in very unexpected behavior. -- https://bugs.ruby-lang.org/