1.0.0[−][src]Trait nom::lib::std::str::FromStr
A trait to abstract the idea of creating a new instance of a type from a string.
FromStr
's from_str
method is often used implicitly, through
str
's parse
method. See parse
's documentation for examples.
Examples
Basic implementation of FromStr
on an example Point
type:
use std::str::FromStr; use std::num::ParseIntError; #[derive(Debug, PartialEq)] struct Point { x: i32, y: i32 } impl FromStr for Point { type Err = ParseIntError; fn from_str(s: &str) -> Result<Self, Self::Err> { let coords: Vec<&str> = s.trim_matches(|p| p == '(' || p == ')' ) .split(',') .collect(); let x_fromstr = coords[0].parse::<i32>()?; let y_fromstr = coords[1].parse::<i32>()?; Ok(Point { x: x_fromstr, y: y_fromstr }) } } let p = Point::from_str("(1,2)"); assert_eq!(p.unwrap(), Point{ x: 1, y: 2} )
Associated Types
type Err
The associated error which can be returned from parsing.
Required Methods
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 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);
Implementations on Foreign Types
impl FromStr for SocketAddr
[src]
impl FromStr for SocketAddr
type Err = AddrParseError
fn from_str(s: &str) -> Result<SocketAddr, AddrParseError>
[src]
fn from_str(s: &str) -> Result<SocketAddr, AddrParseError>
impl FromStr for SocketAddrV6
[src]
impl FromStr for SocketAddrV6
type Err = AddrParseError
fn from_str(s: &str) -> Result<SocketAddrV6, AddrParseError>
[src]
fn from_str(s: &str) -> Result<SocketAddrV6, AddrParseError>
impl FromStr for Ipv4Addr
[src]
impl FromStr for Ipv4Addr
type Err = AddrParseError
fn from_str(s: &str) -> Result<Ipv4Addr, AddrParseError>
[src]
fn from_str(s: &str) -> Result<Ipv4Addr, AddrParseError>
impl FromStr for Ipv6Addr
[src]
impl FromStr for Ipv6Addr
type Err = AddrParseError
fn from_str(s: &str) -> Result<Ipv6Addr, AddrParseError>
[src]
fn from_str(s: &str) -> Result<Ipv6Addr, AddrParseError>
impl FromStr for IpAddr
[src]
impl FromStr for IpAddr
type Err = AddrParseError
fn from_str(s: &str) -> Result<IpAddr, AddrParseError>
[src]
fn from_str(s: &str) -> Result<IpAddr, AddrParseError>
impl FromStr for SocketAddrV4
[src]
impl FromStr for SocketAddrV4
type Err = AddrParseError
fn from_str(s: &str) -> Result<SocketAddrV4, AddrParseError>
[src]
fn from_str(s: &str) -> Result<SocketAddrV4, AddrParseError>
impl FromStr for u32
[src]
impl FromStr for u32
type Err = ParseIntError
fn from_str(src: &str) -> Result<u32, ParseIntError>
[src]
fn from_str(src: &str) -> Result<u32, ParseIntError>
impl FromStr for i64
[src]
impl FromStr for i64
type Err = ParseIntError
fn from_str(src: &str) -> Result<i64, ParseIntError>
[src]
fn from_str(src: &str) -> Result<i64, ParseIntError>
impl FromStr for usize
[src]
impl FromStr for usize
type Err = ParseIntError
fn from_str(src: &str) -> Result<usize, ParseIntError>
[src]
fn from_str(src: &str) -> Result<usize, ParseIntError>
impl FromStr for u16
[src]
impl FromStr for u16
type Err = ParseIntError
fn from_str(src: &str) -> Result<u16, ParseIntError>
[src]
fn from_str(src: &str) -> Result<u16, ParseIntError>
impl FromStr for isize
[src]
impl FromStr for isize
type Err = ParseIntError
fn from_str(src: &str) -> Result<isize, ParseIntError>
[src]
fn from_str(src: &str) -> Result<isize, ParseIntError>
impl FromStr for i128
[src]
impl FromStr for i128
type Err = ParseIntError
fn from_str(src: &str) -> Result<i128, ParseIntError>
[src]
fn from_str(src: &str) -> Result<i128, ParseIntError>
impl FromStr for f64
[src]
impl FromStr for f64
type Err = ParseFloatError
fn from_str(src: &str) -> Result<f64, ParseFloatError>
[src]
fn from_str(src: &str) -> Result<f64, ParseFloatError>
Converts a string in base 10 to a float. Accepts an optional decimal exponent.
This function accepts strings such as
- '3.14'
- '-3.14'
- '2.5E10', or equivalently, '2.5e10'
- '2.5E-10'
- '5.'
- '.5', or, equivalently, '0.5'
- 'inf', '-inf', 'NaN'
Leading and trailing whitespace represent an error.
Arguments
- src - A string
Return value
Err(ParseFloatError)
if the string did not represent a valid
number. Otherwise, Ok(n)
where n
is the floating-point
number represented by src
.
impl FromStr for u8
[src]
impl FromStr for u8
type Err = ParseIntError
fn from_str(src: &str) -> Result<u8, ParseIntError>
[src]
fn from_str(src: &str) -> Result<u8, ParseIntError>
impl FromStr for char
[src]
impl FromStr for char
impl FromStr for u128
[src]
impl FromStr for u128
type Err = ParseIntError
fn from_str(src: &str) -> Result<u128, ParseIntError>
[src]
fn from_str(src: &str) -> Result<u128, ParseIntError>
impl FromStr for bool
[src]
impl FromStr for bool
type Err = ParseBoolError
fn from_str(s: &str) -> Result<bool, ParseBoolError>
[src]
fn from_str(s: &str) -> Result<bool, ParseBoolError>
Parse a bool
from a string.
Yields a Result<bool, ParseBoolError>
, because s
may or may not
actually be parseable.
Examples
use std::str::FromStr; assert_eq!(FromStr::from_str("true"), Ok(true)); assert_eq!(FromStr::from_str("false"), Ok(false)); assert!(<bool as FromStr>::from_str("not even a boolean").is_err());
Note, in many cases, the .parse()
method on str
is more proper.
assert_eq!("true".parse(), Ok(true)); assert_eq!("false".parse(), Ok(false)); assert!("not even a boolean".parse::<bool>().is_err());
impl FromStr for u64
[src]
impl FromStr for u64
type Err = ParseIntError
fn from_str(src: &str) -> Result<u64, ParseIntError>
[src]
fn from_str(src: &str) -> Result<u64, ParseIntError>
impl FromStr for i16
[src]
impl FromStr for i16
type Err = ParseIntError
fn from_str(src: &str) -> Result<i16, ParseIntError>
[src]
fn from_str(src: &str) -> Result<i16, ParseIntError>
impl FromStr for f32
[src]
impl FromStr for f32
type Err = ParseFloatError
fn from_str(src: &str) -> Result<f32, ParseFloatError>
[src]
fn from_str(src: &str) -> Result<f32, ParseFloatError>
Converts a string in base 10 to a float. Accepts an optional decimal exponent.
This function accepts strings such as
- '3.14'
- '-3.14'
- '2.5E10', or equivalently, '2.5e10'
- '2.5E-10'
- '5.'
- '.5', or, equivalently, '0.5'
- 'inf', '-inf', 'NaN'
Leading and trailing whitespace represent an error.
Arguments
- src - A string
Return value
Err(ParseFloatError)
if the string did not represent a valid
number. Otherwise, Ok(n)
where n
is the floating-point
number represented by src
.
impl FromStr for i32
[src]
impl FromStr for i32
type Err = ParseIntError
fn from_str(src: &str) -> Result<i32, ParseIntError>
[src]
fn from_str(src: &str) -> Result<i32, ParseIntError>
impl FromStr for i8
[src]
impl FromStr for i8
type Err = ParseIntError
fn from_str(src: &str) -> Result<i8, ParseIntError>
[src]
fn from_str(src: &str) -> Result<i8, ParseIntError>
Implementors
impl FromStr for String
[src]
impl FromStr for String
type Err = ParseError
fn from_str(s: &str) -> Result<String, ParseError>
[src]
fn from_str(s: &str) -> Result<String, ParseError>