summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorJim Meyering <jim@meyering.net>1997-09-15 13:24:43 +0000
committerJim Meyering <jim@meyering.net>1997-09-15 13:24:43 +0000
commitb4204ff74c557431aba7076db6946f545bc78932 (patch)
tree7a490ca7a7aed5e26ac91882079cbdeea6477638 /src
parent45853bf653708146f01b8d1c60dd90e545962667 (diff)
downloadcoreutils-b4204ff74c557431aba7076db6946f545bc78932.tar.xz
(remove_cwd_entries): Don't free entries -- they're alloca'd, now.
Diffstat (limited to 'src')
-rw-r--r--src/rm.c36
1 files changed, 21 insertions, 15 deletions
diff --git a/src/rm.c b/src/rm.c
index 7d357634c..2767a3572 100644
--- a/src/rm.c
+++ b/src/rm.c
@@ -543,6 +543,7 @@ remove_cwd_entries (void)
error (0, errno, "%s", full_filename ("."));
status = RM_ERROR;
}
+ dirp = NULL;
}
do
@@ -561,6 +562,10 @@ remove_cwd_entries (void)
while ((dp = readdir (dirp)) != NULL)
{
+ char *entry_name;
+ struct File_spec fs;
+ enum RM_status tmp_status;
+
/* Skip this entry if it's `.' or `..'. */
if (DOT_OR_DOTDOT (dp->d_name))
continue;
@@ -570,16 +575,21 @@ remove_cwd_entries (void)
if (ht && hash_find_item (ht, (dp)->d_name))
continue;
- {
- struct File_spec fs;
- enum RM_status tmp_status;
- fspec_init_dp (&fs, dp);
- tmp_status = rm (&fs, 0);
- /* Update status. */
- if (tmp_status > status)
- status = tmp_status;
- assert (VALID_STATUS (status));
- }
+ fspec_init_dp (&fs, dp);
+
+ /* Save a copy of the name of this entry, in case we have
+ to add it to the set of unremoved entries below. */
+ ASSIGN_STRDUPA (entry_name, dp->d_name);
+
+ /* CAUTION: after this call to rm, DP may not be valid --
+ it may have been freed due to a close in a recursive call
+ (through rm and remove_dir) to this function. */
+ tmp_status = rm (&fs, 0);
+
+ /* Update status. */
+ if (tmp_status > status)
+ status = tmp_status;
+ assert (VALID_STATUS (status));
/* If this entry was not removed (due either to an error or to
an interactive `no' response), record it in the hash table so
@@ -587,7 +597,6 @@ remove_cwd_entries (void)
if (status != RM_OK)
{
void *old_item;
- char *p;
int fail;
if (ht == NULL)
@@ -598,9 +607,7 @@ remove_cwd_entries (void)
if (ht == NULL)
error (1, 0, _("Memory exhausted"));
}
- p = xmalloc (NLENGTH (dp) + 1);
- memcpy (p, (dp)->d_name, NLENGTH (dp) + 1);
- fail = hash_insert_item (ht, p, &old_item);
+ fail = hash_insert_item (ht, entry_name, &old_item);
assert (old_item == NULL);
if (fail)
error (1, 0, _("Memory exhausted"));
@@ -621,7 +628,6 @@ remove_cwd_entries (void)
if (ht)
{
- hash_free_items (ht);
hash_free_table (ht);
free (ht);
}