macros.rs 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169
  1. #[cfg(not(test))]
  2. #[cfg(feature = "log")]
  3. macro_rules! net_log {
  4. (trace, $($arg:expr),*) => { log::trace!($($arg),*) };
  5. (debug, $($arg:expr),*) => { log::debug!($($arg),*) };
  6. }
  7. #[cfg(test)]
  8. #[cfg(feature = "log")]
  9. macro_rules! net_log {
  10. (trace, $($arg:expr),*) => { println!($($arg),*) };
  11. (debug, $($arg:expr),*) => { println!($($arg),*) };
  12. }
  13. #[cfg(feature = "defmt")]
  14. macro_rules! net_log {
  15. (trace, $($arg:expr),*) => { defmt::trace!($($arg),*) };
  16. (debug, $($arg:expr),*) => { defmt::debug!($($arg),*) };
  17. }
  18. #[cfg(not(any(feature = "log", feature = "defmt")))]
  19. macro_rules! net_log {
  20. ($level:ident, $($arg:expr),*) => {{ $( let _ = $arg; )* }}
  21. }
  22. macro_rules! net_trace {
  23. ($($arg:expr),*) => (net_log!(trace, $($arg),*));
  24. }
  25. macro_rules! net_debug {
  26. ($($arg:expr),*) => (net_log!(debug, $($arg),*));
  27. }
  28. macro_rules! enum_with_unknown {
  29. (
  30. $( #[$enum_attr:meta] )*
  31. pub enum $name:ident($ty:ty) {
  32. $(
  33. $( #[$variant_attr:meta] )*
  34. $variant:ident = $value:expr
  35. ),+ $(,)?
  36. }
  37. ) => {
  38. #[derive(Debug, PartialEq, Eq, PartialOrd, Ord, Clone, Copy, Hash)]
  39. #[cfg_attr(feature = "defmt", derive(defmt::Format))]
  40. $( #[$enum_attr] )*
  41. pub enum $name {
  42. $(
  43. $( #[$variant_attr] )*
  44. $variant
  45. ),*,
  46. Unknown($ty)
  47. }
  48. impl ::core::convert::From<$ty> for $name {
  49. fn from(value: $ty) -> Self {
  50. match value {
  51. $( $value => $name::$variant ),*,
  52. other => $name::Unknown(other)
  53. }
  54. }
  55. }
  56. impl ::core::convert::From<$name> for $ty {
  57. fn from(value: $name) -> Self {
  58. match value {
  59. $( $name::$variant => $value ),*,
  60. $name::Unknown(other) => other
  61. }
  62. }
  63. }
  64. }
  65. }
  66. #[cfg(feature = "proto-rpl")]
  67. macro_rules! get {
  68. ($buffer:expr, into: $into:ty, fun: $fun:ident, field: $field:expr $(,)?) => {
  69. {
  70. <$into>::$fun(&$buffer.as_ref()[$field])
  71. }
  72. };
  73. ($buffer:expr, into: $into:ty, field: $field:expr $(,)?) => {
  74. get!($buffer, into: $into, field: $field, shift: 0, mask: 0b1111_1111)
  75. };
  76. ($buffer:expr, into: $into:ty, field: $field:expr, mask: $bit_mask:expr $(,)?) => {
  77. get!($buffer, into: $into, field: $field, shift: 0, mask: $bit_mask)
  78. };
  79. ($buffer:expr, into: $into:ty, field: $field:expr, shift: $bit_shift:expr, mask: $bit_mask:expr $(,)?) => {
  80. {
  81. <$into>::from((&$buffer.as_ref()[$field] >> $bit_shift) & $bit_mask)
  82. }
  83. };
  84. ($buffer:expr, field: $field:expr $(,)?) => {
  85. get!($buffer, field: $field, shift: 0, mask: 0b1111_1111)
  86. };
  87. ($buffer:expr, field: $field:expr, mask: $bit_mask:expr $(,)?) => {
  88. get!($buffer, field: $field, shift: 0, mask: $bit_mask)
  89. };
  90. ($buffer:expr, field: $field:expr, shift: $bit_shift:expr, mask: $bit_mask:expr $(,)?)
  91. =>
  92. {
  93. {
  94. (&$buffer.as_ref()[$field] >> $bit_shift) & $bit_mask
  95. }
  96. };
  97. ($buffer:expr, u16, field: $field:expr $(,)?) => {
  98. {
  99. NetworkEndian::read_u16(&$buffer.as_ref()[$field])
  100. }
  101. };
  102. ($buffer:expr, bool, field: $field:expr, shift: $bit_shift:expr, mask: $bit_mask:expr $(,)?) => {
  103. {
  104. (($buffer.as_ref()[$field] >> $bit_shift) & $bit_mask) == 0b1
  105. }
  106. };
  107. ($buffer:expr, u32, field: $field:expr $(,)?) => {
  108. {
  109. NetworkEndian::read_u32(&$buffer.as_ref()[$field])
  110. }
  111. };
  112. }
  113. #[cfg(feature = "proto-rpl")]
  114. macro_rules! set {
  115. ($buffer:expr, address: $address:ident, field: $field:expr $(,)?) => {{
  116. $buffer.as_mut()[$field].copy_from_slice($address.as_bytes());
  117. }};
  118. ($buffer:expr, $value:ident, field: $field:expr $(,)?) => {
  119. set!($buffer, $value, field: $field, shift: 0, mask: 0b1111_1111)
  120. };
  121. ($buffer:expr, $value:ident, field: $field:expr, mask: $bit_mask:expr $(,)?) => {
  122. set!($buffer, $value, field: $field, shift: 0, mask: $bit_mask)
  123. };
  124. ($buffer:expr, $value:ident, field: $field:expr, shift: $bit_shift:expr, mask: $bit_mask:expr $(,)?) => {{
  125. let raw =
  126. ($buffer.as_ref()[$field] & !($bit_mask << $bit_shift)) | ($value << $bit_shift);
  127. $buffer.as_mut()[$field] = raw;
  128. }};
  129. ($buffer:expr, $value:ident, bool, field: $field:expr, mask: $bit_mask:expr $(,)?) => {
  130. set!($buffer, $value, bool, field: $field, shift: 0, mask: $bit_mask);
  131. };
  132. ($buffer:expr, $value:ident, bool, field: $field:expr, shift: $bit_shift:expr, mask: $bit_mask:expr $(,)?) => {{
  133. let raw = ($buffer.as_ref()[$field] & !($bit_mask << $bit_shift))
  134. | (if $value { 0b1 } else { 0b0 } << $bit_shift);
  135. $buffer.as_mut()[$field] = raw;
  136. }};
  137. ($buffer:expr, $value:ident, u16, field: $field:expr $(,)?) => {{
  138. NetworkEndian::write_u16(&mut $buffer.as_mut()[$field], $value);
  139. }};
  140. ($buffer:expr, $value:ident, u32, field: $field:expr $(,)?) => {{
  141. NetworkEndian::write_u32(&mut $buffer.as_mut()[$field], $value);
  142. }};
  143. }