{-# LANGUAGE PatternSynonyms #-}

module Argo.Pattern where

import qualified Argo.Type as Type
import qualified Argo.Type.Array as Array
import qualified Argo.Type.Boolean as Boolean
import qualified Argo.Type.Null as Null
import qualified Argo.Type.Number as Number
import qualified Argo.Type.Object as Object
import qualified Argo.Type.Pair as Pair
import qualified Argo.Type.String as String
import qualified Argo.Type.Value as Value
import qualified Data.Text as Text

pattern Null :: Value.Value
pattern $bNull :: Value
$mNull :: forall r. Value -> (Void# -> r) -> (Void# -> r) -> r
Null = Value.Null (Null.Null ())

pattern Boolean :: Bool -> Value.Value
pattern $bBoolean :: Bool -> Value
$mBoolean :: forall r. Value -> (Bool -> r) -> (Void# -> r) -> r
Boolean x = Value.Boolean (Boolean.Boolean x)

pattern Number :: Integer -> Integer -> Value.Value
pattern $bNumber :: Integer -> Integer -> Value
$mNumber :: forall r. Value -> (Integer -> Integer -> r) -> (Void# -> r) -> r
Number x y <- Value.Number (Number.Number x y) where
    Number Integer
x Integer
y = Number -> Value
Value.Number (Number -> Value) -> Number -> Value
forall a b. (a -> b) -> a -> b
$ Integer -> Integer -> Number
Number.number Integer
x Integer
y

pattern String :: Text.Text -> Value.Value
pattern $bString :: Text -> Value
$mString :: forall r. Value -> (Text -> r) -> (Void# -> r) -> r
String x = Value.String (String.String x)

pattern Array :: Type.Array -> Value.Value
pattern $bArray :: Array -> Value
$mArray :: forall r. Value -> (Array -> r) -> (Void# -> r) -> r
Array x = Value.Array (Array.Array x)

pattern Object :: Type.Object -> Value.Value
pattern $bObject :: Object -> Value
$mObject :: forall r. Value -> (Object -> r) -> (Void# -> r) -> r
Object x = Value.Object (Object.Object x)

{-# COMPLETE Null, Boolean, Number, String, Array, Object #-}

pattern Pair :: Text.Text -> Value.Value -> Pair.Pair String.String Value.Value
pattern $bPair :: Text -> Value -> Pair String Value
$mPair :: forall r.
Pair String Value -> (Text -> Value -> r) -> (Void# -> r) -> r
Pair k v = Pair.Pair (String.String k, v)

{-# COMPLETE Pair #-}