{-# language AllowAmbiguousTypes #-}
{-# language DataKinds #-}
{-# language FlexibleContexts #-}
{-# language FlexibleInstances #-}
{-# language MultiParamTypeClasses #-}
{-# language PolyKinds #-}
{-# language RankNTypes #-}
{-# language ScopedTypeVariables #-}
{-# language StandaloneKindSignatures #-}
{-# language TypeApplications #-}
{-# language TypeFamilies #-}
{-# language TypeOperators #-}
{-# language UndecidableInstances #-}

module Rel8.Generic.Table.Record
  ( GTable, GColumns, GContext, gfromColumns, gtoColumns, gtable
  , GSerialize, gfromResult, gtoResult
  )
where

-- base
import Data.Kind ( Constraint, Type )
import Data.Proxy ( Proxy( Proxy ) )
import GHC.Generics
  ( (:*:)( (:*:) ), K1( K1 ), M1( M1 )
  , C, D, S
  , Meta( MetaSel )
  )
import Prelude hiding ( null )

-- rel8
import Rel8.FCF ( Eval, Exp )
import Rel8.Schema.HTable.Label ( HLabel, hlabel, hunlabel )
import Rel8.Schema.HTable.Product ( HProduct(..) )
import qualified Rel8.Schema.Kind as K


type GColumns :: (Type -> Exp K.HTable) -> (Type -> Type) -> K.HTable
type family GColumns _Columns rep where
  GColumns _Columns (M1 D _ rep) = GColumns _Columns rep
  GColumns _Columns (M1 C _ rep) = GColumns _Columns rep
  GColumns _Columns (rep1 :*: rep2) =
    HProduct (GColumns _Columns rep1) (GColumns _Columns rep2)
  GColumns _Columns (M1 S ('MetaSel ('Just label) _ _ _) (K1 _ a)) =
    HLabel label (Eval (_Columns a))


type GContext :: (Type -> Exp K.Context) -> (Type -> Type) -> K.Context
type family GContext _Context rep where
  GContext _Context (M1 _ _ rep) = GContext _Context rep
  GContext _Context (rep1 :*: _rep2) = GContext _Context rep1
  GContext _Context (K1 _ a) = Eval (_Context a)


type GTable
  :: (Type -> Exp Constraint)
  -> (Type -> Exp K.HTable)
  -> (Type -> Type) -> Constraint
class GTable _Table _Columns rep
 where
  gfromColumns :: ()
    => (forall a. Eval (_Table a) => Eval (_Columns a) context -> a)
    -> GColumns _Columns rep context
    -> rep x

  gtoColumns :: ()
    => (forall a. Eval (_Table a) => a -> Eval (_Columns a) context)
    -> rep x
    -> GColumns _Columns rep context

  gtable :: ()
    => (forall a proxy. Eval (_Table a) => proxy a -> Eval (_Columns a) context)
    -> GColumns _Columns rep context


type GSerialize
  :: (Type -> Type -> Exp Constraint)
  -> (Type -> Exp K.HTable)
  -> (Type -> Type) -> (Type -> Type) -> Constraint
class GSerialize _Serialize _Columns exprs rep
 where
  gfromResult :: ()
    => (forall expr a proxy. Eval (_Serialize expr a)
        => proxy expr -> Eval (_Columns expr) context -> a)
    -> GColumns _Columns exprs context
    -> rep x

  gtoResult :: ()
    => (forall expr a proxy. Eval (_Serialize expr a)
        => proxy expr -> a -> Eval (_Columns expr) context)
    -> rep x
    -> GColumns _Columns exprs context


instance GTable _Table _Columns rep => GTable _Table _Columns (M1 D c rep)
 where
  gfromColumns :: (forall a. Eval (_Table a) => Eval (_Columns a) context -> a)
-> GColumns _Columns (M1 D c rep) context -> M1 D c rep x
gfromColumns forall a. Eval (_Table a) => Eval (_Columns a) context -> a
fromColumns =
    rep x -> M1 D c rep x
forall k i (c :: Meta) (f :: k -> *) (p :: k). f p -> M1 i c f p
M1 (rep x -> M1 D c rep x)
-> (GColumns _Columns rep context -> rep x)
-> GColumns _Columns rep context
-> M1 D c rep x
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (forall a. Eval (_Table a) => Eval (_Columns a) context -> a)
-> GColumns _Columns rep context -> rep x
forall (_Table :: * -> Exp Constraint)
       (_Columns :: * -> Exp HTable) (rep :: Context) (context :: Context)
       x.
GTable _Table _Columns rep =>
(forall a. Eval (_Table a) => Eval (_Columns a) context -> a)
-> GColumns _Columns rep context -> rep x
gfromColumns @_Table @_Columns @rep forall a. Eval (_Table a) => Eval (_Columns a) context -> a
fromColumns
  gtoColumns :: (forall a. Eval (_Table a) => a -> Eval (_Columns a) context)
-> M1 D c rep x -> GColumns _Columns (M1 D c rep) context
gtoColumns forall a. Eval (_Table a) => a -> Eval (_Columns a) context
toColumns (M1 rep x
a) =
    (forall a. Eval (_Table a) => a -> Eval (_Columns a) context)
-> rep x -> GColumns _Columns rep context
forall (_Table :: * -> Exp Constraint)
       (_Columns :: * -> Exp HTable) (rep :: Context) (context :: Context)
       x.
GTable _Table _Columns rep =>
(forall a. Eval (_Table a) => a -> Eval (_Columns a) context)
-> rep x -> GColumns _Columns rep context
gtoColumns @_Table @_Columns @rep forall a. Eval (_Table a) => a -> Eval (_Columns a) context
toColumns rep x
a
  gtable :: (forall a (proxy :: Context).
 Eval (_Table a) =>
 proxy a -> Eval (_Columns a) context)
-> GColumns _Columns (M1 D c rep) context
gtable = forall (context :: Context).
GTable _Table _Columns rep =>
(forall a (proxy :: Context).
 Eval (_Table a) =>
 proxy a -> Eval (_Columns a) context)
-> GColumns _Columns rep context
forall (_Table :: * -> Exp Constraint)
       (_Columns :: * -> Exp HTable) (rep :: Context)
       (context :: Context).
GTable _Table _Columns rep =>
(forall a (proxy :: Context).
 Eval (_Table a) =>
 proxy a -> Eval (_Columns a) context)
-> GColumns _Columns rep context
gtable @_Table @_Columns @rep


instance GSerialize _Serialize _Columns exprs rep =>
  GSerialize _Serialize _Columns (M1 D c exprs) (M1 D c rep)
 where
  gfromResult :: (forall expr a (proxy :: Context).
 Eval (_Serialize expr a) =>
 proxy expr -> Eval (_Columns expr) context -> a)
-> GColumns _Columns (M1 D c exprs) context -> M1 D c rep x
gfromResult forall expr a (proxy :: Context).
Eval (_Serialize expr a) =>
proxy expr -> Eval (_Columns expr) context -> a
fromResult =
    rep x -> M1 D c rep x
forall k i (c :: Meta) (f :: k -> *) (p :: k). f p -> M1 i c f p
M1 (rep x -> M1 D c rep x)
-> (GColumns _Columns exprs context -> rep x)
-> GColumns _Columns exprs context
-> M1 D c rep x
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (forall expr a (proxy :: Context).
 Eval (_Serialize expr a) =>
 proxy expr -> Eval (_Columns expr) context -> a)
-> GColumns _Columns exprs context -> rep x
forall (_Serialize :: * -> * -> Exp Constraint)
       (_Columns :: * -> Exp HTable) (exprs :: Context) (rep :: Context)
       (context :: Context) x.
GSerialize _Serialize _Columns exprs rep =>
(forall expr a (proxy :: Context).
 Eval (_Serialize expr a) =>
 proxy expr -> Eval (_Columns expr) context -> a)
-> GColumns _Columns exprs context -> rep x
gfromResult @_Serialize @_Columns @exprs @rep forall expr a (proxy :: Context).
Eval (_Serialize expr a) =>
proxy expr -> Eval (_Columns expr) context -> a
fromResult
  gtoResult :: (forall expr a (proxy :: Context).
 Eval (_Serialize expr a) =>
 proxy expr -> a -> Eval (_Columns expr) context)
-> M1 D c rep x -> GColumns _Columns (M1 D c exprs) context
gtoResult forall expr a (proxy :: Context).
Eval (_Serialize expr a) =>
proxy expr -> a -> Eval (_Columns expr) context
toResult (M1 rep x
a) =
    (forall expr a (proxy :: Context).
 Eval (_Serialize expr a) =>
 proxy expr -> a -> Eval (_Columns expr) context)
-> rep x -> GColumns _Columns exprs context
forall (_Serialize :: * -> * -> Exp Constraint)
       (_Columns :: * -> Exp HTable) (exprs :: Context) (rep :: Context)
       (context :: Context) x.
GSerialize _Serialize _Columns exprs rep =>
(forall expr a (proxy :: Context).
 Eval (_Serialize expr a) =>
 proxy expr -> a -> Eval (_Columns expr) context)
-> rep x -> GColumns _Columns exprs context
gtoResult @_Serialize @_Columns @exprs @rep forall expr a (proxy :: Context).
Eval (_Serialize expr a) =>
proxy expr -> a -> Eval (_Columns expr) context
toResult rep x
a


instance GTable _Table _Columns rep => GTable _Table _Columns (M1 C c rep)
 where
  gfromColumns :: (forall a. Eval (_Table a) => Eval (_Columns a) context -> a)
-> GColumns _Columns (M1 C c rep) context -> M1 C c rep x
gfromColumns forall a. Eval (_Table a) => Eval (_Columns a) context -> a
fromColumns =
    rep x -> M1 C c rep x
forall k i (c :: Meta) (f :: k -> *) (p :: k). f p -> M1 i c f p
M1 (rep x -> M1 C c rep x)
-> (GColumns _Columns rep context -> rep x)
-> GColumns _Columns rep context
-> M1 C c rep x
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (forall a. Eval (_Table a) => Eval (_Columns a) context -> a)
-> GColumns _Columns rep context -> rep x
forall (_Table :: * -> Exp Constraint)
       (_Columns :: * -> Exp HTable) (rep :: Context) (context :: Context)
       x.
GTable _Table _Columns rep =>
(forall a. Eval (_Table a) => Eval (_Columns a) context -> a)
-> GColumns _Columns rep context -> rep x
gfromColumns @_Table @_Columns @rep forall a. Eval (_Table a) => Eval (_Columns a) context -> a
fromColumns
  gtoColumns :: (forall a. Eval (_Table a) => a -> Eval (_Columns a) context)
-> M1 C c rep x -> GColumns _Columns (M1 C c rep) context
gtoColumns forall a. Eval (_Table a) => a -> Eval (_Columns a) context
toColumns (M1 rep x
a) =
    (forall a. Eval (_Table a) => a -> Eval (_Columns a) context)
-> rep x -> GColumns _Columns rep context
forall (_Table :: * -> Exp Constraint)
       (_Columns :: * -> Exp HTable) (rep :: Context) (context :: Context)
       x.
GTable _Table _Columns rep =>
(forall a. Eval (_Table a) => a -> Eval (_Columns a) context)
-> rep x -> GColumns _Columns rep context
gtoColumns @_Table @_Columns @rep forall a. Eval (_Table a) => a -> Eval (_Columns a) context
toColumns rep x
a
  gtable :: (forall a (proxy :: Context).
 Eval (_Table a) =>
 proxy a -> Eval (_Columns a) context)
-> GColumns _Columns (M1 C c rep) context
gtable = forall (context :: Context).
GTable _Table _Columns rep =>
(forall a (proxy :: Context).
 Eval (_Table a) =>
 proxy a -> Eval (_Columns a) context)
-> GColumns _Columns rep context
forall (_Table :: * -> Exp Constraint)
       (_Columns :: * -> Exp HTable) (rep :: Context)
       (context :: Context).
GTable _Table _Columns rep =>
(forall a (proxy :: Context).
 Eval (_Table a) =>
 proxy a -> Eval (_Columns a) context)
-> GColumns _Columns rep context
gtable @_Table @_Columns @rep


instance GSerialize _Serialize _Columns exprs rep =>
  GSerialize _Serialize _Columns (M1 C c exprs) (M1 C c rep)
 where
  gfromResult :: (forall expr a (proxy :: Context).
 Eval (_Serialize expr a) =>
 proxy expr -> Eval (_Columns expr) context -> a)
-> GColumns _Columns (M1 C c exprs) context -> M1 C c rep x
gfromResult forall expr a (proxy :: Context).
Eval (_Serialize expr a) =>
proxy expr -> Eval (_Columns expr) context -> a
fromResult =
    rep x -> M1 C c rep x
forall k i (c :: Meta) (f :: k -> *) (p :: k). f p -> M1 i c f p
M1 (rep x -> M1 C c rep x)
-> (GColumns _Columns exprs context -> rep x)
-> GColumns _Columns exprs context
-> M1 C c rep x
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (forall expr a (proxy :: Context).
 Eval (_Serialize expr a) =>
 proxy expr -> Eval (_Columns expr) context -> a)
-> GColumns _Columns exprs context -> rep x
forall (_Serialize :: * -> * -> Exp Constraint)
       (_Columns :: * -> Exp HTable) (exprs :: Context) (rep :: Context)
       (context :: Context) x.
GSerialize _Serialize _Columns exprs rep =>
(forall expr a (proxy :: Context).
 Eval (_Serialize expr a) =>
 proxy expr -> Eval (_Columns expr) context -> a)
-> GColumns _Columns exprs context -> rep x
gfromResult @_Serialize @_Columns @exprs @rep forall expr a (proxy :: Context).
Eval (_Serialize expr a) =>
proxy expr -> Eval (_Columns expr) context -> a
fromResult
  gtoResult :: (forall expr a (proxy :: Context).
 Eval (_Serialize expr a) =>
 proxy expr -> a -> Eval (_Columns expr) context)
-> M1 C c rep x -> GColumns _Columns (M1 C c exprs) context
gtoResult forall expr a (proxy :: Context).
Eval (_Serialize expr a) =>
proxy expr -> a -> Eval (_Columns expr) context
toResult (M1 rep x
a) =
    (forall expr a (proxy :: Context).
 Eval (_Serialize expr a) =>
 proxy expr -> a -> Eval (_Columns expr) context)
-> rep x -> GColumns _Columns exprs context
forall (_Serialize :: * -> * -> Exp Constraint)
       (_Columns :: * -> Exp HTable) (exprs :: Context) (rep :: Context)
       (context :: Context) x.
GSerialize _Serialize _Columns exprs rep =>
(forall expr a (proxy :: Context).
 Eval (_Serialize expr a) =>
 proxy expr -> a -> Eval (_Columns expr) context)
-> rep x -> GColumns _Columns exprs context
gtoResult @_Serialize @_Columns @exprs @rep forall expr a (proxy :: Context).
Eval (_Serialize expr a) =>
proxy expr -> a -> Eval (_Columns expr) context
toResult rep x
a


instance (GTable _Table _Columns rep1, GTable _Table _Columns rep2) =>
  GTable _Table _Columns (rep1 :*: rep2)
 where
  gfromColumns :: (forall a. Eval (_Table a) => Eval (_Columns a) context -> a)
-> GColumns _Columns (rep1 :*: rep2) context -> (:*:) rep1 rep2 x
gfromColumns forall a. Eval (_Table a) => Eval (_Columns a) context -> a
fromColumns (HProduct a b) =
    (forall a. Eval (_Table a) => Eval (_Columns a) context -> a)
-> GColumns _Columns rep1 context -> rep1 x
forall (_Table :: * -> Exp Constraint)
       (_Columns :: * -> Exp HTable) (rep :: Context) (context :: Context)
       x.
GTable _Table _Columns rep =>
(forall a. Eval (_Table a) => Eval (_Columns a) context -> a)
-> GColumns _Columns rep context -> rep x
gfromColumns @_Table @_Columns @rep1 forall a. Eval (_Table a) => Eval (_Columns a) context -> a
fromColumns GColumns _Columns rep1 context
a rep1 x -> rep2 x -> (:*:) rep1 rep2 x
forall k (f :: k -> *) (g :: k -> *) (p :: k).
f p -> g p -> (:*:) f g p
:*:
    (forall a. Eval (_Table a) => Eval (_Columns a) context -> a)
-> GColumns _Columns rep2 context -> rep2 x
forall (_Table :: * -> Exp Constraint)
       (_Columns :: * -> Exp HTable) (rep :: Context) (context :: Context)
       x.
GTable _Table _Columns rep =>
(forall a. Eval (_Table a) => Eval (_Columns a) context -> a)
-> GColumns _Columns rep context -> rep x
gfromColumns @_Table @_Columns @rep2 forall a. Eval (_Table a) => Eval (_Columns a) context -> a
fromColumns GColumns _Columns rep2 context
b
  gtoColumns :: (forall a. Eval (_Table a) => a -> Eval (_Columns a) context)
-> (:*:) rep1 rep2 x -> GColumns _Columns (rep1 :*: rep2) context
gtoColumns forall a. Eval (_Table a) => a -> Eval (_Columns a) context
toColumns (rep1 x
a :*: rep2 x
b) = GColumns _Columns rep1 context
-> GColumns _Columns rep2 context
-> HProduct
     (GColumns _Columns rep1) (GColumns _Columns rep2) context
forall (a :: HTable) (b :: HTable) (context :: Context).
a context -> b context -> HProduct a b context
HProduct
    ((forall a. Eval (_Table a) => a -> Eval (_Columns a) context)
-> rep1 x -> GColumns _Columns rep1 context
forall (_Table :: * -> Exp Constraint)
       (_Columns :: * -> Exp HTable) (rep :: Context) (context :: Context)
       x.
GTable _Table _Columns rep =>
(forall a. Eval (_Table a) => a -> Eval (_Columns a) context)
-> rep x -> GColumns _Columns rep context
gtoColumns @_Table @_Columns @rep1 forall a. Eval (_Table a) => a -> Eval (_Columns a) context
toColumns rep1 x
a)
    ((forall a. Eval (_Table a) => a -> Eval (_Columns a) context)
-> rep2 x -> GColumns _Columns rep2 context
forall (_Table :: * -> Exp Constraint)
       (_Columns :: * -> Exp HTable) (rep :: Context) (context :: Context)
       x.
GTable _Table _Columns rep =>
(forall a. Eval (_Table a) => a -> Eval (_Columns a) context)
-> rep x -> GColumns _Columns rep context
gtoColumns @_Table @_Columns @rep2 forall a. Eval (_Table a) => a -> Eval (_Columns a) context
toColumns rep2 x
b)
  gtable :: (forall a (proxy :: Context).
 Eval (_Table a) =>
 proxy a -> Eval (_Columns a) context)
-> GColumns _Columns (rep1 :*: rep2) context
gtable forall a (proxy :: Context).
Eval (_Table a) =>
proxy a -> Eval (_Columns a) context
table = GColumns _Columns rep1 context
-> GColumns _Columns rep2 context
-> HProduct
     (GColumns _Columns rep1) (GColumns _Columns rep2) context
forall (a :: HTable) (b :: HTable) (context :: Context).
a context -> b context -> HProduct a b context
HProduct
    ((forall a (proxy :: Context).
 Eval (_Table a) =>
 proxy a -> Eval (_Columns a) context)
-> GColumns _Columns rep1 context
forall (_Table :: * -> Exp Constraint)
       (_Columns :: * -> Exp HTable) (rep :: Context)
       (context :: Context).
GTable _Table _Columns rep =>
(forall a (proxy :: Context).
 Eval (_Table a) =>
 proxy a -> Eval (_Columns a) context)
-> GColumns _Columns rep context
gtable @_Table @_Columns @rep1 forall a (proxy :: Context).
Eval (_Table a) =>
proxy a -> Eval (_Columns a) context
table)
    ((forall a (proxy :: Context).
 Eval (_Table a) =>
 proxy a -> Eval (_Columns a) context)
-> GColumns _Columns rep2 context
forall (_Table :: * -> Exp Constraint)
       (_Columns :: * -> Exp HTable) (rep :: Context)
       (context :: Context).
GTable _Table _Columns rep =>
(forall a (proxy :: Context).
 Eval (_Table a) =>
 proxy a -> Eval (_Columns a) context)
-> GColumns _Columns rep context
gtable @_Table @_Columns @rep2 forall a (proxy :: Context).
Eval (_Table a) =>
proxy a -> Eval (_Columns a) context
table)


instance
  ( GSerialize _Serialize _Columns expr1 rep1
  , GSerialize _Serialize _Columns expr2 rep2
  )
  => GSerialize _Serialize _Columns (expr1 :*: expr2) (rep1 :*: rep2)
 where
  gfromResult :: (forall expr a (proxy :: Context).
 Eval (_Serialize expr a) =>
 proxy expr -> Eval (_Columns expr) context -> a)
-> GColumns _Columns (expr1 :*: expr2) context -> (:*:) rep1 rep2 x
gfromResult forall expr a (proxy :: Context).
Eval (_Serialize expr a) =>
proxy expr -> Eval (_Columns expr) context -> a
fromResult (HProduct a b) =
    (forall expr a (proxy :: Context).
 Eval (_Serialize expr a) =>
 proxy expr -> Eval (_Columns expr) context -> a)
-> GColumns _Columns expr1 context -> rep1 x
forall (_Serialize :: * -> * -> Exp Constraint)
       (_Columns :: * -> Exp HTable) (exprs :: Context) (rep :: Context)
       (context :: Context) x.
GSerialize _Serialize _Columns exprs rep =>
(forall expr a (proxy :: Context).
 Eval (_Serialize expr a) =>
 proxy expr -> Eval (_Columns expr) context -> a)
-> GColumns _Columns exprs context -> rep x
gfromResult @_Serialize @_Columns @expr1 @rep1 forall expr a (proxy :: Context).
Eval (_Serialize expr a) =>
proxy expr -> Eval (_Columns expr) context -> a
fromResult GColumns _Columns expr1 context
a rep1 x -> rep2 x -> (:*:) rep1 rep2 x
forall k (f :: k -> *) (g :: k -> *) (p :: k).
f p -> g p -> (:*:) f g p
:*:
    (forall expr a (proxy :: Context).
 Eval (_Serialize expr a) =>
 proxy expr -> Eval (_Columns expr) context -> a)
-> GColumns _Columns expr2 context -> rep2 x
forall (_Serialize :: * -> * -> Exp Constraint)
       (_Columns :: * -> Exp HTable) (exprs :: Context) (rep :: Context)
       (context :: Context) x.
GSerialize _Serialize _Columns exprs rep =>
(forall expr a (proxy :: Context).
 Eval (_Serialize expr a) =>
 proxy expr -> Eval (_Columns expr) context -> a)
-> GColumns _Columns exprs context -> rep x
gfromResult @_Serialize @_Columns @expr2 @rep2 forall expr a (proxy :: Context).
Eval (_Serialize expr a) =>
proxy expr -> Eval (_Columns expr) context -> a
fromResult GColumns _Columns expr2 context
b
  gtoResult :: (forall expr a (proxy :: Context).
 Eval (_Serialize expr a) =>
 proxy expr -> a -> Eval (_Columns expr) context)
-> (:*:) rep1 rep2 x -> GColumns _Columns (expr1 :*: expr2) context
gtoResult forall expr a (proxy :: Context).
Eval (_Serialize expr a) =>
proxy expr -> a -> Eval (_Columns expr) context
toResult (rep1 x
a :*: rep2 x
b) =
    GColumns _Columns expr1 context
-> GColumns _Columns expr2 context
-> HProduct
     (GColumns _Columns expr1) (GColumns _Columns expr2) context
forall (a :: HTable) (b :: HTable) (context :: Context).
a context -> b context -> HProduct a b context
HProduct
      ((forall expr a (proxy :: Context).
 Eval (_Serialize expr a) =>
 proxy expr -> a -> Eval (_Columns expr) context)
-> rep1 x -> GColumns _Columns expr1 context
forall (_Serialize :: * -> * -> Exp Constraint)
       (_Columns :: * -> Exp HTable) (exprs :: Context) (rep :: Context)
       (context :: Context) x.
GSerialize _Serialize _Columns exprs rep =>
(forall expr a (proxy :: Context).
 Eval (_Serialize expr a) =>
 proxy expr -> a -> Eval (_Columns expr) context)
-> rep x -> GColumns _Columns exprs context
gtoResult @_Serialize @_Columns @expr1 @rep1 forall expr a (proxy :: Context).
Eval (_Serialize expr a) =>
proxy expr -> a -> Eval (_Columns expr) context
toResult rep1 x
a)
      ((forall expr a (proxy :: Context).
 Eval (_Serialize expr a) =>
 proxy expr -> a -> Eval (_Columns expr) context)
-> rep2 x -> GColumns _Columns expr2 context
forall (_Serialize :: * -> * -> Exp Constraint)
       (_Columns :: * -> Exp HTable) (exprs :: Context) (rep :: Context)
       (context :: Context) x.
GSerialize _Serialize _Columns exprs rep =>
(forall expr a (proxy :: Context).
 Eval (_Serialize expr a) =>
 proxy expr -> a -> Eval (_Columns expr) context)
-> rep x -> GColumns _Columns exprs context
gtoResult @_Serialize @_Columns @expr2 @rep2 forall expr a (proxy :: Context).
Eval (_Serialize expr a) =>
proxy expr -> a -> Eval (_Columns expr) context
toResult rep2 x
b)


instance
  ( Eval (_Table a)
  , meta ~ 'MetaSel ('Just label) _su _ss _ds
  , k1 ~ K1 i a
  )
  => GTable _Table _Columns (M1 S meta k1)
 where
  gfromColumns :: (forall a. Eval (_Table a) => Eval (_Columns a) context -> a)
-> GColumns _Columns (M1 S meta k1) context -> M1 S meta k1 x
gfromColumns forall a. Eval (_Table a) => Eval (_Columns a) context -> a
fromColumns = K1 i a x -> M1 S meta (K1 i a) x
forall k i (c :: Meta) (f :: k -> *) (p :: k). f p -> M1 i c f p
M1 (K1 i a x -> M1 S meta (K1 i a) x)
-> (HLabel label (Eval (_Columns a)) context -> K1 i a x)
-> HLabel label (Eval (_Columns a)) context
-> M1 S meta (K1 i a) x
forall b c a. (b -> c) -> (a -> b) -> a -> c
. a -> K1 i a x
forall k i c (p :: k). c -> K1 i c p
K1 (a -> K1 i a x)
-> (HLabel label (Eval (_Columns a)) context -> a)
-> HLabel label (Eval (_Columns a)) context
-> K1 i a x
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Eval (_Columns a) context -> a
forall a. Eval (_Table a) => Eval (_Columns a) context -> a
fromColumns (Eval (_Columns a) context -> a)
-> (HLabel label (Eval (_Columns a)) context
    -> Eval (_Columns a) context)
-> HLabel label (Eval (_Columns a)) context
-> a
forall b c a. (b -> c) -> (a -> b) -> a -> c
. HLabel label (Eval (_Columns a)) context
-> Eval (_Columns a) context
forall (label :: Symbol) (t :: HTable) (context :: Context).
HLabel label t context -> t context
hunlabel
  gtoColumns :: (forall a. Eval (_Table a) => a -> Eval (_Columns a) context)
-> M1 S meta k1 x -> GColumns _Columns (M1 S meta k1) context
gtoColumns forall a. Eval (_Table a) => a -> Eval (_Columns a) context
toColumns (M1 (K1 a)) = Eval (_Columns a) context
-> HLabel label (Eval (_Columns a)) context
forall (label :: Symbol) (t :: HTable) (context :: Context).
t context -> HLabel label t context
hlabel (a -> Eval (_Columns a) context
forall a. Eval (_Table a) => a -> Eval (_Columns a) context
toColumns a
a)
  gtable :: (forall a (proxy :: Context).
 Eval (_Table a) =>
 proxy a -> Eval (_Columns a) context)
-> GColumns _Columns (M1 S meta k1) context
gtable forall a (proxy :: Context).
Eval (_Table a) =>
proxy a -> Eval (_Columns a) context
table = Eval (_Columns a) context
-> HLabel label (Eval (_Columns a)) context
forall (label :: Symbol) (t :: HTable) (context :: Context).
t context -> HLabel label t context
hlabel (Proxy a -> Eval (_Columns a) context
forall a (proxy :: Context).
Eval (_Table a) =>
proxy a -> Eval (_Columns a) context
table (Proxy a
forall k (t :: k). Proxy t
Proxy @a))


instance
  ( Eval (_Serialize expr a)
  , meta ~ 'MetaSel ('Just label) _su _ss _ds
  , k1 ~ K1 i expr
  , k1' ~ K1 i a
  )
  => GSerialize _Serialize _Columns (M1 S meta k1) (M1 S meta k1')
 where
  gfromResult :: (forall expr a (proxy :: Context).
 Eval (_Serialize expr a) =>
 proxy expr -> Eval (_Columns expr) context -> a)
-> GColumns _Columns (M1 S meta k1) context -> M1 S meta k1' x
gfromResult forall expr a (proxy :: Context).
Eval (_Serialize expr a) =>
proxy expr -> Eval (_Columns expr) context -> a
fromResult = K1 i a x -> M1 S meta (K1 i a) x
forall k i (c :: Meta) (f :: k -> *) (p :: k). f p -> M1 i c f p
M1 (K1 i a x -> M1 S meta (K1 i a) x)
-> (HLabel label (Eval (_Columns expr)) context -> K1 i a x)
-> HLabel label (Eval (_Columns expr)) context
-> M1 S meta (K1 i a) x
forall b c a. (b -> c) -> (a -> b) -> a -> c
. a -> K1 i a x
forall k i c (p :: k). c -> K1 i c p
K1 (a -> K1 i a x)
-> (HLabel label (Eval (_Columns expr)) context -> a)
-> HLabel label (Eval (_Columns expr)) context
-> K1 i a x
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Proxy expr -> Eval (_Columns expr) context -> a
forall expr a (proxy :: Context).
Eval (_Serialize expr a) =>
proxy expr -> Eval (_Columns expr) context -> a
fromResult (Proxy expr
forall k (t :: k). Proxy t
Proxy @expr) (Eval (_Columns expr) context -> a)
-> (HLabel label (Eval (_Columns expr)) context
    -> Eval (_Columns expr) context)
-> HLabel label (Eval (_Columns expr)) context
-> a
forall b c a. (b -> c) -> (a -> b) -> a -> c
. HLabel label (Eval (_Columns expr)) context
-> Eval (_Columns expr) context
forall (label :: Symbol) (t :: HTable) (context :: Context).
HLabel label t context -> t context
hunlabel
  gtoResult :: (forall expr a (proxy :: Context).
 Eval (_Serialize expr a) =>
 proxy expr -> a -> Eval (_Columns expr) context)
-> M1 S meta k1' x -> GColumns _Columns (M1 S meta k1) context
gtoResult forall expr a (proxy :: Context).
Eval (_Serialize expr a) =>
proxy expr -> a -> Eval (_Columns expr) context
toResult (M1 (K1 a)) = Eval (_Columns expr) context
-> HLabel label (Eval (_Columns expr)) context
forall (label :: Symbol) (t :: HTable) (context :: Context).
t context -> HLabel label t context
hlabel (Proxy expr -> a -> Eval (_Columns expr) context
forall expr a (proxy :: Context).
Eval (_Serialize expr a) =>
proxy expr -> a -> Eval (_Columns expr) context
toResult (Proxy expr
forall k (t :: k). Proxy t
Proxy @expr) a
a)