FlagSpec

Struct FlagSpec 

Source
pub struct FlagSpec {
    pub name: &'static str,
    pub short: Option<char>,
    pub doc: &'static str,
    pub env: Option<&'static str>,
}
Expand description

Specification for Flag.

Note that noargs does not support flags with only short names.

Fields§

§name: &'static str

Flag long name (usually kebab-case).

§short: Option<char>

Flag short name.

§doc: &'static str

Documentation.

§env: Option<&'static str>

Environment variable name.

If a non-empty value is set to this variable, this flag is considered to be set.

Implementations§

Source§

impl FlagSpec

Source

pub const DEFAULT: Self

The default specification.

Source

pub const fn new(name: &'static str) -> Self

Makes an FlagSpec instance with a specified name (equivalent to noargs::flag(name)).

Source

pub const fn short(self, name: char) -> Self

Updates the value of FlagSpec::short.

Source

pub const fn doc(self, doc: &'static str) -> Self

Updates the value of FlagSpec::doc.

Source

pub const fn env(self, variable_name: &'static str) -> Self

Updates the value of FlagSpec::env.

Source

pub fn take(self, args: &mut RawArgs) -> Flag

Takes the first Flag instance that satisfies this specification from the raw arguments.

Source

pub fn take_help(self, args: &mut RawArgs) -> Flag

Similar to FlagSpec::take(), but updates the help-related metadata of args when the flag is present.

Specifically, the following code is executed:

args.metadata_mut().help_mode = true;
args.metadata_mut().help_flag_name = Some(flag.spec().name);
if matches!(flag, Flag::Long { .. }) {
    args.metadata_mut().full_help = true;
}

Trait Implementations§

Source§

impl Clone for FlagSpec

Source§

fn clone(&self) -> FlagSpec

Returns a duplicate of the value. Read more
1.0.0 · Source§

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

Performs copy-assignment from source. Read more
Source§

impl Debug for FlagSpec

Source§

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

Formats the value using the given formatter. Read more
Source§

impl Default for FlagSpec

Source§

fn default() -> Self

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

impl Hash for FlagSpec

Source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0 · Source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
Source§

impl PartialEq for FlagSpec

Source§

fn eq(&self, other: &FlagSpec) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Copy for FlagSpec

Source§

impl Eq for FlagSpec

Source§

impl StructuralPartialEq for FlagSpec

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

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

fn clone_into(&self, target: &mut T)

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

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

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

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

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

The type returned in the event of a conversion error.
Source§

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

Performs the conversion.