Struct ap::Arg[][src]

pub struct Arg {
    pub option: char,
    pub needs: Need,
    pub help: Option<String>,
    pub required: bool,
    pub value: Option<String>,
    pub count: usize,
}
Expand description

An argument, either an option or a positional argument.

  1. It is used to specify how an argument is to be handled.

    If it is to be considered an option, the [Arg.option] member should be set.

  2. To store the results of the parse for the argument.

    For example, the parser records the number of times the argument was handled in the count member.

Note

  • All members are public for handler convenience.

Fields

option: char

Single character short option name (required). Can be set to special values for non-standard behaviour:

needs: Need

Type of option (required, but defaults).

help: Option<String>

Description of the option.

required: bool

Set if the option must be specified.

value: Option<String>

Value specified for this option (if the needs member is not Need::Nothing).

Notes

  • This is equivalent to getopt(3)’s optarg value.
  • This will be None for flag options.
count: usize

Number of times the option was specified.

Notes

  • Used internally for Error::MissingReqOpt.
  • If a positional argument handler has been registered, value will be incremented for each positional argument specified.
  • This is similar to getopt(3)’s optind value, but rather than being the overall index, it is a value incremented each time the particular option is specified on the command-line.

Implementations

impl Arg[src]

pub fn new(option: char) -> Self[src]

Create a new argument handler.

pub fn option(self, option: char) -> Self[src]

Specify the option character (name) for the option.

pub fn needs(self, needs: Need) -> Self[src]

Specify the requirement for the option.

pub fn help(self, help: &str) -> Self[src]

Specify the help text for the option.

pub fn required(self) -> Self[src]

Specify that the option must be provided on the command-line.

Trait Implementations

impl Clone for Arg[src]

fn clone(&self) -> Arg[src]

Returns a copy of the value. Read more

fn clone_from(&mut self, source: &Self)1.0.0[src]

Performs copy-assignment from source. Read more

impl Debug for Arg[src]

fn fmt(&self, f: &mut Formatter<'_>) -> Result[src]

Formats the value using the given formatter. Read more

impl Default for Arg[src]

fn default() -> Arg[src]

Returns the “default value” for a type. Read more

impl Display for Arg[src]

fn fmt(&self, f: &mut Formatter<'_>) -> Result[src]

Formats the value using the given formatter. Read more

impl Ord for Arg[src]

fn cmp(&self, other: &Arg) -> Ordering[src]

This method returns an Ordering between self and other. Read more

#[must_use]
fn max(self, other: Self) -> Self
1.21.0[src]

Compares and returns the maximum of two values. Read more

#[must_use]
fn min(self, other: Self) -> Self
1.21.0[src]

Compares and returns the minimum of two values. Read more

#[must_use]
fn clamp(self, min: Self, max: Self) -> Self
1.50.0[src]

Restrict a value to a certain interval. Read more

impl PartialEq<Arg> for Arg[src]

fn eq(&self, other: &Arg) -> bool[src]

This method tests for self and other values to be equal, and is used by ==. Read more

fn ne(&self, other: &Arg) -> bool[src]

This method tests for !=.

impl PartialOrd<Arg> for Arg[src]

fn partial_cmp(&self, other: &Arg) -> Option<Ordering>[src]

This method returns an ordering between self and other values if one exists. Read more

#[must_use]
fn lt(&self, other: &Rhs) -> bool
1.0.0[src]

This method tests less than (for self and other) and is used by the < operator. Read more

#[must_use]
fn le(&self, other: &Rhs) -> bool
1.0.0[src]

This method tests less than or equal to (for self and other) and is used by the <= operator. Read more

#[must_use]
fn gt(&self, other: &Rhs) -> bool
1.0.0[src]

This method tests greater than (for self and other) and is used by the > operator. Read more

#[must_use]
fn ge(&self, other: &Rhs) -> bool
1.0.0[src]

This method tests greater than or equal to (for self and other) and is used by the >= operator. Read more

impl Eq for Arg[src]

impl StructuralEq for Arg[src]

impl StructuralPartialEq for Arg[src]

Auto Trait Implementations

impl RefUnwindSafe for Arg

impl Send for Arg

impl Sync for Arg

impl Unpin for Arg

impl UnwindSafe for Arg

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

pub fn type_id(&self) -> TypeId[src]

Gets the TypeId of self. Read more

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

pub fn borrow(&self) -> &T[src]

Immutably borrows from an owned value. Read more

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

pub fn borrow_mut(&mut self) -> &mut T[src]

Mutably borrows from an owned value. Read more

impl<T> From<T> for T[src]

pub fn from(t: T) -> T[src]

Performs the conversion.

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

pub fn into(self) -> U[src]

Performs the conversion.

impl<T> ToOwned for T where
    T: Clone
[src]

type Owned = T

The resulting type after obtaining ownership.

pub fn to_owned(&self) -> T[src]

Creates owned data from borrowed data, usually by cloning. Read more

pub fn clone_into(&self, target: &mut T)[src]

🔬 This is a nightly-only experimental API. (toowned_clone_into)

recently added

Uses borrowed data to replace owned data, usually by cloning. Read more

impl<T> ToString for T where
    T: Display + ?Sized
[src]

pub default fn to_string(&self) -> String[src]

Converts the given value to a String. Read more

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

pub fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>[src]

Performs the conversion.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.

pub fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>[src]

Performs the conversion.