@- Fixed RFC1867 file upload under Windows (Zeev)

Fixed a memory leak
This commit is contained in:
Zeev Suraski 2000-02-15 22:51:18 +00:00
parent ea459657d1
commit 4a211a80fb
2 changed files with 16 additions and 4 deletions

View file

@ -192,7 +192,18 @@ void php_treat_data(int arg, char *str ELS_DC PLS_DC SLS_DC)
INIT_PZVAL(array_ptr);
switch (arg) {
case PARSE_POST:
zend_hash_add_ptr(&EG(symbol_table), "HTTP_POST_VARS", sizeof("HTTP_POST_VARS"), array_ptr, sizeof(pval *),NULL);
if (zend_hash_add_ptr(&EG(symbol_table), "HTTP_POST_VARS", sizeof("HTTP_POST_VARS"), array_ptr, sizeof(pval *),NULL)==FAILURE) {
zval **p;
/* This could happen if we're in RFC 1867 file upload */
/* The parsing portion of the POST reader should actually move
* to this function - Zeev
*/
zval_dtor(array_ptr);
FREE_ZVAL(array_ptr);
zend_hash_find(&EG(symbol_table), "HTTP_POST_VARS", sizeof("HTTP_POST_VARS"), (void **) &p);
array_ptr = *p;
}
break;
case PARSE_GET:
zend_hash_add_ptr(&EG(symbol_table), "HTTP_GET_VARS", sizeof("HTTP_GET_VARS"), array_ptr, sizeof(pval *),NULL);

View file

@ -67,8 +67,9 @@ static void php_mime_split(char *buf, int cnt, char *boundary)
state = 1;
eolsize = 2;
if(*(loc+len)==0x0a)
if(*(loc+len)==0x0a) {
eolsize = 1;
}
rem -= (loc - ptr) + len + eolsize;
ptr = loc + len + eolsize;
@ -217,7 +218,7 @@ static void php_mime_split(char *buf, int cnt, char *boundary)
bytes = 0;
SET_VAR_STRING(namebuf, estrdup("none"));
} else {
fp = fopen(fn, "w");
fp = fopen(fn, "wb");
if (!fp) {
php_error(E_WARNING, "File Upload Error - Unable to open temporary file [%s]", fn);
SAFE_RETURN;