Move macros into their own module.

This allows us to use `enum_with_unknown` in `phy`.
v0.7.x
whitequark 2017-07-23 07:54:36 +00:00
parent eae7907f60
commit fe6fb087e5
3 changed files with 75 additions and 74 deletions

View File

@ -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 {

71
src/macros.rs Normal file
View File

@ -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
}
}
}
}
}

View File

@ -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>;