ba9d5e1
--- tar-1.15.1/src/create.c.sparseTotals	2005-07-27 11:10:38.000000000 +0200
ba9d5e1
+++ tar-1.15.1/src/create.c	2005-07-27 11:10:50.000000000 +0200
ba9d5e1
@@ -332,16 +332,20 @@
ba9d5e1
 }
ba9d5e1
 
ba9d5e1
 
ba9d5e1
-/* A file is not dumpable if
ba9d5e1
+/* A file is considered dumpable if it is sparse and both --sparse and --totals
ba9d5e1
+   are specified.
ba9d5e1
+   Otherwise, it is dumpable unless any of the following conditions occur:
ba9d5e1
+   
ba9d5e1
    a) it is empty *and* world-readable, or
ba9d5e1
    b) current archive is /dev/null */
ba9d5e1
 
ba9d5e1
 bool
ba9d5e1
 file_dumpable_p (struct tar_stat_info *st)
ba9d5e1
 {
ba9d5e1
-  return !(dev_null_output
ba9d5e1
-	   || (st->archive_file_size == 0
ba9d5e1
-	       && (st->stat.st_mode & MODE_R) == MODE_R));
ba9d5e1
+  if (dev_null_output)
ba9d5e1
+    return totals_option && sparse_option && sparse_file_p (st);
ba9d5e1
+  return !(st->archive_file_size == 0
ba9d5e1
+	   && (st->stat.st_mode & MODE_R) == MODE_R);
ba9d5e1
 }
ba9d5e1
 
ba9d5e1
 
ba9d5e1
@@ -1437,7 +1441,7 @@
ba9d5e1
 	  else
ba9d5e1
 	    fd = -1;
ba9d5e1
 
ba9d5e1
-	  if (sparse_option && sparse_file_p (st))
ba9d5e1
+	  if (fd != -1 && sparse_option && sparse_file_p (st))
ba9d5e1
 	    {
ba9d5e1
 	      status = sparse_dump_file (fd, st);
ba9d5e1
 	      if (status == dump_status_not_implemented)