GETFLAGS(8) GETFLAGS(8) NAME getflags, usage - command-line parsing for shell scripts SYNOPSIS getflags $* usage [ progname ] DESCRIPTION Getflags parses the options in its command-line arguments according to the environment variable $flagfmt. This vari- able should be a list of comma-separated options. Each option can be a single letter, indicating that it does not take arguments, or a letter followed by the space-separated names of its arguments. Getflags prints an rc(1) script on standard output which initializes the environment variable $flagx for every option mentioned in $flagfmt. If the option is not present on the command-line, the script sets that option's flag variable to an empty list. Otherwise, the script sets that option's flag variable with a list con- taining the option's arguments or, if the option takes no arguments, with the string 1. The script also sets the variable $* to the list of arguments following the options. The final line in the script sets the $status variable, to the empty string on success and to the string usage when there is an error parsing the command line. Usage prints a usage message to standard error. It creates the message using $flagfmt, as described above, $args, which should contain the string to be printed explaining non- option arguments, and $0, the program name (see rc(1)). If run under sh(1), which does not set $0, the program name must be given explicitly on the command line. EXAMPLE Parse the arguments for Plan 9's leak(1): flagfmt='b,s,f binary,r res,x width' args='name | pid list' if(! ifs=() eval `{getflags $*} || ~ $#* 0){ usage exit usage } SOURCE /usr/local/plan9/src/cmd/getflags.c /usr/local/plan9/src/cmd/usage.c SEE ALSO arg(3) Page 1 Plan 9 (printed 1/2/25)