clash-lib
Copyright(C) 2012-2016 University of Twente
2016 Myrtle Software Ltd
2017 Google Inc.
2021-2024 QBayLogic B.V.
LicenseBSD2 (see the file LICENSE)
MaintainerQBayLogic B.V. <devops@qbaylogic.com>
Safe HaskellNone
LanguageHaskell2010

Clash.Core.Type

Description

Types in CoreHW

Synopsis

Documentation

data Type Source #

Types in CoreHW: function and polymorphic types

Constructors

VarTy !TyVar

Type variable

ConstTy !ConstTy

Type constant

ForAllTy !TyVar !Type

Polymorphic Type

AppTy !Type !Type

Type Application

LitTy !LitTy

Type literal

AnnType [Attr Text] !Type

Annotated type, see Clash.Annotations.SynthesisAttributes

Instances

Instances details
Eq Type Source # 
Instance details

Defined in Clash.Core.Subst

Methods

(==) :: Type -> Type -> Bool Source #

(/=) :: Type -> Type -> Bool Source #

Ord Type Source # 
Instance details

Defined in Clash.Core.Subst

Show Type Source # 
Instance details

Defined in Clash.Core.Type

Generic Type Source # 
Instance details

Defined in Clash.Core.Type

Associated Types

type Rep Type :: Type -> Type Source #

Methods

from :: Type -> Rep Type x Source #

to :: Rep Type x -> Type Source #

