ID:               22288
 User updated by:  andre dot goncalves at martelozero dot com
 Reported By:      andre dot goncalves at martelozero dot com
 Status:           Open
 Bug Type:         Variables related
 Operating System: Linux
 PHP Version:      4.3.1-dev
 New Comment:

Ok, I'm sorry I didn't get any answer from you guys.

The problem is solved. I don't know how, but it suddenly stoped, after
I made some random and desperate changes in the code somewhere.

What I will never understand is what kind of error in my code, that is
not detected by PHP causes such abnormal behaviour.

PHP did not return any Notice, Warning, or Error message, it simply
went beserk with variables. I don't really understand much about this
issues, but someone told me that the stack was getting corrupted, and
to look for recursive function calls. (there were none)

Anyway I think that this issue should be investigated. Not just simply
say that there were "serious issues" with my code. Off course there
were, but certainly not with cookies.

The thing is, if there is a reason for PHP to go nuts, it should issue
some kind of warning (like it normally does).

Thanks anyway

Keep up developing this amazing thing.


Previous Comments:
------------------------------------------------------------------------

[2003-02-19 04:40:10] andre dot goncalves at martelozero dot com

What do you mean by serious issues? Maybe you don't understand the
questions I made, or the absurd behaviour that I describe - or in the
other hand, maybe I don't understand that some stupid error I made
somewhere (with cookies you say) might cause this strange behaviour of
PHP (you sound very natural about it).

Well I have some serious questions:

1. What's the relation between cookies and the Empty + Unavailable +
Unassignable local variables and function parameters in the method's
implementation?

2. What causes the script to go crazy in terms of variable value
assignment?

3. Why do local vars fail to accept values from a certain point on?

4. Hhy it only happens the first time the script runs, and why only in
the second time the method is called? After a code-induced &
cookie-related error, you say?
 
5. How does a variable echo a value that it was not assigned? Again,
how does $this->tmp2 = "whatever" makes $_query = "whatever"? And why
var_dump'ing ($_query) returns NULL?

6. Why $localvar = "foo", does not make $localvar = "foo", i.e., why
local vars and parameters are unavailable and unassignable?

Thanks

------------------------------------------------------------------------

[2003-02-18 23:52:01] [EMAIL PROTECTED]

Your script has serious issues...it sets some cookies?
It also has some errors, apparently caused by the missing
cookie value? This really doesn't seem like any 
problem in PHP..


------------------------------------------------------------------------

[2003-02-18 23:26:04] andre dot goncalves at martelozero dot com

Hi! this is really a spooky situation!  

A. problem with a class only happening in one site (other
implementations use same class and always worked fine).

B. It only happens the first time I hit the site. 

C. press F5, or re-enter address, and the problem is gone. 

D. restarting browser, causes the problem again. 

E. problem is: 

The 2nd time I call a method on a certain object, 
neither the method parameters, neither the global vars are 
acessible, only the pre-declared class members are there.

Remember, i have made a call to this method in the same script
exexcutation, some 20 lines before.

F. Even more spooky, some vars tend to echo values (wrong 
values) but var_dump shows NULL for the same var, 
right from the next line of code!!! 

G. Check below example: 

output 1, 3 and 4 show vardump of function parameters NULL 

ouput 2 shows that local var $_query (the function's parameter $_query)
receives the return value of the previous function foofunction() call

output 3 shows that variable is in fact NULL 

output 5 shows that local var is not accessible 

output 6 shows that global var is accessible 

output 7 and 8 shows class members ok 

output 9 and 10 shows assigning local vars impossible!!!! 

H. Don't belive me? TEST IT: 

http://66.220.28.17/zero/index.php 


Looks like assignment of variables is totally messed up (currupt?) 

The script is like dead: I also tried unseting the global 
instance of $mydbclass and recreating it, but I get NULL 
if I vardump the new instance!!! 

Please help me on this one! 


//:: CODE EXTRACT FOLLOWS 

//:: test function 
function foofunction($_bla) { 
return "YOUR BLAH: ".$_bla; 
} 

$fooglobal= "fooglobal"; 

// function call 
$mydbclass->query("select id from user"); 

//class definition 
class mydbclass { 

var $version = 1.0 

function mydbclass() { 
$this->connect(); } 

// more class methods ... 

function query($_query = "foo", $_fooparam = "bar") { 
global $fooglobal; 
global $queryix; 

$queryix++; 
$foolocal = "foolocal"; 
$this->foonewmember = "foonewmember"; 

echo "($queryix) _query="; 
var_dump($_query);echo BR; 
//:: 1 outputs: (2) _query=NULL 

if (!($this->tmp = mysql_query($_query))) { ; 

$this->tmp2 = $this->bla("select id from zero_user"); 

echo "_query echo="; 
echo($_query); 
//::2 outputs: _query echo=YOUR BLAH: bla bla 

echo "_query dump="; 
var_dump($_query); 
//::3 ouputs: _query dump=NULL 

echo "_fooparam="; 
var_dump($_fooparam); 
//::4 ouputs: fooparam=NULL 

echo "globalfoo="; 
var_dump($fooglobal); 
//::5 ouputs: fooglobal=fooglobal 

echo "foolocal="; 
var_dump($foolocal); 
//::6 ouputs: foolocal=NULL 

echo "foonewmember="; 
var_dump($this->foonewmember); 
//::7 ouputs: foonewmember=string(12) "foonewmember" 

echo "foooldmember="; 
var_dump($this->foooldmember); 
//::8 ouputs: foooldmember=string(9) "foooldmember" 

echo "result1="; 
var_dump($this->result1); 
//::9 ouputs: result1=bool(false) 

echo "result2="; 
var_dump($this->result2); 
//::10 ouputs: result2=NULL 

} 

// more class methods ... 

} // end of class 




__________________
Thanks,

André Gonçalves



------------------------------------------------------------------------


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

Reply via email to