[Object Identifiers] are a standard of the [ITU] used to reference objects, things, and concepts in a globally unique way. This crate provides for data structures and methods to build, parse, and format OIDs.
You can run the example code from examples/basic.rs using cargo:
sh
cargo run --example basic
rust
use oid::prelude::*;
let oid = ObjectIdentifier::try_from("0.1.2.3")?;
rust
use oid::prelude::*;
let oid = ObjectIdentifier::try_from(vec![0x00, 0x01, 0x02, 0x03])?;
rust
use oid::prelude::*;
let oid = ObjectIdentifier::try_from("0.1.2.3")?;
let oid: String = oid.into();
assert_eq!(oid, "0.1.2.3");
rust
use oid::prelude::*;
let oid = ObjectIdentifier::try_from(vec![0x00, 0x01, 0x02, 0x03])?;
let oid: Vec<u8> = oid.into();
assert_eq!(oid, "0.1.2.3");
sh
cargo add oid
!#[no_std]
cratesh
cargo add oid --no-default-features
Cargo.toml
toml
[dependencies]
oid = "0.1.0"
Cargo.toml
for a !#[no_std]
cratetoml
[dependencies]
oid = { default-features = false }
The build routines have been automated with [cargo-make]. If you're not using [cargo-make], you can check [Makefile.toml] for the relevant manual build procedures.
sh
cargo make
#![no_std]
sh
cargo make build_no_std
Profiles for [cargo-fuzz] are included for fuzzing the inputs on public method parameters.
sh
cargo make fuzz_parse_binary
sh
cargo make fuzz_parse_string
Thanks goes to these wonderful people (emoji key):
Sean Bruton ⚠️ 💻 |
Benoît C. ⚠️ 💻 |
snake66 ⚠️ 💻 |
This project follows the all-contributors specification. Contributions of any kind welcome!
Licensed under either of Apache License, Version 2.0 or MIT license at your option. Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in this library by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.