isin 0.1.5

Support for creating and validating ISINs
Documentation

isin

An ISIN type for working with validated International Security Identifiers (ISINs) as defined in ISO 6166.

The checksum calculation uses a table-driven algorithm to minimize overhead vs. a direct translation of the formula definition.

Usage

Add this to your Cargo.toml:

[dependencies]
isin = "0.1"

Example

use isin::ISIN;
let isin_string = "US0378331005";
match ISIN::parse_strict(isin_string) {
    Ok(isin) => {
        println!("Parsed ISIN: {}", isin.value()); // "US0378331005"
        println!("  Country code: {}", isin.country_code()); // "US"
        println!("  Security identifier: {}", isin.security_identifier()); // "037833100"
        println!("  Check digit: {}", isin.check_digit()); // "5"
    }
    Err(err_string) => panic!("Unable to parse ISIN {}: {}", isin_string, err_string),
}

License

Licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.