1
Fork 0
simple-sql-parser/website/RenderTestCases.lhs

77 lines
2.5 KiB
Plaintext
Raw Normal View History

2015-08-08 19:49:23 +02:00
2015-08-08 21:30:17 +02:00
Converts the test data to asciidoc
2015-08-08 19:49:23 +02:00
> import Language.SQL.SimpleSQL.Tests
> import Text.Show.Pretty
> import Control.Monad.State
2016-02-22 22:16:36 +01:00
> import Language.SQL.SimpleSQL.Parse
> import Language.SQL.SimpleSQL.Lex
> import Data.List
2015-08-08 19:49:23 +02:00
> data TableItem = Heading Int String
> | Row String String
> doc :: Int -> TestItem -> [TableItem]
> -- filter out some groups of tests
> doc n (Group nm _) | "generated" `isInfixOf` nm = []
2015-08-08 19:49:23 +02:00
> doc n (Group nm is) =
> Heading n nm
> : concatMap (doc (n + 1)) is
2016-02-22 22:24:25 +01:00
> doc _ (TestScalarExpr _ str e) =
2015-08-08 19:49:23 +02:00
> [Row str (ppShow e)]
> doc _ (TestQueryExpr _ str e) =
> [Row str (ppShow e)]
> doc _ (TestStatement _ str e) =
> [Row str (ppShow e)]
> doc _ (TestStatements _ str e) =
> [Row str (ppShow e)]
> doc _ (ParseQueryExpr d str) =
> [Row str (ppShow $ parseQueryExpr d "" Nothing str)]
> doc _ (ParseQueryExprFails d str) =
> [Row str (ppShow $ parseQueryExpr d "" Nothing str)]
2016-02-22 22:24:25 +01:00
> doc _ (ParseScalarExprFails d str) =
> [Row str (ppShow $ parseScalarExpr d "" Nothing str)]
2015-08-08 19:49:23 +02:00
2016-02-22 22:16:36 +01:00
> doc _ (LexTest d str t) =
> [Row str (ppShow $ lexSQL d "" Nothing str)]
> doc _ (LexFails d str) =
> [Row str (ppShow $ lexSQL d "" Nothing str)]
2015-08-08 19:49:23 +02:00
TODO: should put the dialect in the html output
> render :: [TableItem] -> IO ()
> render = go False
> where
> go t (Heading level title : is) = do
2015-08-08 21:30:17 +02:00
> when t $ putStrLn "|==="
> -- slight hack
> when (level > 1) $
> putStrLn $ "\n" ++ replicate level '=' ++ " " ++ title
2015-08-08 19:49:23 +02:00
> go False is
> go t (Row sql hask : is) = do
2015-08-08 21:30:17 +02:00
> unless t $ putStrLn "[cols=\"2\"]\n|==="
> let sql' = "\n[source,sql]\n----\n" ++ sql ++ "\n----\n"
> hask' = "\n[source,haskell]\n----\n" ++ hask ++ "\n----\n"
> putStrLn $ "a| " ++ escapePipe sql'
> ++ "a| " ++ escapePipe hask' ++ " "
2015-08-08 19:49:23 +02:00
> go True is
2015-08-08 21:30:17 +02:00
> go t [] = when t $ putStrLn "|==="
> escapePipe [] = []
> escapePipe ('\\':'|':xs) = '\\' : '\\' : '\\' : '|' : escapePipe xs
> escapePipe ('|':xs) = '\\' : '|' : escapePipe xs
> escapePipe (x:xs) = x : escapePipe xs
2015-08-08 19:49:23 +02:00
> main :: IO ()
2015-08-08 21:30:17 +02:00
> main = do
> putStrLn "\n:toc:\n\
> \:toc-placement: macro\n\
> \:sectnums:\n\
> \:toclevels: 10\n\
> \:sectnumlevels: 10\n\
> \:source-highlighter: pygments\n\n\
> \= simple-sql-parser examples/test cases\n\n\
> \toc::[]\n"
> render $ doc 1 testData