summaryrefslogtreecommitdiff
path: root/ext/hyperwave/hw.c
diff options
context:
space:
mode:
Diffstat (limited to 'ext/hyperwave/hw.c')
-rw-r--r--ext/hyperwave/hw.c28
1 files changed, 16 insertions, 12 deletions
diff --git a/ext/hyperwave/hw.c b/ext/hyperwave/hw.c
index cd4d8823ed..f1e807661c 100644
--- a/ext/hyperwave/hw.c
+++ b/ext/hyperwave/hw.c
@@ -225,13 +225,17 @@ int make_return_objrec(pval **return_value, char **objrecs, int count)
int make_return_array_from_objrec(pval **return_value, char *objrec) {
char *attrname, *str, *temp, language[3], *title;
int iTitle, iDesc, iKeyword;
- pval title_arr;
- pval desc_arr;
- pval keyword_arr;
+ zval *title_arr;
+ zval *desc_arr;
+ zval *keyword_arr;
int hasTitle = 0;
int hasDescription = 0;
int hasKeyword = 0;
+ title_arr = (zval *) emalloc(sizeof(zval));
+ desc_arr = (zval *) emalloc(sizeof(zval));
+ keyword_arr = (zval *) emalloc(sizeof(zval));
+
if (array_init(*return_value) == FAILURE) {
(*return_value)->type = IS_STRING;
(*return_value)->value.str.val = empty_string;
@@ -248,21 +252,21 @@ int make_return_array_from_objrec(pval **return_value, char *objrec) {
iDesc = 0;
iKeyword = 0;
if(0 == strncmp(attrname, "Title=", 6)) {
- if ((hasTitle == 0) && (array_init(&title_arr) == FAILURE)) {
+ if ((hasTitle == 0) && (array_init(title_arr) == FAILURE)) {
return -1;
}
hasTitle = 1;
str += 6;
iTitle = 1;
} else if(0 == strncmp(attrname, "Description=", 12)) {
- if ((hasDescription == 0) && (array_init(&desc_arr) == FAILURE)) {
+ if ((hasDescription == 0) && (array_init(desc_arr) == FAILURE)) {
return -1;
}
hasDescription = 1;
str += 12;
iDesc = 1;
} else if(0 == strncmp(attrname, "Keyword=", 8)) {
- if ((hasKeyword == 0) && (array_init(&keyword_arr) == FAILURE)) {
+ if ((hasKeyword == 0) && (array_init(keyword_arr) == FAILURE)) {
return -1;
}
hasKeyword = 1;
@@ -279,11 +283,11 @@ int make_return_array_from_objrec(pval **return_value, char *objrec) {
title = str;
if(iTitle)
- add_assoc_string(&title_arr, language, title, 1);
+ add_assoc_string(title_arr, language, title, 1);
else if(iDesc)
- add_assoc_string(&desc_arr, language, title, 1);
+ add_assoc_string(desc_arr, language, title, 1);
else if(iKeyword)
- add_assoc_string(&keyword_arr, language, title, 1);
+ add_assoc_string(keyword_arr, language, title, 1);
}
attrname = strtok(NULL, "\n");
}
@@ -291,21 +295,21 @@ int make_return_array_from_objrec(pval **return_value, char *objrec) {
/* Add the title array, if we have one */
if(hasTitle) {
- zend_hash_update((*return_value)->value.ht, "Title", 6, &title_arr, sizeof(pval), NULL);
+ zend_hash_update((*return_value)->value.ht, "Title", 6, &title_arr, sizeof(zval *), NULL);
/* The title array can now be freed, but I don't know how */
}
if(hasDescription) {
/* Add the description array, if we have one */
- zend_hash_update((*return_value)->value.ht, "Description", 12, &desc_arr, sizeof(pval), NULL);
+ zend_hash_update((*return_value)->value.ht, "Description", 12, &desc_arr, sizeof(zval *), NULL);
/* The description array can now be freed, but I don't know how */
}
if(hasKeyword) {
/* Add the keyword array, if we have one */
- zend_hash_update((*return_value)->value.ht, "Keyword", 8, &keyword_arr, sizeof(pval), NULL);
+ zend_hash_update((*return_value)->value.ht, "Keyword", 8, &keyword_arr, sizeof(zval *), NULL);
/* The keyword array can now be freed, but I don't know how */
}