commit | 302dd54ee61758db1a30f9d8054d016551979674 | [log] [tgz] |
---|---|---|
author | Android Build Coastguard Worker <android-build-coastguard-worker@google.com> | Wed May 10 16:18:06 2023 +0000 |
committer | Android Build Coastguard Worker <android-build-coastguard-worker@google.com> | Wed May 10 16:18:06 2023 +0000 |
tree | 8f15ba3e99b73d800c773a193ff9c84a4368e8d1 | |
parent | 1c4c53fce76b7e161f379a84f3d018a365a363c3 [diff] | |
parent | 1f25bdad18c283ff8680699c4dd992bf446beb8b [diff] |
Snap for 10103804 from 1f25bdad18c283ff8680699c4dd992bf446beb8b to mainline-tzdata5-release Change-Id: I1a98cd5e76dd89ed5c97cf180ce0313d9812befa
MAC address types for Rust
This crate provides types for a MAC address identifiers, both in IEEE EUI-48 and EUI-64 formats.
It is like a std::net::SocketAddr
enum with a std::net::SocketAddrV4
and std::net::SocketAddrV6
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 and MacAddr8 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!
Add this to your Cargo.toml
[dependencies] macaddr = "1.0"
Check out the documentation for each type available, all of them have a plenty of examples.
Licensed under either of Apache License 2.0 or MIT license 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.