#include "internal.h"
#define BB_DECLARE_EXTERN
#define bb_need_invalid_option
+#define bb_need_too_few_args
#include "messages.c"
#include <stdio.h>
#include <pwd.h>
-static uid_t uid = -1;
-static gid_t gid = -1;
+static unsigned long uid = -1;
+static unsigned long gid = -1;
static int whichApp;
-static char *invocationName = NULL;
static char *theMode = NULL;
case CHMOD_APP:
/* Parse the specified modes */
if (parse_mode(theMode, &(statbuf->st_mode)) == FALSE) {
- fatalError( "%s: unknown mode: %s\n", invocationName, theMode);
+ fatalError( "unknown mode: %s\n", theMode);
}
if (chmod(fileName, statbuf->st_mode) == 0)
return (TRUE);
int chmod_chown_chgrp_main(int argc, char **argv)
{
int recursiveFlag = FALSE;
- char *groupName;
- char *p;
+ char *groupName=NULL;
+ char *p=NULL;
const char *appUsage;
- whichApp = (strcmp(*argv, "chown") == 0)?
- CHOWN_APP : (strcmp(*argv, "chmod") == 0)?
+ whichApp = (strcmp(applet_name, "chown") == 0)?
+ CHOWN_APP : (strcmp(applet_name, "chmod") == 0)?
CHMOD_APP : CHGRP_APP;
appUsage = (whichApp == CHOWN_APP)?
if (argc < 2)
usage(appUsage);
- invocationName = *argv;
- argc--;
argv++;
/* Parse options */
- while (**argv == '-') {
- while (*++(*argv))
+ while (--argc >= 0 && *argv && (**argv == '-')) {
+ while (*++(*argv)) {
switch (**argv) {
- case 'R':
- recursiveFlag = TRUE;
- break;
- default:
- fprintf(stderr, invalid_option, invocationName, **argv);
- usage(appUsage);
+ case 'R':
+ recursiveFlag = TRUE;
+ break;
+ default:
+ fprintf(stderr, invalid_option, applet_name, **argv);
+ usage(appUsage);
}
- argc--;
+ }
argv++;
}
+ if (argc == 0 || *argv == NULL) {
+ fprintf(stderr, too_few_args, applet_name);
+ usage(appUsage);
+ }
+
if (whichApp == CHMOD_APP) {
theMode = *argv;
} else {
if (*argv == p)
uid = my_getpwnam(*argv);
if (uid == -1) {
- fatalError( "%s: unknown user name: %s\n",
- invocationName, *argv);
+ fatalError( "unknown user name: %s\n", *argv);
}
}
}
/* Ok, ready to do the deed now */
if (argc <= 1) {
- fatalError( "%s: too few arguments\n", invocationName);
+ fatalError( "too few arguments\n");
}
while (argc-- > 1) {
if (recursiveAction (*(++argv), recursiveFlag, FALSE, FALSE,
exit(TRUE);
bad_group:
- fatalError( "%s: unknown group name: %s\n", invocationName, groupName);
+ fatalError( "unknown group name: %s\n", groupName);
}
/*