FromStr

Trait FromStr 

1.0.0 (const: unstable) · Source
pub trait FromStr: Sized {
    type Err;

    // Required method
    fn from_str(s: &str) -> Result<Self, Self::Err>;
}
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.

§Input format and round-tripping

The input format expected by a type’s FromStr implementation depends on the type. Check the type’s documentation for the input formats it knows how to parse. Note that the input format of a type’s FromStr implementation might not necessarily accept the output format of its Display implementation, and even if it does, the Display implementation may not be lossless so the round-trip may lose information.

However, if a type has a lossless Display implementation whose output is meant to be conveniently machine-parseable and not just meant for human consumption, then the type may wish to accept the same format in FromStr, and document that usage. Having both Display and FromStr implementations where the result of Display cannot be parsed with FromStr may surprise users.

§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 AppSettings

Source§

impl FromStr for ArgSettings

Source§

impl FromStr for Shell

Source§

impl FromStr for hyper_old_types::header::common::accept_ranges::RangeUnit

Source§

impl FromStr for hyper_old_types::header::common::cache_control::CacheDirective

Source§

impl FromStr for hyper_old_types::header::common::connection::ConnectionOption

Source§

impl FromStr for hyper_old_types::header::common::content_range::ContentRangeSpec

Source§

impl FromStr for hyper_old_types::header::common::link::MediaDesc

Source§

impl FromStr for hyper_old_types::header::common::link::RelationType

Source§

impl FromStr for hyper_old_types::header::common::prefer::Preference

Source§

impl FromStr for hyper_old_types::header::common::range::ByteRangeSpec

Source§

impl FromStr for hyper_old_types::header::common::range::Range

Source§

impl FromStr for hyper_old_types::header::common::upgrade::ProtocolName

Source§

impl FromStr for hyper_old_types::header::shared::charset::Charset

Source§

impl FromStr for hyper_old_types::header::shared::encoding::Encoding

Source§

impl FromStr for hyper_old_types::method::Method

Source§

impl FromStr for hyper_old_types::version::HttpVersion

Source§

impl FromStr for hyper::header::common::accept_ranges::RangeUnit

Source§

impl FromStr for hyper::header::common::cache_control::CacheDirective

Source§

impl FromStr for hyper::header::common::connection::ConnectionOption

Source§

impl FromStr for hyper::header::common::content_range::ContentRangeSpec

Source§

impl FromStr for hyper::header::common::link::MediaDesc

Source§

impl FromStr for hyper::header::common::link::RelationType

Source§

impl FromStr for hyper::header::common::prefer::Preference

Source§

impl FromStr for hyper::header::common::range::ByteRangeSpec

Source§

impl FromStr for hyper::header::common::range::Range

Source§

impl FromStr for hyper::header::common::upgrade::ProtocolName

Source§

impl FromStr for hyper::header::shared::charset::Charset

Source§

impl FromStr for hyper::header::shared::encoding::Encoding

Source§

impl FromStr for hyper::method::Method

Source§

impl FromStr for RequestUri

Source§

impl FromStr for hyper::version::HttpVersion

Source§

impl FromStr for Level

Source§

impl FromStr for LevelFilter

Source§

impl FromStr for LogLevel

Source§

impl FromStr for LogLevelFilter

Source§

impl FromStr for Attr

Source§

impl FromStr for SubLevel

Source§

impl FromStr for TopLevel

Source§

impl FromStr for mime::Value

Source§

impl FromStr for MediaType

Source§

type Err = &'static str

Source§

impl FromStr for Signal

Available on crate feature signal only.
Source§

impl FromStr for Json

Source§

impl FromStr for Op

Source§

impl FromStr for serde_json::value::Value

Source§

impl FromStr for toml::value::Value

1.0.0 · Source§

impl FromStr for bool

1.20.0 · Source§

impl FromStr for char

1.0.0 · Source§

impl FromStr for f16

1.0.0 · Source§

impl FromStr for f32

1.0.0 · Source§

impl FromStr for f64

1.0.0 (const: unstable) · Source§

impl FromStr for i8

1.0.0 (const: unstable) · Source§

impl FromStr for i16

1.0.0 (const: unstable) · Source§

impl FromStr for i32

1.0.0 (const: unstable) · Source§

impl FromStr for i64

1.0.0 (const: unstable) · Source§

impl FromStr for i128

1.0.0 (const: unstable) · Source§

impl FromStr for isize

1.0.0 (const: unstable) · Source§

impl FromStr for u8

1.0.0 (const: unstable) · Source§

impl FromStr for u16

1.0.0 (const: unstable) · Source§

impl FromStr for u32

1.0.0 (const: unstable) · Source§

