{-# LANGUAGE MultiParamTypeClasses #-}
{-# LANGUAGE DataKinds #-}
{-# LANGUAGE TypeOperators #-}
{-# LANGUAGE PolyKinds #-}
{-# LANGUAGE FlexibleInstances #-}
{-# LANGUAGE FlexibleContexts #-}
{-# LANGUAGE ScopedTypeVariables #-}
{-# LANGUAGE AllowAmbiguousTypes #-}
{-# LANGUAGE TypeApplications #-}
{-# LANGUAGE TypeFamilies #-}
module Data.TypedEncoding.Combinators.Encode.Experimental where
import Data.TypedEncoding.Combinators.Encode
import Data.TypedEncoding.Common.Types.Enc
import Data.TypedEncoding.Common.Types.Common
import Data.TypedEncoding.Common.Util.TypeLits
import Data.TypedEncoding.Common.Class.Encode
import Data.Functor.Identity
import GHC.TypeLits
_encodeF :: forall nm xs f c str alg . (Encode f nm alg c str, alg ~ AlgNm nm) => Enc xs c str -> f (Enc (nm ': xs) c str)
_encodeF = encodeF' @(AlgNm nm) @nm
_encodeFAll :: forall nms f c str algs . (Monad f, EncodeAll f nms algs c str, algs ~ AlgNmMap nms) =>
Enc ('[]::[Symbol]) c str
-> f (Enc nms c str)
_encodeFAll = encodeFAll' @(AlgNmMap nms) @nms
_encodeAll :: forall nms c str algs . (EncodeAll Identity nms algs c str, algs ~ AlgNmMap nms) =>
Enc ('[]::[Symbol]) c str
-> Enc nms c str
_encodeAll = encodeAll' @(AlgNmMap nms) @nms
_encodeFPart :: forall xs xsf f c str algs . (Monad f, EncodeAll f xs algs c str, algs ~ AlgNmMap xs) => Enc xsf c str -> f (Enc (Append xs xsf) c str)
_encodeFPart = encodeFPart' @(AlgNmMap xs) @xs
_encodePart :: forall xs xsf c str algs . (EncodeAll Identity xs algs c str, algs ~ AlgNmMap xs) => Enc xsf c str -> Enc (Append xs xsf) c str
_encodePart = encodePart' @(AlgNmMap xs) @xs