aboutsummaryrefslogtreecommitdiff
path: root/main.c
diff options
context:
space:
mode:
authorRob Landley <rob@landley.net>2021-06-18 08:57:07 -0500
committerRob Landley <rob@landley.net>2021-06-18 08:57:07 -0500
commit29e7ed94a1fe2836d38960b9b3ab3e3b7e61c791 (patch)
treedb99e26587f20bc129add53e7c236ea31c5e55f1 /main.c
parent39f64538c2f5f56918d3352bc8a03aae6be0d1d9 (diff)
downloadtoybox-29e7ed94a1fe2836d38960b9b3ab3e3b7e61c791.tar.gz
Second attempt at making --help work with alias ls="ls --color"
Diffstat (limited to 'main.c')
-rw-r--r--main.c34
1 files changed, 19 insertions, 15 deletions
diff --git a/main.c b/main.c
index ffaece07..8f00158c 100644
--- a/main.c
+++ b/main.c
@@ -67,6 +67,21 @@ static void unknown(char *name)
help_exit("Unknown command %s", name);
}
+void check_help(char **arg)
+{
+ if (!strcmp(*arg, "--help")) {
+ if (CFG_TOYBOX && toys.which == toy_list && arg[1])
+ if (!(toys.which = toy_find(arg[1]))) unknown(arg[1]);
+ show_help(stdout, 1);
+ xexit();
+ }
+
+ if (!strcmp(*arg, "--version")) {
+ xprintf("toybox %s\n", toybox_version);
+ xexit();
+ }
+}
+
// Setup toybox global state for this command.
void toy_singleinit(struct toy_list *which, char *argv[])
{
@@ -74,23 +89,12 @@ void toy_singleinit(struct toy_list *which, char *argv[])
toys.argv = argv;
toys.toycount = ARRAY_LEN(toy_list);
- // Parse --help and --version for (almost) all commands
- if (CFG_TOYBOX_HELP_DASHDASH && !(which->flags & TOYFLAG_NOHELP) && argv[1]) {
- if (!strcmp(argv[1], "--help")) {
- if (CFG_TOYBOX && toys.which == toy_list && toys.argv[2])
- if (!(toys.which = toy_find(toys.argv[2]))) unknown(toys.argv[2]);
- show_help(stdout, 1);
- xexit();
- }
-
- if (!strcmp(argv[1], "--version")) {
- xprintf("toybox %s\n", toybox_version);
- xexit();
- }
- }
-
if (NEED_OPTIONS && which->options) get_optflags();
else {
+ // Parse --help and --version for (almost) all commands
+ if (CFG_TOYBOX_HELP_DASHDASH && !(which->flags & TOYFLAG_NOHELP) && argv[1])
+ check_help(argv+1);
+
toys.optargs = argv+1;
for (toys.optc = 0; toys.optargs[toys.optc]; toys.optc++);
}