Title: | Command Line Option Parser |
---|---|
Description: | A command line parser inspired by Python's 'optparse' library to be used with Rscript to write "#!" shebang scripts that accept short and long flag/options. |
Authors: | Trevor L. Davis [aut, cre] , Allen Day [ctb] (Some documentation and examples ported from the getopt package.), Python Software Foundation [ctb] (Some documentation from the optparse Python module.), Steve Lianoglou [ctb], Jim Nikelski [ctb], Kirill Müller [ctb], Peter Humburg [ctb], Rich FitzJohn [ctb], Gyu Jin Choi [ctb] |
Maintainer: | Trevor L. Davis <[email protected]> |
License: | GPL (>= 2) |
Version: | 1.7.5 |
Built: | 2025-01-12 04:35:00 UTC |
Source: | https://github.com/trevorld/r-optparse |
Goal is to create an R package of a command line parser inspired by Python's “optparse” library.
optparse
is primarily intended to be used with
“Rscript”. It facilitates writing “#!” shebang scripts that
accept short and long flags/options. It can also be used from directly, but
is probably less useful in this context.
See package vignette for a more detailed example.
Notes on naming convention in package: 1. An option is one of the shell-split input strings. 2. A flag is a type of option. a flag can be defined as having no argument (defined below), a required argument, or an optional argument. 3. An argument is a type of option, and is the value associated with a flag. 4. A long flag is a type of flag, and begins with the string “–”. If the long flag has an associated argument, it may be delimited from the long flag by either a trailing =, or may be the subsequent option. 5. A short flag is a type of flag, and begins with the string “-”. If a short flag has an associated argument, it is the subsequent option. short flags may be bundled together, sharing a single leading “"-"”, but only the final short flag is able to have a corresponding argument. %%%
Trevor L. Davis.
Some documentation and unit tests ported from Allen Day's getopt package.
The documentation for Python's optparse library, which this package is based on, is Copyright 1990-2009, Python Software Foundation.
Python's optparse
library, which this package is based on,
is described here: https://docs.python.org/3/library/optparse.html
example_file <- system.file("exec", "example.R", package = "optparse") example_file_2 <- system.file("exec", "display_file.R", package = "optparse") ## Not run: readLines(example_file) readLines(example_file_2) ## End(Not run)
example_file <- system.file("exec", "example.R", package = "optparse") example_file_2 <- system.file("exec", "display_file.R", package = "optparse") ## Not run: readLines(example_file) readLines(example_file_2) ## End(Not run)
IndentedHelpFormatter()
is the default help text formatter.
TitledHelpFormatter()
is an alternative help text formatter.
IndentedHelpFormatter(object) TitledHelpFormatter(object)
IndentedHelpFormatter(object) TitledHelpFormatter(object)
object |
An |
NULL
invisibly. As a side effect prints out help text.
parser <- OptionParser(formatter = IndentedHelpFormatter) parser <- add_option(parser, "--generator", help = "Generator option") parser <- add_option(parser, "--count", help = "Count option") print_help(parser) parser <- OptionParser(formatter = TitledHelpFormatter) parser <- add_option(parser, "--generator", help = "Generator option") parser <- add_option(parser, "--count", help = "Count option") print_help(parser)
parser <- OptionParser(formatter = IndentedHelpFormatter) parser <- add_option(parser, "--generator", help = "Generator option") parser <- add_option(parser, "--count", help = "Count option") print_help(parser) parser <- OptionParser(formatter = TitledHelpFormatter) parser <- add_option(parser, "--generator", help = "Generator option") parser <- add_option(parser, "--count", help = "Count option") print_help(parser)
add_option
adds a option to a prexisting OptionParser
instance
whereas make_option
is used to create a list of
OptionParserOption
instances that will be used in the
option_list
argument of the OptionParser
function to create a
new OptionParser
instance.
make_option( opt_str, action = NULL, type = NULL, dest = NULL, default = NULL, help = "", metavar = NULL, callback = NULL, callback_args = NULL ) add_option( object, opt_str, action = NULL, type = NULL, dest = NULL, default = NULL, help = "", metavar = NULL, callback = NULL, callback_args = NULL )
make_option( opt_str, action = NULL, type = NULL, dest = NULL, default = NULL, help = "", metavar = NULL, callback = NULL, callback_args = NULL ) add_option( object, opt_str, action = NULL, type = NULL, dest = NULL, default = NULL, help = "", metavar = NULL, callback = NULL, callback_args = NULL )
opt_str |
A character vector containing the string of the desired long flag comprised of “–” followed by a letter and then a sequence of alphanumeric characters and optionally a string of the desired short flag comprised of the “-” followed by a letter. |
action |
A character string that describes the action |
type |
A character string that describes specifies which data type
should be stored, either “logical”, “integer”, “double”,
“complex”, or “character”. Default is “logical” if
|
dest |
A character string that specifies what field in the list returned
by |
default |
The default value |
help |
A character string describing the option to be used by
|
metavar |
A character string that stands in for the option argument when
printing help text. Default is the value of |
callback |
A function that executes after the each option value is fully
parsed. It's value is assigned to the option and its arguments are
the option S4 object, the long flag string, the value of the option,
the parser S4 object, and |
callback_args |
A list of additional arguments passed to callback function (via |
object |
An instance of the |
Both make_option
and add_option
return instances of
class OptionParserOption
.
Trevor Davis.
Python's optparse
library, which inspires this package,
is described here: https://docs.python.org/3/library/optparse.html
make_option("--longflag") make_option(c("-l", "--longflag")) make_option("--integer", type = "integer", default = 5) make_option("--integer", default = as.integer(5)) # same as previous # examples from package vignette make_option(c("-v", "--verbose"), action = "store_true", default = TRUE, help = "Print extra output [default]") make_option(c("-q", "--quietly"), action = "store_false", dest = "verbose", help = "Print little output") make_option(c("-c", "--count"), type = "integer", default = 5, help = "Number of random normals to generate [default %default]", metavar = "number") make_option("--generator", default = "rnorm", help = "Function to generate random deviates [default \"%default\"]") make_option("--mean", default = 0, help = "Mean if generator == \"rnorm\" [default %default]") make_option("--sd", default = 1, metavar = "standard deviation", help = "Standard deviation if generator == \"rnorm\" [default %default]")
make_option("--longflag") make_option(c("-l", "--longflag")) make_option("--integer", type = "integer", default = 5) make_option("--integer", default = as.integer(5)) # same as previous # examples from package vignette make_option(c("-v", "--verbose"), action = "store_true", default = TRUE, help = "Print extra output [default]") make_option(c("-q", "--quietly"), action = "store_false", dest = "verbose", help = "Print little output") make_option(c("-c", "--count"), type = "integer", default = 5, help = "Number of random normals to generate [default %default]", metavar = "number") make_option("--generator", default = "rnorm", help = "Function to generate random deviates [default \"%default\"]") make_option("--mean", default = 0, help = "Mean if generator == \"rnorm\" [default %default]") make_option("--sd", default = 1, metavar = "standard deviation", help = "Standard deviation if generator == \"rnorm\" [default %default]")
This function is used to create an instance of a parser object
which when combined with the parse_args
, make_option
, and add_option
methods is very useful for parsing options from the command line.
OptionParser( usage = "usage: %prog [options]", option_list = list(), add_help_option = TRUE, prog = NULL, description = "", epilogue = "", formatter = IndentedHelpFormatter )
OptionParser( usage = "usage: %prog [options]", option_list = list(), add_help_option = TRUE, prog = NULL, description = "", epilogue = "", formatter = IndentedHelpFormatter )
usage |
The program usage message that will printed out if
|
option_list |
A list of of |
add_help_option |
Whether a standard help option should be automatically
added to the |
prog |
Program name to be substituted for |
description |
Additional text for |
epilogue |
Additional text for |
formatter |
A function that formats usage text.
The function should take only one argument (an |
An instance of the OptionParser
class.
Trevor Davis.
Python's optparse
library, which inspired this package,
is described here: https://docs.python.org/3/library/optparse.html
parse_args
make_option
add_option
Option Parser
usage
The program usage message that will printed out if
parse_args
finds a help option, %prog
is substituted with the
value of the prog
argument.
options
A list of of OptionParserOption
instances that will
define how parse_args
reacts to command line options.
OptionParserOption
instances are usually created by make_option
and can also be added to an existing OptionParser
instance via the
add_option
function.
description
Additional text for print_help
to print out between
usage statement and options statement
epilogue
Additional text for print_help
to print out after
the options statement
formatter
A function that print_help
will use to print out after
the options statement. Default is IndentedHelpFormatter()
. This
package also provides the builtin formatter TitledHelpFormatter()
.
Trevor Davis.
Class to hold information about command-line options
short_flag
String of the desired short flag comprised of the “-” followed by a letter.
long_flag
String of the desired long flag comprised of “–” followed by a letter and then a sequence of alphanumeric characters.
action
A character string that describes the action optparse
should take when it encounters an option, either “store”,
“store_true”, or “store_false”. The default is “store”
which signifies that optparse
should store the specified following
value if the option is found on the command string. “store_true”
stores TRUE
if the option is found and “store_false” stores
FALSE
if the option is found.
type
A character string that describes specifies which data type
should be stored, either “logical”, “integer”, “double”,
“complex”, or “character”. Default is “logical” if
action %in% c("store_true", store_false)
, typeof(default)
if
action == "store"
and default is not NULL
and
“character” if action == "store"
and default is NULL
.
“numeric” will be converted to “double”.
dest
A character string that specifies what field in the list returned
by parse_args
should optparse
store option values. Default is
derived from the long flag in opt_str
.
default
The default value optparse
should use if it does not
find the option on the command line.
help
A character string describing the option to be used by
print_help
in generating a usage message. %default
will be
substituted by the value of default
.
metavar
A character string that stands in for the option argument when
printing help text. Default is the value of dest
.
callback
A function that executes after the each option value is fully parsed
callback_args
Additional arguments that pass to the callback function.
parse_args
parses command line options using an OptionParser
instance for guidance. parse_args2
is a wrapper to parse_args
setting the options positional_arguments
and convert_hyphens_to_underscores
to TRUE
.
parse_args( object, args = commandArgs(trailingOnly = TRUE), print_help_and_exit = TRUE, positional_arguments = FALSE, convert_hyphens_to_underscores = FALSE ) parse_args2( object, args = commandArgs(trailingOnly = TRUE), print_help_and_exit = TRUE )
parse_args( object, args = commandArgs(trailingOnly = TRUE), print_help_and_exit = TRUE, positional_arguments = FALSE, convert_hyphens_to_underscores = FALSE ) parse_args2( object, args = commandArgs(trailingOnly = TRUE), print_help_and_exit = TRUE )
object |
An |
args |
A character vector containing command line options to be parsed.
Default is everything after the Rscript program in the command line. If
|
print_help_and_exit |
Whether |
positional_arguments |
Number of positional arguments. A numeric
denoting the exact number of supported arguments, or a numeric vector of
length two denoting the minimum and maximum number of arguments
( |
convert_hyphens_to_underscores |
If the names in the returned list of options
contains hyphens then convert them to underscores. The default |
Returns a list with field options
containing our option values
as well as another field args
which contains a vector of
positional arguments. For backward compatibility, if and only if
positional_arguments
is FALSE
, returns a list containing
option values.
A big thanks to Steve Lianoglou for a bug report and patch; Juan Carlos Borrás for a bug report; Jim Nikelski for a bug report and patch; Ino de Brujin and Benjamin Tyner for a bug report; Jonas Zimmermann for bug report; Miroslav Posta for bug reports; Stefan Seemayer for bug report and patch; Kirill Müller for patches; Steve Humburg for patch.
Trevor Davis.
Python's optparse
library, which inspired this package,
is described here: https://docs.python.org/3/library/optparse.html
# example from vignette option_list <- list( make_option(c("-v", "--verbose"), action = "store_true", default = TRUE, help = "Print extra output [default]"), make_option(c("-q", "--quietly"), action = "store_false", dest = "verbose", help = "Print little output"), make_option(c("-c", "--count"), type = "integer", default = 5, help = "Number of random normals to generate [default %default]", metavar = "number"), make_option("--generator", default = "rnorm", help = "Function to generate random deviates [default \"%default\"]"), make_option("--mean", default = 0, help = "Mean if generator == \"rnorm\" [default %default]"), make_option("--sd", default = 1, metavar = "standard deviation", help = "Standard deviation if generator == \"rnorm\" [default %default]") ) parse_args(OptionParser(option_list = option_list), args = c("--sd=3", "--quietly")) # example from vignette using positional arguments option_list2 <- list( make_option(c("-n", "--add-numbers"), action = "store_true", default = FALSE, help = "Print line number at the beginning of each line [default]") ) parser <- OptionParser(usage = "%prog [options] file", option_list = option_list2) parse_args(parser, args = c("--add-numbers", "example.txt"), positional_arguments = TRUE) parse_args(parser, args = c("--add-numbers", "example.txt"), positional_arguments = TRUE, convert_hyphens_to_underscores = TRUE) parse_args2(parser, args = c("--add-numbers", "example.txt"))
# example from vignette option_list <- list( make_option(c("-v", "--verbose"), action = "store_true", default = TRUE, help = "Print extra output [default]"), make_option(c("-q", "--quietly"), action = "store_false", dest = "verbose", help = "Print little output"), make_option(c("-c", "--count"), type = "integer", default = 5, help = "Number of random normals to generate [default %default]", metavar = "number"), make_option("--generator", default = "rnorm", help = "Function to generate random deviates [default \"%default\"]"), make_option("--mean", default = 0, help = "Mean if generator == \"rnorm\" [default %default]"), make_option("--sd", default = 1, metavar = "standard deviation", help = "Standard deviation if generator == \"rnorm\" [default %default]") ) parse_args(OptionParser(option_list = option_list), args = c("--sd=3", "--quietly")) # example from vignette using positional arguments option_list2 <- list( make_option(c("-n", "--add-numbers"), action = "store_true", default = FALSE, help = "Print line number at the beginning of each line [default]") ) parser <- OptionParser(usage = "%prog [options] file", option_list = option_list2) parse_args(parser, args = c("--add-numbers", "example.txt"), positional_arguments = TRUE) parse_args(parser, args = c("--add-numbers", "example.txt"), positional_arguments = TRUE, convert_hyphens_to_underscores = TRUE) parse_args2(parser, args = c("--add-numbers", "example.txt"))
print_help
print an usage message from an OptionParser object, usually
called by parse_args
when it encounters a help option.
print_help(object)
print_help(object)
object |
A |
print_help
uses the cat
function to print out a usage
message. It returns invisible(NULL)
.
Trevor Davis.
Python's optparse
library, which inspired this package,
is described here: https://docs.python.org/3/library/optparse.html
{parse_args}
{OptionParser}