Struct docopt::Docopt [] [src]

pub struct Docopt {
    // some fields omitted
}

The main Docopt type, which is constructed with a Docopt usage string.

This can be used to match command line arguments to produce a ArgvMap.

Methods

impl Docopt

fn new<S>(usage: S) -> Result<Docopt, Error> where S: Deref<Target=str>

Parse the Docopt usage string given.

The Docopt value returned may be used immediately to parse command line arguments with a default configuration.

If there was a problem parsing the usage string, a Usage error is returned.

fn decode<D>(&self) -> Result<D, Error> where D: Decodable

Parse and decode the given argv.

This is a convenience method for parse().and_then(|vals| vals.decode()).

For details on how decoding works, please see the documentation for ArgvMap.

fn parse(&self) -> Result<ArgvMap, Error>

Parse command line arguments and try to match them against a usage pattern specified in the Docopt string.

If there is a match, then an ArgvMap is returned, which maps flags, commands and arguments to values.

If parsing the command line arguments fails, then an Argv error is returned. If parsing succeeds but there is no match, then a NoMatch error is returned. Both of these errors are always returned inside a WithProgramUsage error.

If special handling of help or version is enabled (the former is enabled by default), then Help or Version errors are returned if --help or --version is present.

fn argv<I, S>(self, argv: I) -> Docopt where I: IntoIterator<Item=S>, S: AsRef<str>

Set the argv to be used for Docopt parsing.

By default, when no argv is set, and it is automatically taken from std::env::args().

The argv given must be the full set of argv passed to the program. e.g., ["cp", "src", "dest"] is right while ["src", "dest"] is wrong.

fn options_first(self, yes: bool) -> Docopt

Enables the "options first" Docopt behavior.

The options first behavior means that all flags must appear before position arguments. That is, after the first position argument is seen, all proceeding arguments are interpreted as positional arguments unconditionally.

fn help(self, yes: bool) -> Docopt

Enables automatic handling of --help.

When this is enabled and --help appears anywhere in the arguments, then a Help error will be returned. You may then use the exit method on the error value to conveniently quit the program (which will print the full usage string to stdout).

Note that for this to work, --help must be a valid pattern.

When disabled, there is no special handling of --help.

fn version(self, version: Option<String>) -> Docopt

Enables automatic handling of --version.

When this is enabled and --version appears anywhere in the arguments, then a Version(s) error will be returned, where s is the string given here. You may then use the exit method on the error value to convenient quit the program (which will print the version to stdout).

When disabled (a None value), there is no special handling of --version.

Trait Implementations

Derived Implementations

impl Debug for Docopt

fn fmt(&self, __arg_0: &mut Formatter) -> Result

impl Clone for Docopt

fn clone(&self) -> Docopt

fn clone_from(&mut self, source: &Self)