| /* |
| * Mini xargs implementation for busybox |
| * |
| * Copyright (C) 2000 by Lineo, inc. |
| * Written by Erik Andersen <andersen@lineo.com>, <andersee@debian.org> |
| * Remixed by Mark Whitley <markw@lineo.com>, <markw@codepoet.org> |
| * |
| * This program is free software; you can redistribute it and/or modify |
| * it under the terms of the GNU General Public License as published by |
| * the Free Software Foundation; either version 2 of the License, or |
| * (at your option) any later version. |
| * |
| * This program is distributed in the hope that it will be useful, |
| * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
| * General Public License for more details. |
| * |
| * You should have received a copy of the GNU General Public License |
| * along with this program; if not, write to the Free Software |
| * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
| * |
| */ |
| |
| #include "busybox.h" |
| #include <stdio.h> |
| #include <stdlib.h> |
| #include <string.h> |
| |
| int xargs_main(int argc, char **argv) |
| { |
| char *cmd_to_be_executed = NULL; |
| char *file_to_act_on = NULL; |
| |
| /* |
| * No options are supported in this version of xargs; no getopt. |
| * |
| * Re: The missing -t flag: Most programs that produce output also print |
| * the filename, so xargs doesn't really need to do it again. Supporting |
| * the -t flag =greatly= bloats up the size of this app and the memory it |
| * uses because you have to buffer all the input file strings in memory. If |
| * you really want to see the filenames that xargs will act on, just run it |
| * once with no args and xargs will echo the filename. Simple. |
| */ |
| |
| /* Store the command to be executed (taken from the command line) */ |
| if (argc == 1) { |
| /* default behavior is to echo all the filenames */ |
| cmd_to_be_executed = strdup("/bin/echo "); |
| } else { |
| /* concatenate all the arguments passed to xargs together */ |
| int i; |
| int len = 1; /* for the '\0' */ |
| for (i = 1; i < argc; i++) { |
| len += strlen(argv[i]); |
| len += 1; /* for the space between the args */ |
| cmd_to_be_executed = xrealloc(cmd_to_be_executed, len); |
| strcat(cmd_to_be_executed, argv[i]); |
| strcat(cmd_to_be_executed, " "); |
| } |
| } |
| |
| /* Now, read in one line at a time from stdin, and store this |
| * line to be used later as an argument to the command */ |
| while ((file_to_act_on = get_line_from_file(stdin)) !=NULL) { |
| |
| FILE *cmd_output = NULL; |
| char *output_line = NULL; |
| char *execstr = NULL; |
| |
| /* eat the newline off the filename. */ |
| if (file_to_act_on[strlen(file_to_act_on)-1] == '\n') |
| file_to_act_on[strlen(file_to_act_on)-1] = '\0'; |
| |
| /* eat blank lines */ |
| if (strlen(file_to_act_on) == 0) |
| continue; |
| |
| /* assemble the command and execute it */ |
| execstr = xcalloc(strlen(cmd_to_be_executed) + |
| strlen(file_to_act_on) + 1, sizeof(char)); |
| strcat(execstr, cmd_to_be_executed); |
| strcat(execstr, file_to_act_on); |
| cmd_output = popen(execstr, "r"); |
| if (cmd_output == NULL) |
| perror_msg_and_die("popen"); |
| |
| /* harvest the output */ |
| while ((output_line = get_line_from_file(cmd_output)) != NULL) { |
| fputs(output_line, stdout); |
| free(output_line); |
| } |
| |
| /* clean up */ |
| pclose(cmd_output); |
| free(execstr); |
| free(file_to_act_on); |
| } |
| |
| #ifdef BB_FEATURE_CLEAN_UP |
| free(cmd_to_be_executed); |
| #endif |
| |
| return 0; |
| } |
| |
| /* vi: set sw=4 ts=4: */ |