ID: 38504
Updated by: [EMAIL PROTECTED]
Reported By: kn1g at yahoo dot com dot br
Status: Bogus
Bug Type: Class/Object related
Operating System: Linux
PHP Version: 4.4.4
New Comment:
You can always add a note youself.
Previous Comments:
------------------------------------------------------------------------
[2006-08-19 02:45:09] kn1g at yahoo dot com dot br
I see, well, I think that class_exists function manual could have a
note warning about this (I didn't find this information anywhere).
------------------------------------------------------------------------
[2006-08-18 20:38:56] [EMAIL PROTECTED]
Classes are declared during the compile time.
So the class DOES exist and when you actually run the code, the if
condition evaluates to TRUE, hence return is executed.
This is expected behaviour.
------------------------------------------------------------------------
[2006-08-18 18:27:15] kn1g at yahoo dot com dot br
Description:
------------
class_exists with return appears to avoid setting a variable after a
class definition.
Avoiding the return inside the if block like work as expected:
<?
if(!class_exists('newclass')){
class newclass(){
}
}
$var_newclass = "newclass ok\n";
?>
But I couldn't find anything in the documentation explaining this
behaviour.
Reproduce code:
---------------
"class.php"
<?
if(class_exists('newclass')){
return;
}
class newclass{
function newclass(){
echo "hi\n";
}
}
$var_newclass = "newclass ok\n";
?>
"test.php"
<?
include("class.php");
new newclass;
echo $var_newclass;
?>
Expected result:
----------------
hi
newclass ok
Actual result:
--------------
hi
------------------------------------------------------------------------
--
Edit this bug report at http://bugs.php.net/?id=38504&edit=1