diff options
author | vda <vda@69ca8d6d-28ef-0310-b511-8ec308f3f277> | 2006-12-23 00:49:10 +0000 |
---|---|---|
committer | vda <vda@69ca8d6d-28ef-0310-b511-8ec308f3f277> | 2006-12-23 00:49:10 +0000 |
commit | d5dd7716747effab3ebbe891ec21ba753499aa33 (patch) | |
tree | 79b9cc0ea2e0077dc8e78c1adc6a61c6992becba /libbb | |
parent | fcdd3306620f9cf2317f222eebc7c0eced9d8a07 (diff) | |
download | busybox-w32-d5dd7716747effab3ebbe891ec21ba753499aa33.tar.gz busybox-w32-d5dd7716747effab3ebbe891ec21ba753499aa33.tar.bz2 busybox-w32-d5dd7716747effab3ebbe891ec21ba753499aa33.zip |
find: fix spurious -exec error messages
(bug reported by Bernhard Fischer <rep.nop@aon.at>)
git-svn-id: svn://busybox.net/trunk/busybox@17060 69ca8d6d-28ef-0310-b511-8ec308f3f277
Diffstat (limited to 'libbb')
-rw-r--r-- | libbb/xfuncs.c | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/libbb/xfuncs.c b/libbb/xfuncs.c index 9efccc542..136dd1cca 100644 --- a/libbb/xfuncs.c +++ b/libbb/xfuncs.c | |||
@@ -181,6 +181,7 @@ void xfflush_stdout(void) | |||
181 | // -1 for failure. Runs argv[0], searching path if that has no / in it. | 181 | // -1 for failure. Runs argv[0], searching path if that has no / in it. |
182 | pid_t spawn(char **argv) | 182 | pid_t spawn(char **argv) |
183 | { | 183 | { |
184 | /* Why static? */ | ||
184 | static int failed; | 185 | static int failed; |
185 | pid_t pid; | 186 | pid_t pid; |
186 | void *app = ENABLE_FEATURE_SH_STANDALONE_SHELL ? find_applet_by_name(argv[0]) : 0; | 187 | void *app = ENABLE_FEATURE_SH_STANDALONE_SHELL ? find_applet_by_name(argv[0]) : 0; |
@@ -196,10 +197,14 @@ pid_t spawn(char **argv) | |||
196 | // and then exit to unblock parent (but don't run atexit() stuff, which | 197 | // and then exit to unblock parent (but don't run atexit() stuff, which |
197 | // would screw up parent.) | 198 | // would screw up parent.) |
198 | 199 | ||
199 | failed = -1; | 200 | failed = errno; |
200 | _exit(0); | 201 | _exit(0); |
201 | } | 202 | } |
202 | return failed ? failed : pid; | 203 | if (failed) { |
204 | errno = failed; | ||
205 | return -1; | ||
206 | } | ||
207 | return pid; | ||
203 | } | 208 | } |
204 | 209 | ||
205 | // Die with an error message if we can't spawn a child process. | 210 | // Die with an error message if we can't spawn a child process. |