mirror of
https://github.com/achanda/ipnetwork.git
synced 2025-06-20 18:29:48 +00:00
Merge pull request #8 from faern/clonable-structs
Implement useful traits on the Ip*Network structs
This commit is contained in:
35
src/lib.rs
35
src/lib.rs
@ -12,23 +12,25 @@ const IPV4_BITS: u8 = 32;
|
|||||||
const IPV6_BITS: u8 = 128;
|
const IPV6_BITS: u8 = 128;
|
||||||
|
|
||||||
// A network
|
// A network
|
||||||
#[derive(Debug)]
|
#[derive(Debug,Clone,Copy,Hash,PartialEq,Eq)]
|
||||||
pub enum IpNetwork {
|
pub enum IpNetwork {
|
||||||
V4(Ipv4Network),
|
V4(Ipv4Network),
|
||||||
V6(Ipv6Network),
|
V6(Ipv6Network),
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[derive(Debug,Clone,Copy,Hash,PartialEq,Eq)]
|
||||||
pub struct Ipv4Network {
|
pub struct Ipv4Network {
|
||||||
addr: Ipv4Addr,
|
addr: Ipv4Addr,
|
||||||
prefix: u8,
|
prefix: u8,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[derive(Debug,Clone,Copy,Hash,PartialEq,Eq)]
|
||||||
pub struct Ipv6Network {
|
pub struct Ipv6Network {
|
||||||
addr: Ipv6Addr,
|
addr: Ipv6Addr,
|
||||||
prefix: u8,
|
prefix: u8,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug)]
|
#[derive(Debug,Clone,PartialEq,Eq)]
|
||||||
pub enum IpNetworkError {
|
pub enum IpNetworkError {
|
||||||
InvalidAddr(String),
|
InvalidAddr(String),
|
||||||
InvalidPrefix,
|
InvalidPrefix,
|
||||||
@ -165,9 +167,8 @@ impl Ipv6Network {
|
|||||||
|
|
||||||
pub fn from_cidr(cidr: &str) -> Result<Ipv6Network, IpNetworkError> {
|
pub fn from_cidr(cidr: &str) -> Result<Ipv6Network, IpNetworkError> {
|
||||||
let (addr_str, prefix_str) = try!(cidr_parts(cidr));
|
let (addr_str, prefix_str) = try!(cidr_parts(cidr));
|
||||||
let addr = try!(Ipv6Addr::from_str(addr_str).map_err(|_| {
|
let addr = try!(Ipv6Addr::from_str(addr_str)
|
||||||
IpNetworkError::InvalidAddr(format!("{}", addr_str))
|
.map_err(|_| IpNetworkError::InvalidAddr(format!("{}", addr_str))));
|
||||||
}));
|
|
||||||
let prefix = try!(parse_prefix(prefix_str, IPV6_BITS));
|
let prefix = try!(parse_prefix(prefix_str, IPV6_BITS));
|
||||||
Self::new(addr, prefix)
|
Self::new(addr, prefix)
|
||||||
}
|
}
|
||||||
@ -204,13 +205,13 @@ impl IpNetwork {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl fmt::Debug for Ipv4Network {
|
impl fmt::Display for Ipv4Network {
|
||||||
fn fmt(&self, fmt: &mut fmt::Formatter) -> fmt::Result {
|
fn fmt(&self, fmt: &mut fmt::Formatter) -> fmt::Result {
|
||||||
write!(fmt, "{}/{}", self.ip(), self.prefix())
|
write!(fmt, "{}/{}", self.ip(), self.prefix())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl fmt::Debug for Ipv6Network {
|
impl fmt::Display for Ipv6Network {
|
||||||
fn fmt(&self, fmt: &mut fmt::Formatter) -> fmt::Result {
|
fn fmt(&self, fmt: &mut fmt::Formatter) -> fmt::Result {
|
||||||
write!(fmt, "{}/{}", self.ip(), self.prefix())
|
write!(fmt, "{}/{}", self.ip(), self.prefix())
|
||||||
}
|
}
|
||||||
@ -237,6 +238,8 @@ fn parse_prefix(prefix: &str, max: u8) -> Result<u8, IpNetworkError> {
|
|||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
mod test {
|
mod test {
|
||||||
|
use std::mem;
|
||||||
|
use std::collections::HashMap;
|
||||||
use std::net::{Ipv4Addr, Ipv6Addr};
|
use std::net::{Ipv4Addr, Ipv6Addr};
|
||||||
use super::*;
|
use super::*;
|
||||||
|
|
||||||
@ -343,6 +346,24 @@ mod test {
|
|||||||
assert!(net.nth(1).is_none());
|
assert!(net.nth(1).is_none());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn hash_eq_compatibility_v4() {
|
||||||
|
let mut map = HashMap::new();
|
||||||
|
let net = Ipv4Network::new(Ipv4Addr::new(127, 0, 0, 1), 16).unwrap();
|
||||||
|
map.insert(net, 137);
|
||||||
|
let out = map.get(&net).unwrap();
|
||||||
|
assert_eq!(137, *out);
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn copy_compatibility_v4() {
|
||||||
|
let net = Ipv4Network::new(Ipv4Addr::new(127, 0, 0, 1), 16).unwrap();
|
||||||
|
mem::drop(net);
|
||||||
|
assert_eq!(16, net.prefix());
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn create_v6() {
|
fn create_v6() {
|
||||||
let cidr = Ipv6Network::new(Ipv6Addr::new(0, 0, 0, 0, 0, 0, 0, 1), 24).unwrap();
|
let cidr = Ipv6Network::new(Ipv6Addr::new(0, 0, 0, 0, 0, 0, 0, 1), 24).unwrap();
|
||||||
|
Reference in New Issue
Block a user