diff options
Diffstat (limited to '')
-rw-r--r-- | info/argparser.texinfo | 42 |
1 files changed, 34 insertions, 8 deletions
diff --git a/info/argparser.texinfo b/info/argparser.texinfo index 899978b..d774d8b 100644 --- a/info/argparser.texinfo +++ b/info/argparser.texinfo @@ -55,6 +55,7 @@ Texts. A copy of the license is included in the section entitled * Java version:: Using the Java version. * C version:: Using the C version. * Bash version:: Using the Bash version. +* Trigger functions:: Trigger events at the time an option is parsed. * Colours in help message:: Configuring colour use in help message * GNU Free Documentation License:: Copying and sharing this manual. @end menu @@ -246,11 +247,11 @@ which takes the options followed by a description as its parameters, the description can be @code{NULL}. To create an options use either @code{args_new_argumentless}, @code{args_new_argumented} or @code{args_new_variadic}. With the exception -that @code{args_new_argumentless} does not have the first parameters, these -methods have three parameters: a descriptive short name of a argument -associated with the option, the index of the primary alternative, and -finally a variadic parameter with the alternatives, meaning that each -alternative is an argument. +that @code{args_new_argumentless} does not have the second parameters, +these methods have three parameters: a trigger function pointer a descriptive +short name of a argument associated with the option, the index of the +primary alternative, and finally a variadic parameter with the alternatives, +meaning that each alternative is an argument. To list all valid options, use the method @code{args_get_opts} which returns a string array of all options, and @code{args_get_opts_count} which returns @@ -294,9 +295,9 @@ maxmimum count. To add valid options use the methods @code{args_add_argumentless}, @code{args_add_argumented} and @code{args_add_variadic}. With the except that @code{args_add_argumentless} does not take a name of -the argument, these methods takes the index of the primary alternative, -a one word name of the argument, a description (empty for none), and -then one argument per alternative. +the argument, these methods takes the name of the trigger function, +index of the primary alternative, a one word name of the argument, +a description (empty for none), and then one argument per alternative. @code{args_argcount} is the number of elements in @code{args_arguments} and @code{args_files} does not have any such counterpart. @@ -316,6 +317,31 @@ values are echoed. +@node Trigger functions +@chapter Trigger functions + +If you do not want to add a trigger function, use an empty string +instead in the Bash version, and @code{NULL} in the C version. +In the Python version, the trigger function is the last parameter +in the functions for creating options, and defaults to @code{None}. + +Trigger functions are invoked at the time an option is found an +can be used to keep track of the order of the options, or to +add additional options. + +The trigger functions are functions that does not return any value, +and has two or three parameters: the used option alternative, the +standard option alternative, and for argumented but not variadic +options: the used value. + +The the Java version, the standard option is not passed, so there +are only one or two parameters. Instead, the function is defined +by overriding the function @code{trigger} when creating the option, +and @code{this.standard} can be used to get the standard option +alternative. + + + @node Colours in help message @chapter Colours in help message |