module Hasql.Decoding.Composite where
import Hasql.Prelude
import qualified Database.PostgreSQL.LibPQ as LibPQ
import qualified PostgreSQL.Binary.Decoder as Decoder
newtype Composite a =
Composite (ReaderT Bool Decoder.CompositeDecoder a)
deriving (Functor, Applicative, Monad)
run :: Composite a -> Bool -> Decoder.Decoder a
run (Composite imp) env =
Decoder.composite (runReaderT imp env)
value :: (Bool -> Decoder.Decoder a) -> Composite (Maybe a)
value decoder' =
Composite $ ReaderT $ Decoder.compositeValue . decoder'
nonNullValue :: (Bool -> Decoder.Decoder a) -> Composite a
nonNullValue decoder' =
Composite $ ReaderT $ Decoder.compositeNonNullValue . decoder'