use crate::traits::Mask;
use std::net::Ipv4Addr;
#[derive(Copy, Clone, Debug, PartialEq, Eq, Hash)]
pub struct Netv4Addr {
addr: Ipv4Addr,
mask: Ipv4Addr,
}
impl Netv4Addr {
pub const fn mask(&self) -> Ipv4Addr {
self.mask
}
pub const fn addr(&self) -> Ipv4Addr {
self.addr
}
#[allow(clippy::trivially_copy_pass_by_ref)]
pub fn is_cidr(&self) -> bool {
let mask: u32 = self.mask.into();
let ones: u32 = mask.count_ones();
let cidr_mask: u32 = u32::max_value().checked_shl(32 - ones).unwrap_or(0);
mask == cidr_mask
}
pub fn new(addr: Ipv4Addr, mask: Ipv4Addr) -> Self {
let addr = addr.mask(&mask);
Self { addr, mask }
}
}
mod broadcast;
mod contains;
mod display;
mod from;
mod fromstr;
mod hash;
mod merge;
mod ord;
mod partialord;
#[cfg(feature = "serde")]
mod de;
#[cfg(feature = "serde")]
mod ser;
#[cfg(test)]
mod tests {
use super::*;
mod mask {
use super::*;
#[test]
fn returns_mask_field() {
let netaddr: Netv4Addr = Netv4Addr {
mask: "255.255.255.255".parse().unwrap(),
addr: "0.0.0.0".parse().unwrap(),
};
assert_eq!(
netaddr.mask(),
"255.255.255.255".parse::<Ipv4Addr>().unwrap()
);
}
}
mod addr {
use super::*;
#[test]
fn returns_addr_field() {
let netaddr: Netv4Addr = Netv4Addr {
mask: "255.255.255.255".parse().unwrap(),
addr: "0.0.0.0".parse().unwrap(),
};
assert_eq!(netaddr.addr(), "0.0.0.0".parse::<Ipv4Addr>().unwrap());
}
}
mod is_cidr {
use super::*;
#[test]
fn non_cidr_returns_false() {
let netaddr: Netv4Addr = Netv4Addr {
mask: "255.127.255.0".parse().unwrap(),
addr: "0.0.0.0".parse().unwrap(),
};
assert!(!netaddr.is_cidr());
}
#[test]
fn cidr_returns_true() {
let netaddr: Netv4Addr = Netv4Addr {
mask: "255.224.0.0".parse().unwrap(),
addr: "0.0.0.0".parse().unwrap(),
};
assert!(netaddr.is_cidr());
}
}
mod new {
use super::*;
#[test]
fn masks_addr() {
let addr: Ipv4Addr = "192.168.16.32".parse().unwrap();
let mask: Ipv4Addr = "255.64.128.3".parse().unwrap();
let netaddr: Netv4Addr = Netv4Addr::new(addr, mask);
assert_eq!(netaddr.mask(), mask);
assert_eq!(netaddr.addr(), "192.0.0.0".parse::<Ipv4Addr>().unwrap());
}
}
}