moriyoshi               Tue Feb 25 15:12:22 2003 EDT

  Modified files:              
    /php4/ext/standard  file.c 
  Log:
  Set fgetss() free from the length parameter
  
  
Index: php4/ext/standard/file.c
diff -u php4/ext/standard/file.c:1.313 php4/ext/standard/file.c:1.314
--- php4/ext/standard/file.c:1.313      Mon Feb 24 20:39:06 2003
+++ php4/ext/standard/file.c    Tue Feb 25 15:12:18 2003
@@ -21,7 +21,7 @@
    +----------------------------------------------------------------------+
  */
 
-/* $Id: file.c,v 1.313 2003/02/25 01:39:06 iliaa Exp $ */
+/* $Id: file.c,v 1.314 2003/02/25 20:12:18 moriyoshi Exp $ */
 
 /* Synced with php 3.0 revision 1.218 1999-06-16 [ssb] */
 
@@ -1668,19 +1668,24 @@
 }
 /* }}} */
 
-/* {{{ proto string fgetss(resource fp, int length [, string allowable_tags])
+/* {{{ proto string fgetss(resource fp [, int length, string allowable_tags])
    Get a line from file pointer and strip HTML tags */
 PHPAPI PHP_FUNCTION(fgetss)
 {
-       zval **fd, **bytes, **allow=NULL;
-       int len;
+       zval **fd, **bytes = NULL, **allow=NULL;
+       size_t len = 0;
        size_t actual_len, retval_len;
-       char *buf;
+       char *buf = NULL, *retval;
        php_stream *stream;
        char *allowed_tags=NULL;
        int allowed_tags_len=0;
 
        switch(ZEND_NUM_ARGS()) {
+       case 1:
+               if (zend_get_parameters_ex(1, &fd) == FAILURE) {
+                       RETURN_FALSE;
+               }
+               break;
        case 2:
                if (zend_get_parameters_ex(2, &fd, &bytes) == FAILURE) {
                        RETURN_FALSE;
@@ -1702,26 +1707,29 @@
 
        php_stream_from_zval(stream, fd);
 
-       convert_to_long_ex(bytes);
-       len = Z_LVAL_PP(bytes);
-    if (len < 0) {
-               php_error_docref(NULL TSRMLS_CC, E_WARNING, "Length parameter may not 
be negative");
-               RETURN_FALSE;
-    }
-
-       buf = emalloc(sizeof(char) * (len + 1));
-       /*needed because recv doesnt set null char at end*/
-       memset(buf, 0, len + 1);
+       if (bytes != NULL) {
+               convert_to_long_ex(bytes);
+               if (Z_LVAL_PP(bytes) < 0) {
+                       php_error_docref(NULL TSRMLS_CC, E_WARNING, "Length parameter 
may not be negative");
+                       RETURN_FALSE;
+               }
 
-       if (php_stream_get_line(stream, buf, len, &actual_len) == NULL) {
-               efree(buf);
+               len = (size_t) Z_LVAL_PP(bytes);
+               buf = emalloc(sizeof(char) * (len + 1));
+               /*needed because recv doesnt set null char at end*/
+               memset(buf, 0, len + 1);
+       }
+
+       if ((retval = php_stream_get_line(stream, buf, len, &actual_len)) == NULL)     
 {
+               if (buf != NULL) {
+                       efree(buf);
+               }
                RETURN_FALSE;
        }
 
-       /* strlen() can be used here since we are doing it on the return of an fgets() 
anyway */
-       retval_len = php_strip_tags(buf, actual_len, &stream->fgetss_state, 
allowed_tags, allowed_tags_len);
+       retval_len = php_strip_tags(retval, actual_len, &stream->fgetss_state, 
allowed_tags, allowed_tags_len);
 
-       RETURN_STRINGL(buf, retval_len, 0);
+       RETURN_STRINGL(retval, retval_len, 0);
 }
 /* }}} */
 



-- 
PHP CVS Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php

Reply via email to