generated from tpl/purs
commit
72bfaf2046
16
bower.json
16
bower.json
@ -11,15 +11,15 @@
|
||||
"output"
|
||||
],
|
||||
"dependencies": {
|
||||
"purescript-console": "^0.1.0",
|
||||
"js-yaml": "~3.4.6",
|
||||
"purescript-functions": "~0.1.0",
|
||||
"purescript-foreign": "~0.7.2",
|
||||
"purescript-generics": "~0.7.0",
|
||||
"purescript-foreign-generic": "~0.3.0",
|
||||
"purescript-unsafe-coerce": "~0.1.0"
|
||||
"js-yaml": "^3.4.6",
|
||||
"purescript-functions": "^2.0.0",
|
||||
"purescript-foreign": "^3.2.0",
|
||||
"purescript-foreign-generic": "^3.0.0",
|
||||
"purescript-unsafe-coerce": "^2.0.0"
|
||||
},
|
||||
"devDependencies": {
|
||||
"purescript-spec": "~0.7.2"
|
||||
"purescript-console": "^2.0.0",
|
||||
"purescript-spec": "~0.12.1"
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -11,7 +11,7 @@ Attempt to parse a YAML string, returning the result as foreign data.
|
||||
#### `readYAML`
|
||||
|
||||
``` purescript
|
||||
readYAML :: forall a. (IsForeign a) => String -> F a
|
||||
readYAML :: forall a. IsForeign a => String -> F a
|
||||
```
|
||||
|
||||
Attempt to parse a YAML string into the datastructure you want.
|
||||
@ -19,7 +19,7 @@ Attempt to parse a YAML string into the datastructure you want.
|
||||
#### `readYAMLGeneric`
|
||||
|
||||
``` purescript
|
||||
readYAMLGeneric :: forall a. (Generic a) => Options -> String -> F a
|
||||
readYAMLGeneric :: forall a rep. (Generic a rep, GenericDecode rep) => Options -> String -> F a
|
||||
```
|
||||
|
||||
Automatically generate a YAML parser for your data from a generic instance.
|
||||
|
@ -15,7 +15,7 @@ type YArray = Array YValue
|
||||
#### `YAML`
|
||||
|
||||
``` purescript
|
||||
data YAML :: *
|
||||
data YAML :: Type
|
||||
```
|
||||
|
||||
#### `YValue`
|
||||
@ -60,18 +60,22 @@ ToYAML String
|
||||
type Pair = Tuple String YValue
|
||||
```
|
||||
|
||||
#### `(:=)`
|
||||
#### `entry`
|
||||
|
||||
``` purescript
|
||||
(:=) :: forall a. (ToYAML a) => String -> a -> Pair
|
||||
entry :: forall a. ToYAML a => String -> a -> Pair
|
||||
```
|
||||
|
||||
_left-associative / precedence -1_
|
||||
|
||||
Helper function to create a key-value tuple for a YAML object.
|
||||
|
||||
`name = "Name" := "This is the name"`
|
||||
|
||||
#### `(:=)`
|
||||
|
||||
``` purescript
|
||||
infixl 4 entry as :=
|
||||
```
|
||||
|
||||
#### `object`
|
||||
|
||||
``` purescript
|
||||
@ -109,7 +113,7 @@ toYAMLImpl :: YAML -> String
|
||||
#### `printYAML`
|
||||
|
||||
``` purescript
|
||||
printYAML :: forall a. (ToYAML a) => a -> String
|
||||
printYAML :: forall a. ToYAML a => a -> String
|
||||
```
|
||||
|
||||
|
||||
|
@ -1,24 +1,25 @@
|
||||
module Data.YAML.Foreign.Decode (parseYAML, readYAML, readYAMLGeneric) where
|
||||
|
||||
import Control.Bind ((>=>))
|
||||
import Data.Either
|
||||
import Data.Foreign (Foreign (), F (), ForeignError (..))
|
||||
import Data.Foreign.Class (IsForeign, read)
|
||||
import Data.Foreign.Generic
|
||||
import Data.Function (Fn3(), runFn3)
|
||||
import Data.Generic (Generic)
|
||||
import Prelude (Show, (<<<), (++), (>>=))
|
||||
import Data.Foreign (F, Foreign, ForeignError(..), fail)
|
||||
import Data.Foreign.Class (class IsForeign, read)
|
||||
import Data.Foreign.Generic (readGeneric)
|
||||
import Data.Foreign.Generic.Classes (class GenericDecode)
|
||||
import Data.Foreign.Generic.Types (Options)
|
||||
import Data.Function.Uncurried (Fn3, runFn3)
|
||||
import Data.Generic.Rep (class Generic)
|
||||
import Prelude (pure, (<<<), (>>=), (>=>))
|
||||
|
||||
foreign import parseYAMLImpl :: forall r. Fn3 (String -> r) (Foreign -> r) String r
|
||||
|
||||
-- | Attempt to parse a YAML string, returning the result as foreign data.
|
||||
parseYAML :: String -> F Foreign
|
||||
parseYAML yaml = runFn3 parseYAMLImpl (Left <<< JSONError) Right yaml
|
||||
parseYAML yaml = runFn3 parseYAMLImpl (fail <<< JSONError) pure yaml
|
||||
|
||||
-- | Attempt to parse a YAML string into the datastructure you want.
|
||||
readYAML :: forall a. (IsForeign a) => String -> F a
|
||||
readYAML yaml = parseYAML yaml >>= read
|
||||
|
||||
-- | Automatically generate a YAML parser for your data from a generic instance.
|
||||
readYAMLGeneric :: forall a. (Generic a) => Options -> String -> F a
|
||||
readYAMLGeneric :: forall a rep. (Generic a rep, GenericDecode rep) => Options -> String -> F a
|
||||
readYAMLGeneric opts = parseYAML >=> readGeneric opts
|
||||
|
||||
|
@ -1,11 +1,12 @@
|
||||
module Data.YAML.Foreign.Encode where
|
||||
|
||||
import Data.Function (Fn4(), runFn4)
|
||||
import Data.List (fromList, toList)
|
||||
import qualified Data.Map as M
|
||||
import Data.Maybe (Maybe (), maybe)
|
||||
import Data.Map as M
|
||||
import Data.Array (fromFoldable, toUnfoldable)
|
||||
import Data.Function.Uncurried (Fn4, runFn4)
|
||||
import Data.List (List)
|
||||
import Data.Maybe (Maybe, maybe)
|
||||
import Data.Tuple (Tuple(..), fst, snd)
|
||||
import Prelude (Eq, Show, map, show, ($), (++), (==), (<<<))
|
||||
import Prelude (class Eq, class Show, map, show, ($), (<>), (==), (<<<))
|
||||
import Unsafe.Coerce (unsafeCoerce)
|
||||
|
||||
type YObject = M.Map String YValue
|
||||
@ -22,12 +23,12 @@ data YValue
|
||||
| YNull
|
||||
|
||||
instance showYValue :: Show YValue where
|
||||
show (YObject m) = "YObject " ++ show m
|
||||
show (YArray vs) = "YArray " ++ show vs
|
||||
show (YString s) = "YString " ++ show s
|
||||
show (YNumber n) = "YNumber " ++ show n
|
||||
show (YInt i) = "YInt " ++ show i
|
||||
show (YBoolean b) = "YBoolean " ++ show b
|
||||
show (YObject m) = "YObject " <> show m
|
||||
show (YArray vs) = "YArray " <> show vs
|
||||
show (YString s) = "YString " <> show s
|
||||
show (YNumber n) = "YNumber " <> show n
|
||||
show (YInt i) = "YInt " <> show i
|
||||
show (YBoolean b) = "YBoolean " <> show b
|
||||
show YNull = "YNull"
|
||||
|
||||
instance eqYValue :: Eq YValue where
|
||||
@ -66,14 +67,16 @@ type Pair = Tuple String YValue
|
||||
-- | Helper function to create a key-value tuple for a YAML object.
|
||||
-- |
|
||||
-- | `name = "Name" := "This is the name"`
|
||||
(:=) :: forall a. (ToYAML a) => String -> a -> Pair
|
||||
(:=) name value = Tuple name (toYAML value)
|
||||
entry :: forall a. (ToYAML a) => String -> a -> Pair
|
||||
entry name value = Tuple name (toYAML value)
|
||||
|
||||
infixl 4 entry as :=
|
||||
|
||||
-- | Helper function to create a YAML object.
|
||||
-- |
|
||||
-- | `obj = object [ "Name" := "This is the name", "Size" := 1.5 ]`
|
||||
object :: Array Pair -> YValue
|
||||
object ps = YObject $ M.fromList $ toList $ ps
|
||||
object ps = YObject $ M.fromFoldable (toUnfoldable ps :: List Pair)
|
||||
|
||||
foreign import jsNull :: YAML
|
||||
foreign import objToHash ::
|
||||
@ -84,7 +87,7 @@ foreign import objToHash ::
|
||||
YAML
|
||||
|
||||
valueToYAML :: YValue -> YAML
|
||||
valueToYAML (YObject o) = runFn4 objToHash valueToYAML fst snd $ fromList $ M.toList o
|
||||
valueToYAML (YObject o) = runFn4 objToHash valueToYAML fst snd $ fromFoldable $ M.toList o
|
||||
valueToYAML (YArray a) = unsafeCoerce $ map valueToYAML a
|
||||
valueToYAML (YString s) = unsafeCoerce s
|
||||
valueToYAML (YNumber n) = unsafeCoerce n
|
||||
@ -96,3 +99,4 @@ foreign import toYAMLImpl :: YAML -> String
|
||||
|
||||
printYAML :: forall a. (ToYAML a) => a -> String
|
||||
printYAML = toYAMLImpl <<< valueToYAML <<< toYAML
|
||||
|
||||
|
@ -1,11 +1,9 @@
|
||||
module Test.Instances where
|
||||
|
||||
import Prelude
|
||||
import Data.Either
|
||||
import Data.Foreign
|
||||
import Data.Foreign.Class
|
||||
import Data.Generic (Generic, gShow, gEq)
|
||||
|
||||
import Prelude (class Eq, class Show, bind, pure, ($))
|
||||
import Data.Foreign (ForeignError(..), fail, readString)
|
||||
import Data.Foreign.Class (class IsForeign, readProp)
|
||||
import Data.Generic (class Generic, gShow, gEq)
|
||||
import Data.YAML.Foreign.Encode
|
||||
|
||||
data Point = Point Int Int
|
||||
@ -41,21 +39,21 @@ instance archiObjectIsForeign :: IsForeign GeoObject where
|
||||
points <- readProp "Points" value
|
||||
mobility <- readProp "Mobility" value
|
||||
coverage <- readProp "Coverage" value
|
||||
return $ GeoObject { name, scale, points, mobility, coverage }
|
||||
pure $ GeoObject { name, scale, points, mobility, coverage }
|
||||
|
||||
instance pointIsForeign :: IsForeign Point where
|
||||
read value = do
|
||||
x <- readProp "X" value
|
||||
y <- readProp "Y" value
|
||||
return $ Point x y
|
||||
pure $ Point x y
|
||||
|
||||
instance mobilityIsForeign :: IsForeign Mobility where
|
||||
read value = do
|
||||
mob <- readString value
|
||||
case mob of
|
||||
"Fix" -> return Fix
|
||||
"Flex" -> return Flex
|
||||
_ -> Left $ JSONError "Mobility must be either Flex or Fix"
|
||||
"Fix" -> pure Fix
|
||||
"Flex" -> pure Flex
|
||||
_ -> fail $ JSONError "Mobility must be either Flex or Fix"
|
||||
|
||||
instance pointToYAML :: ToYAML Point where
|
||||
toYAML (Point x y) =
|
||||
@ -77,3 +75,4 @@ instance archiObjectToYAML :: ToYAML GeoObject where
|
||||
, "Mobility" := o.mobility
|
||||
, "Coverage" := o.coverage
|
||||
]
|
||||
|
||||
|
@ -1,19 +1,17 @@
|
||||
module Test.Main where
|
||||
|
||||
import Prelude
|
||||
|
||||
import Data.Either
|
||||
import Data.Foreign
|
||||
import Control.Monad.Eff
|
||||
import Control.Monad.Eff.Console (CONSOLE ())
|
||||
import Control.Monad.Eff (Eff)
|
||||
import Control.Monad.Except (runExcept)
|
||||
import Data.Either (Either(..))
|
||||
import Data.Foreign (F)
|
||||
import Data.YAML.Foreign.Decode (readYAML)
|
||||
import Data.YAML.Foreign.Encode (printYAML)
|
||||
import Prelude (Unit, bind, ($))
|
||||
import Test.Instances (GeoObject(..), Mobility(..), Point(..))
|
||||
import Test.Spec (describe, it)
|
||||
import Test.Spec.Runner (Process (), run)
|
||||
import Test.Spec.Assertions (shouldEqual)
|
||||
import Test.Spec.Reporter.Console (consoleReporter)
|
||||
|
||||
import Data.YAML.Foreign.Decode
|
||||
import Data.YAML.Foreign.Encode
|
||||
import Test.Instances
|
||||
import Test.Spec.Runner (RunnerEffects, run)
|
||||
|
||||
yamlInput :: String
|
||||
yamlInput = """
|
||||
@ -85,14 +83,15 @@ parsedData =
|
||||
}
|
||||
]
|
||||
|
||||
main :: Eff (console :: CONSOLE, process :: Process) Unit
|
||||
main :: Eff (RunnerEffects ()) Unit
|
||||
main = run [consoleReporter] do
|
||||
describe "purescript-yaml" do
|
||||
describe "decode" do
|
||||
it "Decodes YAML" do
|
||||
let decoded = (readYAML yamlInput) :: F (Array GeoObject)
|
||||
decoded `shouldEqual` (Right parsedData)
|
||||
(runExcept decoded) `shouldEqual` (Right parsedData)
|
||||
describe "encode" do
|
||||
it "Encodes YAML" $ do
|
||||
let encoded = printYAML parsedData
|
||||
encoded `shouldEqual` yamlOutput
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user