run-parts: stop providing incompatible short options
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
This commit is contained in:
parent
0496e824a5
commit
1e43a381b2
@ -21,26 +21,24 @@
|
|||||||
* taken from debian-utils. I've only removed the long options and the
|
* taken from debian-utils. I've only removed the long options and the
|
||||||
* report mode. As the original run-parts support only long options, I've
|
* report mode. As the original run-parts support only long options, I've
|
||||||
* broken compatibility because the BusyBox policy doesn't allow them.
|
* broken compatibility because the BusyBox policy doesn't allow them.
|
||||||
* The supported options are:
|
|
||||||
* -t test. Print the name of the files to be executed, without
|
|
||||||
* execute them.
|
|
||||||
* -a ARG argument. Pass ARG as an argument the program executed. It can
|
|
||||||
* be repeated to pass multiple arguments.
|
|
||||||
* -u MASK umask. Set the umask of the program executed to MASK.
|
|
||||||
* -e exit as soon as a script returns with a non-zero exit code
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
//usage:#define run_parts_trivial_usage
|
//usage:#define run_parts_trivial_usage
|
||||||
//usage: "[-t"IF_FEATURE_RUN_PARTS_FANCY("l")"] [-a ARG]... [-u MASK] [-e] DIRECTORY"
|
//usage: "[-a ARG]... [-u UMASK] "
|
||||||
|
//usage: IF_FEATURE_RUN_PARTS_LONG_OPTIONS("[--reverse] [--test] [-−exit−on−error] "IF_FEATURE_RUN_PARTS_FANCY("[--list] "))
|
||||||
|
//usage: "DIRECTORY"
|
||||||
//usage:#define run_parts_full_usage "\n\n"
|
//usage:#define run_parts_full_usage "\n\n"
|
||||||
//usage: "Run a bunch of scripts in DIRECTORY\n"
|
//usage: "Run a bunch of scripts in DIRECTORY\n"
|
||||||
//usage: "\n -t Dry run"
|
//usage: "\n -a ARG Pass ARG as argument to scripts"
|
||||||
|
//usage: "\n -u UMASK Set UMASK before running scripts"
|
||||||
|
//usage: IF_FEATURE_RUN_PARTS_LONG_OPTIONS(
|
||||||
|
//usage: "\n -−reverse Reverse execution order"
|
||||||
|
//usage: "\n --test Dry run"
|
||||||
|
//usage: "\n -−exit−on−error Exit if a script exits with non-zero"
|
||||||
//usage: IF_FEATURE_RUN_PARTS_FANCY(
|
//usage: IF_FEATURE_RUN_PARTS_FANCY(
|
||||||
//usage: "\n -l Print names of matching files even if they are not executable"
|
//usage: "\n --list Print names of matching files even if they are not executable"
|
||||||
|
//usage: )
|
||||||
//usage: )
|
//usage: )
|
||||||
//usage: "\n -a ARG Pass ARG as argument to programs"
|
|
||||||
//usage: "\n -u MASK Set umask to MASK before running programs"
|
|
||||||
//usage: "\n -e Exit as soon as a script returns with a non-zero exit code"
|
|
||||||
//usage:
|
//usage:
|
||||||
//usage:#define run_parts_example_usage
|
//usage:#define run_parts_example_usage
|
||||||
//usage: "$ run-parts -a start /etc/init.d\n"
|
//usage: "$ run-parts -a start /etc/init.d\n"
|
||||||
@ -72,20 +70,15 @@ struct globals {
|
|||||||
enum { NUM_CMD = (COMMON_BUFSIZE - sizeof(G)) / sizeof(cmd[0]) - 1 };
|
enum { NUM_CMD = (COMMON_BUFSIZE - sizeof(G)) / sizeof(cmd[0]) - 1 };
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
OPT_r = (1 << 0),
|
OPT_a = (1 << 0),
|
||||||
OPT_a = (1 << 1),
|
OPT_u = (1 << 1),
|
||||||
OPT_u = (1 << 2),
|
OPT_r = (1 << 2) * ENABLE_FEATURE_RUN_PARTS_LONG_OPTIONS,
|
||||||
OPT_t = (1 << 3),
|
OPT_t = (1 << 3) * ENABLE_FEATURE_RUN_PARTS_LONG_OPTIONS,
|
||||||
OPT_e = (1 << 4),
|
OPT_e = (1 << 4) * ENABLE_FEATURE_RUN_PARTS_LONG_OPTIONS,
|
||||||
OPT_l = (1 << 5) * ENABLE_FEATURE_RUN_PARTS_FANCY,
|
OPT_l = (1 << 5) * ENABLE_FEATURE_RUN_PARTS_LONG_OPTIONS
|
||||||
|
* ENABLE_FEATURE_RUN_PARTS_FANCY,
|
||||||
};
|
};
|
||||||
|
|
||||||
#if ENABLE_FEATURE_RUN_PARTS_FANCY
|
|
||||||
#define list_mode (option_mask32 & OPT_l)
|
|
||||||
#else
|
|
||||||
#define list_mode 0
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Is this a valid filename (upper/lower alpha, digits,
|
/* Is this a valid filename (upper/lower alpha, digits,
|
||||||
* underscores, and hyphens only?)
|
* underscores, and hyphens only?)
|
||||||
*/
|
*/
|
||||||
@ -113,7 +106,7 @@ static int FAST_FUNC act(const char *file, struct stat *statbuf, void *args UNUS
|
|||||||
if (depth == 2
|
if (depth == 2
|
||||||
&& ( !(statbuf->st_mode & (S_IFREG | S_IFLNK))
|
&& ( !(statbuf->st_mode & (S_IFREG | S_IFLNK))
|
||||||
|| invalid_name(file)
|
|| invalid_name(file)
|
||||||
|| (!list_mode && access(file, X_OK) != 0))
|
|| (!(option_mask32 & OPT_l) && access(file, X_OK) != 0))
|
||||||
) {
|
) {
|
||||||
return SKIP;
|
return SKIP;
|
||||||
}
|
}
|
||||||
@ -129,12 +122,12 @@ static int FAST_FUNC act(const char *file, struct stat *statbuf, void *args UNUS
|
|||||||
static const char runparts_longopts[] ALIGN1 =
|
static const char runparts_longopts[] ALIGN1 =
|
||||||
"arg\0" Required_argument "a"
|
"arg\0" Required_argument "a"
|
||||||
"umask\0" Required_argument "u"
|
"umask\0" Required_argument "u"
|
||||||
"test\0" No_argument "t"
|
|
||||||
"exit-on-error\0" No_argument "e"
|
|
||||||
#if ENABLE_FEATURE_RUN_PARTS_FANCY
|
|
||||||
"list\0" No_argument "l"
|
|
||||||
"reverse\0" No_argument "r"
|
|
||||||
//TODO: "verbose\0" No_argument "v"
|
//TODO: "verbose\0" No_argument "v"
|
||||||
|
"reverse\0" No_argument "\xf0"
|
||||||
|
"test\0" No_argument "\xf1"
|
||||||
|
"exit-on-error\0" No_argument "\xf2"
|
||||||
|
#if ENABLE_FEATURE_RUN_PARTS_FANCY
|
||||||
|
"list\0" No_argument "\xf3"
|
||||||
#endif
|
#endif
|
||||||
;
|
;
|
||||||
#endif
|
#endif
|
||||||
@ -154,7 +147,7 @@ int run_parts_main(int argc UNUSED_PARAM, char **argv)
|
|||||||
#endif
|
#endif
|
||||||
/* We require exactly one argument: the directory name */
|
/* We require exactly one argument: the directory name */
|
||||||
opt_complementary = "=1:a::";
|
opt_complementary = "=1:a::";
|
||||||
getopt32(argv, "ra:u:te"IF_FEATURE_RUN_PARTS_FANCY("l"), &arg_list, &umask_p);
|
getopt32(argv, "a:u:", &arg_list, &umask_p);
|
||||||
|
|
||||||
umask(xstrtou_range(umask_p, 8, 0, 07777));
|
umask(xstrtou_range(umask_p, 8, 0, 07777));
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user