ID:               35470
 User updated by:  prgallier at yahoo dot com
 Reported By:      prgallier at yahoo dot com
 Status:           Assigned
 Bug Type:         Scripting Engine problem
 Operating System: *
 PHP Version:      5CVS-2005-11-29 (cvs)
 Assigned To:      dmitry
 New Comment:

The following generates a segfault on my system:

function dotest()
{
  $link = mysql_connect("localhost","test","test");
  mysql_select_db("test");
  mysql_query("CREATE TABLE config (num smallint(5) unsigned NOT NULL
auto_increment, conf varchar(20) NOT NULL default '')");
  mysql_query("INSERT INTO config (conf,type) VALUES('Test1','33')");
  $result = mysql_query("SELECT conf,value FROM config");
  while ($row = mysql_fetch_row($result))
  {
    global ${$row[0]};
    ${$row[0]} = $row[1];
  }
  mysql_free_result($result);
}

dotest();
echo "Test: $test<br>\n";


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

[2005-11-29 13:09:49] [EMAIL PROTECTED]

Dmitry, can you check this out please.

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

[2005-11-29 11:33:26] prgallier at yahoo dot com

Oops...the expected and actual result fields are switched.

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

[2005-11-29 11:32:20] prgallier at yahoo dot com

Description:
------------
The below code does not store the value "55" in the variable "test" as
it should, and did in PHP 5.0.5.  Leaving out the global declaration
allows the output to display properly.  I have also had segmentation
faults caused by similar routines, but have been unable to reproduce
this outside of the full program.

Reproduce code:
---------------
$x = array("test", "55");
global ${$x[0]};
${$x[0]} = $x[1];
echo "Test: $test<br>\n";;


Expected result:
----------------
Displays:
Test: 

Actual result:
--------------
Should display:
Test: 55



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


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

Reply via email to