ID: 25329
Updated by: [EMAIL PROTECTED]
Reported By: firepages at firepages dot com dot au
-Status: Open
+Status: Verified
Bug Type: SQLite related
Operating System: win XP
-PHP Version: 4.3.3
+PHP Version: 5.0.0b2-dev, 4.3.3
New Comment:
PECL_4_3:
/usr/src/web/php/php4_3/Zend/zend_hash.c(544) : ht=0x08212634 is being
destroyed
/usr/src/web/php/php4_3/Zend/zend_hash.c(108) : Bailed out without a
bailout address!
HEAD:
Program received signal SIGSEGV, Segmentation fault.
[Switching to Thread 1024 (runnable)]
_efree (ptr=0x0) at /usr/src/web/php/php5/Zend/zend_alloc.c:257
257 CALCULATE_REAL_SIZE_AND_CACHE_INDEX(p->size);
(gdb) bt
#0 _efree (ptr=0x0) at /usr/src/web/php/php5/Zend/zend_alloc.c:257
#1 0x816cdfb in _zval_ptr_dtor (zval_ptr=0x4029bac4) at
/usr/src/web/php/php5/Zend/zend_execute.h:67
#2 0x80b80c2 in php_sqlite_callback_invalidator (funcs=0x4029babc) at
/usr/src/web/php/php5/ext/sqlite/sqlite.c:288
#3 0x80b8110 in php_sqlite_callback_dtor (pDest=0x4029babc) at
/usr/src/web/php/php5/ext/sqlite/sqlite.c:310
#4 0x817a738 in zend_hash_destroy (ht=0x4029b8ec) at
/usr/src/web/php/php5/Zend/zend_hash.c:513
#5 0x80b813c in php_sqlite_db_dtor (rsrc=0x4029b95c) at
/usr/src/web/php/php5/ext/sqlite/sqlite.c:321
#6 0x817bb4d in list_entry_destructor (ptr=0x4029b95c) at
/usr/src/web/php/php5/Zend/zend_list.c:178
#7 0x817a89e in zend_hash_apply_deleter (ht=0x8349f10, p=0x4029b924)
at /usr/src/web/php/php5/Zend/zend_hash.c:568
#8 0x817a9da in zend_hash_graceful_reverse_destroy (ht=0x8349f10) at
/usr/src/web/php/php5/Zend/zend_hash.c:634
#9 0x817bc56 in zend_destroy_rsrc_list (ht=0x8349f10) at
/usr/src/web/php/php5/Zend/zend_list.c:234
#10 0x816cc93 in shutdown_executor () at
/usr/src/web/php/php5/Zend/zend_execute_API.c:279
#11 0x817555f in zend_deactivate () at
/usr/src/web/php/php5/Zend/zend.c:795
#12 0x8149224 in php_request_shutdown (dummy=0x0) at
/usr/src/web/php/php5/main/main.c:1197
#13 0x81ab61e in main (argc=2, argv=0xbffff694) at
/usr/src/web/php/php5/sapi/cli/php_cli.c:1013
#14 0x401b19cb in __libc_start_main (main=0x81aa848 <main>, argc=2,
argv=0xbffff694, init=0x8070368 <_init>,
fini=0x81abbe4 <_fini>, rtld_fini=0x4000aea0 <_dl_fini>,
stack_end=0xbffff68c)
at ../sysdeps/generic/libc-start.c:92
Previous Comments:
------------------------------------------------------------------------
[2003-08-31 00:00:32] firepages at firepages dot com dot au
Description:
------------
when trying to use sqlite_create_function() & passing a class method of
$this apache dies orribly (appreciate it may be an apache issue)
Win XP Pro / php 4.3.3 compiled (MSVC) against apache 2.0.47
eg
sqlite_create_function($this->db, 'link_keywords', array(
$this,'linkers' ) , 1);
/*OR*/
sqlite_create_function($this->db, 'link_keywords', array(
&$this,'linkers' ) , 1);
note that calling an external class method or normal function
[array($ext_class,$method)]gives no problem , just methods of $this
not tested on apache 1.*
Reproduce code:
---------------
class sqlite_help{
function sqlite_help(){
$this->db = sqlite_open('e:/phpdev/cp/my_admin.sqldb.eng', 0666,
$sqliteerror);
sqlite_create_function($this->db, 'link_keywords', array( $this ,
'linkers') , 1);
return $this->db;
}
function get_single( $key ){
$res = sqlite_query( $this->db,"SELECT link_keywords(var) FROM
my_admin WHERE key = '$key'" );
$r = sqlite_fetch_array( $res , SQLITE_NUM );
return $r[0];
}
function linkers( $str ){
$keywords = array('phpmyadmin'=>'<a
href="http://localhost/phpmyadmin/index.php"">phpMyAdmin</a>');
foreach($keywords as $k=>$v){$str = str_replace( $k , $v , $str );}
return nl2br( $str );
}
}
$yaks=new sqlite_help();
echo $yaks->get_single('general');
Expected result:
----------------
str_replaced data from DB
works if function is external or external class method
Actual result:
--------------
an MS 'Apache has encountered an ....' etc Dialog no apache error log
available , no PHP error logged.
------------------------------------------------------------------------
--
Edit this bug report at http://bugs.php.net/?id=25329&edit=1