X-Git-Url: http://gitweb.michael.orlitzky.com/?p=haeredes.git;a=blobdiff_plain;f=src%2FDNS.hs;h=f649e0ad5da96ea4c8ab34b250eeaf9ab2948044;hp=5222cbec3f3a54c1d8b334bb52b615e56b1cc2e2;hb=7d54d3e3e239342eae8b7fda5f5e4fb43adbbde8;hpb=fa4220513eb9d2036c3db0cc9c518c6346050318 diff --git a/src/DNS.hs b/src/DNS.hs index 5222cbe..f649e0a 100644 --- a/src/DNS.hs +++ b/src/DNS.hs @@ -6,6 +6,7 @@ module DNS ( ) where +import Control.Monad (liftM) import qualified Data.ByteString.Char8 as BS ( append, last, @@ -22,7 +23,7 @@ type LookupResult = (Domain, Maybe [Domain]) lookupMX' :: Resolver -> Domain -> IO LookupResult lookupMX' resolver domain = - lookupMX resolver domain >>= return . pair_em . drop_priority + liftM (pair_em . drop_priority) $ lookupMX resolver domain where drop_priority :: Maybe [(Domain, Int)] -> Maybe [Domain] drop_priority = fmap (map fst) @@ -33,7 +34,7 @@ lookupMX' resolver domain = -- This function keeps the domain matches with its NS records. lookupNS' :: Resolver -> Domain -> IO LookupResult lookupNS' resolver domain = - lookupNS resolver domain >>= return . pair_em + liftM pair_em $ lookupNS resolver domain where pair_em :: a -> (Domain, a) pair_em = (,) domain