]> git.ipfire.org Git - thirdparty/tar.git/commitdiff
(gnu_restore): Renamed to purge_directory().
authorSergey Poznyakoff <gray@gnu.org.ua>
Tue, 29 Jun 2004 10:11:46 +0000 (10:11 +0000)
committerSergey Poznyakoff <gray@gnu.org.ua>
Tue, 29 Jun 2004 10:11:46 +0000 (10:11 +0000)
Do not attempt to purge the directory if it is on a different
device and one_file_system_option is set.

src/incremen.c

index 5e853f6bf658b74611ada2aab92dc2f5c5a674aa..1ef55e55add66cd85ae86324e836639fdc29dc98 100644 (file)
@@ -460,10 +460,9 @@ write_directory_file (void)
 /* Restoration of incremental dumps.  */
 
 /* Examine the directories under directory_name and delete any
-   files that were not there at the time of the back-up.
-   FIXME: The function name is obviously a misnomer */
+   files that were not there at the time of the back-up. */
 void
-gnu_restore (char const *directory_name)
+purge_directory (char const *directory_name)
 {
   char *archive_dir;
   char *current_dir;
@@ -516,13 +515,30 @@ gnu_restore (char const *directory_name)
        }
       if (*arc == '\0')
        {
+         struct stat st;
          char *p = new_name (directory_name, cur);
+
+         if (deref_stat (true, p, &st))
+           {
+             stat_diag (p);
+             WARN((0, 0, _("%s: Not purging directory %s: unable to stat"),
+                   quotearg_colon (p)));
+             continue; 
+           }
+         else if (one_file_system_option && st.st_dev != root_device)
+           {
+             WARN((0, 0,
+                   _("%s: directory %s is on a different device: not purging"),
+                   quotearg_colon (p)));
+             continue;
+           }
+           
          if (! interactive_option || confirm ("delete", p))
            {
              if (verbose_option)
                fprintf (stdlis, _("%s: Deleting %s\n"),
                         program_name, quote (p));
-             if (! remove_any_file (p, 1))
+             if (! remove_any_file (p, RECURSIVE_REMOVE_OPTION))
                {
                  int e = errno;
                  ERROR ((0, e, _("%s: Cannot remove"), quotearg_colon (p)));