summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndi Gutmans <andi@php.net>1999-12-27 17:29:35 +0000
committerAndi Gutmans <andi@php.net>1999-12-27 17:29:35 +0000
commit27daca31f376a323462aeff76bc1b55bab7d8841 (patch)
treed818c3e39186b0bd77daba0b21e50415ed696d53
parent1ad06e428dc96a8b229d45fa31f754024f67e1cd (diff)
downloadphp-git-27daca31f376a323462aeff76bc1b55bab7d8841.tar.gz
- Make zend_internal_function allocate a full zend_function structure so
that we don't get memory overruns and Thies doesn't get angry :)
-rw-r--r--Zend/zend_API.c15
1 files changed, 8 insertions, 7 deletions
diff --git a/Zend/zend_API.c b/Zend/zend_API.c
index 0cd1433ce1..9f8d4bba81 100644
--- a/Zend/zend_API.c
+++ b/Zend/zend_API.c
@@ -676,7 +676,8 @@ ZEND_API int _register_list_destructors(void (*list_destructor)(void *), void (*
int zend_register_functions(zend_function_entry *functions, HashTable *function_table)
{
zend_function_entry *ptr = functions;
- zend_internal_function internal_function;
+ zend_function function;
+ zend_internal_function *internal_function = &function;
int count=0,unload=0;
HashTable *target_function_table = function_table;
CLS_FETCH();
@@ -684,18 +685,18 @@ int zend_register_functions(zend_function_entry *functions, HashTable *function_
if (!target_function_table) {
target_function_table = CG(function_table);
}
- internal_function.type = ZEND_INTERNAL_FUNCTION;
+ internal_function->type = ZEND_INTERNAL_FUNCTION;
while (ptr->fname) {
- internal_function.handler = ptr->handler;
- internal_function.arg_types = ptr->func_arg_types;
- internal_function.function_name = ptr->fname;
- if (!internal_function.handler) {
+ internal_function->handler = ptr->handler;
+ internal_function->arg_types = ptr->func_arg_types;
+ internal_function->function_name = ptr->fname;
+ if (!internal_function->handler) {
zend_error(E_CORE_WARNING,"Null function defined as active function");
zend_unregister_functions(functions, count, target_function_table);
return FAILURE;
}
- if (zend_hash_add(target_function_table, ptr->fname, strlen(ptr->fname)+1, &internal_function, sizeof(zend_internal_function), NULL) == FAILURE) {
+ if (zend_hash_add(target_function_table, ptr->fname, strlen(ptr->fname)+1, &function, sizeof(zend_function), NULL) == FAILURE) {
unload=1;
break;
}