summaryrefslogtreecommitdiff
path: root/src/Text/Hakyll.hs
diff options
context:
space:
mode:
authorJasper Van der Jeugt <jaspervdj@gmail.com>2009-12-27 13:25:02 +0100
committerJasper Van der Jeugt <jaspervdj@gmail.com>2009-12-27 13:25:02 +0100
commit586998c9119d33708f21d6365d6f19cd1869b439 (patch)
treefdd69ba4ead18de6f204b91d2d1adce6ba2b6ece /src/Text/Hakyll.hs
parent9608a9bde5cf490788809609425d890a814f7b75 (diff)
downloadhakyll-586998c9119d33708f21d6365d6f19cd1869b439.tar.gz
Added a simple HTTP server for testing purposes.
Diffstat (limited to 'src/Text/Hakyll.hs')
-rw-r--r--src/Text/Hakyll.hs29
1 files changed, 19 insertions, 10 deletions
diff --git a/src/Text/Hakyll.hs b/src/Text/Hakyll.hs
index 6e85907..4aa88cb 100644
--- a/src/Text/Hakyll.hs
+++ b/src/Text/Hakyll.hs
@@ -2,6 +2,8 @@ module Text.Hakyll
( hakyll
) where
+import Network.Hakyll.SimpleServer (simpleServer)
+
import System.Environment (getArgs, getProgName)
import System.Directory (doesDirectoryExist, removeDirectoryRecursive)
@@ -9,10 +11,13 @@ import System.Directory (doesDirectoryExist, removeDirectoryRecursive)
hakyll :: IO () -> IO ()
hakyll action = do
args <- getArgs
- case args of [] -> action
- ["--clean"] -> clean
- _ -> showHelp
+ case args of [] -> action
+ ["--clean"] -> clean
+ ["--server", p] -> server (read p)
+ ["--server"] -> server 8000
+ _ -> help
+-- | Clean up directories.
clean :: IO ()
clean = do remove' "_cache"
remove' "_site"
@@ -21,13 +26,17 @@ clean = do remove' "_cache"
else return ()
-- | Show usage information.
-showHelp :: IO ()
-showHelp = do
+help :: IO ()
+help = do
name <- getProgName
- putStrLn $ "This is a hakyll site generator program. You should always run\n"
- ++ "it from the project root directory.\n"
+ putStrLn $ "This is a hakyll site generator program. You should always\n"
+ ++ "run it from the project root directory.\n"
++ "\n"
++ "Usage:\n"
- ++ name ++ " Generate the site.\n"
- ++ name ++ " --clean Clean up and remove cache.\n"
- ++ name ++ " --help Show this message.\n"
+ ++ name ++ " Generate the site.\n"
+ ++ name ++ " --clean Clean up and remove cache.\n"
+ ++ name ++ " --help Show this message.\n"
+ ++ name ++ " --server [port] Run a local test server.\n"
+
+server :: Integer -> IO ()
+server p = do simpleServer (fromIntegral $ p)