Shouldn't you also be comparing device? Inode is not necessarily unique.
At 03:29 AM 3/3/2005 +0000, Ilia Alshanetsky wrote:
iliaa Wed Mar 2 22:29:24 2005 EDT
Modified files: /php-src/ext/standard file.c Log: Fixed bug #32160 (file truncation in copy() when source & destination are the same).
http://cvs.php.net/diff.php/php-src/ext/standard/file.c?r1=1.398&r2=1.399&ty=u Index: php-src/ext/standard/file.c diff -u php-src/ext/standard/file.c:1.398 php-src/ext/standard/file.c:1.399 --- php-src/ext/standard/file.c:1.398 Thu Feb 17 08:56:49 2005 +++ php-src/ext/standard/file.c Wed Mar 2 22:29:23 2005 @@ -21,7 +21,7 @@ +----------------------------------------------------------------------+ */
-/* $Id: file.c,v 1.398 2005/02/17 13:56:49 hyanantha Exp $ */ +/* $Id: file.c,v 1.399 2005/03/03 03:29:23 iliaa Exp $ */
/* Synced with php 3.0 revision 1.218 1999-06-16 [ssb] */
@@ -1699,6 +1699,12 @@
{
php_stream *srcstream = NULL, *deststream = NULL;
int ret = FAILURE;
+ struct stat src_s, dest_s;
+
+ /* safety check to ensure that source & destination files are not the same file */
+ if (stat(src, &src_s) || (stat(dest, &dest_s) == 0 && src_s.st_ino == dest_s.st_ino)) {
+ return ret;
+ }
srcstream = php_stream_open_wrapper(src, "rb", STREAM_DISABLE_OPEN_BASEDIR | REPORT_ERRORS, NULL);
-- PHP CVS Mailing List (http://www.php.net/) To unsubscribe, visit: http://www.php.net/unsub.php
-- PHP CVS Mailing List (http://www.php.net/) To unsubscribe, visit: http://www.php.net/unsub.php