You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
52 lines
2.3 KiB
52 lines
2.3 KiB
7 months ago
|
# macaddr
|
||
|
|
||
|
> MAC address types for Rust
|
||
|
|
||
|
[data:image/s3,"s3://crabby-images/beb49/beb4994cf62ff29894cdb8eed93c68e2867f50a6" alt="Latest Version"](https://crates.io/crates/macaddr)
|
||
|
[data:image/s3,"s3://crabby-images/14ef0/14ef03b610398e0ef818d7449a6f2f96f35b780a" alt="Latest Version"](https://docs.rs/macaddr)
|
||
|
[data:image/s3,"s3://crabby-images/c79b0/c79b08279f93f545ffd37d23435b49d0aa7f89e9" alt="Build Status"](https://github.com/svartalf/rust-macaddr/actions)
|
||
|
[data:image/s3,"s3://crabby-images/a33ea/a33eae0713f8f9628caed5335102944e9e19c8c5" alt="Coverage Status"](https://coveralls.io/github/svartalf/rust-macaddr?branch=master)
|
||
|
data:image/s3,"s3://crabby-images/3b0c1/3b0c100f817658a0eb50f0d4c6bd08f94d9ebf89" alt="Minimum rustc version"
|
||
|
data:image/s3,"s3://crabby-images/52a6f/52a6fdc61c50d0a1b88499d229118d1095b7be54" alt="Apache 2.0 OR MIT licensed"
|
||
|
data:image/s3,"s3://crabby-images/f70cd/f70cda7f11533b5cc2c3864a02c4865a049f2717" alt="unsafe forbidden"
|
||
|
|
||
|
This crate provides types for a [MAC address](https://en.wikipedia.org/wiki/MAC_address)
|
||
|
identifiers, both in IEEE *EUI-48* and *EUI-64* formats.
|
||
|
|
||
|
It is like a [`std::net::SocketAddr`](https://doc.rust-lang.org/std/net/enum.SocketAddr.html) enum with a
|
||
|
[`std::net::SocketAddrV4`](https://doc.rust-lang.org/std/net/struct.SocketAddrV4.html) and
|
||
|
[`std::net::SocketAddrV6`](https://doc.rust-lang.org/std/net/struct.SocketAddrV6.html) members,
|
||
|
but for MAC addresses instead.
|
||
|
|
||
|
Obviously, MAC address can be represented as a `[u8; 6]` or `[u8; 8]`,
|
||
|
but it is error-prone and inconvenient, so here they are —
|
||
|
[MacAddr6](https://docs.rs/macaddr/latest/macaddr/struct.MacAddr6.html) and
|
||
|
[MacAddr8](https://docs.rs/macaddr/latest/macaddr/struct.MacAddr8.html)
|
||
|
structs with helpful methods and standard Rust traits implementations,
|
||
|
intended to be the first-class Rust objects.
|
||
|
|
||
|
And it is `serde`- and `no_std`-friendly also!
|
||
|
|
||
|
## Installation
|
||
|
|
||
|
Add this to your `Cargo.toml`
|
||
|
|
||
|
```toml
|
||
|
[dependencies]
|
||
|
macaddr = "1.0"
|
||
|
```
|
||
|
|
||
|
## Usage
|
||
|
|
||
|
Check out the [documentation](https://docs.rs/macaddr) for each type
|
||
|
available, all of them have a plenty of examples.
|
||
|
|
||
|
## License
|
||
|
|
||
|
Licensed under either of [Apache License 2.0](https://github.com/svartalf/rust-macaddr/blob/master/LICENSE-APACHE)
|
||
|
or [MIT license](https://github.com/svartalf/rust-macaddr/blob/master/LICENSE-MIT) at your option.
|
||
|
|
||
|
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in this crate by you,
|
||
|
as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.
|
||
|
|