rust_script_ext::prelude

Struct Args

Source
pub struct Args { /* private fields */ }
Expand description

Arguments iterator.

This provides an additional utility layer on top of std::env::Args. It does not aim to be a fully feature argument parser, clap is great for this, at the cost of a much heavier crate.

This struct is meant to provide an iterator-like interface layering on parsing and error handling.

The two most common functions are req and opt, which will parse the current argument position and advance to the next position.

To create an Args, use the args function.

Implementations§

Source§

impl Args

Source

pub fn req<T>(&mut self, desc: impl AsRef<str>) -> Result<T>
where T: FromStr, Result<T, T::Err>: IntoDiagnostic<T, T::Err>,

Parse current argument, requiring it exist, and advance the argument position.

T should implement FromStr with FromStr::Err implementing IntoDiagnostic. desc describes the argument in case of failure.

§Example
let mut args = Args::from(vec!["fst.txt", "24h"]);

let fst = args.req::<PathBuf>("filepath").unwrap();
// humantime::Duration can parse nicely
let dur = args.req::<Duration>("delay length").unwrap();

let err = args.req::<String>("output").unwrap_err().to_string();
assert_eq!(&err, "expecting an argument at position 3");
Source

pub fn opt<T>(&mut self, desc: impl AsRef<str>) -> Result<Option<T>>
where T: FromStr, Result<T, T::Err>: IntoDiagnostic<T, T::Err>,

Parse current argument, returning None if it does not exist. If it does exist (and parses), advances the argument position.

T should implement FromStr with FromStr::Err implementing IntoDiagnostic. desc describes the argument in case of failure.

§Example
let mut args = Args::from(vec!["fst.txt"]);

let fst = args.opt::<String>("filepath").unwrap();
assert_eq!(fst, Some("fst.txt".to_string()));
let dur = args.opt::<Duration>("delay").unwrap();
assert!(dur.is_none());

// parsing error
let mut args = Args::from(vec!["text"]);
let err = args.opt::<f64>("a number").unwrap_err();
assert_eq!(&err.to_string(), "failed to parse `text` as f64");
Source

pub fn has<P>(&mut self, pred: P) -> bool
where P: FnMut(&str) -> bool,

Test if there is an argument satifying the predicate.

This tests from the current argument position, supplying the argument text to the predicate closure.

If the argument satisfies the predicate, true is returned and that argument is excluded from future queries (including req and opt).

This is useful to test for flags.

§Example
let mut args = Args::from(vec!["fst.txt", "-c", "24h"]);

let cut = args.has(|x| x == "-c" || x == "--cut");
assert!(cut);

// skips '-c' argument when advancing
assert_eq!(&args.req::<String>("").unwrap(), "fst.txt");
assert_eq!(&args.req::<String>("").unwrap(), "24h");
Source

pub fn finish(&mut self) -> Result<()>

Assert that no more arguments should be present.

§Example
let mut args = Args::from(vec!["fst.txt", "-c", "24h"]);

args.req::<String>("").unwrap();

let err = args.finish().unwrap_err().to_string();
assert_eq!(&err, "unconsumed arguments provided");
Source

pub fn peek<T>(&mut self) -> Result<Option<T>>
where T: FromStr, Result<T, T::Err>: IntoDiagnostic<T, T::Err>,

Parse the current argument without advancing the argument position.

T should implement FromStr with FromStr::Err implementing IntoDiagnostic.

§Example
let mut args = Args::from(vec!["24h"]);

let d = args.peek::<Duration>().unwrap().unwrap();
assert_eq!(d, Duration::from_str("24h").unwrap());

assert!(args.finish().is_err()); // position not advanced
Source

pub fn peek_str(&mut self) -> Option<&str>

Retrieve the current argument as a string without advancing the argument position.

§Example
let mut args = Args::from(vec!["fst.txt", "24h"]);

assert_eq!(args.peek_str(), Some("fst.txt"));
assert_eq!(&args.req::<String>("filepath").unwrap(), "fst.txt");
assert_eq!(args.peek_str(), Some("24h"));
Source

pub fn move_back(&mut self)

Retreat the argument position back one.

Skips over excluded arguments.

§Example
let mut args = Args::from(vec!["fst.txt", "-c", "24h"]);

args.has(|x| x == "-c"); // exclude -c flag
args.req::<String>("").ok();
args.req::<String>("").ok(); // at end now

args.move_back();
assert_eq!(args.peek_str(), Some("24h"));