impl FromStr for u64

1.0.0 (const: unstable) · Source§

impl FromStr for u128

1.0.0 (const: unstable) · Source§

impl FromStr for usize

Source§

impl FromStr for artifact_app::types::Name

Source§

impl FromStr for SearchSettings

1.45.0 · Source§

impl FromStr for OsString

1.32.0 · Source§

impl FromStr for PathBuf

Source§

impl FromStr for artifact_app::dev_prefix::Regex

Source§

impl FromStr for ByteString

1.85.0 · Source§

impl FromStr for CString

1.0.0 · Source§

impl FromStr for String

Available on non-no_global_oom_handling only.
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>

Source§

impl FromStr for Cookie<'static>

Source§

impl FromStr for HeaderName

Source§

impl FromStr for HeaderValue

Source§

impl FromStr for http::method::Method

Source§

impl FromStr for StatusCode

Source§

impl FromStr for Authority

Source§

impl FromStr for PathAndQuery

Source§

impl FromStr for Scheme

Source§

impl FromStr for http::uri::Uri

Source§

impl FromStr for hyper_old_types::header::common::authorization::Basic

creates a Basic from a base-64 encoded, :-delimited utf-8 string

Source§

impl FromStr for hyper_old_types::header::common::authorization::Bearer

Source§

impl FromStr for hyper_old_types::header::common::host::Host

Source§

impl FromStr for hyper_old_types::header::common::origin::Origin

Source§

impl FromStr for hyper_old_types::header::common::strict_transport_security::StrictTransportSecurity

Source§

impl FromStr for hyper_old_types::header::common::upgrade::Protocol

Source§

impl FromStr for Warning

Source§

impl FromStr for hyper_old_types::header::shared::entity::EntityTag

Source§

impl FromStr for hyper_old_types::header::shared::httpdate::HttpDate

Source§

impl FromStr for hyper_old_types::uri::Uri

Source§

impl FromStr for hyper::client::connect::dns::Name

Source§

impl FromStr for hyper::header::common::authorization::Basic

Source§

impl FromStr for hyper::header::common::authorization::Bearer

Source§

impl FromStr for hyper::header::common::host::Host

Source§

impl FromStr for hyper::header::common::origin::Origin

Source§

impl FromStr for hyper::header::common::strict_transport_security::StrictTransportSecurity

Source§

impl FromStr for hyper::header::common::upgrade::Protocol

Source§

impl FromStr for hyper::header::shared::entity::EntityTag

Source§

impl FromStr for hyper::header::shared::httpdate::HttpDate

Source§

impl FromStr for icu_locale_core::extensions::private::other::Subtag

Source§

impl FromStr for icu_locale_core::extensions::transform::key::Key

Source§

impl FromStr for Attribute

Source§

impl FromStr for icu_locale_core::extensions::unicode::key::Key

Source§

impl FromStr for SubdivisionId

Source§

impl FromStr for SubdivisionSuffix

Source§

impl FromStr for Language

Source§

impl FromStr for Region

Source§

impl FromStr for Script

Source§

impl FromStr for icu_locale_core::subtags::Subtag

Source§

impl FromStr for Variant

Source§

impl FromStr for LanguageTag

Source§

impl FromStr for mime::Mime

Source§

impl FromStr for mime::Mime

Source§

impl FromStr for regex::re_bytes::Regex

Source§

impl FromStr for regex::regex::bytes::Regex

Source§

impl FromStr for regex::regex::string::Regex

Source§

impl FromStr for Version

Source§

impl FromStr for VersionReq

Source§

impl FromStr for Map<String, Value>

Source§

impl FromStr for Number

Source§

impl FromStr for Datetime

Source§

impl FromStr for url::Url

Parse a string as an URL, without a base URL or encoding override.

Source§

impl FromStr for url::Url

Parse a string as an URL, without a base URL or encoding override.

Source§

impl FromStr for uuid::Uuid

Source§

impl FromStr for uuid::Uuid

Source§

impl<S> FromStr for Ascii<S>
where S: FromStr,

Source§

type Err = <S as FromStr>::Err

Source§

impl<S> FromStr for unicase::UniCase<S>
where S: FromStr + AsRef<str>,

Source§

type Err = <S as FromStr>::Err

Source§

impl<S> FromStr for unicase::UniCase<S>
where S: FromStr,

Source§

type Err = <S as FromStr>::Err

Source§

impl<T> FromStr for hyper_old_types::header::shared::quality_item::QualityItem<T>
where T: FromStr,

Source§

impl<T> FromStr for hyper::header::shared::quality_item::QualityItem<T>
where T: FromStr,

Source§

impl<const N: usize> FromStr for TinyAsciiStr<N>