{-# LANGUAGE TemplateHaskell #-}
module Clash.Annotations.BitRepresentation.ClashLib
  ( coreToType'
  , bitsToBits
  ) where
import           Clash.Annotations.BitRepresentation.Internal
  (Type'(AppTy',ConstTy',LitTy'))
import qualified Clash.Annotations.BitRepresentation.Util as BitRepresentation
import qualified Clash.Core.Type                          as C
import           Clash.Core.Name                          (nameOcc)
import qualified Clash.Netlist.Types                      as Netlist
import           Clash.Util                               (curLoc)
coreToType'
  :: C.Type
  
  -> Either
       String
       
       Type'
       
coreToType' :: Type -> Either String Type'
coreToType' (C.AppTy t1 :: Type
t1 t2 :: Type
t2) =
  Type' -> Type' -> Type'
AppTy' (Type' -> Type' -> Type')
-> Either String Type' -> Either String (Type' -> Type')
forall (f :: Type -> Type) a b. Functor f => (a -> b) -> f a -> f b
<$> Type -> Either String Type'
coreToType' Type
t1 Either String (Type' -> Type')
-> Either String Type' -> Either String Type'
forall (f :: Type -> Type) a b.
Applicative f =>
f (a -> b) -> f a -> f b
<*> Type -> Either String Type'
coreToType' Type
t2
coreToType' (C.ConstTy (C.TyCon name :: TyConName
name)) =
  Type' -> Either String Type'
forall (m :: Type -> Type) a. Monad m => a -> m a
return (Type' -> Either String Type') -> Type' -> Either String Type'
forall a b. (a -> b) -> a -> b
$ Text -> Type'
ConstTy' (TyConName -> Text
forall a. Name a -> Text
nameOcc TyConName
name)
coreToType' (C.LitTy (C.NumTy n :: Integer
n)) =
  Type' -> Either String Type'
forall (m :: Type -> Type) a. Monad m => a -> m a
return (Type' -> Either String Type') -> Type' -> Either String Type'
forall a b. (a -> b) -> a -> b
$ Integer -> Type'
LitTy' Integer
n
coreToType' e :: Type
e =
  String -> Either String Type'
forall a b. a -> Either a b
Left (String -> Either String Type') -> String -> Either String Type'
forall a b. (a -> b) -> a -> b
$ $(curLoc) String -> String -> String
forall a. [a] -> [a] -> [a]
++ "Unexpected type: " String -> String -> String
forall a. [a] -> [a] -> [a]
++ Type -> String
forall a. Show a => a -> String
show Type
e
bitToBit
  :: BitRepresentation.Bit
  -> Netlist.Bit
bitToBit :: Bit -> Bit
bitToBit BitRepresentation.H = Bit
Netlist.H
bitToBit BitRepresentation.L = Bit
Netlist.L
bitToBit BitRepresentation.U = Bit
Netlist.U
bitsToBits
  :: [BitRepresentation.Bit]
  -> [Netlist.Bit]
bitsToBits :: [Bit] -> [Bit]
bitsToBits = (Bit -> Bit) -> [Bit] -> [Bit]
forall a b. (a -> b) -> [a] -> [b]
map Bit -> Bit
bitToBit