module Opaleye.Internal.TableMaker where
import qualified Opaleye.Column as C
import qualified Opaleye.Internal.Column as IC
import qualified Opaleye.Internal.PackMap as PM
import Data.Profunctor (Profunctor, dimap)
import Data.Profunctor.Product (ProductProfunctor, empty, (***!))
import qualified Data.Profunctor.Product as PP
import Data.Profunctor.Product.Default (Default, def)
import Control.Applicative (Applicative, pure, (<*>))
import qualified Opaleye.Internal.HaskellDB.PrimQuery as HPQ
newtype ViewColumnMaker strings columns =
ViewColumnMaker (PM.PackMap () () strings columns)
newtype ColumnMaker columns columns' =
ColumnMaker (PM.PackMap HPQ.PrimExpr HPQ.PrimExpr columns columns')
runViewColumnMaker :: ViewColumnMaker strings tablecolumns ->
strings -> tablecolumns
runViewColumnMaker (ViewColumnMaker f) = PM.overPM f id
runColumnMaker :: Applicative f
=> ColumnMaker tablecolumns columns
-> (HPQ.PrimExpr -> f HPQ.PrimExpr)
-> tablecolumns -> f columns
runColumnMaker (ColumnMaker f) = PM.traversePM f
tableColumn :: ViewColumnMaker String (C.Column a)
tableColumn = ViewColumnMaker
(PM.PackMap (\f s -> fmap (const (mkColumn s)) (f ())))
where mkColumn = IC.Column . HPQ.BaseTableAttrExpr
column :: ColumnMaker (C.Column a) (C.Column a)
column = ColumnMaker
(PM.PackMap (\f (IC.Column s)
-> fmap IC.Column (f s)))
instance Default ViewColumnMaker String (C.Column a) where
def = tableColumn
instance Default ColumnMaker (C.Column a) (C.Column a) where
def = column
instance Functor (ViewColumnMaker a) where
fmap f (ViewColumnMaker g) = ViewColumnMaker (fmap f g)
instance Applicative (ViewColumnMaker a) where
pure = ViewColumnMaker . pure
ViewColumnMaker f <*> ViewColumnMaker x = ViewColumnMaker (f <*> x)
instance Profunctor ViewColumnMaker where
dimap f g (ViewColumnMaker q) = ViewColumnMaker (dimap f g q)
instance ProductProfunctor ViewColumnMaker where
empty = PP.defaultEmpty
(***!) = PP.defaultProfunctorProduct
instance Functor (ColumnMaker a) where
fmap f (ColumnMaker g) = ColumnMaker (fmap f g)
instance Applicative (ColumnMaker a) where
pure = ColumnMaker . pure
ColumnMaker f <*> ColumnMaker x = ColumnMaker (f <*> x)
instance Profunctor ColumnMaker where
dimap f g (ColumnMaker q) = ColumnMaker (dimap f g q)
instance ProductProfunctor ColumnMaker where
empty = PP.defaultEmpty
(***!) = PP.defaultProfunctorProduct
--}