# HG changeset patch # User Paul Eggert # Date 1096863887 0 # Node ID 707482f5c10632d8ff846bb92cc1e65f0fca0532 # Parent 1e92d75c6d3a7feb812f0626525436963b9d4ca0 (mode_compile): Don't decrement a pointer that points to the start of a string, as the C Standard says the resulting behavior is undefined. diff --git a/lib/modechange.c b/lib/modechange.c --- a/lib/modechange.c +++ b/lib/modechange.c @@ -211,10 +211,9 @@ umask_value = umask (0); umask (umask_value); /* Restore the old value. */ - --mode_string; /* One loop iteration for each "ugoa...=+-rwxXstugo...[=+-rwxXstugo...]". */ - do + for (;; mode_string++) { /* Which bits in the mode are operated on. */ mode_t affected_bits = 0; @@ -226,7 +225,7 @@ bool who_specified_p; /* Turn on all the bits in `affected_bits' for each group given. */ - for (++mode_string;; ++mode_string) + for (;; mode_string++) switch (*mode_string) { case 'u': @@ -349,7 +348,11 @@ } no_more_values:; } - } while (*mode_string == ','); + + if (*mode_string != ',') + break; + } + if (*mode_string == 0) return head; invalid: