Skip to content

Commit

Permalink
WIP: need to respect --omittable-lists
Browse files Browse the repository at this point in the history
  • Loading branch information
akshaymankar committed Oct 10, 2019
1 parent a24ddfc commit 355bbbf
Show file tree
Hide file tree
Showing 6 changed files with 33 additions and 12 deletions.
31 changes: 22 additions & 9 deletions dhall-json/src/Dhall/JSONToDhall.hs
Original file line number Diff line number Diff line change
Expand Up @@ -255,6 +255,7 @@ parseConversion = Conversion <$> parseStrict
<*> parseKVArr
<*> parseKVMap
<*> parseUnion
<*> parseOmittableLists
where
parseStrict =
O.flag' True
Expand All @@ -275,6 +276,10 @@ parseConversion = Conversion <$> parseStrict
( O.long "no-keyval-maps"
<> O.help "Disable conversion of homogeneous map objects to association lists"
)
parseOmittableLists = O.switch
( O.long "omittable-lists"
<> O.help "Tolerate missing list values, they are assumed empty"
)

-- | Parser for command options related to treating union types
parseUnion :: Parser UnionConv
Expand Down Expand Up @@ -303,21 +308,23 @@ parseUnion =

-- | JSON-to-dhall translation options
data Conversion = Conversion
{ strictRecs :: Bool
, noKeyValArr :: Bool
, noKeyValMap :: Bool
, unions :: UnionConv
{ strictRecs :: Bool
, noKeyValArr :: Bool
, noKeyValMap :: Bool
, unions :: UnionConv
, ommitableLists :: Bool
} deriving Show

data UnionConv = UFirst | UNone | UStrict deriving (Show, Read, Eq)

-- | Default conversion options
defaultConversion :: Conversion
defaultConversion = Conversion
{ strictRecs = False
, noKeyValArr = False
, noKeyValMap = False
, unions = UFirst
defaultConversion = Conversion
{ strictRecs = False
, noKeyValArr = False
, noKeyValMap = False
, unions = UFirst
, ommitableLists = False
}

-- | The 'Expr' type concretization used throughout this module
Expand Down Expand Up @@ -416,6 +423,8 @@ dhallFromJSON (Conversion {..}) expressionType =
= loop t value
| App D.Optional t' <- t
= Right (App D.None t')
| App D.List t' <- t
= Right (D.ListLit (Just $ D.App D.List t') [])
| otherwise
= Left (MissingKey k t v)
in D.RecordLit <$> Map.traverseWithKey f r
Expand Down Expand Up @@ -470,6 +479,10 @@ dhallFromJSON (Conversion {..}) expressionType =
(Seq.fromList es)
in f <$> traverse (loop t) (toList a)

-- null ~> List
loop (App D.List t) (A.Null)
= Right (D.ListLit (Just $ D.App D.List t) [])

-- number ~> Integer
loop D.Integer (A.Number x)
| Right n <- floatingOrInteger x :: Either Double Integer
Expand Down
11 changes: 8 additions & 3 deletions dhall-json/tasty/Main.hs
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,7 @@ testTree =
, testJSONToDhall "./tasty/data/emptyList"
, testJSONToDhall "./tasty/data/emptyObjectStrongType"
, testJSONToDhall "./tasty/data/emptyListStrongType"
, testCustomConversionJSONToDhall undefined "./tasty/data/missingList"
, Test.Tasty.testGroup "Nesting"
[ testDhallToJSON "./tasty/data/nesting0"
, testDhallToJSON "./tasty/data/nesting1"
Expand Down Expand Up @@ -92,8 +93,9 @@ testDhallToJSON prefix = Test.Tasty.HUnit.testCase prefix $ do

Test.Tasty.HUnit.assertEqual message expectedValue actualValue

testJSONToDhall :: String -> TestTree
testJSONToDhall prefix = Test.Tasty.HUnit.testCase prefix $ do
testCustomConversionJSONToDhall :: Conversion -> String -> TestTree
testCustomConversionJSONToDhall conversion prefix =
Test.Tasty.HUnit.testCase prefix $ do
let inputFile = prefix <> ".json"
let schemaFile = prefix <> "Schema.dhall"
let outputFile = prefix <> ".dhall"
Expand All @@ -114,7 +116,7 @@ testJSONToDhall prefix = Test.Tasty.HUnit.testCase prefix $ do
_ <- Core.throws (Dhall.TypeCheck.typeOf schema)

actualExpression <- do
Core.throws (JSONToDhall.dhallFromJSON JSONToDhall.defaultConversion schema value)
Core.throws (JSONToDhall.dhallFromJSON conversion schema value)

outputText <- Data.Text.IO.readFile outputFile

Expand All @@ -132,6 +134,9 @@ testJSONToDhall prefix = Test.Tasty.HUnit.testCase prefix $ do

Test.Tasty.HUnit.assertEqual message expectedExpression actualExpression

testJSONToDhall :: String -> TestTree
testJSONToDhall = testCustomConversionJSONToDhall JSONToDhall.defaultConversion

testDhallToYaml :: Dhall.Yaml.Options -> String -> TestTree
testDhallToYaml options prefix = Test.Tasty.HUnit.testCase prefix $ do
let inputFile = prefix <> ".dhall"
Expand Down
1 change: 1 addition & 0 deletions dhall-json/tasty/data/missingList.dhall
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
{present = ["some-stuff"], null = [] : List Text, missing = [] : List Text}
1 change: 1 addition & 0 deletions dhall-json/tasty/data/missingList.json
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
{"present": ["some-stuff"], "null": null}
1 change: 1 addition & 0 deletions dhall-json/tasty/data/missingListSchema.dhall
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
{present : List Text, null : List Text, missing : List Text}
Empty file added dhall-json/test.yml
Empty file.

0 comments on commit 355bbbf

Please sign in to comment.