(TypeError (('Text "A broken implementation of Hashable Type has been " :<>: 'Text "removed in Clash 1.4.7. If this is an issue for you, please submit ") :<>: 'Text "an issue report at https://github.com/clash-lang/clash-compiler/issues.") :: Constraint) => Hashable Type Source # 
Instance details

Defined in Clash.Core.Type

Binary Type Source # 
Instance details

Defined in Clash.Core.Type

NFData Type Source # 
Instance details

Defined in Clash.Core.Type

Methods

rnf :: Type -> () Source #

ClashPretty Type Source # 
Instance details

Defined in Clash.Core.Pretty

Methods

clashPretty :: Type -> Doc () Source #

PrettyPrec Type Source # 
Instance details

Defined in Clash.Core.Pretty

HasFreeVars Type Source # 
Instance details

Defined in Clash.Core.HasFreeVars

InferType Type Source # 
Instance details

Defined in Clash.Core.HasType

HasType Type Source # 
Instance details

Defined in Clash.Core.HasType

Methods

coreTypeOf :: Type -> Type Source #

type Rep Type Source # 
Instance details

Defined in Clash.Core.Type

data TypeView Source #

An easier view on types

Constructors

FunTy !Type !Type

Function type

TyConApp !TyConName [Type]

Applied TyCon

OtherType !Type

Neither of the above

Instances

Instances details
Show TypeView Source # 
Instance details

Defined in Clash.Core.Type

data ConstTy Source #

Type Constants

Constructors

TyCon !TyConName

TyCon type

Arrow

Function type

Instances

Instances details
Eq ConstTy Source # 
Instance details

Defined in Clash.Core.Type

Ord ConstTy Source # 
Instance details

Defined in Clash.Core.Type

Show ConstTy Source # 
Instance details

Defined in Clash.Core.Type

Generic ConstTy Source # 
Instance details

Defined in Clash.Core.Type

Associated Types

type Rep ConstTy :: Type -> Type Source #

Hashable ConstTy Source # 
Instance details

Defined in Clash.Core.Type

Binary ConstTy Source # 
Instance details

Defined in Clash.Core.Type

NFData ConstTy Source # 
Instance details

Defined in Clash.Core.Type

Methods

rnf :: ConstTy -> () Source #

type Rep ConstTy Source # 
Instance details

Defined in Clash.Core.Type

type Rep ConstTy = D1 ('MetaData "ConstTy" "Clash.Core.Type" "clash-lib-1.8.2-inplace" 'False) (C1 ('MetaCons "TyCon" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: Maybe Symbol) 'NoSourceUnpackedness 'SourceStrict 'DecidedStrict) (Rec0 TyConName)) :+: C1 ('MetaCons "Arrow" 'PrefixI 'False) (U1 :: Type -> Type))

data LitTy Source #

Literal Types

Constructors

NumTy !Integer 
SymTy !String 
CharTy !Char 

Instances

Instances details
Eq LitTy Source # 
Instance details

Defined in Clash.Core.Type

Methods

(==) :: LitTy -> LitTy -> Bool Source #

(/=) :: LitTy -> LitTy -> Bool Source #

Ord LitTy Source # 
Instance details

Defined in Clash.Core.Type

Show LitTy Source # 
Instance details

Defined in Clash.Core.Type

Generic LitTy Source # 
Instance details

Defined in Clash.Core.Type

Associated Types

type Rep LitTy :: Type -> Type Source #

Methods

from :: LitTy -> Rep LitTy x Source #

to :: Rep LitTy x -> LitTy Source #

Hashable LitTy Source # 
Instance details

Defined in Clash.Core.Type

Binary LitTy Source # 
Instance details

Defined in Clash.Core.Type

NFData LitTy Source # 
Instance details

Defined in Clash.Core.Type

Methods

rnf :: LitTy -> () Source #

Pretty LitTy Source # 
Instance details

Defined in Clash.Core.Pretty

Methods

pretty :: LitTy -> Doc ann Source #

prettyList :: [LitTy] -> Doc ann Source #

PrettyPrec LitTy Source # 
Instance details

Defined in Clash.Core.Pretty

type Rep LitTy Source # 
Instance details

Defined in Clash.Core.Type

type Kind = Type Source #

The level above types

type KindOrType = Type Source #

Either a Kind or a Type

type KiName = Name Kind Source #

Reference to a Kind

type TyName = Name Type Source #

Reference to a Type

type TyVar = Var Type Source #

Type variable

tyView :: Type -> TypeView Source #

An easier view on types

Note [Arrow arguments]

Clash' Arrow type can either have 2 or 4 arguments, depending on who created it. By default it has two arguments: the argument type of a function, and the result type of a function.

So when do we have 4 arguments? When in Haskell/GHC land the arrow was unsaturated. This can happen in instance heads, or in the eta-reduced representation of newtypes. So what are those additional 2 arguments compared to the "normal" function type? They're the kinds of argument and result type.

coreView :: TyConMap -> Type -> Type Source #

A view on types in which newtypes are transparent, the Signal type is transparent, and type functions are evaluated to WHNF (when possible).

Strips away ALL layers. If no layers are found it returns the given type.

coreView1 :: TyConMap -> Type -> Maybe Type Source #

A view on types in which newtypes are transparent, the Signal type is transparent, and type functions are evaluated to WHNF (when possible).

Only strips away one "layer".

mkTyConTy :: TyConName -> Type Source #

Make a Type out of a TyCon

mkFunTy :: Type -> Type -> Type Source #

Make a function type of an argument and result type

mkPolyFunTy Source #

Arguments

:: Type

Result type

-> [Either TyVar Type]

List of quantifiers and function argument types

-> Type 

Make a polymorphic function type out of a result type and a list of quantifiers and function argument types

mkTyConApp :: TyConName -> [Type] -> Type Source #

Make a TyCon Application out of a TyCon and a list of argument types

splitFunTy :: TyConMap -> Type -> Maybe (Type, Type) Source #

Split a function type in an argument and result type

splitFunForallTy :: Type -> ([Either TyVar Type], Type) Source #

Split a poly-function type in a: list of type-binders and argument types, and the result type

splitCoreFunForallTy :: TyConMap -> Type -> ([Either TyVar Type], Type) Source #

Split a poly-function type in a: list of type-binders and argument types, and the result type. Looks through Signal and type functions.

splitTyConAppM :: Type -> Maybe (TyConName, [Type]) Source #

Split a TyCon Application in a TyCon and its arguments

isPolyFunTy :: Type -> Bool Source #

Is a type a polymorphic or function type?

isPolyFunCoreTy :: TyConMap -> Type -> Bool Source #

Is a type a polymorphic or function type under coreView1?

isPolyTy :: Type -> Bool Source #

Is a type polymorphic?

isFunTy :: TyConMap -> Type -> Bool Source #

Is a type a function type?

applyFunTy :: TyConMap -> Type -> Type -> Type Source #

Apply a function type to an argument type and get the result type

normalizeType :: TyConMap -> Type -> Type Source #

Normalize a type, looking through Signals and newtypes

For example: Signal a (Vec (6-1) (Unsigned (3+1))) normalizes to Vec 5 (Unsigned 4)

varAttrs :: Var a -> [Attr Text] Source #

typeAttrs :: Type -> [Attr Text] Source #

Extract attributes from type. Will return an empty list if this is an AnnType with an empty list AND if this is not an AnnType at all.