felipe          Mon Feb  4 18:45:40 2008 UTC

  Modified files:              
    /php-src/ext/standard       file.c 
  Log:
  Fixed Bug #42057 (fwrite() writes data into file when length is given as a 
negative value)
  
http://cvs.php.net/viewvc.cgi/php-src/ext/standard/file.c?r1=1.504&r2=1.505&diff_format=u
Index: php-src/ext/standard/file.c
diff -u php-src/ext/standard/file.c:1.504 php-src/ext/standard/file.c:1.505
--- php-src/ext/standard/file.c:1.504   Mon Dec 31 07:12:15 2007
+++ php-src/ext/standard/file.c Mon Feb  4 18:45:40 2008
@@ -21,7 +21,7 @@
    +----------------------------------------------------------------------+
 */
 
-/* $Id: file.c,v 1.504 2007/12/31 07:12:15 sebastian Exp $ */
+/* $Id: file.c,v 1.505 2008/02/04 18:45:40 felipe Exp $ */
 
 /* Synced with php 3.0 revision 1.218 1999-06-16 [ssb] */
 
@@ -1359,22 +1359,20 @@
                RETURN_NULL();
        }
 
-       if (!write_len) {
+       if (write_len <= 0) {
                RETURN_LONG(0);
        }
 
        php_stream_from_zval(stream, &zstream);
 
        if (Z_TYPE_P(zstring) == IS_UNICODE) {
-               if (write_len >= 0) {
-                       /* Convert code units to data points */
-                       int32_t write_uchars = 0;
+               /* Convert code units to data points */
+               int32_t write_uchars = 0;
 
-                       U16_FWD_N(Z_USTRVAL_P(zstring), write_uchars, 
Z_USTRLEN_P(zstring), write_len);
-                       write_len = write_uchars;
-               }
+               U16_FWD_N(Z_USTRVAL_P(zstring), write_uchars, 
Z_USTRLEN_P(zstring), write_len);
+               write_len = write_uchars;
 
-               if (write_len < 0 || write_len > Z_USTRLEN_P(zstring)) {
+               if (write_len > Z_USTRLEN_P(zstring)) {
                        write_len = Z_USTRLEN_P(zstring);
                }
                ret = php_stream_write_unicode(stream, Z_USTRVAL_P(zstring), 
write_len);
@@ -1385,7 +1383,7 @@
                }
        } else {
                convert_to_string(zstring);
-               if (write_len < 0 || write_len > Z_STRLEN_P(zstring)) {
+               if (write_len > Z_STRLEN_P(zstring)) {
                        write_len = Z_STRLEN_P(zstring);
                }
 

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

Reply via email to