New method of checking out and configuring gnulib - define which version we need...
[findutils.git] / xargs / xargs.c
blobbc2332f9c0d4798f6c18ff78683e1c6a81f9a350
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");
668 linebuf = (char *) xmalloc (bc_ctl.arg_max + 1);
669 bc_state.argbuf = (char *) xmalloc (bc_ctl.arg_max + 1);
671 /* Make sure to listen for the kids. */
672 signal (SIGCHLD, SIG_DFL);
674 if (!bc_ctl.replace_pat)
676 for (; optind < argc; optind++)
677 bc_push_arg (&bc_ctl, &bc_state,
678 argv[optind], strlen (argv[optind]) + 1,
679 NULL, 0,
680 initial_args);
681 initial_args = false;
682 bc_ctl.initial_argc = bc_state.cmd_argc;
683 bc_state.cmd_initial_argv_chars = bc_state.cmd_argv_chars;
685 while ((*read_args) () != -1)
686 if (bc_ctl.lines_per_exec && lineno >= bc_ctl.lines_per_exec)
688 xargs_do_exec (&bc_ctl, &bc_state);
689 lineno = 0;
692 /* SYSV xargs seems to do at least one exec, even if the
693 input is empty. */
694 if (bc_state.cmd_argc != bc_ctl.initial_argc
695 || (always_run_command && procs_executed == 0))
696 xargs_do_exec (&bc_ctl, &bc_state);
699 else
701 int i;
702 size_t len;
703 size_t *arglen = (size_t *) xmalloc (sizeof (size_t) * argc);
705 for (i = optind; i < argc; i++)
706 arglen[i] = strlen(argv[i]);
707 bc_ctl.rplen = strlen (bc_ctl.replace_pat);
708 while ((len = (*read_args) ()) != -1)
710 /* Don't do insert on the command name. */
711 bc_clear_args(&bc_ctl, &bc_state);
712 bc_state.cmd_argv_chars = 0; /* begin at start of buffer */
714 bc_push_arg (&bc_ctl, &bc_state,
715 argv[optind], arglen[optind] + 1,
716 NULL, 0,
717 initial_args);
718 len--;
719 initial_args = false;
721 for (i = optind + 1; i < argc; i++)
722 bc_do_insert (&bc_ctl, &bc_state,
723 argv[i], arglen[i],
724 NULL, 0,
725 linebuf, len,
726 initial_args);
727 xargs_do_exec (&bc_ctl, &bc_state);
731 original_exit_value = child_error;
732 return child_error;
736 /* Read a line of arguments from the input and add them to the list of
737 arguments to pass to the command. Ignore blank lines and initial blanks.
738 Single and double quotes and backslashes quote metacharacters and blanks
739 as they do in the shell.
740 Return -1 if eof (either physical or logical) is reached,
741 otherwise the length of the last string read (including the null). */
743 static int
744 read_line (void)
746 /* States for read_line. */
747 enum read_line_state
749 NORM = 0,
750 SPACE = 1,
751 QUOTE = 2,
752 BACKSLASH = 3
754 static boolean eof = false;
755 /* Start out in mode SPACE to always strip leading spaces (even with -i). */
756 enum read_line_state state = SPACE; /* The type of character we last read. */
757 int prevc; /* The previous value of c. */
758 int quotc = 0; /* The last quote character read. */
759 int c = EOF;
760 boolean first = true; /* true if reading first arg on line. */
761 boolean seen_arg = false; /* true if we have seen any arg (or part of one) yet */
762 int len;
763 char *p = linebuf;
764 /* Including the NUL, the args must not grow past this point. */
765 char *endbuf = linebuf + bc_ctl.arg_max - bc_state.cmd_initial_argv_chars - 1;
767 if (eof)
768 return -1;
769 while (1)
771 prevc = c;
772 c = getc (input_stream);
774 if (c == EOF)
776 /* COMPAT: SYSV seems to ignore stuff on a line that
777 ends without a \n; we don't. */
778 eof = true;
779 if (p == linebuf)
780 return -1;
781 *p++ = '\0';
782 len = p - linebuf;
783 if (state == QUOTE)
785 exec_if_possible ();
786 error (1, 0, _("unmatched %s quote; by default quotes are special to xargs unless you use the -0 option"),
787 quotc == '"' ? _("double") : _("single"));
789 if (first && EOF_STR (linebuf))
790 return -1;
791 if (!bc_ctl.replace_pat)
792 bc_push_arg (&bc_ctl, &bc_state,
793 linebuf, len,
794 NULL, 0,
795 initial_args);
796 return len;
798 switch (state)
800 case SPACE:
801 if (ISSPACE (c))
802 continue;
803 state = NORM;
804 /* aaahhhh.... */
806 case NORM:
807 if (c == '\n')
809 if (!ISBLANK (prevc))
810 lineno++; /* For -l. */
811 if (p == linebuf)
813 if (seen_arg)
815 /* An empty argument, add it to the list as normal. */
817 else
819 /* Blank line. */
820 state = SPACE;
821 continue;
824 *p++ = '\0';
825 len = p - linebuf;
826 if (EOF_STR (linebuf))
828 eof = true;
829 return first ? -1 : len;
831 if (!bc_ctl.replace_pat)
832 bc_push_arg (&bc_ctl, &bc_state,
833 linebuf, len,
834 NULL, 0,
835 initial_args);
836 return len;
838 seen_arg = true;
840 /* POSIX: In the POSIX locale, the separators are <SPC> and
841 * <TAB>, but not <FF> or <VT>.
843 if (!bc_ctl.replace_pat && ISBLANK (c))
845 *p++ = '\0';
846 len = p - linebuf;
847 if (EOF_STR (linebuf))
849 eof = true;
850 return first ? -1 : len;
852 bc_push_arg (&bc_ctl, &bc_state,
853 linebuf, len,
854 NULL, 0,
855 initial_args);
856 p = linebuf;
857 state = SPACE;
858 first = false;
859 continue;
861 switch (c)
863 case '\\':
864 state = BACKSLASH;
865 continue;
867 case '\'':
868 case '"':
869 state = QUOTE;
870 quotc = c;
871 continue;
873 break;
875 case QUOTE:
876 if (c == '\n')
878 exec_if_possible ();
879 error (1, 0, _("unmatched %s quote; by default quotes are special to xargs unless you use the -0 option"),
880 quotc == '"' ? _("double") : _("single"));
882 if (c == quotc)
884 state = NORM;
885 seen_arg = true; /* Makes a difference for e.g. just '' or "" as the first arg on a line */
886 continue;
888 break;
890 case BACKSLASH:
891 state = NORM;
892 break;
895 if ( (0 == c) && !nullwarning_given )
897 /* This is just a warning message. We only issue it once. */
898 error (0, 0,
899 _("warning: a NUL character occurred in the input. "
900 "It cannot be passed through in the argument list. "
901 "Did you mean to use the --null option?"));
902 nullwarning_given = 1;
905 #if 1
906 if (p >= endbuf)
908 exec_if_possible ();
909 error (1, 0, _("argument line too long"));
911 *p++ = c;
912 #else
913 append_char_to_buf(&linebuf, &endbuf, &p, c);
914 #endif
918 /* Read a null-terminated string from the input and add it to the list of
919 arguments to pass to the command.
920 Return -1 if eof (either physical or logical) is reached,
921 otherwise the length of the string read (including the null). */
923 static int
924 read_string (void)
926 static boolean eof = false;
927 int len;
928 char *p = linebuf;
929 /* Including the NUL, the args must not grow past this point. */
930 char *endbuf = linebuf + bc_ctl.arg_max - bc_state.cmd_initial_argv_chars - 1;
932 if (eof)
933 return -1;
934 while (1)
936 int c = getc (input_stream);
937 if (c == EOF)
939 eof = true;
940 if (p == linebuf)
941 return -1;
942 *p++ = '\0';
943 len = p - linebuf;
944 if (!bc_ctl.replace_pat)
945 bc_push_arg (&bc_ctl, &bc_state,
946 linebuf, len,
947 NULL, 0,
948 initial_args);
949 return len;
951 if (c == input_delimiter)
953 lineno++; /* For -l. */
954 *p++ = '\0';
955 len = p - linebuf;
956 if (!bc_ctl.replace_pat)
957 bc_push_arg (&bc_ctl, &bc_state,
958 linebuf, len,
959 NULL, 0,
960 initial_args);
961 return len;
963 if (p >= endbuf)
965 exec_if_possible ();
966 error (1, 0, _("argument line too long"));
968 *p++ = c;
972 /* Print the arguments of the command to execute.
973 If ASK is nonzero, prompt the user for a response, and
974 if the user responds affirmatively, return true;
975 otherwise, return false. */
977 static boolean
978 print_args (boolean ask)
980 int i;
982 for (i = 0; i < bc_state.cmd_argc - 1; i++)
983 fprintf (stderr, "%s ", bc_state.cmd_argv[i]);
984 if (ask)
986 static FILE *tty_stream;
987 int c, savec;
989 if (!tty_stream)
991 tty_stream = fopen ("/dev/tty", "r");
992 if (!tty_stream)
993 error (1, errno, "/dev/tty");
995 fputs ("?...", stderr);
996 fflush (stderr);
997 c = savec = getc (tty_stream);
998 while (c != EOF && c != '\n')
999 c = getc (tty_stream);
1000 if (savec == 'y' || savec == 'Y')
1001 return true;
1003 else
1004 putc ('\n', stderr);
1006 return false;
1010 /* Close stdin and attach /dev/null to it.
1011 * This resolves Savannah bug #3992.
1013 static void
1014 prep_child_for_exec (void)
1016 if (!keep_stdin)
1018 const char inputfile[] = "/dev/null";
1019 /* fprintf(stderr, "attaching stdin to /dev/null\n"); */
1021 close(0);
1022 if (open(inputfile, O_RDONLY) < 0)
1024 /* This is not entirely fatal, since
1025 * executing the child with a closed
1026 * stdin is almost as good as executing it
1027 * with its stdin attached to /dev/null.
1029 error (0, errno, "%s", inputfile);
1035 /* Execute the command that has been built in `cmd_argv'. This may involve
1036 waiting for processes that were previously executed. */
1038 static int
1039 xargs_do_exec (const struct buildcmd_control *ctl, struct buildcmd_state *state)
1041 pid_t child;
1043 (void) ctl;
1044 (void) state;
1046 bc_push_arg (&bc_ctl, &bc_state,
1047 (char *) NULL, 0,
1048 NULL, 0,
1049 false); /* Null terminate the arg list. */
1051 if (!query_before_executing || print_args (true))
1053 if (proc_max && procs_executing >= proc_max)
1054 wait_for_proc (false);
1055 if (!query_before_executing && print_command)
1056 print_args (false);
1057 /* If we run out of processes, wait for a child to return and
1058 try again. */
1059 while ((child = fork ()) < 0 && errno == EAGAIN && procs_executing)
1060 wait_for_proc (false);
1061 switch (child)
1063 case -1:
1064 error (1, errno, _("cannot fork"));
1066 case 0: /* Child. */
1067 prep_child_for_exec();
1068 execvp (bc_state.cmd_argv[0], bc_state.cmd_argv);
1069 error (0, errno, "%s", bc_state.cmd_argv[0]);
1070 _exit (errno == ENOENT ? 127 : 126);
1071 /*NOTREACHED*/
1073 add_proc (child);
1076 bc_clear_args(&bc_ctl, &bc_state);
1077 return 1; /* Success */
1080 /* Execute the command if possible. */
1082 static void
1083 exec_if_possible (void)
1085 if (bc_ctl.replace_pat || initial_args ||
1086 bc_state.cmd_argc == bc_ctl.initial_argc || bc_ctl.exit_if_size_exceeded)
1087 return;
1088 xargs_do_exec (&bc_ctl, &bc_state);
1091 /* Add the process with id PID to the list of processes that have
1092 been executed. */
1094 static void
1095 add_proc (pid_t pid)
1097 int i;
1099 /* Find an empty slot. */
1100 for (i = 0; i < pids_alloc && pids[i]; i++)
1102 if (i == pids_alloc)
1104 if (pids_alloc == 0)
1106 pids_alloc = proc_max ? proc_max : 64;
1107 pids = (pid_t *) xmalloc (sizeof (pid_t) * pids_alloc);
1109 else
1111 pids_alloc *= 2;
1112 pids = (pid_t *) xrealloc (pids,
1113 sizeof (pid_t) * pids_alloc);
1115 memset (&pids[i], '\0', sizeof (pid_t) * (pids_alloc - i));
1117 pids[i] = pid;
1118 procs_executing++;
1119 procs_executed++;
1122 /* If ALL is true, wait for all child processes to finish;
1123 otherwise, wait for one child process to finish.
1124 Remove the processes that finish from the list of executing processes. */
1126 static void
1127 wait_for_proc (boolean all)
1129 while (procs_executing)
1131 int i, status;
1135 pid_t pid;
1137 while ((pid = wait (&status)) == (pid_t) -1)
1138 if (errno != EINTR)
1139 error (1, errno, _("error waiting for child process"));
1141 /* Find the entry in `pids' for the child process
1142 that exited. */
1143 for (i = 0; i < pids_alloc && pid != pids[i]; i++)
1146 while (i == pids_alloc); /* A child died that we didn't start? */
1148 /* Remove the child from the list. */
1149 pids[i] = 0;
1150 procs_executing--;
1152 if (WEXITSTATUS (status) == 126 || WEXITSTATUS (status) == 127)
1153 exit (WEXITSTATUS (status)); /* Can't find or run the command. */
1154 if (WEXITSTATUS (status) == 255)
1155 error (124, 0, _("%s: exited with status 255; aborting"), bc_state.cmd_argv[0]);
1156 if (WIFSTOPPED (status))
1157 error (125, 0, _("%s: stopped by signal %d"), bc_state.cmd_argv[0], WSTOPSIG (status));
1158 if (WIFSIGNALED (status))
1159 error (125, 0, _("%s: terminated by signal %d"), bc_state.cmd_argv[0], WTERMSIG (status));
1160 if (WEXITSTATUS (status) != 0)
1161 child_error = 123;
1163 if (!all)
1164 break;
1168 /* Wait for all child processes to finish. */
1170 static void
1171 wait_for_proc_all (void)
1173 static boolean waiting = false;
1175 if (waiting)
1176 return;
1178 waiting = true;
1179 wait_for_proc (true);
1180 waiting = false;
1182 if (original_exit_value != child_error)
1184 /* wait_for_proc() changed the value of child_error(). This
1185 * function is registered via atexit(), and so may have been
1186 * called from exit(). We now know that the original value
1187 * passed to exit() is no longer the exit status we require.
1188 * The POSIX standard states that the behaviour if exit() is
1189 * called more than once is undefined. Therefore we now have to
1190 * exit with _exit() instead of exit().
1192 _exit(child_error);
1197 /* Return the value of the number represented in STR.
1198 OPTION is the command line option to which STR is the argument.
1199 If the value does not fall within the boundaries MIN and MAX,
1200 Print an error message mentioning OPTION. If FATAL is true,
1201 we also exit. */
1203 static long
1204 parse_num (char *str, int option, long int min, long int max, int fatal)
1206 char *eptr;
1207 long val;
1209 val = strtol (str, &eptr, 10);
1210 if (eptr == str || *eptr)
1212 fprintf (stderr, _("%s: invalid number for -%c option\n"),
1213 program_name, option);
1214 usage (stderr);
1215 exit(1);
1217 else if (val < min)
1219 fprintf (stderr, _("%s: value for -%c option should be >= %ld\n"),
1220 program_name, option, min);
1221 if (fatal)
1223 usage (stderr);
1224 exit(1);
1226 else
1228 val = min;
1231 else if (max >= 0 && val > max)
1233 fprintf (stderr, _("%s: value for -%c option should be < %ld\n"),
1234 program_name, option, max);
1235 if (fatal)
1237 usage (stderr);
1238 exit(1);
1240 else
1242 val = max;
1245 return val;
1248 static void
1249 usage (FILE *stream)
1251 fprintf (stream, _("\
1252 Usage: %s [-0prtx] [--interactive] [--null] [-d|--delimiter=delim]\n\
1253 [-E eof-str] [-e[eof-str]] [--eof[=eof-str]]\n\
1254 [-L max-lines] [-l[max-lines]] [--max-lines[=max-lines]]\n\
1255 [-I replace-str] [-i[replace-str]] [--replace[=replace-str]]\n\
1256 [-n max-args] [--max-args=max-args]\n\
1257 [-s max-chars] [--max-chars=max-chars]\n\
1258 [-P max-procs] [--max-procs=max-procs] [--show-limits]\n\
1259 [--verbose] [--exit] [--no-run-if-empty] [--arg-file=file]\n\
1260 [--version] [--help] [command [initial-arguments]]\n"),
1261 program_name);
1262 fputs (_("\nReport bugs to <bug-findutils@gnu.org>.\n"), stream);