Trait levana_perpswap_cosmos::prelude::FromStr

1.0.0 · 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.

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§

source

type Err

The associated error which can be returned from parsing.

Required Methods§

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);

Object Safety§

This trait is not object safe.

Implementors§

source§

impl FromStr for NewContractKind

§

type Err = Error

source§

impl FromStr for StopLoss

source§

impl FromStr for FeeSource

§

type Err = Error

source§

impl FromStr for PythPriceServiceNetwork

§

type Err = Error

source§

impl FromStr for MaxGainsInQuote

source§

impl FromStr for TakeProfitTrader

1.7.0 · source§

impl FromStr for IpAddr

source§

impl FromStr for SocketAddr

source§

impl FromStr for Value

§

type Err = Error

source§

impl FromStr for bool

1.20.0 · source§

impl FromStr for char

source§

impl FromStr for f32

source§

impl FromStr for f64

source§

impl FromStr for i8

source§

impl FromStr for i16

source§

impl FromStr for i32

source§

impl FromStr for i64

source§

impl FromStr for i128

source§

impl FromStr for isize

source§

impl FromStr for u8

source§

impl FromStr for u16

source§

impl FromStr for u32

source§

impl FromStr for u64

source§

impl FromStr for u128

source§

impl FromStr for usize

source§

impl FromStr for DecQueuePositionId

source§

impl FromStr for IncQueuePositionId

source§

impl FromStr for DeferredExecId

source§

impl FromStr for OrderId

source§

impl FromStr for PositionId

source§

impl FromStr for LeverageToBase

§

type Err = Error

source§

impl FromStr for SignedLeverageToBase

§

type Err = Error

source§

impl FromStr for MarketId

§

type Err = StdError

source§

impl FromStr for Base

§

type Err = Error

source§

impl FromStr for Collateral

§

type Err = Error

source§

impl FromStr for FarmingToken

§

type Err = Error

source§

impl FromStr for LockdropShares

§

type Err = Error

source§

impl FromStr for LpToken

§

type Err = Error

source§

impl FromStr for LvnToken

§

type Err = Error

source§

impl FromStr for Notional

§

type Err = Error

source§

impl FromStr for Quote

§

type Err = Error

source§

impl FromStr for Usd

§

type Err = Error

source§

impl FromStr for PriceBaseInQuote

§

type Err = Error

source§

impl FromStr for PriceCollateralInUsd

§

type Err = Error

source§

impl FromStr for Timestamp

source§

impl FromStr for String

source§

impl FromStr for Ipv4Addr

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 NonZeroI8

1.35.0 · source§

impl FromStr for NonZeroI16

1.35.0 · source§

impl FromStr for NonZeroI32

1.35.0 · source§

impl FromStr for NonZeroI64

1.35.0 · source§

impl FromStr for NonZeroI128

1.35.0 · source§

impl FromStr for NonZeroIsize

1.35.0 · source§

impl FromStr for NonZeroU8

1.35.0 · source§

impl FromStr for NonZeroU16

1.35.0 · source§

impl FromStr for NonZeroU32

1.35.0 · source§

impl FromStr for NonZeroU64

1.35.0 · source§

impl FromStr for NonZeroU128

1.35.0 · source§

impl FromStr for NonZeroUsize

1.45.0 · source§

impl FromStr for OsString

1.32.0 · source§

impl FromStr for PathBuf

source§

impl FromStr for BigInt

source§

impl FromStr for BigUint

source§

impl FromStr for BuildMetadata

§

type Err = Error

source§

impl FromStr for Comparator

§

type Err = Error

source§

impl FromStr for Prerelease

§

type Err = Error

source§

impl FromStr for Version

§

type Err = Error

source§

impl FromStr for VersionReq

§

type Err = Error

source§

impl FromStr for Number

§

type Err = Error

§

impl FromStr for Decimal256

§

type Err = StdError

§

impl FromStr for Coin

§

type Err = CoinFromStrError

§

impl FromStr for Coins

§

type Err = StdError

§

impl FromStr for DateTime

§

type Err = Error

§

impl FromStr for Decimal

§

type Err = StdError

§

impl FromStr for Int64

§

type Err = StdError

§

impl FromStr for Int128

§

type Err = StdError

§

impl FromStr for Int256

§

type Err = StdError

§

impl FromStr for Int512

§

type Err = StdError

§

impl FromStr for ObjectIdentifier

§

type Err = Error

§

impl FromStr for Signature

Decode a signature from hexadecimal.

Upper and lower case hexadecimal are both accepted, however mixed case is rejected.

§

type Err = Error

§

impl FromStr for SignedDecimal

§

type Err = StdError

§

impl FromStr for SignedDecimal256

§

type Err = StdError

§

impl FromStr for TagMode

§

type Err = Error

§

impl FromStr for Uint128

§

type Err = StdError

§

impl FromStr for Uint256

§

type Err = StdError

§

impl FromStr for Uint512

§

type Err = StdError

§

impl<C> FromStr for NonZeroScalar<C>where C: CurveArithmetic,

§

type Err = Error

§

impl<C> FromStr for ScalarPrimitive<C>where C: Curve,

§

type Err = Error

§

impl<C> FromStr for Signature<C>where C: PrimeCurve + CurveArithmetic, <<C as Curve>::FieldBytesSize as Add>::Output: ArrayLength<u8>,

§

type Err = Error

§

impl<P, const N: usize> FromStr for Fp<P, N>where P: FpConfig<N>,

§

type Err = ()

§

impl<Size> FromStr for EncodedPoint<Size>where Size: ModulusSize,

Decode a SEC1-encoded point from hexadecimal.

Upper and lower case hexadecimal are both accepted, however mixed case is rejected.

§

type Err = Error

source§

impl<T: UnsignedDecimal> FromStr for NonZero<T>

§

type Err = Error

source§

impl<T: UnsignedDecimal> FromStr for Signed<T>

§

type Err = Error

§

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

§

type Err = ParseIntError

§

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

§

type Err = ParseIntError

§

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

§

type Err = ParseIntError

§

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

§

type Err = ParseIntError

§

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

§

type Err = ParseIntError

§

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

§

type Err = ParseIntError

§

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

§

type Err = ParseIntError

§

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

§

type Err = ParseIntError