sbase

suckless unix tools
git clone git://git.suckless.org/sbase
Log | Files | Refs | README | LICENSE

commit 556797632991c4458682aa4cc7399a69ac7c77a8
parent 8f9824e34bbf5a7c61a425ebfca93bff6364ecb9
Author: Tavian Barnes <tavianator@tavianator.com>
Date:   Sat, 22 Feb 2025 13:14:49 +0100

find: Don't exit successfully after errors

Diffstat:
Mfind.c | 4++++
1 file changed, 4 insertions(+), 0 deletions(-)

diff --git a/find.c b/find.c @@ -964,6 +964,7 @@ find(char *path, struct findhist *hist) if (do_stat(path, &st, hist) < 0) { weprintf("failed to stat %s:", path); + gflags.ret = 1; return; } @@ -985,6 +986,7 @@ find(char *path, struct findhist *hist) for (f = hist; f; f = f->next) { if (f->dev == st.st_dev && f->ino == st.st_ino) { weprintf("loop detected '%s' is '%s'\n", path, f->path); + gflags.ret = 1; return; } } @@ -995,6 +997,7 @@ find(char *path, struct findhist *hist) if (!(dir = opendir(path))) { weprintf("failed to opendir %s:", path); + gflags.ret = 1; /* should we just ignore this since we hit an error? */ if (gflags.depth) eval(root, &arg); @@ -1018,6 +1021,7 @@ find(char *path, struct findhist *hist) free(pathbuf); if (errno) { weprintf("readdir %s:", path); + gflags.ret = 1; closedir(dir); return; }