X-Git-Url: http://gitweb.michael.orlitzky.com/?a=blobdiff_plain;f=src%2FCidr.hs;h=df35138aa8fca2d6f43c7a952f146f1fc8e4da87;hb=b90b397f348edca15cf8181309f25d3be1e641ab;hp=12d9689df71a7cbe955f4be1edb74c934263ef65;hpb=aa99fa9dea5d738c25c3585ac9653819bcda5bae;p=hath.git diff --git a/src/Cidr.hs b/src/Cidr.hs index 12d9689..df35138 100644 --- a/src/Cidr.hs +++ b/src/Cidr.hs @@ -1,7 +1,7 @@ module Cidr ( Cidr(..), cidr_from_string, - contains + combine_all ) where import IPv4Address @@ -13,7 +13,12 @@ import Octet data Cidr = None | Cidr { ipv4address :: IPv4Address, maskbits :: Maskbits } - deriving (Eq, Show) + deriving (Eq) + + +instance Show Cidr where + show Cidr.None = "None" + show cidr = (show (ipv4address cidr)) ++ "/" ++ (show (maskbits cidr)) -- Returns the mask portion of a CIDR address. That is, everything @@ -91,3 +96,21 @@ contains (Cidr addr1 mbits1) (Cidr addr2 mbits2) where addr1masked = apply_mask addr1 mbits1 addr2masked = apply_mask addr2 mbits1 + + +contains_proper :: Cidr -> Cidr -> Bool +contains_proper cidr1 cidr2 = + (cidr1 `contains` cidr2) && (not (cidr1 == cidr2)) + + +-- A CIDR range is redundant (with respect to the given list) if +-- another CIDR range in that list properly contains it. +redundant :: [Cidr] -> Cidr -> Bool +redundant cidrlist cidr = any ((flip contains_proper) cidr) cidrlist + + +-- We want to get rid of all the Cidrs that are properly contained +-- in some other Cidr. +combine_all :: [Cidr] -> [Cidr] +combine_all cidrs = + filter (not . (redundant cidrs)) cidrs