mknod: better --help, much clearer code

function                                             old     new   delta
packed_usage                                       32066   32091     +25
mknod_main                                           173     174      +1

Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
This commit is contained in:
Denys Vlasenko 2018-01-08 11:22:37 +01:00
parent 83c99ab446
commit 2f55404bbc

View File

@ -20,7 +20,7 @@
/* BB_AUDIT SUSv3 N/A -- Matches GNU behavior. */ /* BB_AUDIT SUSv3 N/A -- Matches GNU behavior. */
//usage:#define mknod_trivial_usage //usage:#define mknod_trivial_usage
//usage: "[-m MODE] " IF_SELINUX("[-Z] ") "NAME TYPE MAJOR MINOR" //usage: "[-m MODE] " IF_SELINUX("[-Z] ") "NAME TYPE [MAJOR MINOR]"
//usage:#define mknod_full_usage "\n\n" //usage:#define mknod_full_usage "\n\n"
//usage: "Create a special file (block, character, or pipe)\n" //usage: "Create a special file (block, character, or pipe)\n"
//usage: "\n -m MODE Creation mode (default a=rw)" //usage: "\n -m MODE Creation mode (default a=rw)"
@ -30,7 +30,7 @@
//usage: "\nTYPE:" //usage: "\nTYPE:"
//usage: "\n b Block device" //usage: "\n b Block device"
//usage: "\n c or u Character device" //usage: "\n c or u Character device"
//usage: "\n p Named pipe (MAJOR and MINOR are ignored)" //usage: "\n p Named pipe (MAJOR MINOR must be omitted)"
//usage: //usage:
//usage:#define mknod_example_usage //usage:#define mknod_example_usage
//usage: "$ mknod /dev/fd0 b 2 0\n" //usage: "$ mknod /dev/fd0 b 2 0\n"
@ -47,40 +47,40 @@ static const char modes_chars[] ALIGN1 = { 'p', 'c', 'u', 'b', 0, 1, 1, 2 };
static const mode_t modes_cubp[] = { S_IFIFO, S_IFCHR, S_IFBLK }; static const mode_t modes_cubp[] = { S_IFIFO, S_IFCHR, S_IFBLK };
int mknod_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE; int mknod_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE;
int mknod_main(int argc, char **argv) int mknod_main(int argc UNUSED_PARAM, char **argv)
{ {
mode_t mode; mode_t mode;
dev_t dev; dev_t dev;
const char *name; const char *type, *arg;
mode = getopt_mk_fifo_nod(argv); mode = getopt_mk_fifo_nod(argv);
argv += optind; argv += optind;
argc -= optind; //argc -= optind;
if (argc >= 2) { if (!argv[0] || !argv[1])
name = strchr(modes_chars, argv[1][0]); bb_show_usage();
if (name != NULL) { type = strchr(modes_chars, argv[1][0]);
mode |= modes_cubp[(int)(name[4])]; if (!type)
bb_show_usage();
dev = 0; mode |= modes_cubp[(int)(type[4])];
if (*name != 'p') {
argc -= 2;
if (argc == 2) {
/* Autodetect what the system supports; these macros should
* optimize out to two constants. */
dev = makedev(xatoul_range(argv[2], 0, major(UINT_MAX)),
xatoul_range(argv[3], 0, minor(UINT_MAX)));
}
}
if (argc == 2) { dev = 0;
name = *argv; arg = argv[2];
if (mknod(name, mode, dev) == 0) { if (*type != 'p') {
return EXIT_SUCCESS; if (!argv[2] || !argv[3])
} bb_show_usage();
bb_simple_perror_msg_and_die(name); /* Autodetect what the system supports; these macros should
} * optimize out to two constants. */
} dev = makedev(xatoul_range(argv[2], 0, major(UINT_MAX)),
xatoul_range(argv[3], 0, minor(UINT_MAX)));
arg = argv[4];
} }
bb_show_usage(); if (arg)
bb_show_usage();
if (mknod(argv[0], mode, dev) != 0) {
bb_simple_perror_msg_and_die(argv[0]);
}
return EXIT_SUCCESS;
} }