*
*/
-#include "internal.h"
+#include "busybox.h"
#define BB_DECLARE_EXTERN
#define bb_need_invalid_option
#define bb_need_too_few_args
#define CHOWN_APP 2
#define CHMOD_APP 3
-static const char chgrp_usage[] = "chgrp [OPTION]... GROUP FILE...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
- "\nChange the group membership of each FILE to GROUP.\n"
- "\nOptions:\n\t-R\tChanges files and directories recursively.\n"
-#endif
- ;
-static const char chown_usage[] =
- "chown [OPTION]... OWNER[<.|:>[GROUP] FILE...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
- "\nChange the owner and/or group of each FILE to OWNER and/or GROUP.\n"
- "\nOptions:\n\t-R\tChanges files and directories recursively.\n"
-#endif
- ;
-static const char chmod_usage[] =
- "chmod [-R] MODE[,MODE]... FILE...\n"
-#ifndef BB_FEATURE_TRIVIAL_HELP
- "\nEach MODE is one or more of the letters ugoa, one of the symbols +-= and\n"
- "one or more of the letters rwxst.\n\n"
- "\nOptions:\n\t-R\tChanges files and directories recursively.\n"
-#endif
- ;
-
-
static int fileAction(const char *fileName, struct stat *statbuf, void* junk)
{
switch (whichApp) {
case CHMOD_APP:
/* Parse the specified modes */
if (parse_mode(theMode, &(statbuf->st_mode)) == FALSE) {
- fatalError( "unknown mode: %s\n", theMode);
+ error_msg_and_die( "unknown mode: %s\n", theMode);
}
if (chmod(fileName, statbuf->st_mode) == 0)
return (TRUE);
int chmod_chown_chgrp_main(int argc, char **argv)
{
+ int stopIt = FALSE;
int recursiveFlag = FALSE;
char *groupName=NULL;
char *p=NULL;
/* Parse options */
while (--argc >= 0 && *argv && (**argv == '-')) {
- while (*++(*argv)) {
+ while (stopIt==FALSE && *++(*argv)) {
switch (**argv) {
case 'R':
recursiveFlag = TRUE;
break;
default:
- errorMsg(invalid_option, **argv);
- usage(appUsage);
+ theMode=*argv-1;
+ stopIt = TRUE;
}
}
+ if (stopIt==TRUE)
+ break;
argv++;
}
if (argc == 0 || *argv == NULL) {
- errorMsg(too_few_args);
- usage(appUsage);
+ error_msg(too_few_args);
}
if (whichApp == CHMOD_APP) {
- theMode = *argv;
+ if (theMode==NULL)
+ theMode = *argv;
} else {
/* Find the selected group */
if (*argv == p)
uid = my_getpwnam(*argv);
if (uid == -1) {
- fatalError( "unknown user name: %s\n", *argv);
+ error_msg_and_die( "unknown user name: %s\n", *argv);
}
}
}
/* Ok, ready to do the deed now */
- if (argc <= 1) {
- fatalError(too_few_args);
+ if (argc < 1) {
+ error_msg_and_die(too_few_args);
}
while (argc-- > 1) {
- if (recursiveAction (*(++argv), recursiveFlag, FALSE, FALSE,
+ if (recursive_action (*(++argv), recursiveFlag, FALSE, FALSE,
fileAction, fileAction, NULL) == FALSE)
- exit(FALSE);
+ return EXIT_FAILURE;
}
- exit(TRUE);
+ return EXIT_SUCCESS;
bad_group:
- fatalError( "unknown group name: %s\n", groupName);
+ error_msg_and_die( "unknown group name: %s\n", groupName);
}
/*