#hexadecimal #hex #decimal #binary #octal

parse_int

Parse &str with common prefixes to integer values

6 releases (3 breaking)

✓ Uses Rust 2018 edition

new 0.4.0 Jan 14, 2020
0.3.0 Jan 13, 2020
0.2.1 Jan 6, 2020
0.1.1 Jan 6, 2020

#4 in #hexadecimal

30 downloads per month

Apache-2.0/MIT/BSL-1.0/CC0-1.0

10KB
149 lines

parse_int

Parse &str with common prefixes to integer values:

use parse_int::parse;

let d = parse::<usize>("42")?;
assert_eq!(42, d);

let d = parse::<isize>("0x42")?;
assert_eq!(66, d);

// you can use underscores for more readable inputs
let d = parse::<isize>("0x42_424_242")?;
assert_eq!(1_111_638_594, d);

let d = parse::<u8>("0o42")?;
assert_eq!(34, d);
#[cfg(feature = "implicit-octal")]
{
    let d = parse::<u8>("042")?;
    assert_eq!(34, d);
}

let d = parse::<u16>("0b0110")?;
assert_eq!(6, d);

Documentation.

Enable the "implicit-octal" feature

Specify the crate like this:

[dependencies]
parse_int = { version = "0.4", features = ["implicit-octal"] }

Then this code will return Hello, Ok(34)!:

use parse_int::parse;
fn main() {
    println!("Hello, {:?}!", parse::<i128>("00042"));
}

License

This work is distributed under the super-Rust quad-license:

Apache-2.0/MIT/BSL-1.0/CC0-1.0

This is equivalent to public domain in jurisdictions that allow it (CC0-1.0). Otherwise it is compatible with the Rust license, plus the option of the runtime-exception-containing BSL-1. This means that, outside of public domain jurisdictions, the source must be distributed along with author attribution and at least one of the licenses; but in binary form no attribution or license distribution is required.

Dependencies

~140KB