From 1a1913e7b86b02044b6c4eb5c158f9043bd2f0d3 Mon Sep 17 00:00:00 2001 From: Jake Wheat Date: Sat, 31 Aug 2019 13:50:12 +0100 Subject: [PATCH] example of a custom dialect which allows date('xxx') syntax by removing 'date' from the list of keywords --- simple-sql-parser.cabal | 3 ++- tools/Language/SQL/SimpleSQL/CustomDialect.lhs | 11 +++++++++++ tools/Language/SQL/SimpleSQL/TestTypes.lhs | 5 +++-- tools/Language/SQL/SimpleSQL/Tests.lhs | 2 ++ 4 files changed, 18 insertions(+), 3 deletions(-) create mode 100644 tools/Language/SQL/SimpleSQL/CustomDialect.lhs diff --git a/simple-sql-parser.cabal b/simple-sql-parser.cabal index db4c4cb..8432372 100644 --- a/simple-sql-parser.cabal +++ b/simple-sql-parser.cabal @@ -90,7 +90,8 @@ Test-Suite Tests Language.SQL.SimpleSQL.Tests, Language.SQL.SimpleSQL.Tpch, Language.SQL.SimpleSQL.ScalarExprs, - Language.SQL.SimpleSQL.LexerTests + Language.SQL.SimpleSQL.LexerTests, + Language.SQL.SimpleSQL.CustomDialect other-extensions: TupleSections,DeriveDataTypeable default-language: Haskell2010 diff --git a/tools/Language/SQL/SimpleSQL/CustomDialect.lhs b/tools/Language/SQL/SimpleSQL/CustomDialect.lhs new file mode 100644 index 0000000..ab04d5b --- /dev/null +++ b/tools/Language/SQL/SimpleSQL/CustomDialect.lhs @@ -0,0 +1,11 @@ + +> module Language.SQL.SimpleSQL.CustomDialect (customDialectTests) where + +> import Language.SQL.SimpleSQL.TestTypes + +> customDialectTests :: TestItem +> customDialectTests = Group "custom dialect tests" (map (ParseQueryExpr myDialect) sometests +> ++ [ParseScalarExprFails ansi2011 "SELECT DATE('2000-01-01')"]) +> where +> myDialect = ansi2011 {diKeywords = filter (/="date") (diKeywords ansi2011)} +> sometests = ["SELECT DATE('2000-01-01')"] diff --git a/tools/Language/SQL/SimpleSQL/TestTypes.lhs b/tools/Language/SQL/SimpleSQL/TestTypes.lhs index 90d7034..dbdf140 100644 --- a/tools/Language/SQL/SimpleSQL/TestTypes.lhs +++ b/tools/Language/SQL/SimpleSQL/TestTypes.lhs @@ -4,11 +4,12 @@ Tests.lhs module for the 'interpreter'. > module Language.SQL.SimpleSQL.TestTypes > (TestItem(..) -> ,ansi2011,mysql,postgres,oracle,sqlserver -> ,diOdbc) where +> ,module Language.SQL.SimpleSQL.Dialect +> ) where > import Language.SQL.SimpleSQL.Syntax > import Language.SQL.SimpleSQL.Lex (Token) +> import Language.SQL.SimpleSQL.Dialect TODO: maybe make the dialect args into [dialect], then each test checks all the dialects mentioned work, and all the dialects not diff --git a/tools/Language/SQL/SimpleSQL/Tests.lhs b/tools/Language/SQL/SimpleSQL/Tests.lhs index 8b5baf1..0c0c3ca 100644 --- a/tools/Language/SQL/SimpleSQL/Tests.lhs +++ b/tools/Language/SQL/SimpleSQL/Tests.lhs @@ -38,6 +38,7 @@ test data to the Test.Framework tests. > import Language.SQL.SimpleSQL.MySQL > import Language.SQL.SimpleSQL.Oracle +> import Language.SQL.SimpleSQL.CustomDialect Order the tests to start from the simplest first. This is also the order on the generated documentation. @@ -62,6 +63,7 @@ order on the generated documentation. > ,sql2011BitsTests > ,mySQLTests > ,oracleTests +> ,customDialectTests > ] > tests :: T.TestTree