summaryrefslogtreecommitdiff
path: root/fileio.c
diff options
context:
space:
mode:
authorWayne Davison <wayned@samba.org>2010-11-06 09:57:23 -0700
committerWayne Davison <wayned@samba.org>2010-11-06 10:13:16 -0700
commit96e051c86abc046034b371b75709ecb597497c63 (patch)
tree7e0b2e86f7f3a2456f269abc0d261f18a6a632bf /fileio.c
parent55f767c5caab53386e17686c69dd1bfe5afe752e (diff)
downloadrsync-96e051c86abc046034b371b75709ecb597497c63.tar.gz
rsync-96e051c86abc046034b371b75709ecb597497c63.tar.bz2
rsync-96e051c86abc046034b371b75709ecb597497c63.zip
Use ftruncate() at the end of a --sparse file.
Fixes bug 7337.
Diffstat (limited to 'fileio.c')
-rw-r--r--fileio.c28
1 files changed, 16 insertions, 12 deletions
diff --git a/fileio.c b/fileio.c
index 0faa6195..d8ac0974 100644
--- a/fileio.c
+++ b/fileio.c
@@ -28,24 +28,32 @@
extern int sparse_files;
-static char last_byte;
static OFF_T sparse_seek = 0;
-int sparse_end(int f)
+int sparse_end(int f, OFF_T size)
{
int ret;
if (!sparse_seek)
return 0;
- do_lseek(f, sparse_seek-1, SEEK_CUR);
- sparse_seek = 0;
+#ifdef HAVE_FTRUNCATE
+ ret = do_ftruncate(f, size);
+#else
+ if (do_lseek(f, sparse_seek-1, SEEK_CUR) != size-1)
+ ret = -1;
+ else {
+ do {
+ ret = write(f, "", 1);
+ } while (ret < 0 && errno == EINTR);
+
+ ret = ret <= 0 ? -1 : 0;
+ }
+#endif
- do {
- ret = write(f, "", 1);
- } while (ret < 0 && errno == EINTR);
+ sparse_seek = 0;
- return ret <= 0 ? -1 : 0;
+ return ret;
}
@@ -57,10 +65,6 @@ static int write_sparse(int f, char *buf, int len)
for (l1 = 0; l1 < len && buf[l1] == 0; l1++) {}
for (l2 = 0; l2 < len-l1 && buf[len-(l2+1)] == 0; l2++) {}
- /* XXX Riddle me this: why does this function SLOW DOWN when I
- * remove the following (unneeded) line?? Core Duo weirdness? */
- last_byte = buf[len-1];
-
sparse_seek += l1;
if (l1 == len)