diff options
author | Christian Franke <christian.franke@t-online.de> | 2021-05-20 11:05:29 +0200 |
---|---|---|
committer | Corinna Vinschen <corinna@vinschen.de> | 2021-05-20 22:29:58 +0200 |
commit | cb674a4ad14d90852f0d75d72ed110fcce5dea50 (patch) | |
tree | eee5005facc90bca5b1c2542ac1540e1e6ac5e5e /winsup/utils | |
parent | 0c0f3df224c51769d3095769cc78005967495f85 (diff) | |
download | newlib-cb674a4ad14d90852f0d75d72ed110fcce5dea50.zip newlib-cb674a4ad14d90852f0d75d72ed110fcce5dea50.tar.gz newlib-cb674a4ad14d90852f0d75d72ed110fcce5dea50.tar.bz2 |
Cygwin: utils: chattr: Improve option parsing, fix some messages.
Allow multiple characters also in first '-mode' argument.
Use '-H' instead of '-h' for '--help' to fix ambiguity with
hidden attribute. Fix help and usage texts and documentation.
Signed-off-by: Christian Franke <christian.franke@t-online.de>
Diffstat (limited to 'winsup/utils')
-rw-r--r-- | winsup/utils/chattr.c | 32 |
1 files changed, 14 insertions, 18 deletions
diff --git a/winsup/utils/chattr.c b/winsup/utils/chattr.c index 98f693a..c7dc649 100644 --- a/winsup/utils/chattr.c +++ b/winsup/utils/chattr.c @@ -28,12 +28,12 @@ struct option longopts[] = { { "recursive", no_argument, NULL, 'R' }, { "verbose", no_argument, NULL, 'V' }, { "force", no_argument, NULL, 'f' }, - { "help", no_argument, NULL, 'h' }, + { "help", no_argument, NULL, 'H' }, { "version", no_argument, NULL, 'v' }, { NULL, no_argument, NULL, 0} }; -const char *opts = "+RVfhv"; +const char *opts = "+RVfHv"; struct { @@ -211,7 +211,7 @@ static void print_version () { printf ("%s (cygwin) %d.%d.%d\n" - "Get POSIX ACL information\n" + "Change file attributes\n" "Copyright (C) 2018 - %s Cygwin Authors\n" "This is free software; see the source for copying conditions. " "There is NO\n" @@ -227,7 +227,7 @@ print_version () static void __attribute__ ((__noreturn__)) usage (FILE *stream) { - fprintf (stream, "Usage: %s [-RVfhv] [+-=mode]... [file]...\n", + fprintf (stream, "Usage: %s [-RVfHv] [+-=mode]... [file]...\n", program_invocation_short_name); if (stream == stderr) fprintf (stream, "Try '%s --help' for more information\n", @@ -236,11 +236,11 @@ usage (FILE *stream) fprintf (stream, "\n" "Change file attributes\n" "\n" - " -R, --recursive recursively list attributes of directories and their \n" + " -R, --recursive recursively apply the changes to directories and their\n" " contents\n" " -V, --verbose Be verbose during operation\n" " -f, --force suppress error messages\n" - " -h, --help this help text\n" + " -H, --help this help text\n" " -v, --version display the program version\n" "\n" "The format of 'mode' is {+-=}[acCehnrsSt]\n" @@ -251,7 +251,7 @@ usage (FILE *stream) "\n" "Supported attributes:\n" "\n" - " 'r', 'Readonly': file is read-only\n" + " 'r', 'Readonly': file is read-only\n" " 'h', 'Hidden': file or directory is hidden\n" " 's', 'System': file or directory that the operating system uses\n" " 'a', 'Archive': file or directory has the archive marker set\n" @@ -271,7 +271,7 @@ int main (int argc, char **argv) { int c, ret = 0; - int lastoptind = 0; + int lastoptind = 1; char *opt; opterr = 0; @@ -281,15 +281,15 @@ main (int argc, char **argv) { case 'R': Ropt = 1; - lastoptind = optind; break; case 'V': Vopt = 1; - lastoptind = optind; break; case 'f': fopt = 1; - lastoptind = optind; + break; + case 'H': + usage (stdout); break; case 'v': print_version (); @@ -297,14 +297,10 @@ main (int argc, char **argv) break; default: if (optind > lastoptind) - { - --optind; - goto next; - } - /*FALLTHRU*/ - case 'h': - usage (c == 'h' ? stdout : stderr); + --optind; + goto next; } + lastoptind = optind; } next: while (optind < argc) |