]> gitweb.michael.orlitzky.com - dead/lwn-epub.git/blobdiff - src/Main.hs
Use cmdargs to parse the one command-line argument.
[dead/lwn-epub.git] / src / Main.hs
index e91654da85a6446d32a02afed636a106dd514a7e..8687488f7817281760813cd06cdbc24a06ffb44f 100644 (file)
@@ -1,14 +1,43 @@
+{-# LANGUAGE ScopedTypeVariables, RecordWildCards #-}
 module Main
 where
 
-data Article = Article { headline  :: String,
-                         byline    :: String,
-                         body_html :: String }
-             deriving (Eq, Show)
+import Data.Maybe (fromJust)
+import System.Console.CmdArgs (cmdArgsRun)
 
-parse_article :: String -> String
-parse_article _ = ""
+import Text.XML.HXT.Core
+
+
+import CommandLine (Args(..), apply_args)
+import Epublishable
+import LWN.ArticlePage
+import LWN.FullPage
+
+my_read :: String -> IOStateArrow s b XmlTree
+my_read =
+  readDocument [ withValidate  no,
+                 withParseHTML yes,
+                 withInputEncoding utf8,
+                 withWarnings no ]
 
 main :: IO ()
 main = do
-  putStrLn "Hello, world."
+  Args{..} <- apply_args
+  print article
+
+  -- let article_html = my_read "test/fixtures/501317-article.html"
+  -- ioap <- parse article_html
+  -- let article_page :: ArticlePage = fromJust $ ioap
+  -- epublish article_page "single_article.epub"
+
+  -- let page_html = my_read "test/fixtures/500848-page.html"
+  -- ioap_f <- parse page_html
+  -- let full_page :: FullPage = fromJust $ ioap_f
+  -- epublish full_page "full_page.epub"
+
+  -- let bigpage_html = my_read "test/fixtures/50844-bigpage.html"
+  -- ioap_bp <- parse bigpage_html
+  -- let bigpage :: FullPage = fromJust $ ioap_bp
+  -- epublish bigpage "bigpage.epub"
+
+  -- putStrLn "Done."