args.move_back();
// skips the excluded
assert_eq!(args.peek_str(), Some("fst.txt"));
Source

pub fn move_front(&mut self)

Move to the front of the arguments.

Skips over excluded arguments.

§Example
let mut args = Args::from(vec!["-c", "fst.txt", "24h"]);

args.has(|x| x == "-c"); // exclude -c flag
args.req::<String>("").ok();
args.req::<String>("").ok(); // at end now

args.move_front();
assert_eq!(args.peek_str(), Some("fst.txt"));

Trait Implementations§

Source§

impl From<Vec<&'static str>> for Args

Source§

fn from(value: Vec<&'static str>) -> Self

Converts to this type from the input type.
Source§

impl From<Vec<String>> for Args

Source§

fn from(value: Vec<String>) -> Self

Converts to this type from the input type.
Source§

impl IntoIterator for Args

Consume the remaining arguments as an iterator over the raw strings.

Note that this starts from the argument position and skips any excluded arguments.

§Example

let mut args = Args::from(vec!["fst.txt", "-c", "24h", "output"]);
args.req::<String>("").unwrap();
args.has(|x| x== "-c");

let rem = args.into_iter().collect::<Vec<_>>();
assert_eq!(&rem, &[
   "24h".to_string(),
   "output".to_string(),
]);
Source§

type Item = String

The type of the elements being iterated over.
Source§

type IntoIter = Box<dyn Iterator<Item = String>>

Which kind of iterator are we turning this into?
Source§

fn into_iter(self) -> Self::IntoIter

Creates an iterator from a value. Read more

Auto Trait Implementations§

§

impl Freeze for Args

§

impl !RefUnwindSafe for Args

§

impl !Send for Args

§

impl !Sync for Args

§

impl Unpin for Args

§

impl !UnwindSafe for Args

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> 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> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<D> OwoColorize for D

Source§

fn fg<C>(&self) -> FgColorDisplay<'_, C, Self>
where C: Color,

Set the foreground color generically Read more
Source§

fn bg<C>(&self) -> BgColorDisplay<'_, C, Self>
where C: Color,

Set the background color generically. Read more
Source§

fn black(&self) -> FgColorDisplay<'_, Black, Self>

Change the foreground color to black
Source§

fn on_black(&self) -> BgColorDisplay<'_, Black, Self>

Change the background color to black
Source§

fn red(&self) -> FgColorDisplay<'_, Red, Self>

Change the foreground color to red
Source§

fn on_red(&self) -> BgColorDisplay<'_, Red, Self>

Change the background color to red
Source§

fn green(&self) -> FgColorDisplay<'_, Green, Self>

Change the foreground color to green
Source§

fn on_green(&self) -> BgColorDisplay<'_, Green, Self>

Change the background color to green
Source§

fn yellow(&self) -> FgColorDisplay<'_, Yellow, Self>

Change the foreground color to yellow
Source§

fn on_yellow(&self) -> BgColorDisplay<'_, Yellow, Self>

Change the background color to yellow
Source§

fn blue(&self) -> FgColorDisplay<'_, Blue, Self>

Change the foreground color to blue
Source§

fn on_blue(&self) -> BgColorDisplay<'_, Blue, Self>

Change the background color to blue
Source§

fn magenta(&self) -> FgColorDisplay<'_, Magenta, Self>

Change the foreground color to magenta
Source§

fn on_magenta(&self) -> BgColorDisplay<'_, Magenta, Self>

Change the background color to magenta
Source§

fn purple(&self) -> FgColorDisplay<'_, Magenta, Self>

Change the foreground color to purple
Source§

fn on_purple(&self) -> BgColorDisplay<'_, Magenta, Self>

Change the background color to purple
Source§

fn cyan(&self) -> FgColorDisplay<'_, Cyan, Self>

Change the foreground color to cyan
Source§

fn on_cyan(&self) -> BgColorDisplay<'_, Cyan, Self>

Change the background color to cyan
Source§

fn white(&self) -> FgColorDisplay<'_, White, Self>

Change the foreground color to white
Source§

fn on_white(&self) -> BgColorDisplay<'_, White, Self>

Change the background color to white
Source§

fn default_color(&self) -> FgColorDisplay<'_, Default, Self>

Change the foreground color to the terminal default
Source§

fn on_default_color(&self) -> BgColorDisplay<'_, Default, Self>

Change the background color to the terminal default
Source§

fn bright_black(&self) -> FgColorDisplay<'_, BrightBlack, Self>

Change the foreground color to bright black
Source§

fn on_bright_black(&self) -> BgColorDisplay<'_, BrightBlack, Self>

Change the background color to bright black
Source§

fn bright_red(&self) -> FgColorDisplay<'_, BrightRed, Self>

Change the foreground color to bright red
Source§

fn on_bright_red(&self) -> BgColorDisplay<'_, BrightRed, Self>

Change the background color to bright red
Source§

fn bright_green(&self) -> FgColorDisplay<'_, BrightGreen, Self>

Change the foreground color to bright green
Source§

fn on_bright_green(&self) -> BgColorDisplay<'_, BrightGreen, Self>

Change the background color to bright green
Source§

fn bright_yellow(&self) -> FgColorDisplay<'_, BrightYellow, Self>

Change the foreground color to bright yellow
Source§

fn on_bright_yellow(&self) -> BgColorDisplay<'_, BrightYellow, Self>

Change the background color to bright yellow
Source§

fn bright_blue(&self) -> FgColorDisplay<'_, BrightBlue, Self>

Change the foreground color to bright blue
Source§

fn on_bright_blue(&self) -> BgColorDisplay<'_, BrightBlue, Self>

Change the background color to bright blue
Source§

fn bright_magenta(&self) -> FgColorDisplay<'_, BrightMagenta, Self>

Change the foreground color to bright magenta
Source§

fn on_bright_magenta(&self) -> BgColorDisplay<'_, BrightMagenta, Self>

Change the background color to bright magenta
Source§

fn bright_purple(&self) -> FgColorDisplay<'_, BrightMagenta, Self>

Change the foreground color to bright purple
Source§

fn on_bright_purple(&self) -> BgColorDisplay<'_, BrightMagenta, Self>

Change the background color to bright purple
Source§

fn bright_cyan(&self) -> FgColorDisplay<'_, BrightCyan, Self>

Change the foreground color to bright cyan
Source§

fn on_bright_cyan(&self) -> BgColorDisplay<'_, BrightCyan, Self>

Change the background color to bright cyan
Source§

fn bright_white(&self) -> FgColorDisplay<'_, BrightWhite, Self>

Change the foreground color to bright white
Source§

fn on_bright_white(&self) -> BgColorDisplay<'_, BrightWhite, Self>

Change the background color to bright white
Source§

fn bold(&self) -> BoldDisplay<'_, Self>

Make the text bold
Source§

fn dimmed(&self) -> DimDisplay<'_, Self>

Make the text dim
Source§

fn italic(&self) -> ItalicDisplay<'_, Self>

Make the text italicized
Source§

fn underline(&self) -> UnderlineDisplay<'_, Self>

Make the text underlined
Make the text blink
Make the text blink (but fast!)
Source§

fn reversed(&self) -> ReversedDisplay<'_, Self>

Swap the foreground and background colors
Source§

fn hidden(&self) -> HiddenDisplay<'_, Self>

Hide the text
Source§

fn strikethrough(&self) -> StrikeThroughDisplay<'_, Self>

Cross out the text
Source§

fn color<Color>(&self, color: Color) -> FgDynColorDisplay<'_, Color, Self>
where Color: DynColor,

Set the foreground color at runtime. Only use if you do not know which color will be used at compile-time. If the color is constant, use either OwoColorize::fg or a color-specific method, such as OwoColorize::green, Read more
Source§

fn on_color<Color>(&self, color: Color) -> BgDynColorDisplay<'_, Color, Self>
where Color: DynColor,

Set the background color at runtime. Only use if you do not know what color to use at compile-time. If the color is constant, use either OwoColorize::bg or a color-specific method, such as OwoColorize::on_yellow, Read more
Source§

fn fg_rgb<const R: u8, const G: u8, const B: u8>( &self, ) -> FgColorDisplay<'_, CustomColor<R, G, B>, Self>

Set the foreground color to a specific RGB value.
Source§

fn bg_rgb<const R: u8, const G: u8, const B: u8>( &self, ) -> BgColorDisplay<'_, CustomColor<R, G, B>, Self>

Set the background color to a specific RGB value.
Source§

fn truecolor(&self, r: u8, g: u8, b: u8) -> FgDynColorDisplay<'_, Rgb, Self>

Sets the foreground color to an RGB value.
Source§

fn on_truecolor(&self, r: u8, g: u8, b: u8) -> BgDynColorDisplay<'_, Rgb, Self>

Sets the background color to an RGB value.
Source§

fn style(&self, style: Style) -> Styled<&Self>

Apply a runtime-determined style
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize = _

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. 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.