module Opaleye.Column (module Opaleye.Column,
Column,
Nullable,
unsafeCoerce) where
import Opaleye.Internal.Column (Column, Nullable, unsafeCoerce)
import qualified Opaleye.Internal.Column as C
import qualified Opaleye.Internal.HaskellDB.PrimQuery as HPQ
null :: Column (Nullable a)
null = unsafeCoerce (C.Column (HPQ.ConstExpr HPQ.NullLit))
isNull :: Column (Nullable a) -> Column Bool
isNull = C.unOp HPQ.OpIsNull
matchNullable :: Column b -> (Column a -> Column b) -> Column (Nullable a)
-> Column b
matchNullable replacement f x = C.ifThenElse (isNull x) replacement
(f (unsafeCoerce x))
fromNullable :: Column a -> Column (Nullable a) -> Column a
fromNullable = flip matchNullable id
toNullable :: Column a -> Column (Nullable a)
toNullable = unsafeCoerce