|
NAMEargparse - parse options passed to a fish script or functionSYNOPSISargparse [OPTIONS] OPTION_SPEC... -- [ARG...] DESCRIPTIONThis command makes it easy for fish scripts and functions to handle arguments like how fish builtin commands handle their arguments. You pass arguments that define the known options, followed by a literal --, then the arguments to be parsed (which might also include a literal --). argparse then sets variables to indicate the passed options with their values, and sets $argv (and always $argv) to the remaining arguments. More on this in the usage section below.Each option specification (OPTION_SPEC) is written in the domain specific language described below. All OPTION_SPECs must appear after any argparse flags and before the -- that separates them from the arguments to be parsed. Each option that is seen in the ARG list will result in variables named _flag_X, where X is the short flag letter and the long flag name (if they are defined). For example a --help option could cause argparse to define one variable called _flag_h and another called _flag_help. The variables will be set with local scope (i.e., as if the script had done set -l _flag_X). If the flag is a boolean (that is, it just is passed or not, it doesn't have a value) the values are the short and long flags seen. If the option is not a boolean the values will be zero or more values corresponding to the values collected when the ARG list is processed. If the flag was not seen the flag variable will not be set. OPTIONSThe following argparse options are available. They must appear before all OPTION_SPECs:
USAGETo use this command, pass the option specifications (OPTION_SPEC), then a mandatory --, and then the arguments you want to have parsed.A simple example: argparse --name=my_function 'h/help' 'n/name=' -- $argv or return If $argv is empty then there is nothing to parse and argparse returns zero to indicate success. If $argv is not empty then it is checked for flags -h, --help, -n and --name. If they are found they are removed from the arguments and local variables called _flag_OPTION are set so the script can determine which options were seen. If $argv doesn't have any errors, like a missing mandatory value for an option, then argparse exits with a status of zero. Otherwise it writes appropriate error messages to stderr and exits with a status of one. The or return means that the function returns argparse's status if it failed, so if it goes on argparse succeeded. The -- argument is required. You do not have to include any arguments after the -- but you must include the --. For example, this is acceptable: set -l argv argparse 'h/help' 'n/name' -- $argv But this is not: set -l argv argparse 'h/help' 'n/name' $argv The first -- seen is what allows the argparse command to reliably separate the option specifications and options to argparse itself (like --ignore-unknown) from the command arguments, so it is required. OPTION SPECIFICATIONSEach option specification consists of:
See the fish_opt command for a friendlier but more verbose way to create option specifications. If a flag is not seen when parsing the arguments then the corresponding _flag_X var(s) will not be set. INTEGER FLAGSometimes commands take numbers directly as options, like foo -55. To allow this one option spec can have the # modifier so that any integer will be understood as this flag, and the last number will be given as its value (as if = was used).The # must follow the short flag letter (if any), and other modifiers like = are not allowed, except for - (for backwards compatibility): m#maximum This does not read numbers given as +NNN, only those that look like flags - -NNN. NOTE: OPTIONAL ARGUMENTSAn option defined with =? can take optional arguments. Optional arguments have to be directly attached to the option they belong to.That means the argument will only be used for the option if you use it like: cmd --flag=value # or cmd -fvalue but not if used like: cmd --flag value # "value" here will be used as a positional argument # and "--flag" won't have an argument. If this weren't the case, using an option without an optional argument would be difficult if you also wanted to use positional arguments. For example: grep --color auto # Here "auto" will be used as the search string, # "color" will not have an argument and will fall back to the default, # which also *happens to be* auto. grep --color always # Here grep will still only use color "auto"matically # and search for the string "always". This isn't specific to argparse but common to all things using getopt(3) (if they have optional arguments at all). That grep example is how GNU grep actually behaves. FLAG VALUE VALIDATIONSometimes you need to validate the option values. For example, that it is a valid integer within a specific range, or an ip address, or something entirely different. You can always do this after argparse returns but you can also request that argparse perform the validation by executing arbitrary fish script. To do so simply append an ! (exclamation-mark) then the fish script to be run. When that code is executed three vars will be defined:
These variables are passed to the function as local exported variables. The script should write any error messages to stdout, not stderr. It should return a status of zero if the flag value is valid otherwise a non-zero status to indicate it is invalid. Fish ships with a _validate_int function that accepts a --min and --max flag. Let's say your command accepts a -m or --max flag and the minimum allowable value is zero and the maximum is 5. You would define the option like this: m/max=!_validate_int --min 0 --max 5. The default if you just call _validate_int without those flags is to simply check that the value is a valid integer with no limits on the min or max value allowed. EXAMPLE OPTION_SPECSSome OPTION_SPEC examples:
After parsing the arguments the argv variable is set with local scope to any values not already consumed during flag processing. If there are no unbound values the variable is set but count $argv will be zero. If an error occurs during argparse processing it will exit with a non-zero status and print error messages to stderr. COPYRIGHT2021, fish-shell developers
Visit the GSP FreeBSD Man Page Interface. |