aboutsummaryrefslogtreecommitdiff
path: root/coreutils
diff options
context:
space:
mode:
Diffstat (limited to 'coreutils')
-rw-r--r--coreutils/ls.c8
-rw-r--r--coreutils/rm.c2
2 files changed, 5 insertions, 5 deletions
diff --git a/coreutils/ls.c b/coreutils/ls.c
index 7bbb19d6c..b9c07adf8 100644
--- a/coreutils/ls.c
+++ b/coreutils/ls.c
@@ -504,11 +504,11 @@ static struct dnode **list_dir(const char *path)
504 504
505 /* are we going to list the file- it may be . or .. or a hidden file */ 505 /* are we going to list the file- it may be . or .. or a hidden file */
506 if (entry->d_name[0] == '.') { 506 if (entry->d_name[0] == '.') {
507 if ((entry->d_name[1] == 0 || ( 507 if ((!entry->d_name[1] || (entry->d_name[1] == '.' && !entry->d_name[2]))
508 entry->d_name[1] == '.' 508 && !(all_fmt & DISP_DOT)
509 && entry->d_name[2] == 0)) 509 ) {
510 && !(all_fmt & DISP_DOT))
511 continue; 510 continue;
511 }
512 if (!(all_fmt & DISP_HIDDEN)) 512 if (!(all_fmt & DISP_HIDDEN))
513 continue; 513 continue;
514 } 514 }
diff --git a/coreutils/rm.c b/coreutils/rm.c
index 61e3e7010..e29073db8 100644
--- a/coreutils/rm.c
+++ b/coreutils/rm.c
@@ -40,7 +40,7 @@ int rm_main(int argc, char **argv)
40 do { 40 do {
41 const char *base = bb_get_last_path_component(*argv); 41 const char *base = bb_get_last_path_component(*argv);
42 42
43 if ((base[0] == '.') && (!base[1] || ((base[1] == '.') && !base[2]))) { 43 if (DOT_OR_DOTDOT(base)) {
44 bb_error_msg("cannot remove '.' or '..'"); 44 bb_error_msg("cannot remove '.' or '..'");
45 } else if (remove_file(*argv, flags) >= 0) { 45 } else if (remove_file(*argv, flags) >= 0) {
46 continue; 46 continue;