.
[platform/upstream/coreutils.git] / src / c99-to-c89.diff
1 Index: remove.c
2 ===================================================================
3 RCS file: /fetish/cu/src/remove.c,v
4 retrieving revision 1.145
5 diff -u -p -r1.145 remove.c
6 --- remove.c    11 Feb 2006 19:25:02 -0000      1.145
7 +++ remove.c    11 Feb 2006 20:28:15 -0000
8 @@ -202,9 +202,10 @@ pop_dir (Dirstack_state *ds)
9  {
10    size_t n_lengths = obstack_object_size (&ds->len_stack) / sizeof (size_t);
11    size_t *length = obstack_base (&ds->len_stack);
12 +  size_t top_len;
13  
14    assert (n_lengths > 0);
15 -  size_t top_len = length[n_lengths - 1];
16 +  top_len = length[n_lengths - 1];
17    assert (top_len >= 2);
18  
19    /* Pop the specified length of file name.  */
20 @@ -336,10 +337,11 @@ AD_stack_top (Dirstack_state const *ds)
21  static void
22  AD_stack_pop (Dirstack_state *ds)
23  {
24 +  struct AD_ent *top;
25    assert (0 < AD_stack_height (ds));
26  
27    /* operate on Active_dir.  pop and free top entry */
28 -  struct AD_ent *top = AD_stack_top (ds);
29 +  top = AD_stack_top (ds);
30    if (top->unremovable)
31      hash_free (top->unremovable);
32    obstack_blank (&ds->Active_dir, -(int) sizeof (struct AD_ent));
33 @@ -1019,6 +1021,7 @@ fd_to_subdirp (int fd_cwd, char const *f
34        return NULL;
35      }
36  
37 +  {
38    DIR *subdir_dirp = fdopendir (fd_sub);
39    if (subdir_dirp == NULL)
40      {
41 @@ -1027,6 +1030,7 @@ fd_to_subdirp (int fd_cwd, char const *f
42      }
43  
44    return subdir_dirp;
45 +  }
46  }
47  
48  /* Remove entries in the directory open on DIRP
49 @@ -1257,9 +1261,10 @@ remove_dir (int fd_cwd, Dirstack_state *
50         /* The name of the directory that we have just processed,
51            nominally removing all of its contents.  */
52         char *empty_dir;
53 +       int fd;
54  
55         AD_pop_and_chdir (&dirp, ds, &empty_dir);
56 -       int fd = (dirp != NULL ? dirfd (dirp) : AT_FDCWD);
57 +       fd = (dirp != NULL ? dirfd (dirp) : AT_FDCWD);
58         assert (dirp != NULL || AD_stack_height (ds) == 1);
59  
60         /* Try to remove EMPTY_DIR only if remove_cwd_entries succeeded.  */
61 @@ -1336,6 +1341,7 @@ rm_1 (Dirstack_state *ds, char const *fi
62    AD_push_initial (ds);
63    AD_INIT_OTHER_MEMBERS ();
64  
65 +  {
66    int fd_cwd = AT_FDCWD;
67    enum RM_status status = remove_entry (fd_cwd, ds, filename, x, NULL);
68    if (status == RM_NONEMPTY_DIR)
69 @@ -1352,6 +1358,7 @@ rm_1 (Dirstack_state *ds, char const *fi
70    ds_clear (ds);
71  
72    return status;
73 +  }
74  }
75  
76  /* Remove all files and/or directories specified by N_FILES and FILE.
77 @@ -1374,9 +1381,11 @@ rm (size_t n_files, char const *const *f
78         }
79  
80        cycle_check_init (&ds->cycle_check_state);
81 +      {
82        enum RM_status s = rm_1 (ds, file[i], x, &cwd_errno);
83        assert (VALID_STATUS (s));
84        UPDATE_STATUS (status, s);
85 +      }
86      }
87  
88    if (x->require_restore_cwd && cwd_errno)