Move macros into their own module.
This allows us to use `enum_with_unknown` in `phy`.v0.7.x
parent
eae7907f60
commit
fe6fb087e5
25
src/lib.rs
25
src/lib.rs
|
@ -84,35 +84,18 @@ extern crate collections;
|
|||
#[macro_use(trace, log, log_enabled)]
|
||||
extern crate log;
|
||||
|
||||
macro_rules! net_trace {
|
||||
($($arg:expr),*) => {
|
||||
#[cfg(feature = "log")]
|
||||
trace!($($arg),*);
|
||||
#[cfg(not(feature = "log"))]
|
||||
$( let _ = $arg );*; // suppress unused variable warnings
|
||||
}
|
||||
}
|
||||
|
||||
macro_rules! net_trace_enabled {
|
||||
() => ({
|
||||
#[cfg(feature = "log")]
|
||||
fn enabled() -> bool { log_enabled!($crate::log::LogLevel::Trace) }
|
||||
#[cfg(not(feature = "log"))]
|
||||
fn enabled() -> bool { false }
|
||||
enabled()
|
||||
})
|
||||
}
|
||||
|
||||
use core::fmt;
|
||||
|
||||
#[macro_use]
|
||||
mod macros;
|
||||
mod parsing;
|
||||
|
||||
pub mod storage;
|
||||
pub mod phy;
|
||||
pub mod wire;
|
||||
pub mod iface;
|
||||
pub mod socket;
|
||||
|
||||
mod parsing;
|
||||
|
||||
/// The error type for the networking stack.
|
||||
#[derive(Debug, PartialEq, Eq, Clone, Copy)]
|
||||
pub enum Error {
|
||||
|
|
|
@ -0,0 +1,71 @@
|
|||
macro_rules! net_trace {
|
||||
($($arg:expr),*) => {
|
||||
#[cfg(feature = "log")]
|
||||
trace!($($arg),*);
|
||||
#[cfg(not(feature = "log"))]
|
||||
$( let _ = $arg );*; // suppress unused variable warnings
|
||||
}
|
||||
}
|
||||
|
||||
macro_rules! net_trace_enabled {
|
||||
() => ({
|
||||
#[cfg(feature = "log")]
|
||||
fn enabled() -> bool { log_enabled!($crate::log::LogLevel::Trace) }
|
||||
#[cfg(not(feature = "log"))]
|
||||
fn enabled() -> bool { false }
|
||||
enabled()
|
||||
})
|
||||
}
|
||||
|
||||
macro_rules! enum_with_unknown {
|
||||
(
|
||||
$( #[$enum_attr:meta] )*
|
||||
pub enum $name:ident($ty:ty) {
|
||||
$( $variant:ident = $value:expr ),+
|
||||
}
|
||||
) => {
|
||||
enum_with_unknown! {
|
||||
$( #[$enum_attr] )*
|
||||
pub doc enum $name($ty) {
|
||||
$( #[doc(shown)] $variant = $value ),+
|
||||
}
|
||||
}
|
||||
};
|
||||
(
|
||||
$( #[$enum_attr:meta] )*
|
||||
pub doc enum $name:ident($ty:ty) {
|
||||
$(
|
||||
$( #[$variant_attr:meta] )+
|
||||
$variant:ident = $value:expr
|
||||
),+
|
||||
}
|
||||
) => {
|
||||
#[derive(Debug, PartialEq, Eq, PartialOrd, Ord, Clone, Copy)]
|
||||
$( #[$enum_attr] )*
|
||||
pub enum $name {
|
||||
$(
|
||||
$( #[$variant_attr] )*
|
||||
$variant
|
||||
),*,
|
||||
Unknown($ty)
|
||||
}
|
||||
|
||||
impl ::core::convert::From<$ty> for $name {
|
||||
fn from(value: $ty) -> Self {
|
||||
match value {
|
||||
$( $value => $name::$variant ),*,
|
||||
other => $name::Unknown(other)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
impl ::core::convert::From<$name> for $ty {
|
||||
fn from(value: $name) -> Self {
|
||||
match value {
|
||||
$( $name::$variant => $value ),*,
|
||||
$name::Unknown(other) => other
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
|
@ -68,59 +68,6 @@ let mut buffer = vec![0; repr.buffer_len() + repr.payload_len];
|
|||
```
|
||||
*/
|
||||
|
||||
macro_rules! enum_with_unknown {
|
||||
(
|
||||
$( #[$enum_attr:meta] )*
|
||||
pub enum $name:ident($ty:ty) {
|
||||
$( $variant:ident = $value:expr ),+
|
||||
}
|
||||
) => {
|
||||
enum_with_unknown! {
|
||||
$( #[$enum_attr] )*
|
||||
pub doc enum $name($ty) {
|
||||
$( #[doc(shown)] $variant = $value ),+
|
||||
}
|
||||
}
|
||||
};
|
||||
(
|
||||
$( #[$enum_attr:meta] )*
|
||||
pub doc enum $name:ident($ty:ty) {
|
||||
$(
|
||||
$( #[$variant_attr:meta] )+
|
||||
$variant:ident = $value:expr
|
||||
),+
|
||||
}
|
||||
) => {
|
||||
#[derive(Debug, PartialEq, Eq, PartialOrd, Ord, Clone, Copy)]
|
||||
$( #[$enum_attr] )*
|
||||
pub enum $name {
|
||||
$(
|
||||
$( #[$variant_attr] )*
|
||||
$variant
|
||||
),*,
|
||||
Unknown($ty)
|
||||
}
|
||||
|
||||
impl ::core::convert::From<$ty> for $name {
|
||||
fn from(value: $ty) -> Self {
|
||||
match value {
|
||||
$( $value => $name::$variant ),*,
|
||||
other => $name::Unknown(other)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
impl ::core::convert::From<$name> for $ty {
|
||||
fn from(value: $name) -> Self {
|
||||
match value {
|
||||
$( $name::$variant => $value ),*,
|
||||
$name::Unknown(other) => other
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
mod field {
|
||||
pub type Field = ::core::ops::Range<usize>;
|
||||
pub type Rest = ::core::ops::RangeFrom<usize>;
|
||||
|
|
Loading…
Reference in New Issue