devela::_dep::_alloc::str

Trait FromStr

1.36.0 · Source
pub trait FromStr: Sized {
    type Err;

    // Required method
    fn from_str(s: &str) -> Result<Self, Self::Err> ;
}
Available on crate feature alloc only.
Expand description

Parse a value from a string

FromStr’s from_str method is often used implicitly, through str’s parse method. See parse’s documentation for examples.

FromStr does not have a lifetime parameter, and so you can only parse types that do not contain a lifetime parameter themselves. In other words, you can parse an i32 with FromStr, but not a &i32. You can parse a struct that contains an i32, but not one that contains an &i32.

§Examples

Basic implementation of FromStr on an example Point type:

use std::str::FromStr;

#[derive(Debug, PartialEq)]
struct Point {
    x: i32,
    y: i32
}

#[derive(Debug, PartialEq, Eq)]
struct ParsePointError;

impl FromStr for Point {
    type Err = ParsePointError;

    fn from_str(s: &str) -> Result<Self, Self::Err> {
        let (x, y) = s
            .strip_prefix('(')
            .and_then(|s| s.strip_suffix(')'))
            .and_then(|s| s.split_once(','))
            .ok_or(ParsePointError)?;

        let x_fromstr = x.parse::<i32>().map_err(|_| ParsePointError)?;
        let y_fromstr = y.parse::<i32>().map_err(|_| ParsePointError)?;

        Ok(Point { x: x_fromstr, y: y_fromstr })
    }
}

let expected = Ok(Point { x: 1, y: 2 });
// Explicit call
assert_eq!(Point::from_str("(1,2)"), expected);
// Implicit calls, through parse
assert_eq!("(1,2)".parse(), expected);
assert_eq!("(1,2)".parse::<Point>(), expected);
// Invalid input string
assert!(Point::from_str("(1 2)").is_err());

Required Associated Types§

1.0.0 · Source

type Err

The associated error which can be returned from parsing.

Required Methods§

1.0.0 · Source

fn from_str(s: &str) -> Result<Self, Self::Err>

Parses a string s to return a value of this type.

If parsing succeeds, return the value inside Ok, otherwise when the string is ill-formatted return an error specific to the inside Err. The error type is specific to the implementation of the trait.

§Examples

Basic usage with i32, a type that implements FromStr:

use std::str::FromStr;

let s = "5";
let x = i32::from_str(s).unwrap();

assert_eq!(5, x);

Dyn Compatibility§

This trait is not dyn compatible.

In older versions of Rust, dyn compatibility was called "object safety", so this trait is not object safe.

Implementors§

1.7.0 · Source§

impl FromStr for IpAddr

1.0.0 · Source§

impl FromStr for SocketAddr

Source§

impl FromStr for Month

Returns a Month from a string containing either the full month name, or any of the month ASCII abbreviations.

Source§

type Err = &'static str

Source§

impl FromStr for Weekday

Returns a Weekday from a string containing either the full weekday name, or any of the weekday ASCII abbreviations.

Source§

type Err = &'static str

§

impl FromStr for Color

§

type Err = ()

Source§

impl FromStr for devela::_dep::log::Level

Source§

impl FromStr for devela::_dep::log::LevelFilter

§

impl FromStr for Mp4Type

§

type Err = String

1.0.0 · Source§

impl FromStr for bool

1.20.0 · Source§

impl FromStr for char

1.0.0 · Source§

impl FromStr for f32

1.0.0 · Source§

impl FromStr for f64

1.0.0 · Source§

impl FromStr for i8

1.0.0 · Source§

impl FromStr for i16

1.0.0 · Source§

impl FromStr for i32

1.0.0 · Source§

impl FromStr for i64

1.0.0 · Source§

impl FromStr for i128

1.0.0 · Source§

impl FromStr for isize

1.0.0 · Source§

impl FromStr for u8

1.0.0 · Source§

impl FromStr for u16

1.0.0 · Source§

impl FromStr for u32

1.0.0 · Source§

impl FromStr for u64

1.0.0 · Source§

impl FromStr for u128

1.0.0 · Source§

impl FromStr for usize

1.0.0 · Source§

impl FromStr for Ipv4Addr

1.0.0 · Source§

impl FromStr for Ipv6Addr

1.5.0 · Source§

impl FromStr for SocketAddrV4

1.5.0 · Source§

impl FromStr for SocketAddrV6

1.35.0 · Source§

impl FromStr for NonZero<i8>

1.35.0 · Source§

impl FromStr for NonZero<i16>

1.35.0 · Source§

impl FromStr for NonZero<i32>

1.35.0 · Source§

impl FromStr for NonZero<i64>

1.35.0 · Source§

impl FromStr for NonZero<i128>

1.35.0 · Source§

impl FromStr for NonZero<isize>

1.35.0 · Source§

impl FromStr for NonZero<u8>

1.35.0 · Source§

impl FromStr for NonZero<u16>

1.35.0 · Source§

impl FromStr for NonZero<u32>

1.35.0 · Source§

impl FromStr for NonZero<u64>

1.35.0 · Source§

impl FromStr for NonZero<u128>

1.35.0 · Source§

impl FromStr for NonZero<usize>

1.32.0 · Source§

impl FromStr for PathBuf

1.0.0 · Source§

impl FromStr for String

Source§

impl FromStr for CString

1.45.0 · Source§

impl FromStr for OsString

§

impl FromStr for Date

§

type Err = Error

§

impl FromStr for DateTime

§

type Err = Error

§

impl FromStr for Time

§

type Err = Error

§

impl FromStr for SignedDuration

§

type Err = Error

§

impl FromStr for Span

§

type Err = Error

§

impl FromStr for Timestamp

§

type Err = Error

§

impl FromStr for Zoned

Parses a zoned timestamp from the Temporal datetime format.

See the fmt::temporal for more information on the precise format.

Note that this is only enabled when the std feature is enabled because it requires access to a global TimeZoneDatabase.

§

type Err = Error

Source§

impl FromStr for BigInt

Source§

impl FromStr for JsString

Source§

impl FromStr for Number

§

impl FromStr for Regex

§

type Err = Error

§

impl FromStr for Gid

§

type Err = <u32 as FromStr>::Err

§

impl FromStr for Pid

§

type Err = <i32 as FromStr>::Err

§

impl FromStr for Uid

§

type Err = <u32 as FromStr>::Err

§

impl FromStr for devela::_dep::tracing::level_filters::LevelFilter

§

impl FromStr for devela::_dep::tracing::Level

§

impl FromStr for Addr

§

type Err = Box<dyn Error>

§

impl FromStr for Format

Source§

impl<const CAP: usize> FromStr for ArrayString<CAP>

Source§

impl<const V: i8> FromStr for devela::_info::examples::niche::NonValueI8<V>

Available on doc only.
Source§

impl<const V: i8> FromStr for devela::all::NonValueI8<V>

Source§

impl<const V: u8> FromStr for NonValueU8<V>

Source§

impl<const V: u16> FromStr for NonValueU16<V>