aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorRob Landley <rob@landley.net>2021-01-01 23:11:25 -0600
committerRob Landley <rob@landley.net>2021-01-01 23:11:25 -0600
commit32eed40a14c1f550e366741f0a2e7aa69093dc3d (patch)
tree4f628959f98e20a31a48b784470cec4f4a089ec1 /lib
parent3bd2e82dac075cd5a79a99e3ca31dc3f9a812b08 (diff)
downloadtoybox-32eed40a14c1f550e366741f0a2e7aa69093dc3d.tar.gz
Fix comma regression reported by Denys Nykula.
Diffstat (limited to 'lib')
-rw-r--r--lib/lib.c21
1 files changed, 10 insertions, 11 deletions
diff --git a/lib/lib.c b/lib/lib.c
index 3129e3e3..dfa4499f 100644
--- a/lib/lib.c
+++ b/lib/lib.c
@@ -976,22 +976,19 @@ mode_t string_to_mode(char *modestr, mode_t mode)
}
// Repeated "hows" are allowed; something like "a=r+w+s" is valid.
- do {
- if (!(dohow = *str) || !strchr(hows, *str)) goto barf;
+ for (;;) {
+ if (-1 == stridx(hows, dohow = *str)) goto barf;
while (*++str && (s = strchr(whats, *str))) dowhat |= 1<<(s-whats);
// Convert X to x for directory or if already executable somewhere
if ((dowhat&32) && (S_ISDIR(mode) || (mode&0111))) dowhat |= 1;
// Copy mode from another category?
- if (!dowhat && *str && (s = strchr(whys, *str))) {
- dowhat = (mode>>(3*(s-whys)))&7;
+ if (!dowhat && -1 != (i = stridx(whys, *str))) {
+ dowhat = (mode>>(3*i))&7;
str++;
}
- // Are we ready to do a thing yet?
- if (*str && (str[1] != ',' && !strchr(hows, *str))) goto barf;
-
// Loop through what=xwrs and who=ogu to apply bits to the mode.
for (i=0; i<4; i++) {
for (j=0; j<3; j++) {
@@ -1015,12 +1012,14 @@ mode_t string_to_mode(char *modestr, mode_t mode)
if (bit && dohow != '-') mode |= where;
}
}
- } while (*str);
-
- if (!*str) break;
+ if (!*str) return mode|extrabits;
+ if (*str == ',') {
+ str++;
+ break;
+ }
+ }
}
- return mode|extrabits;
barf:
error_exit("bad mode '%s'", modestr);
}