--- /dev/null
+--TEST--
+Bug #47320 ($php_errormsg out of scope in functions)
+--INI--
+display_errors=0
+track_errors=1
+--FILE--
+<?php
+if (!@substr('no 2nd parameter')) {
+ echo '$php_errormsg in global: ' . $php_errormsg . "\n";
+}
+
+function foo() {
+ if (!@strpos('no 2nd parameter')) {
+ echo '$php_errormsg in function: ' . $php_errormsg . "\n";
+
+ echo '$GLOBALS[php_errormsg] in function: ' .
+ $GLOBALS['php_errormsg'] . "\n";
+ }
+}
+
+foo();
+?>
+--EXPECT--
+$php_errormsg in global: substr() expects at least 2 parameters, 1 given
+$php_errormsg in function: strpos() expects at least 2 parameters, 1 given
+$GLOBALS[php_errormsg] in function: substr() expects at least 2 parameters, 1 given
return;
}
- if (EG(symtable_cache_ptr)>=EG(symtable_cache)) {
- /*printf("Cache hit! Reusing %x\n", symtable_cache[symtable_cache_ptr]);*/
- EG(active_symbol_table) = *(EG(symtable_cache_ptr)--);
- } else {
- ALLOC_HASHTABLE(EG(active_symbol_table));
- zend_hash_init(EG(active_symbol_table), 0, NULL, ZVAL_PTR_DTOR, 0);
- /*printf("Cache miss! Initialized %x\n", EG(active_symbol_table));*/
- }
if (ex && ex->op_array) {
+ if (EG(symtable_cache_ptr)>=EG(symtable_cache)) {
+ /*printf("Cache hit! Reusing %x\n", symtable_cache[symtable_cache_ptr]);*/
+ EG(active_symbol_table) = *(EG(symtable_cache_ptr)--);
+ } else {
+ ALLOC_HASHTABLE(EG(active_symbol_table));
+ zend_hash_init(EG(active_symbol_table), 0, NULL, ZVAL_PTR_DTOR, 0);
+ /*printf("Cache miss! Initialized %x\n", EG(active_symbol_table));*/
+ }
ex->symbol_table = EG(active_symbol_table);
if (ex->op_array->this_var != -1 &&
php_error(type, "%s", message);
efree(message);
- if (PG(track_errors) && module_initialized && EG(active_symbol_table) &&
+ if (PG(track_errors) && module_initialized &&
(!EG(user_error_handler) || !(EG(user_error_handler_error_reporting) & type))) {
- zval *tmp;
- ALLOC_INIT_ZVAL(tmp);
- ZVAL_RT_STRINGL(tmp, buffer, buffer_len, 1);
- zend_ascii_hash_update(EG(active_symbol_table), "php_errormsg", sizeof("php_errormsg"), (void **) &tmp, sizeof(zval *), NULL);
+ if (!EG(active_symbol_table)) {
+ zend_rebuild_symbol_table(TSRMLS_C);
+ }
+ if (EG(active_symbol_table)) {
+ zval *tmp;
+ ALLOC_INIT_ZVAL(tmp);
+ ZVAL_RT_STRINGL(tmp, buffer, buffer_len, 1);
+ zend_ascii_hash_update(EG(active_symbol_table), "php_errormsg", sizeof("php_errormsg"), (void **) &tmp, sizeof(zval *), NULL);
+ }
}
efree(buffer);
}
efree(buffer);
return;
}
- if (PG(track_errors) && module_initialized && EG(active_symbol_table)) {
- zval *tmp;
+ if (PG(track_errors) && module_initialized) {
+ if (!EG(active_symbol_table)) {
+ zend_rebuild_symbol_table(TSRMLS_C);
+ }
+ if (EG(active_symbol_table)) {
+ zval *tmp;
- ALLOC_INIT_ZVAL(tmp);
- ZVAL_RT_STRINGL(tmp, buffer, buffer_len, 1);
- zend_ascii_hash_update(EG(active_symbol_table), "php_errormsg", sizeof("php_errormsg"), (void **) & tmp, sizeof(zval *), NULL);
+ ALLOC_INIT_ZVAL(tmp);
+ ZVAL_RT_STRINGL(tmp, buffer, buffer_len, 1);
+ zend_ascii_hash_update(EG(active_symbol_table), "php_errormsg", sizeof("php_errormsg"), (void **) & tmp, sizeof(zval *), NULL);
+ }
}
efree(buffer);
}