X-Git-Url: http://gitweb.michael.orlitzky.com/?p=dead%2Flwn-epub.git;a=blobdiff_plain;f=src%2FLWN%2FPage.hs;h=c61bf6a5c028dd55e41c71a75748426790dd9885;hp=f0ada7cd13cfff0707904272f93fa2b4b354f9e3;hb=22c3f63a91361fddfe8315d7e7d5daef42700957;hpb=fc0052e451aa03675ebd9a128dfa46573b9357d7 diff --git a/src/LWN/Page.hs b/src/LWN/Page.hs index f0ada7c..c61bf6a 100644 --- a/src/LWN/Page.hs +++ b/src/LWN/Page.hs @@ -3,6 +3,7 @@ module LWN.Page where +import Control.Concurrent.ParallelIO (parallel) import qualified Data.Map as Map (lookup) import Data.Time (getCurrentTime) import qualified Data.ByteString.Lazy as B (ByteString, hPut) @@ -172,7 +173,7 @@ type StoryMap = Map.Map URL Article -- These come *before* preprocessing. download_full_story_urls :: Cfg -> [URL] -> IO StoryMap download_full_story_urls cfg story_urls = do - pages <- mapM (page_from_url cfg) story_urls + pages <- parallel $ map (page_from_url cfg) story_urls let pairs = zip story_urls pages return $ foldl my_insert empty_map pairs where @@ -352,7 +353,6 @@ fp_parse_articles xml = do [] -> [] -- Put the separator back, it was lost during the split. let split_articles = map (article_separator ++) split_articles' - --_ <- mapM print_article split_articles real_articles <- mapM parse_html_article split_articles let just_articles = catMaybes real_articles return just_articles