On Thu, Aug 04, 2016 at 01:54:11AM -0400, Kylie McClain wrote: > From: Kylie McClain <somasis@xxxxxxxxxxx> > This fallback code seems to go back the import of the repository back > in 2005, it fails on musl libc, and there aren't any comments > explaining why this difference is needed. Regardless, any > compatibility ifdefs should probably be checking macros defined on > systems that need a different code path, rather than just having > fallback code for non-glibc. Setting optreset is required on FreeBSD and NetBSD which do not recognize setting optind to 0. POSIX specifies neither of these methods to reset getopt(). However, removing the dependency on this feature is simple. The shell already features a function nextopt() that can be used to parse options and is automatically set up for builtins. >From 23da600dcff616662a93f307420d9142598e2cae Mon Sep 17 00:00:00 2001 From: Jilles Tjoelker <jilles@xxxxxxxx> Date: Thu, 4 Aug 2016 17:51:12 +0200 Subject: [PATCH 1/2] [HISTEDIT] Stop depending on getopt reset feature. Instead, use our own nextopt() function. --- src/histedit.c | 7 +------ 1 file changed, 1 insertion(+), 6 deletions(-) diff --git a/src/histedit.c b/src/histedit.c index 94465d7..ec45065 100644 --- a/src/histedit.c +++ b/src/histedit.c @@ -214,13 +214,8 @@ histcmd(int argc, char **argv) if (argc == 1) sh_error("missing history argument"); -#ifdef __GLIBC__ - optind = 0; -#else - optreset = 1; optind = 1; /* initialize getopt */ -#endif while (not_fcnumber(argv[optind]) && - (ch = getopt(argc, argv, ":e:lnrs")) != -1) + (ch = nextopt(":e:lnrs")) != '\0') switch ((char)ch) { case 'e': editor = optionarg; -- 2.9.2 -- Jilles Tjoelker -- To unsubscribe from this list: send the line "unsubscribe dash" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html