forked from php/php-src
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* PHP-5.4: fix bug #63462 (Magic methods called twice for unset protected properties) NEWS for bug #64011. See 77ee200 Fix bug #64011 (get_html_translation_table()) Fix News Update the arguments in the prototype of fpm_socket_unix_test_connect(). fixed build NEWS for bug #63893 Fixed inconsequential bug in strtr() Revert "Apply the fputcsv test fix to SplFileObject_fputcsv.phpt. Mea culpa." Revert "Update fputcsv() to escape all characters equally." Remove _GNU_SOURCE, add local heap sort The compiler can figure this out Remove unused block strtr() with 2nd param array - optimization Refactoring, bugs & leaks Optimize strtr w/ 2nd arg array
- Loading branch information
Showing
10 changed files
with
588 additions
and
122 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,74 @@ | ||
--TEST-- | ||
Test script to verify that magic methods should be called only once when accessing an unset property. | ||
--CREDITS-- | ||
Marco Pivetta <ocramius@gmail.com> | ||
--FILE-- | ||
<?php | ||
class Test { | ||
public $publicProperty; | ||
protected $protectedProperty; | ||
private $privateProperty; | ||
|
||
public function __construct() { | ||
unset( | ||
$this->publicProperty, | ||
$this->protectedProperty, | ||
$this->privateProperty | ||
); | ||
} | ||
|
||
function __get($name) { | ||
echo '__get ' . $name . "\n"; | ||
return $this->$name; | ||
} | ||
|
||
function __set($name, $value) { | ||
echo '__set ' . $name . "\n"; | ||
$this->$name = $value; | ||
} | ||
|
||
function __isset($name) { | ||
echo '__isset ' . $name . "\n"; | ||
return isset($this->$name); | ||
} | ||
} | ||
|
||
$test = new Test(); | ||
|
||
$test->nonExisting; | ||
$test->publicProperty; | ||
$test->protectedProperty; | ||
$test->privateProperty; | ||
isset($test->nonExisting); | ||
isset($test->publicProperty); | ||
isset($test->protectedProperty); | ||
isset($test->privateProperty); | ||
$test->nonExisting = 'value'; | ||
$test->publicProperty = 'value'; | ||
$test->protectedProperty = 'value'; | ||
$test->privateProperty = 'value'; | ||
|
||
?> | ||
|
||
--EXPECTF-- | ||
__get nonExisting | ||
|
||
Notice: Undefined property: Test::$nonExisting in %s on line %d | ||
__get publicProperty | ||
|
||
Notice: Undefined property: Test::$publicProperty in %s on line %d | ||
__get protectedProperty | ||
|
||
Notice: Undefined property: Test::$protectedProperty in %s on line %d | ||
__get privateProperty | ||
|
||
Notice: Undefined property: Test::$privateProperty in %s on line %d | ||
__isset nonExisting | ||
__isset publicProperty | ||
__isset protectedProperty | ||
__isset privateProperty | ||
__set nonExisting | ||
__set publicProperty | ||
__set protectedProperty | ||
__set privateProperty | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.