felipe Mon Feb 4 19:48:14 2008 UTC
Modified files:
/php-src/ext/standard file.c
Log:
Fixed wrong fix
http://cvs.php.net/viewvc.cgi/php-src/ext/standard/file.c?r1=1.505&r2=1.506&diff_format=u
Index: php-src/ext/standard/file.c
diff -u php-src/ext/standard/file.c:1.505 php-src/ext/standard/file.c:1.506
--- php-src/ext/standard/file.c:1.505 Mon Feb 4 18:45:40 2008
+++ php-src/ext/standard/file.c Mon Feb 4 19:48:14 2008
@@ -21,7 +21,7 @@
+----------------------------------------------------------------------+
*/
-/* $Id: file.c,v 1.505 2008/02/04 18:45:40 felipe Exp $ */
+/* $Id: file.c,v 1.506 2008/02/04 19:48:14 felipe Exp $ */
/* Synced with php 3.0 revision 1.218 1999-06-16 [ssb] */
@@ -1359,22 +1359,22 @@
RETURN_NULL();
}
- if (write_len <= 0) {
+ php_stream_from_zval(stream, &zstream);
+
+ if (argc > 2 && write_len <= 0) {
RETURN_LONG(0);
}
- php_stream_from_zval(stream, &zstream);
-
if (Z_TYPE_P(zstring) == IS_UNICODE) {
+ if (write_len < 0 || write_len > Z_USTRLEN_P(zstring)) {
+ write_len = Z_USTRLEN_P(zstring);
+ }
/* 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;
- 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);
/* Convert data points back to code units */
@@ -1383,7 +1383,7 @@
}
} else {
convert_to_string(zstring);
- if (write_len > Z_STRLEN_P(zstring)) {
+ if (write_len < 0 || 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