[PHP-BUG] Bug #60694 [NEW]: print() results in bad logic

2012-01-09 Thread MarkAndrewSlade at gmail dot com
From: 
Operating system: CentOS release 5.4 (Final)
PHP version:  5.3.8
Package:  Scripting Engine problem
Bug Type: Bug
Bug description:print() results in bad logic

Description:

Unlike echo, the print construct is allowed inside logic clauses.  If it is

reached (not short-circuited), it will cause the rest of that clause to be
true.  
Tested with 5.3.8 and PHP 5.3.9RC5-dev, both with default configure.



Test script:
---


Expected result:

The word "Pass" five times.

Actual result:
--
The middle three fail.  The first and last pass, and are included to
demonstrate 
the limits of the bug.

-- 
Edit bug report at https://bugs.php.net/bug.php?id=60694&edit=1
-- 
Try a snapshot (PHP 5.4):
https://bugs.php.net/fix.php?id=60694&r=trysnapshot54
Try a snapshot (PHP 5.3):
https://bugs.php.net/fix.php?id=60694&r=trysnapshot53
Try a snapshot (trunk):  
https://bugs.php.net/fix.php?id=60694&r=trysnapshottrunk
Fixed in SVN:
https://bugs.php.net/fix.php?id=60694&r=fixed
Fixed in SVN and need be documented: 
https://bugs.php.net/fix.php?id=60694&r=needdocs
Fixed in release:
https://bugs.php.net/fix.php?id=60694&r=alreadyfixed
Need backtrace:  
https://bugs.php.net/fix.php?id=60694&r=needtrace
Need Reproduce Script:   
https://bugs.php.net/fix.php?id=60694&r=needscript
Try newer version:   
https://bugs.php.net/fix.php?id=60694&r=oldversion
Not developer issue: 
https://bugs.php.net/fix.php?id=60694&r=support
Expected behavior:   
https://bugs.php.net/fix.php?id=60694&r=notwrong
Not enough info: 
https://bugs.php.net/fix.php?id=60694&r=notenoughinfo
Submitted twice: 
https://bugs.php.net/fix.php?id=60694&r=submittedtwice
register_globals:
https://bugs.php.net/fix.php?id=60694&r=globals
PHP 4 support discontinued:  
https://bugs.php.net/fix.php?id=60694&r=php4
Daylight Savings:https://bugs.php.net/fix.php?id=60694&r=dst
IIS Stability:   
https://bugs.php.net/fix.php?id=60694&r=isapi
Install GNU Sed: 
https://bugs.php.net/fix.php?id=60694&r=gnused
Floating point limitations:  
https://bugs.php.net/fix.php?id=60694&r=float
No Zend Extensions:  
https://bugs.php.net/fix.php?id=60694&r=nozend
MySQL Configuration Error:   
https://bugs.php.net/fix.php?id=60694&r=mysqlcfg



Bug #60694 [Opn]: print() results in bad logic

2012-01-10 Thread MarkAndrewSlade at gmail dot com
Edit report at https://bugs.php.net/bug.php?id=60694&edit=1

 ID: 60694
 User updated by:MarkAndrewSlade at gmail dot com
 Reported by:MarkAndrewSlade at gmail dot com
 Summary:print() results in bad logic
 Status: Open
 Type:   Bug
 Package:Scripting Engine problem
 Operating System:   CentOS release 5.4 (Final)
 PHP Version:5.3.8
 Block user comment: N
 Private report: N

 New Comment:

Oh, I see what happened.  I agree with your recommendation.  The documentation 
says they are "not required" (implying optional), and they are used in the 
actual example.  I normally use echo, and without parens, so I just kinda 
randomly came across this.

I'm not sure if you were saying the parser's interpretation was invalid or 
mine, 
but in case the latter and this is considered correct parsing, the 
documentation 
should be updated to reflect that it's "print ", without parens.  
Developers can deduce for themselves that "print ('foo')" is allowed, but the 
semantics will be clearer.


Previous Comments:

[2012-01-10 10:24:08] phpmpan at mpan dot pl

Invalid interpretation of the code caused by misleading parenthenses.
1. false && print ('')
   -> false && (print (''))
   -> false && 1
   -> false
2. print('') && false
   -> (print (('') && false))
   -> (print false)
   -> 1
   -> true
3. print('') && false && false
   -> (print ((('') && false) && false))
   -> (print false)
   -> 1
   -> true
4. (print('') && false) && true
   -> ( print (('') && false) ) && true
   -> (print false) && true
   -> 1 && true
   -> true
5. (print('') && false) && false
   -> (print (('') && false) && false
   -> (print false) && false
   -> 1 && false
   -> false

I believe that documentation for all language constructs (`echo`, `include`, 
`print`, ...) should explicitly discourage use of parenthenses around 
arguments. They're very misleading.


[2012-01-10 02:26:21] MarkAndrewSlade at gmail dot com

Description:

Unlike echo, the print construct is allowed inside logic clauses.  If it is 
reached (not short-circuited), it will cause the rest of that clause to be 
true.  
Tested with 5.3.8 and PHP 5.3.9RC5-dev, both with default configure.



Test script:
---


Expected result:

The word "Pass" five times.

Actual result:
--
The middle three fail.  The first and last pass, and are included to 
demonstrate 
the limits of the bug.






-- 
Edit this bug report at https://bugs.php.net/bug.php?id=60694&edit=1