Did make dist
[findutils.git] / xargs / xargs.c
blob47d96c5ca09a965d92086c8b7c5c48d856a6d4ef
1 /* xargs -- build and execute command lines from standard input
2 Copyright (C) 1990, 91, 92, 93, 94, 2000, 2003, 2004, 2005, 2006, 2007 Free Software Foundation, Inc.
4 This program is free software; you can redistribute it and/or modify
5 it under the terms of the GNU General Public License as published by
6 the Free Software Foundation; either version 2, or (at your option)
7 any later version.
9 This program is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 GNU General Public License for more details.
14 You should have received a copy of the GNU General Public License
15 along with this program; if not, write to the Free Software
16 Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
17 USA.
20 /* Written by Mike Rendell <michael@cs.mun.ca>
21 and David MacKenzie <djm@gnu.org>.
22 Modifications by
23 James Youngman
24 Dmitry V. Levin
27 #include <config.h>
29 # ifndef PARAMS
30 # if defined PROTOTYPES || (defined __STDC__ && __STDC__)
31 # define PARAMS(Args) Args
32 # else
33 # define PARAMS(Args) ()
34 # endif
35 # endif
37 #include <ctype.h>
39 #if !defined (isascii) || defined (STDC_HEADERS)
40 #ifdef isascii
41 #undef isascii
42 #endif
43 #define isascii(c) 1
44 #endif
46 #ifdef isblank
47 #define ISBLANK(c) (isascii (c) && isblank (c))
48 #else
49 #define ISBLANK(c) ((c) == ' ' || (c) == '\t')
50 #endif
52 #define ISSPACE(c) (ISBLANK (c) || (c) == '\n' || (c) == '\r' \
53 || (c) == '\f' || (c) == '\v')
55 #include <sys/types.h>
56 #include <stdio.h>
57 #include <errno.h>
58 #include <getopt.h>
59 #include <fcntl.h>
61 #if defined(STDC_HEADERS)
62 #include <assert.h>
63 #endif
65 #if defined(HAVE_STRING_H) || defined(STDC_HEADERS)
66 #include <string.h>
67 #if !defined(STDC_HEADERS)
68 #include <memory.h>
69 #endif
70 #else
71 #include <strings.h>
72 #define memcpy(dest, source, count) (bcopy((source), (dest), (count)))
73 #endif
75 #ifndef _POSIX_SOURCE
76 #include <sys/param.h>
77 #endif
79 #ifdef HAVE_LIMITS_H
80 #include <limits.h>
81 #endif
83 #ifndef LONG_MAX
84 #define LONG_MAX (~(1 << (sizeof (long) * 8 - 1)))
85 #endif
87 /* The presence of unistd.h is assumed by gnulib these days, so we
88 * might as well assume it too.
90 #include <unistd.h>
92 #include <signal.h>
94 #if !defined(SIGCHLD) && defined(SIGCLD)
95 #define SIGCHLD SIGCLD
96 #endif
98 #include "wait.h"
101 #ifdef STDC_HEADERS
102 #include <stdlib.h>
103 #else
104 extern int errno;
105 #endif
107 #ifdef HAVE_LOCALE_H
108 #include <locale.h>
109 #endif
110 #if ENABLE_NLS
111 # include <libintl.h>
112 # define _(Text) gettext (Text)
113 #else
114 # define _(Text) Text
115 #define textdomain(Domain)
116 #define bindtextdomain(Package, Directory)
117 #endif
118 #ifdef gettext_noop
119 # define N_(String) gettext_noop (String)
120 #else
121 /* See locate.c for explanation as to why not use (String) */
122 # define N_(String) String
123 #endif
125 #include "buildcmd.h"
128 /* Return nonzero if S is the EOF string. */
129 #define EOF_STR(s) (eof_str && *eof_str == *s && !strcmp (eof_str, s))
131 /* Do multibyte processing if multibyte characters are supported,
132 unless multibyte sequences are search safe. Multibyte sequences
133 are search safe if searching for a substring using the byte
134 comparison function 'strstr' gives no false positives. All 8-bit
135 encodings and the UTF-8 multibyte encoding are search safe, but
136 the EUC encodings are not.
137 BeOS uses the UTF-8 encoding exclusively, so it is search safe. */
138 #if defined __BEOS__
139 # define MULTIBYTE_IS_SEARCH_SAFE 1
140 #endif
141 #define DO_MULTIBYTE (HAVE_MBLEN && ! MULTIBYTE_IS_SEARCH_SAFE)
143 #if DO_MULTIBYTE
144 # if HAVE_MBRLEN
145 # include <wchar.h>
146 # else
147 /* Simulate mbrlen with mblen as best we can. */
148 # define mbstate_t int
149 # define mbrlen(s, n, ps) mblen (s, n)
150 # endif
151 #endif
153 /* Not char because of type promotion; NeXT gcc can't handle it. */
154 typedef int boolean;
155 #define true 1
156 #define false 0
158 #if __STDC__
159 #define VOID void
160 #else
161 #define VOID char
162 #endif
164 #include <xalloc.h>
165 #include "closeout.h"
166 #include "gnulib-version.h"
168 void error PARAMS ((int status, int errnum, char *message,...));
170 extern char *version_string;
172 /* The name this program was run with. */
173 char *program_name;
175 static FILE *input_stream;
177 /* Buffer for reading arguments from input. */
178 static char *linebuf;
180 static int keep_stdin = 0;
182 /* Line number in stdin since the last command was executed. */
183 static int lineno = 0;
185 static struct buildcmd_state bc_state;
186 static struct buildcmd_control bc_ctl;
188 /* Did we already complain about NUL characters in the input? */
189 static int nullwarning_given = 0;
192 /* If nonzero, when this string is read on stdin it is treated as
193 end of file.
194 IEEE Std 1003.1, 2004 Edition allows this to be NULL.
195 In findutils releases up to and including 4.2.8, this was "_".
197 static char *eof_str = NULL;
199 /* Number of chars in the initial args. */
200 /* static int initial_argv_chars = 0; */
202 /* true when building up initial arguments in `cmd_argv'. */
203 static boolean initial_args = true;
205 /* If nonzero, the maximum number of child processes that can be running
206 at once. */
207 static int proc_max = 1;
209 /* Total number of child processes that have been executed. */
210 static int procs_executed = 0;
212 /* The number of elements in `pids'. */
213 static int procs_executing = 0;
215 /* List of child processes currently executing. */
216 static pid_t *pids = NULL;
218 /* The number of allocated elements in `pids'. */
219 static int pids_alloc = 0;
221 /* Exit status; nonzero if any child process exited with a
222 status of 1-125. */
223 static volatile int child_error = 0;
225 static volatile int original_exit_value;
227 /* If true, print each command on stderr before executing it. */
228 static boolean print_command = false; /* Option -t */
230 /* If true, query the user before executing each command, and only
231 execute the command if the user responds affirmatively. */
232 static boolean query_before_executing = false;
234 /* The delimiter for input arguments. This is only consulted if the
235 * -0 or -d option had been given.
237 static char input_delimiter = '\0';
240 static struct option const longopts[] =
242 {"null", no_argument, NULL, '0'},
243 {"arg-file", required_argument, NULL, 'a'},
244 {"delimiter", required_argument, NULL, 'd'},
245 {"eof", optional_argument, NULL, 'e'},
246 {"replace", optional_argument, NULL, 'I'},
247 {"max-lines", optional_argument, NULL, 'l'},
248 {"max-args", required_argument, NULL, 'n'},
249 {"interactive", no_argument, NULL, 'p'},
250 {"no-run-if-empty", no_argument, NULL, 'r'},
251 {"max-chars", required_argument, NULL, 's'},
252 {"verbose", no_argument, NULL, 't'},
253 {"show-limits", no_argument, NULL, 'S'},
254 {"exit", no_argument, NULL, 'x'},
255 {"max-procs", required_argument, NULL, 'P'},
256 {"version", no_argument, NULL, 'v'},
257 {"help", no_argument, NULL, 'h'},
258 {NULL, no_argument, NULL, 0}
261 static int read_line PARAMS ((void));
262 static int read_string PARAMS ((void));
263 static boolean print_args PARAMS ((boolean ask));
264 /* static void do_exec PARAMS ((void)); */
265 static int xargs_do_exec (const struct buildcmd_control *cl, struct buildcmd_state *state);
266 static void exec_if_possible PARAMS ((void));
267 static void add_proc PARAMS ((pid_t pid));
268 static void wait_for_proc PARAMS ((boolean all));
269 static void wait_for_proc_all PARAMS ((void));
270 static long parse_num PARAMS ((char *str, int option, long min, long max, int fatal));
271 static void usage PARAMS ((FILE * stream));
275 static char
276 get_char_oct_or_hex_escape(const char *s)
278 const char * p;
279 int base = 8;
280 unsigned long val;
281 char *endp;
283 assert('\\' == s[0]);
285 if ('x' == s[1])
287 /* hex */
288 p = s+2;
289 base = 16;
291 else if (isdigit(s[1]))
293 /* octal */
294 p = s+1;
295 base = 8;
297 else
299 p = NULL; /* Silence compiler warning. */
300 error(1, 0,
301 _("Invalid escape sequence %s in input delimiter specification."),
304 errno = 0;
305 endp = (char*)p;
306 val = strtoul(p, &endp, base);
308 /* This if condition is carefully constructed to do
309 * the right thing if UCHAR_MAX has the same
310 * value as ULONG_MAX. IF UCHAR_MAX==ULONG_MAX,
311 * then val can never be greater than UCHAR_MAX.
313 if ((ULONG_MAX == val && ERANGE == errno)
314 || (val > UCHAR_MAX))
316 if (16 == base)
318 error(1, 0,
319 _("Invalid escape sequence %s in input delimiter specification; character values must not exceed %lx."),
320 s, (unsigned long)UCHAR_MAX);
322 else
324 error(1, 0,
325 _("Invalid escape sequence %s in input delimiter specification; character values must not exceed %lo."),
326 s, (unsigned long)UCHAR_MAX);
330 /* check for trailing garbage */
331 if (0 != *endp)
333 error(1, 0,
334 _("Invalid escape sequence %s in input delimiter specification; trailing characters %s not recognised."),
335 s, endp);
338 return (char) val;
342 static char
343 get_input_delimiter(const char *s)
345 if (1 == strlen(s))
347 return s[0];
349 else
351 if ('\\' == s[0])
353 /* an escape code */
354 switch (s[1])
356 case 'a':
357 return '\a';
358 case 'b':
359 return '\b';
360 case 'f':
361 return '\f';
362 case 'n':
363 return '\n';
364 case 'r':
365 return '\r';
366 case 't':
367 return'\t';
368 case 'v':
369 return '\v';
370 case '\\':
371 return '\\';
372 default:
373 return get_char_oct_or_hex_escape(s);
376 else
378 error(1, 0,
379 _("Invalid input delimiter specification %s: the delimiter must be either a single character or an escape sequence starting with \\."),
381 /*NOTREACHED*/
382 return 0;
387 static void
388 noop (void)
390 /* does nothing. */
393 static void
394 fail_due_to_env_size (void)
396 error (1, 0, _("environment is too large for exec"));
401 main (int argc, char **argv)
403 int optc;
404 int show_limits = 0; /* --show-limits */
405 int always_run_command = 1;
406 char *input_file = "-"; /* "-" is stdin */
407 char *default_cmd = "/bin/echo";
408 int (*read_args) PARAMS ((void)) = read_line;
409 void (*act_on_init_result)(void) = noop;
410 enum BC_INIT_STATUS bcstatus;
412 program_name = argv[0];
413 original_exit_value = 0;
415 #ifdef HAVE_SETLOCALE
416 setlocale (LC_ALL, "");
417 #endif
418 bindtextdomain (PACKAGE, LOCALEDIR);
419 textdomain (PACKAGE);
420 atexit (close_stdout);
421 atexit (wait_for_proc_all);
423 bcstatus = bc_init_controlinfo(&bc_ctl);
425 /* The bc_init_controlinfo call may have determined that the
426 * environment is too big. In that case, we will fail with
427 * an error message after processing the command-line options,
428 * as "xargs --help" should still work even if the environment is
429 * too big.
431 * Some of the argument processing depends on the contents of
432 * bc_ctl, which will be in an undefined state if bc_init_controlinfo()
433 * failed.
435 if (BC_INIT_ENV_TOO_BIG == bcstatus)
437 act_on_init_result = fail_due_to_env_size;
439 else
441 /* IEEE Std 1003.1, 2003 specifies that the combined argument and
442 * environment list shall not exceed {ARG_MAX}-2048 bytes. It also
443 * specifies that it shall be at least LINE_MAX.
445 #if defined(ARG_MAX)
446 assert(bc_ctl.arg_max <= (ARG_MAX-2048));
447 #endif
448 assert(bc_ctl.arg_max >= LINE_MAX);
450 bc_ctl.exec_callback = xargs_do_exec;
452 /* Start with a reasonable default size, though this can be
453 * adjusted via the -s option.
455 bc_use_sensible_arg_max(&bc_ctl);
458 while ((optc = getopt_long (argc, argv, "+0a:E:e::i::I:l::L:n:prs:txP:d:",
459 longopts, (int *) 0)) != -1)
461 switch (optc)
463 case '0':
464 read_args = read_string;
465 input_delimiter = '\0';
466 break;
468 case 'd':
469 read_args = read_string;
470 input_delimiter = get_input_delimiter(optarg);
471 break;
473 case 'E': /* POSIX */
474 case 'e': /* deprecated */
475 if (optarg && (strlen(optarg) > 0))
476 eof_str = optarg;
477 else
478 eof_str = 0;
479 break;
481 case 'h':
482 usage (stdout);
483 return 0;
485 case 'I': /* POSIX */
486 case 'i': /* deprecated */
487 if (optarg)
488 bc_ctl.replace_pat = optarg;
489 else
490 bc_ctl.replace_pat = "{}";
491 /* -i excludes -n -l. */
492 bc_ctl.args_per_exec = 0;
493 bc_ctl.lines_per_exec = 0;
494 break;
496 case 'L': /* POSIX */
497 bc_ctl.lines_per_exec = parse_num (optarg, 'L', 1L, -1L, 1);
498 /* -L excludes -i -n. */
499 bc_ctl.args_per_exec = 0;
500 bc_ctl.replace_pat = NULL;
501 break;
503 case 'l': /* deprecated */
504 if (optarg)
505 bc_ctl.lines_per_exec = parse_num (optarg, 'l', 1L, -1L, 1);
506 else
507 bc_ctl.lines_per_exec = 1;
508 /* -l excludes -i -n. */
509 bc_ctl.args_per_exec = 0;
510 bc_ctl.replace_pat = NULL;
511 break;
513 case 'n':
514 bc_ctl.args_per_exec = parse_num (optarg, 'n', 1L, -1L, 1);
515 /* -n excludes -i -l. */
516 bc_ctl.lines_per_exec = 0;
517 if (bc_ctl.args_per_exec == 1 && bc_ctl.replace_pat)
518 /* ignore -n1 in '-i -n1' */
519 bc_ctl.args_per_exec = 0;
520 else
521 bc_ctl.replace_pat = NULL;
522 break;
524 /* The POSIX standard specifies that it is not an error
525 * for the -s option to specify a size that the implementation
526 * cannot support - in that case, the relevant limit is used.
528 case 's':
530 size_t arg_size;
531 act_on_init_result();
532 arg_size = parse_num (optarg, 's', 1L,
533 bc_ctl.posix_arg_size_max, 0);
534 if (arg_size > bc_ctl.posix_arg_size_max)
536 error (0, 0,
537 _("warning: value %ld for -s option is too large, "
538 "using %ld instead"),
539 arg_size, bc_ctl.posix_arg_size_max);
540 arg_size = bc_ctl.posix_arg_size_max;
542 bc_ctl.arg_max = arg_size;
544 break;
546 case 'S':
547 show_limits = true;
548 break;
550 case 't':
551 print_command = true;
552 break;
554 case 'x':
555 bc_ctl.exit_if_size_exceeded = true;
556 break;
558 case 'p':
559 query_before_executing = true;
560 print_command = true;
561 break;
563 case 'r':
564 always_run_command = 0;
565 break;
567 case 'P':
568 proc_max = parse_num (optarg, 'P', 0L, -1L, 1);
569 break;
571 case 'a':
572 input_file = optarg;
573 break;
575 case 'v':
576 printf (_("GNU xargs version %s\n"), version_string);
577 printf (_("Built using GNU gnulib version %s\n"), gnulib_version);
578 return 0;
580 default:
581 usage (stderr);
582 return 1;
586 /* If we had deferred failing due to problems in bc_init_controlinfo(),
587 * do it now.
589 * We issue this error message after processing command line
590 * arguments so that it is possible to use "xargs --help" even if
591 * the environment is too large.
593 act_on_init_result();
594 assert(BC_INIT_OK == bcstatus);
596 if (0 == strcmp (input_file, "-"))
598 input_stream = stdin;
600 else
602 keep_stdin = 1; /* see prep_child_for_exec() */
603 input_stream = fopen (input_file, "r");
604 if (NULL == input_stream)
606 error (1, errno,
607 _("Cannot open input file `%s'"),
608 input_file);
612 if (bc_ctl.replace_pat || bc_ctl.lines_per_exec)
613 bc_ctl.exit_if_size_exceeded = true;
615 if (optind == argc)
617 optind = 0;
618 argc = 1;
619 argv = &default_cmd;
622 /* We want to be able to print size_t values as unsigned long, so if
623 * the cast isn't value-preserving, we have a problem. This isn't a
624 * problem in C89, because size_t was known to be no wider than
625 * unsigned long. In C99 this is no longer the case, but there are
626 * special C99 ways to print such values. Unfortunately this
627 * program tries to work on both C89 and C99 systems.
629 #if defined(SIZE_MAX)
630 # if SIZE_MAX > ULONG_MAX
631 # error "I'm not sure how to print size_t values on your system"
632 # endif
633 #else
634 /* Without SIZE_MAX (i.e. limits.h) this is probably
635 * close to the best we can do.
637 assert(sizeof(size_t) <= sizeof(unsigned long));
638 #endif
640 if (show_limits)
642 fprintf(stderr,
643 _("Your environment variables take up %lu bytes\n"),
644 (unsigned long)bc_size_of_environment());
645 fprintf(stderr,
646 _("POSIX lower and upper limits on argument length: %lu, %lu\n"),
647 (unsigned long)bc_ctl.posix_arg_size_min,
648 (unsigned long)bc_ctl.posix_arg_size_max);
649 fprintf(stderr,
650 _("Maximum length of command we could actually use: %ld\n"),
651 (unsigned long)(bc_ctl.posix_arg_size_max -
652 bc_size_of_environment()));
653 fprintf(stderr,
654 _("Size of command buffer we are actually using: %lu\n"),
655 (unsigned long)bc_ctl.arg_max);
657 if (isatty(STDIN_FILENO))
659 fprintf(stderr,
660 _("\n"
661 "Execution of xargs will continue now, and it will "
662 "try to read its input and run commands; if this is "
663 "not what you wanted to happen, please type the "
664 "end-of-file keystroke.\n"));
665 if (always_run_command)
667 fprintf(stderr,
668 _("Warning: %s will be run at least once. "
669 "If you do not want that to happen, then press "
670 "the interrupt keystroke.\n"),
671 argv[optind]);
676 linebuf = (char *) xmalloc (bc_ctl.arg_max + 1);
677 bc_state.argbuf = (char *) xmalloc (bc_ctl.arg_max + 1);
679 /* Make sure to listen for the kids. */
680 signal (SIGCHLD, SIG_DFL);
682 if (!bc_ctl.replace_pat)
684 for (; optind < argc; optind++)
685 bc_push_arg (&bc_ctl, &bc_state,
686 argv[optind], strlen (argv[optind]) + 1,
687 NULL, 0,
688 initial_args);
689 initial_args = false;
690 bc_ctl.initial_argc = bc_state.cmd_argc;
691 bc_state.cmd_initial_argv_chars = bc_state.cmd_argv_chars;
693 while ((*read_args) () != -1)
694 if (bc_ctl.lines_per_exec && lineno >= bc_ctl.lines_per_exec)
696 xargs_do_exec (&bc_ctl, &bc_state);
697 lineno = 0;
700 /* SYSV xargs seems to do at least one exec, even if the
701 input is empty. */
702 if (bc_state.cmd_argc != bc_ctl.initial_argc
703 || (always_run_command && procs_executed == 0))
704 xargs_do_exec (&bc_ctl, &bc_state);
707 else
709 int i;
710 size_t len;
711 size_t *arglen = (size_t *) xmalloc (sizeof (size_t) * argc);
713 for (i = optind; i < argc; i++)
714 arglen[i] = strlen(argv[i]);
715 bc_ctl.rplen = strlen (bc_ctl.replace_pat);
716 while ((len = (*read_args) ()) != -1)
718 /* Don't do insert on the command name. */
719 bc_clear_args(&bc_ctl, &bc_state);
720 bc_state.cmd_argv_chars = 0; /* begin at start of buffer */
722 bc_push_arg (&bc_ctl, &bc_state,
723 argv[optind], arglen[optind] + 1,
724 NULL, 0,
725 initial_args);
726 len--;
727 initial_args = false;
729 for (i = optind + 1; i < argc; i++)
730 bc_do_insert (&bc_ctl, &bc_state,
731 argv[i], arglen[i],
732 NULL, 0,
733 linebuf, len,
734 initial_args);
735 xargs_do_exec (&bc_ctl, &bc_state);
739 original_exit_value = child_error;
740 return child_error;
744 /* Read a line of arguments from the input and add them to the list of
745 arguments to pass to the command. Ignore blank lines and initial blanks.
746 Single and double quotes and backslashes quote metacharacters and blanks
747 as they do in the shell.
748 Return -1 if eof (either physical or logical) is reached,
749 otherwise the length of the last string read (including the null). */
751 static int
752 read_line (void)
754 /* States for read_line. */
755 enum read_line_state
757 NORM = 0,
758 SPACE = 1,
759 QUOTE = 2,
760 BACKSLASH = 3
762 static boolean eof = false;
763 /* Start out in mode SPACE to always strip leading spaces (even with -i). */
764 enum read_line_state state = SPACE; /* The type of character we last read. */
765 int prevc; /* The previous value of c. */
766 int quotc = 0; /* The last quote character read. */
767 int c = EOF;
768 boolean first = true; /* true if reading first arg on line. */
769 boolean seen_arg = false; /* true if we have seen any arg (or part of one) yet */
770 int len;
771 char *p = linebuf;
772 /* Including the NUL, the args must not grow past this point. */
773 char *endbuf = linebuf + bc_ctl.arg_max - bc_state.cmd_initial_argv_chars - 1;
775 if (eof)
776 return -1;
777 while (1)
779 prevc = c;
780 c = getc (input_stream);
782 if (c == EOF)
784 /* COMPAT: SYSV seems to ignore stuff on a line that
785 ends without a \n; we don't. */
786 eof = true;
787 if (p == linebuf)
788 return -1;
789 *p++ = '\0';
790 len = p - linebuf;
791 if (state == QUOTE)
793 exec_if_possible ();
794 error (1, 0, _("unmatched %s quote; by default quotes are special to xargs unless you use the -0 option"),
795 quotc == '"' ? _("double") : _("single"));
797 if (first && EOF_STR (linebuf))
798 return -1;
799 if (!bc_ctl.replace_pat)
800 bc_push_arg (&bc_ctl, &bc_state,
801 linebuf, len,
802 NULL, 0,
803 initial_args);
804 return len;
806 switch (state)
808 case SPACE:
809 if (ISSPACE (c))
810 continue;
811 state = NORM;
812 /* aaahhhh.... */
814 case NORM:
815 if (c == '\n')
817 if (!ISBLANK (prevc))
818 lineno++; /* For -l. */
819 if (p == linebuf)
821 if (seen_arg)
823 /* An empty argument, add it to the list as normal. */
825 else
827 /* Blank line. */
828 state = SPACE;
829 continue;
832 *p++ = '\0';
833 len = p - linebuf;
834 if (EOF_STR (linebuf))
836 eof = true;
837 return first ? -1 : len;
839 if (!bc_ctl.replace_pat)
840 bc_push_arg (&bc_ctl, &bc_state,
841 linebuf, len,
842 NULL, 0,
843 initial_args);
844 return len;
846 seen_arg = true;
848 /* POSIX: In the POSIX locale, the separators are <SPC> and
849 * <TAB>, but not <FF> or <VT>.
851 if (!bc_ctl.replace_pat && ISBLANK (c))
853 *p++ = '\0';
854 len = p - linebuf;
855 if (EOF_STR (linebuf))
857 eof = true;
858 return first ? -1 : len;
860 bc_push_arg (&bc_ctl, &bc_state,
861 linebuf, len,
862 NULL, 0,
863 initial_args);
864 p = linebuf;
865 state = SPACE;
866 first = false;
867 continue;
869 switch (c)
871 case '\\':
872 state = BACKSLASH;
873 continue;
875 case '\'':
876 case '"':
877 state = QUOTE;
878 quotc = c;
879 continue;
881 break;
883 case QUOTE:
884 if (c == '\n')
886 exec_if_possible ();
887 error (1, 0, _("unmatched %s quote; by default quotes are special to xargs unless you use the -0 option"),
888 quotc == '"' ? _("double") : _("single"));
890 if (c == quotc)
892 state = NORM;
893 seen_arg = true; /* Makes a difference for e.g. just '' or "" as the first arg on a line */
894 continue;
896 break;
898 case BACKSLASH:
899 state = NORM;
900 break;
903 if ( (0 == c) && !nullwarning_given )
905 /* This is just a warning message. We only issue it once. */
906 error (0, 0,
907 _("warning: a NUL character occurred in the input. "
908 "It cannot be passed through in the argument list. "
909 "Did you mean to use the --null option?"));
910 nullwarning_given = 1;
913 #if 1
914 if (p >= endbuf)
916 exec_if_possible ();
917 error (1, 0, _("argument line too long"));
919 *p++ = c;
920 #else
921 append_char_to_buf(&linebuf, &endbuf, &p, c);
922 #endif
926 /* Read a null-terminated string from the input and add it to the list of
927 arguments to pass to the command.
928 Return -1 if eof (either physical or logical) is reached,
929 otherwise the length of the string read (including the null). */
931 static int
932 read_string (void)
934 static boolean eof = false;
935 int len;
936 char *p = linebuf;
937 /* Including the NUL, the args must not grow past this point. */
938 char *endbuf = linebuf + bc_ctl.arg_max - bc_state.cmd_initial_argv_chars - 1;
940 if (eof)
941 return -1;
942 while (1)
944 int c = getc (input_stream);
945 if (c == EOF)
947 eof = true;
948 if (p == linebuf)
949 return -1;
950 *p++ = '\0';
951 len = p - linebuf;
952 if (!bc_ctl.replace_pat)
953 bc_push_arg (&bc_ctl, &bc_state,
954 linebuf, len,
955 NULL, 0,
956 initial_args);
957 return len;
959 if (c == input_delimiter)
961 lineno++; /* For -l. */
962 *p++ = '\0';
963 len = p - linebuf;
964 if (!bc_ctl.replace_pat)
965 bc_push_arg (&bc_ctl, &bc_state,
966 linebuf, len,
967 NULL, 0,
968 initial_args);
969 return len;
971 if (p >= endbuf)
973 exec_if_possible ();
974 error (1, 0, _("argument line too long"));
976 *p++ = c;
980 /* Print the arguments of the command to execute.
981 If ASK is nonzero, prompt the user for a response, and
982 if the user responds affirmatively, return true;
983 otherwise, return false. */
985 static boolean
986 print_args (boolean ask)
988 int i;
990 for (i = 0; i < bc_state.cmd_argc - 1; i++)
991 fprintf (stderr, "%s ", bc_state.cmd_argv[i]);
992 if (ask)
994 static FILE *tty_stream;
995 int c, savec;
997 if (!tty_stream)
999 tty_stream = fopen ("/dev/tty", "r");
1000 if (!tty_stream)
1001 error (1, errno, "/dev/tty");
1003 fputs ("?...", stderr);
1004 fflush (stderr);
1005 c = savec = getc (tty_stream);
1006 while (c != EOF && c != '\n')
1007 c = getc (tty_stream);
1008 if (savec == 'y' || savec == 'Y')
1009 return true;
1011 else
1012 putc ('\n', stderr);
1014 return false;
1018 /* Close stdin and attach /dev/null to it.
1019 * This resolves Savannah bug #3992.
1021 static void
1022 prep_child_for_exec (void)
1024 if (!keep_stdin)
1026 const char inputfile[] = "/dev/null";
1027 /* fprintf(stderr, "attaching stdin to /dev/null\n"); */
1029 close(0);
1030 if (open(inputfile, O_RDONLY) < 0)
1032 /* This is not entirely fatal, since
1033 * executing the child with a closed
1034 * stdin is almost as good as executing it
1035 * with its stdin attached to /dev/null.
1037 error (0, errno, "%s", inputfile);
1043 /* Execute the command that has been built in `cmd_argv'. This may involve
1044 waiting for processes that were previously executed. */
1046 static int
1047 xargs_do_exec (const struct buildcmd_control *ctl, struct buildcmd_state *state)
1049 pid_t child;
1051 (void) ctl;
1052 (void) state;
1054 bc_push_arg (&bc_ctl, &bc_state,
1055 (char *) NULL, 0,
1056 NULL, 0,
1057 false); /* Null terminate the arg list. */
1059 if (!query_before_executing || print_args (true))
1061 if (proc_max && procs_executing >= proc_max)
1062 wait_for_proc (false);
1063 if (!query_before_executing && print_command)
1064 print_args (false);
1065 /* If we run out of processes, wait for a child to return and
1066 try again. */
1067 while ((child = fork ()) < 0 && errno == EAGAIN && procs_executing)
1068 wait_for_proc (false);
1069 switch (child)
1071 case -1:
1072 error (1, errno, _("cannot fork"));
1074 case 0: /* Child. */
1075 prep_child_for_exec();
1076 execvp (bc_state.cmd_argv[0], bc_state.cmd_argv);
1077 error (0, errno, "%s", bc_state.cmd_argv[0]);
1078 _exit (errno == ENOENT ? 127 : 126);
1079 /*NOTREACHED*/
1081 add_proc (child);
1084 bc_clear_args(&bc_ctl, &bc_state);
1085 return 1; /* Success */
1088 /* Execute the command if possible. */
1090 static void
1091 exec_if_possible (void)
1093 if (bc_ctl.replace_pat || initial_args ||
1094 bc_state.cmd_argc == bc_ctl.initial_argc || bc_ctl.exit_if_size_exceeded)
1095 return;
1096 xargs_do_exec (&bc_ctl, &bc_state);
1099 /* Add the process with id PID to the list of processes that have
1100 been executed. */
1102 static void
1103 add_proc (pid_t pid)
1105 int i;
1107 /* Find an empty slot. */
1108 for (i = 0; i < pids_alloc && pids[i]; i++)
1110 if (i == pids_alloc)
1112 if (pids_alloc == 0)
1114 pids_alloc = proc_max ? proc_max : 64;
1115 pids = (pid_t *) xmalloc (sizeof (pid_t) * pids_alloc);
1117 else
1119 pids_alloc *= 2;
1120 pids = (pid_t *) xrealloc (pids,
1121 sizeof (pid_t) * pids_alloc);
1123 memset (&pids[i], '\0', sizeof (pid_t) * (pids_alloc - i));
1125 pids[i] = pid;
1126 procs_executing++;
1127 procs_executed++;
1130 /* If ALL is true, wait for all child processes to finish;
1131 otherwise, wait for one child process to finish.
1132 Remove the processes that finish from the list of executing processes. */
1134 static void
1135 wait_for_proc (boolean all)
1137 while (procs_executing)
1139 int i, status;
1143 pid_t pid;
1145 while ((pid = wait (&status)) == (pid_t) -1)
1146 if (errno != EINTR)
1147 error (1, errno, _("error waiting for child process"));
1149 /* Find the entry in `pids' for the child process
1150 that exited. */
1151 for (i = 0; i < pids_alloc && pid != pids[i]; i++)
1154 while (i == pids_alloc); /* A child died that we didn't start? */
1156 /* Remove the child from the list. */
1157 pids[i] = 0;
1158 procs_executing--;
1160 if (WEXITSTATUS (status) == 126 || WEXITSTATUS (status) == 127)
1161 exit (WEXITSTATUS (status)); /* Can't find or run the command. */
1162 if (WEXITSTATUS (status) == 255)
1163 error (124, 0, _("%s: exited with status 255; aborting"), bc_state.cmd_argv[0]);
1164 if (WIFSTOPPED (status))
1165 error (125, 0, _("%s: stopped by signal %d"), bc_state.cmd_argv[0], WSTOPSIG (status));
1166 if (WIFSIGNALED (status))
1167 error (125, 0, _("%s: terminated by signal %d"), bc_state.cmd_argv[0], WTERMSIG (status));
1168 if (WEXITSTATUS (status) != 0)
1169 child_error = 123;
1171 if (!all)
1172 break;
1176 /* Wait for all child processes to finish. */
1178 static void
1179 wait_for_proc_all (void)
1181 static boolean waiting = false;
1183 if (waiting)
1184 return;
1186 waiting = true;
1187 wait_for_proc (true);
1188 waiting = false;
1190 if (original_exit_value != child_error)
1192 /* wait_for_proc() changed the value of child_error(). This
1193 * function is registered via atexit(), and so may have been
1194 * called from exit(). We now know that the original value
1195 * passed to exit() is no longer the exit status we require.
1196 * The POSIX standard states that the behaviour if exit() is
1197 * called more than once is undefined. Therefore we now have to
1198 * exit with _exit() instead of exit().
1200 _exit(child_error);
1205 /* Return the value of the number represented in STR.
1206 OPTION is the command line option to which STR is the argument.
1207 If the value does not fall within the boundaries MIN and MAX,
1208 Print an error message mentioning OPTION. If FATAL is true,
1209 we also exit. */
1211 static long
1212 parse_num (char *str, int option, long int min, long int max, int fatal)
1214 char *eptr;
1215 long val;
1217 val = strtol (str, &eptr, 10);
1218 if (eptr == str || *eptr)
1220 fprintf (stderr, _("%s: invalid number for -%c option\n"),
1221 program_name, option);
1222 usage (stderr);
1223 exit(1);
1225 else if (val < min)
1227 fprintf (stderr, _("%s: value for -%c option should be >= %ld\n"),
1228 program_name, option, min);
1229 if (fatal)
1231 usage (stderr);
1232 exit(1);
1234 else
1236 val = min;
1239 else if (max >= 0 && val > max)
1241 fprintf (stderr, _("%s: value for -%c option should be < %ld\n"),
1242 program_name, option, max);
1243 if (fatal)
1245 usage (stderr);
1246 exit(1);
1248 else
1250 val = max;
1253 return val;
1256 static void
1257 usage (FILE *stream)
1259 fprintf (stream, _("\
1260 Usage: %s [-0prtx] [--interactive] [--null] [-d|--delimiter=delim]\n\
1261 [-E eof-str] [-e[eof-str]] [--eof[=eof-str]]\n\
1262 [-L max-lines] [-l[max-lines]] [--max-lines[=max-lines]]\n\
1263 [-I replace-str] [-i[replace-str]] [--replace[=replace-str]]\n\
1264 [-n max-args] [--max-args=max-args]\n\
1265 [-s max-chars] [--max-chars=max-chars]\n\
1266 [-P max-procs] [--max-procs=max-procs] [--show-limits]\n\
1267 [--verbose] [--exit] [--no-run-if-empty] [--arg-file=file]\n\
1268 [--version] [--help] [command [initial-arguments]]\n"),
1269 program_name);
1270 fputs (_("\nReport bugs to <bug-findutils@gnu.org>.\n"), stream);