{-# LANGUAGE CPP #-}
module TysPrim(
mkPrimTyConName,
mkTemplateKindVars, mkTemplateTyVars, mkTemplateTyVarsFrom,
mkTemplateKiTyVars, mkTemplateKiTyVar,
mkTemplateTyConBinders, mkTemplateKindTyConBinders,
mkTemplateAnonTyConBinders,
alphaTyVars, alphaTyVar, betaTyVar, gammaTyVar, deltaTyVar,
alphaTys, alphaTy, betaTy, gammaTy, deltaTy,
alphaTyVarsUnliftedRep, alphaTyVarUnliftedRep,
alphaTysUnliftedRep, alphaTyUnliftedRep,
runtimeRep1TyVar, runtimeRep2TyVar, runtimeRep1Ty, runtimeRep2Ty,
openAlphaTy, openBetaTy, openAlphaTyVar, openBetaTyVar,
tYPETyCon, tYPETyConName,
tYPE, primRepToRuntimeRep,
funTyCon, funTyConName,
unexposedPrimTyCons, exposedPrimTyCons, primTyCons,
charPrimTyCon, charPrimTy, charPrimTyConName,
intPrimTyCon, intPrimTy, intPrimTyConName,
wordPrimTyCon, wordPrimTy, wordPrimTyConName,
addrPrimTyCon, addrPrimTy, addrPrimTyConName,
floatPrimTyCon, floatPrimTy, floatPrimTyConName,
doublePrimTyCon, doublePrimTy, doublePrimTyConName,
voidPrimTyCon, voidPrimTy,
statePrimTyCon, mkStatePrimTy,
realWorldTyCon, realWorldTy, realWorldStatePrimTy,
proxyPrimTyCon, mkProxyPrimTy,
arrayPrimTyCon, mkArrayPrimTy,
byteArrayPrimTyCon, byteArrayPrimTy,
arrayArrayPrimTyCon, mkArrayArrayPrimTy,
smallArrayPrimTyCon, mkSmallArrayPrimTy,
mutableArrayPrimTyCon, mkMutableArrayPrimTy,
mutableByteArrayPrimTyCon, mkMutableByteArrayPrimTy,
mutableArrayArrayPrimTyCon, mkMutableArrayArrayPrimTy,
smallMutableArrayPrimTyCon, mkSmallMutableArrayPrimTy,
mutVarPrimTyCon, mkMutVarPrimTy,
mVarPrimTyCon, mkMVarPrimTy,
tVarPrimTyCon, mkTVarPrimTy,
stablePtrPrimTyCon, mkStablePtrPrimTy,
stableNamePrimTyCon, mkStableNamePrimTy,
compactPrimTyCon, compactPrimTy,
bcoPrimTyCon, bcoPrimTy,
weakPrimTyCon, mkWeakPrimTy,
threadIdPrimTyCon, threadIdPrimTy,
int8PrimTyCon, int8PrimTy, int8PrimTyConName,
word8PrimTyCon, word8PrimTy, word8PrimTyConName,
int16PrimTyCon, int16PrimTy, int16PrimTyConName,
word16PrimTyCon, word16PrimTy, word16PrimTyConName,
int32PrimTyCon, int32PrimTy, int32PrimTyConName,
word32PrimTyCon, word32PrimTy, word32PrimTyConName,
int64PrimTyCon, int64PrimTy, int64PrimTyConName,
word64PrimTyCon, word64PrimTy, word64PrimTyConName,
eqPrimTyCon,
eqReprPrimTyCon,
eqPhantPrimTyCon,
equalityTyCon,
#include "primop-vector-tys-exports.hs-incl"
) where
#include "GhclibHsVersions.h"
import GhcPrelude
import {-# SOURCE #-} TysWiredIn
( runtimeRepTy, unboxedTupleKind, liftedTypeKind
, vecRepDataConTyCon, tupleRepDataConTyCon
, liftedRepDataConTy, unliftedRepDataConTy
, intRepDataConTy
, int8RepDataConTy, int16RepDataConTy, int32RepDataConTy, int64RepDataConTy
, wordRepDataConTy
, word16RepDataConTy, word8RepDataConTy, word32RepDataConTy, word64RepDataConTy
, addrRepDataConTy
, floatRepDataConTy, doubleRepDataConTy
, vec2DataConTy, vec4DataConTy, vec8DataConTy, vec16DataConTy, vec32DataConTy
, vec64DataConTy
, int8ElemRepDataConTy, int16ElemRepDataConTy, int32ElemRepDataConTy
, int64ElemRepDataConTy, word8ElemRepDataConTy, word16ElemRepDataConTy
, word32ElemRepDataConTy, word64ElemRepDataConTy, floatElemRepDataConTy
, doubleElemRepDataConTy
, mkPromotedListTy )
import Var ( TyVar, mkTyVar )
import Name
import TyCon
import SrcLoc
import Unique
import PrelNames
import FastString
import Outputable
import TyCoRep
import Data.Char
primTyCons :: [TyCon]
primTyCons :: [TyCon]
primTyCons = [TyCon]
unexposedPrimTyCons [TyCon] -> [TyCon] -> [TyCon]
forall a. [a] -> [a] -> [a]
++ [TyCon]
exposedPrimTyCons
unexposedPrimTyCons :: [TyCon]
unexposedPrimTyCons :: [TyCon]
unexposedPrimTyCons
= [ TyCon
eqPrimTyCon
, TyCon
eqReprPrimTyCon
, TyCon
eqPhantPrimTyCon
]
exposedPrimTyCons :: [TyCon]
exposedPrimTyCons :: [TyCon]
exposedPrimTyCons
= [ TyCon
addrPrimTyCon
, TyCon
arrayPrimTyCon
, TyCon
byteArrayPrimTyCon
, TyCon
arrayArrayPrimTyCon
, TyCon
smallArrayPrimTyCon
, TyCon
charPrimTyCon
, TyCon
doublePrimTyCon
, TyCon
floatPrimTyCon
, TyCon
intPrimTyCon
, TyCon
int8PrimTyCon
, TyCon
int16PrimTyCon
, TyCon
int32PrimTyCon
, TyCon
int64PrimTyCon
, TyCon
bcoPrimTyCon
, TyCon
weakPrimTyCon
, TyCon
mutableArrayPrimTyCon
, TyCon
mutableByteArrayPrimTyCon
, TyCon
mutableArrayArrayPrimTyCon
, TyCon
smallMutableArrayPrimTyCon
, TyCon
mVarPrimTyCon
, TyCon
tVarPrimTyCon
, TyCon
mutVarPrimTyCon
, TyCon
realWorldTyCon
, TyCon
stablePtrPrimTyCon
, TyCon
stableNamePrimTyCon
, TyCon
compactPrimTyCon
, TyCon
statePrimTyCon
, TyCon
voidPrimTyCon
, TyCon
proxyPrimTyCon
, TyCon
threadIdPrimTyCon
, TyCon
wordPrimTyCon
, TyCon
word8PrimTyCon
, TyCon
word16PrimTyCon
, TyCon
word32PrimTyCon
, TyCon
word64PrimTyCon
, TyCon
tYPETyCon
#include "primop-vector-tycons.hs-incl"
]
mkPrimTc :: FastString -> Unique -> TyCon -> Name
mkPrimTc :: FastString -> Unique -> TyCon -> Name
mkPrimTc FastString
fs Unique
unique TyCon
tycon
= Module -> OccName -> Unique -> TyThing -> BuiltInSyntax -> Name
mkWiredInName Module
gHC_PRIM (FastString -> OccName
mkTcOccFS FastString
fs)
Unique
unique
(TyCon -> TyThing
ATyCon TyCon
tycon)
BuiltInSyntax
UserSyntax
mkBuiltInPrimTc :: FastString -> Unique -> TyCon -> Name
mkBuiltInPrimTc :: FastString -> Unique -> TyCon -> Name
mkBuiltInPrimTc FastString
fs Unique
unique TyCon
tycon
= Module -> OccName -> Unique -> TyThing -> BuiltInSyntax -> Name
mkWiredInName Module
gHC_PRIM (FastString -> OccName
mkTcOccFS FastString
fs)
Unique
unique
(TyCon -> TyThing
ATyCon TyCon
tycon)
BuiltInSyntax
BuiltInSyntax
charPrimTyConName, intPrimTyConName, int8PrimTyConName, int16PrimTyConName, int32PrimTyConName, int64PrimTyConName, wordPrimTyConName, word32PrimTyConName, word8PrimTyConName, word16PrimTyConName, word64PrimTyConName, addrPrimTyConName, floatPrimTyConName, doublePrimTyConName, statePrimTyConName, proxyPrimTyConName, realWorldTyConName, arrayPrimTyConName, arrayArrayPrimTyConName, smallArrayPrimTyConName, byteArrayPrimTyConName, mutableArrayPrimTyConName, mutableByteArrayPrimTyConName, mutableArrayArrayPrimTyConName, smallMutableArrayPrimTyConName, mutVarPrimTyConName, mVarPrimTyConName, tVarPrimTyConName, stablePtrPrimTyConName, stableNamePrimTyConName, compactPrimTyConName, bcoPrimTyConName, weakPrimTyConName, threadIdPrimTyConName, eqPrimTyConName, eqReprPrimTyConName, eqPhantPrimTyConName, voidPrimTyConName :: Name
charPrimTyConName :: Name
charPrimTyConName = FastString -> Unique -> TyCon -> Name
mkPrimTc (String -> FastString
fsLit String
"Char#") Unique
charPrimTyConKey TyCon
charPrimTyCon
intPrimTyConName :: Name
intPrimTyConName = FastString -> Unique -> TyCon -> Name
mkPrimTc (String -> FastString
fsLit String
"Int#") Unique
intPrimTyConKey TyCon
intPrimTyCon
int8PrimTyConName :: Name
int8PrimTyConName = FastString -> Unique -> TyCon -> Name
mkPrimTc (String -> FastString
fsLit String
"Int8#") Unique
int8PrimTyConKey TyCon
int8PrimTyCon
int16PrimTyConName :: Name
int16PrimTyConName = FastString -> Unique -> TyCon -> Name
mkPrimTc (String -> FastString
fsLit String
"Int16#") Unique
int16PrimTyConKey TyCon
int16PrimTyCon
int32PrimTyConName :: Name
int32PrimTyConName = FastString -> Unique -> TyCon -> Name
mkPrimTc (String -> FastString
fsLit String
"Int32#") Unique
int32PrimTyConKey TyCon
int32PrimTyCon
int64PrimTyConName :: Name
int64PrimTyConName = FastString -> Unique -> TyCon -> Name
mkPrimTc (String -> FastString
fsLit String
"Int64#") Unique
int64PrimTyConKey TyCon
int64PrimTyCon
wordPrimTyConName :: Name
wordPrimTyConName = FastString -> Unique -> TyCon -> Name
mkPrimTc (String -> FastString
fsLit String
"Word#") Unique
wordPrimTyConKey TyCon
wordPrimTyCon
word8PrimTyConName :: Name
word8PrimTyConName = FastString -> Unique -> TyCon -> Name
mkPrimTc (String -> FastString
fsLit String
"Word8#") Unique
word8PrimTyConKey TyCon
word8PrimTyCon
word16PrimTyConName :: Name
word16PrimTyConName = FastString -> Unique -> TyCon -> Name
mkPrimTc (String -> FastString
fsLit String
"Word16#") Unique
word16PrimTyConKey TyCon
word16PrimTyCon
word32PrimTyConName :: Name
word32PrimTyConName = FastString -> Unique -> TyCon -> Name
mkPrimTc (String -> FastString
fsLit String
"Word32#") Unique
word32PrimTyConKey TyCon
word32PrimTyCon
word64PrimTyConName :: Name
word64PrimTyConName = FastString -> Unique -> TyCon -> Name
mkPrimTc (String -> FastString
fsLit String
"Word64#") Unique
word64PrimTyConKey TyCon
word64PrimTyCon
addrPrimTyConName :: Name
addrPrimTyConName = FastString -> Unique -> TyCon -> Name
mkPrimTc (String -> FastString
fsLit String
"Addr#") Unique
addrPrimTyConKey TyCon
addrPrimTyCon
floatPrimTyConName :: Name
floatPrimTyConName = FastString -> Unique -> TyCon -> Name
mkPrimTc (String -> FastString
fsLit String
"Float#") Unique
floatPrimTyConKey TyCon
floatPrimTyCon
doublePrimTyConName :: Name
doublePrimTyConName = FastString -> Unique -> TyCon -> Name
mkPrimTc (String -> FastString
fsLit String
"Double#") Unique
doublePrimTyConKey TyCon
doublePrimTyCon
statePrimTyConName :: Name
statePrimTyConName = FastString -> Unique -> TyCon -> Name
mkPrimTc (String -> FastString
fsLit String
"State#") Unique
statePrimTyConKey TyCon
statePrimTyCon
voidPrimTyConName :: Name
voidPrimTyConName = FastString -> Unique -> TyCon -> Name
mkPrimTc (String -> FastString
fsLit String
"Void#") Unique
voidPrimTyConKey TyCon
voidPrimTyCon
proxyPrimTyConName :: Name
proxyPrimTyConName = FastString -> Unique -> TyCon -> Name
mkPrimTc (String -> FastString
fsLit String
"Proxy#") Unique
proxyPrimTyConKey TyCon
proxyPrimTyCon
eqPrimTyConName :: Name
eqPrimTyConName = FastString -> Unique -> TyCon -> Name
mkPrimTc (String -> FastString
fsLit String
"~#") Unique
eqPrimTyConKey TyCon
eqPrimTyCon
eqReprPrimTyConName :: Name
eqReprPrimTyConName = FastString -> Unique -> TyCon -> Name
mkBuiltInPrimTc (String -> FastString
fsLit String
"~R#") Unique
eqReprPrimTyConKey TyCon
eqReprPrimTyCon
eqPhantPrimTyConName :: Name
eqPhantPrimTyConName = FastString -> Unique -> TyCon -> Name
mkBuiltInPrimTc (String -> FastString
fsLit String
"~P#") Unique
eqPhantPrimTyConKey TyCon
eqPhantPrimTyCon
realWorldTyConName :: Name
realWorldTyConName = FastString -> Unique -> TyCon -> Name
mkPrimTc (String -> FastString
fsLit String
"RealWorld") Unique
realWorldTyConKey TyCon
realWorldTyCon
arrayPrimTyConName :: Name
arrayPrimTyConName = FastString -> Unique -> TyCon -> Name
mkPrimTc (String -> FastString
fsLit String
"Array#") Unique
arrayPrimTyConKey TyCon
arrayPrimTyCon
byteArrayPrimTyConName :: Name
byteArrayPrimTyConName = FastString -> Unique -> TyCon -> Name
mkPrimTc (String -> FastString
fsLit String
"ByteArray#") Unique
byteArrayPrimTyConKey TyCon
byteArrayPrimTyCon
arrayArrayPrimTyConName :: Name
arrayArrayPrimTyConName = FastString -> Unique -> TyCon -> Name
mkPrimTc (String -> FastString
fsLit String
"ArrayArray#") Unique
arrayArrayPrimTyConKey TyCon
arrayArrayPrimTyCon
smallArrayPrimTyConName :: Name
smallArrayPrimTyConName = FastString -> Unique -> TyCon -> Name
mkPrimTc (String -> FastString
fsLit String
"SmallArray#") Unique
smallArrayPrimTyConKey TyCon
smallArrayPrimTyCon
mutableArrayPrimTyConName :: Name
mutableArrayPrimTyConName = FastString -> Unique -> TyCon -> Name
mkPrimTc (String -> FastString
fsLit String
"MutableArray#") Unique
mutableArrayPrimTyConKey TyCon
mutableArrayPrimTyCon
mutableByteArrayPrimTyConName :: Name
mutableByteArrayPrimTyConName = FastString -> Unique -> TyCon -> Name
mkPrimTc (String -> FastString
fsLit String
"MutableByteArray#") Unique
mutableByteArrayPrimTyConKey TyCon
mutableByteArrayPrimTyCon
mutableArrayArrayPrimTyConName :: Name
mutableArrayArrayPrimTyConName= FastString -> Unique -> TyCon -> Name
mkPrimTc (String -> FastString
fsLit String
"MutableArrayArray#") Unique
mutableArrayArrayPrimTyConKey TyCon
mutableArrayArrayPrimTyCon
smallMutableArrayPrimTyConName :: Name
smallMutableArrayPrimTyConName= FastString -> Unique -> TyCon -> Name
mkPrimTc (String -> FastString
fsLit String
"SmallMutableArray#") Unique
smallMutableArrayPrimTyConKey TyCon
smallMutableArrayPrimTyCon
mutVarPrimTyConName :: Name
mutVarPrimTyConName = FastString -> Unique -> TyCon -> Name
mkPrimTc (String -> FastString
fsLit String
"MutVar#") Unique
mutVarPrimTyConKey TyCon
mutVarPrimTyCon
mVarPrimTyConName :: Name
mVarPrimTyConName = FastString -> Unique -> TyCon -> Name
mkPrimTc (String -> FastString
fsLit String
"MVar#") Unique
mVarPrimTyConKey TyCon
mVarPrimTyCon
tVarPrimTyConName :: Name
tVarPrimTyConName = FastString -> Unique -> TyCon -> Name
mkPrimTc (String -> FastString
fsLit String
"TVar#") Unique
tVarPrimTyConKey TyCon
tVarPrimTyCon
stablePtrPrimTyConName :: Name
stablePtrPrimTyConName = FastString -> Unique -> TyCon -> Name
mkPrimTc (String -> FastString
fsLit String
"StablePtr#") Unique
stablePtrPrimTyConKey TyCon
stablePtrPrimTyCon
stableNamePrimTyConName :: Name
stableNamePrimTyConName = FastString -> Unique -> TyCon -> Name
mkPrimTc (String -> FastString
fsLit String
"StableName#") Unique
stableNamePrimTyConKey TyCon
stableNamePrimTyCon
compactPrimTyConName :: Name
compactPrimTyConName = FastString -> Unique -> TyCon -> Name
mkPrimTc (String -> FastString
fsLit String
"Compact#") Unique
compactPrimTyConKey TyCon
compactPrimTyCon
bcoPrimTyConName :: Name
bcoPrimTyConName = FastString -> Unique -> TyCon -> Name
mkPrimTc (String -> FastString
fsLit String
"BCO#") Unique
bcoPrimTyConKey TyCon
bcoPrimTyCon
weakPrimTyConName :: Name
weakPrimTyConName = FastString -> Unique -> TyCon -> Name
mkPrimTc (String -> FastString
fsLit String
"Weak#") Unique
weakPrimTyConKey TyCon
weakPrimTyCon
threadIdPrimTyConName :: Name
threadIdPrimTyConName = FastString -> Unique -> TyCon -> Name
mkPrimTc (String -> FastString
fsLit String
"ThreadId#") Unique
threadIdPrimTyConKey TyCon
threadIdPrimTyCon
mkTemplateKindVar :: Kind -> TyVar
mkTemplateKindVar :: Kind -> TyVar
mkTemplateKindVar = Name -> Kind -> TyVar
mkTyVar (Int -> String -> Name
mk_tv_name Int
0 String
"k")
mkTemplateKindVars :: [Kind] -> [TyVar]
mkTemplateKindVars :: [Kind] -> [TyVar]
mkTemplateKindVars [Kind
kind] = [Kind -> TyVar
mkTemplateKindVar Kind
kind]
mkTemplateKindVars [Kind]
kinds
= [ Name -> Kind -> TyVar
mkTyVar (Int -> String -> Name
mk_tv_name Int
u (Char
'k' Char -> String -> String
forall a. a -> [a] -> [a]
: Int -> String
forall a. Show a => a -> String
show Int
u)) Kind
kind
| (Kind
kind, Int
u) <- [Kind]
kinds [Kind] -> [Int] -> [(Kind, Int)]
forall a b. [a] -> [b] -> [(a, b)]
`zip` [Int
0..] ]
mk_tv_name :: Int -> String -> Name
mk_tv_name :: Int -> String -> Name
mk_tv_name Int
u String
s = Unique -> OccName -> SrcSpan -> Name
mkInternalName (Int -> Unique
mkAlphaTyVarUnique Int
u)
(FastString -> OccName
mkTyVarOccFS (String -> FastString
mkFastString String
s))
SrcSpan
noSrcSpan
mkTemplateTyVarsFrom :: Int -> [Kind] -> [TyVar]
mkTemplateTyVarsFrom :: Int -> [Kind] -> [TyVar]
mkTemplateTyVarsFrom Int
n [Kind]
kinds
= [ Name -> Kind -> TyVar
mkTyVar Name
name Kind
kind
| (Kind
kind, Int
index) <- [Kind] -> [Int] -> [(Kind, Int)]
forall a b. [a] -> [b] -> [(a, b)]
zip [Kind]
kinds [Int
0..],
let ch_ord :: Int
ch_ord = Int
index Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Char -> Int
ord Char
'a'
name_str :: String
name_str | Int
ch_ord Int -> Int -> Bool
forall a. Ord a => a -> a -> Bool
<= Char -> Int
ord Char
'z' = [Int -> Char
chr Int
ch_ord]
| Bool
otherwise = Char
't'Char -> String -> String
forall a. a -> [a] -> [a]
:Int -> String
forall a. Show a => a -> String
show Int
index
name :: Name
name = Int -> String -> Name
mk_tv_name (Int
index Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Int
n) String
name_str
]
mkTemplateTyVars :: [Kind] -> [TyVar]
mkTemplateTyVars :: [Kind] -> [TyVar]
mkTemplateTyVars = Int -> [Kind] -> [TyVar]
mkTemplateTyVarsFrom Int
1
mkTemplateTyConBinders
:: [Kind]
-> ([Kind] -> [Kind])
-> [TyConBinder]
mkTemplateTyConBinders :: [Kind] -> ([Kind] -> [Kind]) -> [TyConBinder]
mkTemplateTyConBinders [Kind]
kind_var_kinds [Kind] -> [Kind]
mk_anon_arg_kinds
= [TyConBinder]
kv_bndrs [TyConBinder] -> [TyConBinder] -> [TyConBinder]
forall a. [a] -> [a] -> [a]
++ [TyConBinder]
tv_bndrs
where
kv_bndrs :: [TyConBinder]
kv_bndrs = [Kind] -> [TyConBinder]
mkTemplateKindTyConBinders [Kind]
kind_var_kinds
anon_kinds :: [Kind]
anon_kinds = [Kind] -> [Kind]
mk_anon_arg_kinds ([TyVar] -> [Kind]
mkTyVarTys ([TyConBinder] -> [TyVar]
forall tv argf. [VarBndr tv argf] -> [tv]
binderVars [TyConBinder]
kv_bndrs))
tv_bndrs :: [TyConBinder]
tv_bndrs = Int -> [Kind] -> [TyConBinder]
mkTemplateAnonTyConBindersFrom ([TyConBinder] -> Int
forall (t :: * -> *) a. Foldable t => t a -> Int
length [TyConBinder]
kv_bndrs) [Kind]
anon_kinds
mkTemplateKiTyVars
:: [Kind]
-> ([Kind] -> [Kind])
-> [TyVar]
mkTemplateKiTyVars :: [Kind] -> ([Kind] -> [Kind]) -> [TyVar]
mkTemplateKiTyVars [Kind]
kind_var_kinds [Kind] -> [Kind]
mk_arg_kinds
= [TyVar]
kv_bndrs [TyVar] -> [TyVar] -> [TyVar]
forall a. [a] -> [a] -> [a]
++ [TyVar]
tv_bndrs
where
kv_bndrs :: [TyVar]
kv_bndrs = [Kind] -> [TyVar]
mkTemplateKindVars [Kind]
kind_var_kinds
anon_kinds :: [Kind]
anon_kinds = [Kind] -> [Kind]
mk_arg_kinds ([TyVar] -> [Kind]
mkTyVarTys [TyVar]
kv_bndrs)
tv_bndrs :: [TyVar]
tv_bndrs = Int -> [Kind] -> [TyVar]
mkTemplateTyVarsFrom ([TyVar] -> Int
forall (t :: * -> *) a. Foldable t => t a -> Int
length [TyVar]
kv_bndrs) [Kind]
anon_kinds
mkTemplateKiTyVar
:: Kind
-> (Kind -> [Kind])
-> [TyVar]
mkTemplateKiTyVar :: Kind -> (Kind -> [Kind]) -> [TyVar]
mkTemplateKiTyVar Kind
kind Kind -> [Kind]
mk_arg_kinds
= TyVar
kv_bndr TyVar -> [TyVar] -> [TyVar]
forall a. a -> [a] -> [a]
: [TyVar]
tv_bndrs
where
kv_bndr :: TyVar
kv_bndr = Kind -> TyVar
mkTemplateKindVar Kind
kind
anon_kinds :: [Kind]
anon_kinds = Kind -> [Kind]
mk_arg_kinds (TyVar -> Kind
mkTyVarTy TyVar
kv_bndr)
tv_bndrs :: [TyVar]
tv_bndrs = Int -> [Kind] -> [TyVar]
mkTemplateTyVarsFrom Int
1 [Kind]
anon_kinds
mkTemplateKindTyConBinders :: [Kind] -> [TyConBinder]
mkTemplateKindTyConBinders :: [Kind] -> [TyConBinder]
mkTemplateKindTyConBinders [Kind]
kinds = [ArgFlag -> TyVar -> TyConBinder
mkNamedTyConBinder ArgFlag
Specified TyVar
tv | TyVar
tv <- [Kind] -> [TyVar]
mkTemplateKindVars [Kind]
kinds]
mkTemplateAnonTyConBinders :: [Kind] -> [TyConBinder]
mkTemplateAnonTyConBinders :: [Kind] -> [TyConBinder]
mkTemplateAnonTyConBinders [Kind]
kinds = AnonArgFlag -> [TyVar] -> [TyConBinder]
mkAnonTyConBinders AnonArgFlag
VisArg ([Kind] -> [TyVar]
mkTemplateTyVars [Kind]
kinds)
mkTemplateAnonTyConBindersFrom :: Int -> [Kind] -> [TyConBinder]
mkTemplateAnonTyConBindersFrom :: Int -> [Kind] -> [TyConBinder]
mkTemplateAnonTyConBindersFrom Int
n [Kind]
kinds = AnonArgFlag -> [TyVar] -> [TyConBinder]
mkAnonTyConBinders AnonArgFlag
VisArg (Int -> [Kind] -> [TyVar]
mkTemplateTyVarsFrom Int
n [Kind]
kinds)
alphaTyVars :: [TyVar]
alphaTyVars :: [TyVar]
alphaTyVars = [Kind] -> [TyVar]
mkTemplateTyVars ([Kind] -> [TyVar]) -> [Kind] -> [TyVar]
forall a b. (a -> b) -> a -> b
$ Kind -> [Kind]
forall a. a -> [a]
repeat Kind
liftedTypeKind
alphaTyVar, betaTyVar, gammaTyVar, deltaTyVar :: TyVar
(TyVar
alphaTyVar:TyVar
betaTyVar:TyVar
gammaTyVar:TyVar
deltaTyVar:[TyVar]
_) = [TyVar]
alphaTyVars
alphaTys :: [Type]
alphaTys :: [Kind]
alphaTys = [TyVar] -> [Kind]
mkTyVarTys [TyVar]
alphaTyVars
alphaTy, betaTy, gammaTy, deltaTy :: Type
(Kind
alphaTy:Kind
betaTy:Kind
gammaTy:Kind
deltaTy:[Kind]
_) = [Kind]
alphaTys
alphaTyVarsUnliftedRep :: [TyVar]
alphaTyVarsUnliftedRep :: [TyVar]
alphaTyVarsUnliftedRep = [Kind] -> [TyVar]
mkTemplateTyVars ([Kind] -> [TyVar]) -> [Kind] -> [TyVar]
forall a b. (a -> b) -> a -> b
$ Kind -> [Kind]
forall a. a -> [a]
repeat (Kind -> Kind
tYPE Kind
unliftedRepDataConTy)
alphaTyVarUnliftedRep :: TyVar
(TyVar
alphaTyVarUnliftedRep:[TyVar]
_) = [TyVar]
alphaTyVarsUnliftedRep
alphaTysUnliftedRep :: [Type]
alphaTysUnliftedRep :: [Kind]
alphaTysUnliftedRep = [TyVar] -> [Kind]
mkTyVarTys [TyVar]
alphaTyVarsUnliftedRep
alphaTyUnliftedRep :: Type
(Kind
alphaTyUnliftedRep:[Kind]
_) = [Kind]
alphaTysUnliftedRep
runtimeRep1TyVar, runtimeRep2TyVar :: TyVar
(TyVar
runtimeRep1TyVar : TyVar
runtimeRep2TyVar : [TyVar]
_)
= Int -> [TyVar] -> [TyVar]
forall a. Int -> [a] -> [a]
drop Int
16 ([Kind] -> [TyVar]
mkTemplateTyVars (Kind -> [Kind]
forall a. a -> [a]
repeat Kind
runtimeRepTy))
runtimeRep1Ty, runtimeRep2Ty :: Type
runtimeRep1Ty :: Kind
runtimeRep1Ty = TyVar -> Kind
mkTyVarTy TyVar
runtimeRep1TyVar
runtimeRep2Ty :: Kind
runtimeRep2Ty = TyVar -> Kind
mkTyVarTy TyVar
runtimeRep2TyVar
openAlphaTyVar, openBetaTyVar :: TyVar
[TyVar
openAlphaTyVar,TyVar
openBetaTyVar]
= [Kind] -> [TyVar]
mkTemplateTyVars [Kind -> Kind
tYPE Kind
runtimeRep1Ty, Kind -> Kind
tYPE Kind
runtimeRep2Ty]
openAlphaTy, openBetaTy :: Type
openAlphaTy :: Kind
openAlphaTy = TyVar -> Kind
mkTyVarTy TyVar
openAlphaTyVar
openBetaTy :: Kind
openBetaTy = TyVar -> Kind
mkTyVarTy TyVar
openBetaTyVar
funTyConName :: Name
funTyConName :: Name
funTyConName = FastString -> Unique -> TyCon -> Name
mkPrimTyConName (String -> FastString
fsLit String
"->") Unique
funTyConKey TyCon
funTyCon
funTyCon :: TyCon
funTyCon :: TyCon
funTyCon = Name -> [TyConBinder] -> Name -> TyCon
mkFunTyCon Name
funTyConName [TyConBinder]
tc_bndrs Name
tc_rep_nm
where
tc_bndrs :: [TyConBinder]
tc_bndrs = [ ArgFlag -> TyVar -> TyConBinder
mkNamedTyConBinder ArgFlag
Inferred TyVar
runtimeRep1TyVar
, ArgFlag -> TyVar -> TyConBinder
mkNamedTyConBinder ArgFlag
Inferred TyVar
runtimeRep2TyVar ]
[TyConBinder] -> [TyConBinder] -> [TyConBinder]
forall a. [a] -> [a] -> [a]
++ [Kind] -> [TyConBinder]
mkTemplateAnonTyConBinders [ Kind -> Kind
tYPE Kind
runtimeRep1Ty
, Kind -> Kind
tYPE Kind
runtimeRep2Ty
]
tc_rep_nm :: Name
tc_rep_nm = Name -> Name
mkPrelTyConRepName Name
funTyConName
tYPETyCon :: TyCon
tYPETyConName :: Name
tYPETyCon :: TyCon
tYPETyCon = Name -> [TyConBinder] -> Kind -> [Role] -> Name -> TyCon
mkKindTyCon Name
tYPETyConName
([Kind] -> [TyConBinder]
mkTemplateAnonTyConBinders [Kind
runtimeRepTy])
Kind
liftedTypeKind
[Role
Nominal]
(Name -> Name
mkPrelTyConRepName Name
tYPETyConName)
tYPETyConName :: Name
tYPETyConName = FastString -> Unique -> TyCon -> Name
mkPrimTyConName (String -> FastString
fsLit String
"TYPE") Unique
tYPETyConKey TyCon
tYPETyCon
mkPrimTyConName :: FastString -> Unique -> TyCon -> Name
mkPrimTyConName :: FastString -> Unique -> TyCon -> Name
mkPrimTyConName = BuiltInSyntax -> FastString -> Unique -> TyCon -> Name
mkPrimTcName BuiltInSyntax
BuiltInSyntax
mkPrimTcName :: BuiltInSyntax -> FastString -> Unique -> TyCon -> Name
mkPrimTcName :: BuiltInSyntax -> FastString -> Unique -> TyCon -> Name
mkPrimTcName BuiltInSyntax
built_in_syntax FastString
occ Unique
key TyCon
tycon
= Module -> OccName -> Unique -> TyThing -> BuiltInSyntax -> Name
mkWiredInName Module
gHC_PRIM (FastString -> OccName
mkTcOccFS FastString
occ) Unique
key (TyCon -> TyThing
ATyCon TyCon
tycon) BuiltInSyntax
built_in_syntax
tYPE :: Type -> Type
tYPE :: Kind -> Kind
tYPE Kind
rr = TyCon -> [Kind] -> Kind
TyConApp TyCon
tYPETyCon [Kind
rr]
pcPrimTyCon :: Name -> [Role] -> PrimRep -> TyCon
pcPrimTyCon :: Name -> [Role] -> PrimRep -> TyCon
pcPrimTyCon Name
name [Role]
roles PrimRep
rep
= Name -> [TyConBinder] -> Kind -> [Role] -> TyCon
mkPrimTyCon Name
name [TyConBinder]
binders Kind
result_kind [Role]
roles
where
binders :: [TyConBinder]
binders = [Kind] -> [TyConBinder]
mkTemplateAnonTyConBinders ((Role -> Kind) -> [Role] -> [Kind]
forall a b. (a -> b) -> [a] -> [b]
map (Kind -> Role -> Kind
forall a b. a -> b -> a
const Kind
liftedTypeKind) [Role]
roles)
result_kind :: Kind
result_kind = Kind -> Kind
tYPE (PrimRep -> Kind
primRepToRuntimeRep PrimRep
rep)
primRepToRuntimeRep :: PrimRep -> Type
primRepToRuntimeRep :: PrimRep -> Kind
primRepToRuntimeRep PrimRep
rep = case PrimRep
rep of
PrimRep
VoidRep -> TyCon -> [Kind] -> Kind
TyConApp TyCon
tupleRepDataConTyCon [Kind -> [Kind] -> Kind
mkPromotedListTy Kind
runtimeRepTy []]
PrimRep
LiftedRep -> Kind
liftedRepDataConTy
PrimRep
UnliftedRep -> Kind
unliftedRepDataConTy
PrimRep
IntRep -> Kind
intRepDataConTy
PrimRep
Int8Rep -> Kind
int8RepDataConTy
PrimRep
Int16Rep -> Kind
int16RepDataConTy
PrimRep
Int32Rep -> Kind
int32RepDataConTy
PrimRep
Int64Rep -> Kind
int64RepDataConTy
PrimRep
WordRep -> Kind
wordRepDataConTy
PrimRep
Word8Rep -> Kind
word8RepDataConTy
PrimRep
Word16Rep -> Kind
word16RepDataConTy
PrimRep
Word32Rep -> Kind
word32RepDataConTy
PrimRep
Word64Rep -> Kind
word64RepDataConTy
PrimRep
AddrRep -> Kind
addrRepDataConTy
PrimRep
FloatRep -> Kind
floatRepDataConTy
PrimRep
DoubleRep -> Kind
doubleRepDataConTy
VecRep Int
n PrimElemRep
elem -> TyCon -> [Kind] -> Kind
TyConApp TyCon
vecRepDataConTyCon [Kind
n', Kind
elem']
where
n' :: Kind
n' = case Int
n of
Int
2 -> Kind
vec2DataConTy
Int
4 -> Kind
vec4DataConTy
Int
8 -> Kind
vec8DataConTy
Int
16 -> Kind
vec16DataConTy
Int
32 -> Kind
vec32DataConTy
Int
64 -> Kind
vec64DataConTy
Int
_ -> String -> SDoc -> Kind
forall a. HasCallStack => String -> SDoc -> a
pprPanic String
"Disallowed VecCount" (Int -> SDoc
forall a. Outputable a => a -> SDoc
ppr Int
n)
elem' :: Kind
elem' = case PrimElemRep
elem of
PrimElemRep
Int8ElemRep -> Kind
int8ElemRepDataConTy
PrimElemRep
Int16ElemRep -> Kind
int16ElemRepDataConTy
PrimElemRep
Int32ElemRep -> Kind
int32ElemRepDataConTy
PrimElemRep
Int64ElemRep -> Kind
int64ElemRepDataConTy
PrimElemRep
Word8ElemRep -> Kind
word8ElemRepDataConTy
PrimElemRep
Word16ElemRep -> Kind
word16ElemRepDataConTy
PrimElemRep
Word32ElemRep -> Kind
word32ElemRepDataConTy
PrimElemRep
Word64ElemRep -> Kind
word64ElemRepDataConTy
PrimElemRep
FloatElemRep -> Kind
floatElemRepDataConTy
PrimElemRep
DoubleElemRep -> Kind
doubleElemRepDataConTy
pcPrimTyCon0 :: Name -> PrimRep -> TyCon
pcPrimTyCon0 :: Name -> PrimRep -> TyCon
pcPrimTyCon0 Name
name PrimRep
rep
= Name -> [Role] -> PrimRep -> TyCon
pcPrimTyCon Name
name [] PrimRep
rep
charPrimTy :: Type
charPrimTy :: Kind
charPrimTy = TyCon -> Kind
mkTyConTy TyCon
charPrimTyCon
charPrimTyCon :: TyCon
charPrimTyCon :: TyCon
charPrimTyCon = Name -> PrimRep -> TyCon
pcPrimTyCon0 Name
charPrimTyConName PrimRep
WordRep
intPrimTy :: Type
intPrimTy :: Kind
intPrimTy = TyCon -> Kind
mkTyConTy TyCon
intPrimTyCon
intPrimTyCon :: TyCon
intPrimTyCon :: TyCon
intPrimTyCon = Name -> PrimRep -> TyCon
pcPrimTyCon0 Name
intPrimTyConName PrimRep
IntRep
int8PrimTy :: Type
int8PrimTy :: Kind
int8PrimTy = TyCon -> Kind
mkTyConTy TyCon
int8PrimTyCon
int8PrimTyCon :: TyCon
int8PrimTyCon :: TyCon
int8PrimTyCon = Name -> PrimRep -> TyCon
pcPrimTyCon0 Name
int8PrimTyConName PrimRep
Int8Rep
int16PrimTy :: Type
int16PrimTy :: Kind
int16PrimTy = TyCon -> Kind
mkTyConTy TyCon
int16PrimTyCon
int16PrimTyCon :: TyCon
int16PrimTyCon :: TyCon
int16PrimTyCon = Name -> PrimRep -> TyCon
pcPrimTyCon0 Name
int16PrimTyConName PrimRep
Int16Rep
int32PrimTy :: Type
int32PrimTy :: Kind
int32PrimTy = TyCon -> Kind
mkTyConTy TyCon
int32PrimTyCon
int32PrimTyCon :: TyCon
int32PrimTyCon :: TyCon
int32PrimTyCon = Name -> PrimRep -> TyCon
pcPrimTyCon0 Name
int32PrimTyConName PrimRep
Int32Rep
int64PrimTy :: Type
int64PrimTy :: Kind
int64PrimTy = TyCon -> Kind
mkTyConTy TyCon
int64PrimTyCon
int64PrimTyCon :: TyCon
int64PrimTyCon :: TyCon
int64PrimTyCon = Name -> PrimRep -> TyCon
pcPrimTyCon0 Name
int64PrimTyConName PrimRep
Int64Rep
wordPrimTy :: Type
wordPrimTy :: Kind
wordPrimTy = TyCon -> Kind
mkTyConTy TyCon
wordPrimTyCon
wordPrimTyCon :: TyCon
wordPrimTyCon :: TyCon
wordPrimTyCon = Name -> PrimRep -> TyCon
pcPrimTyCon0 Name
wordPrimTyConName PrimRep
WordRep
word8PrimTy :: Type
word8PrimTy :: Kind
word8PrimTy = TyCon -> Kind
mkTyConTy TyCon
word8PrimTyCon
word8PrimTyCon :: TyCon
word8PrimTyCon :: TyCon
word8PrimTyCon = Name -> PrimRep -> TyCon
pcPrimTyCon0 Name
word8PrimTyConName PrimRep
Word8Rep
word16PrimTy :: Type
word16PrimTy :: Kind
word16PrimTy = TyCon -> Kind
mkTyConTy TyCon
word16PrimTyCon
word16PrimTyCon :: TyCon
word16PrimTyCon :: TyCon
word16PrimTyCon = Name -> PrimRep -> TyCon
pcPrimTyCon0 Name
word16PrimTyConName PrimRep
Word16Rep
word32PrimTy :: Type
word32PrimTy :: Kind
word32PrimTy = TyCon -> Kind
mkTyConTy TyCon
word32PrimTyCon
word32PrimTyCon :: TyCon
word32PrimTyCon :: TyCon
word32PrimTyCon = Name -> PrimRep -> TyCon
pcPrimTyCon0 Name
word32PrimTyConName PrimRep
Word32Rep
word64PrimTy :: Type
word64PrimTy :: Kind
word64PrimTy = TyCon -> Kind
mkTyConTy TyCon
word64PrimTyCon
word64PrimTyCon :: TyCon
word64PrimTyCon :: TyCon
word64PrimTyCon = Name -> PrimRep -> TyCon
pcPrimTyCon0 Name
word64PrimTyConName PrimRep
Word64Rep
addrPrimTy :: Type
addrPrimTy :: Kind
addrPrimTy = TyCon -> Kind
mkTyConTy TyCon
addrPrimTyCon
addrPrimTyCon :: TyCon
addrPrimTyCon :: TyCon
addrPrimTyCon = Name -> PrimRep -> TyCon
pcPrimTyCon0 Name
addrPrimTyConName PrimRep
AddrRep
floatPrimTy :: Type
floatPrimTy :: Kind
floatPrimTy = TyCon -> Kind
mkTyConTy TyCon
floatPrimTyCon
floatPrimTyCon :: TyCon
floatPrimTyCon :: TyCon
floatPrimTyCon = Name -> PrimRep -> TyCon
pcPrimTyCon0 Name
floatPrimTyConName PrimRep
FloatRep
doublePrimTy :: Type
doublePrimTy :: Kind
doublePrimTy = TyCon -> Kind
mkTyConTy TyCon
doublePrimTyCon
doublePrimTyCon :: TyCon
doublePrimTyCon :: TyCon
doublePrimTyCon = Name -> PrimRep -> TyCon
pcPrimTyCon0 Name
doublePrimTyConName PrimRep
DoubleRep
mkStatePrimTy :: Type -> Type
mkStatePrimTy :: Kind -> Kind
mkStatePrimTy Kind
ty = TyCon -> [Kind] -> Kind
TyConApp TyCon
statePrimTyCon [Kind
ty]
statePrimTyCon :: TyCon
statePrimTyCon :: TyCon
statePrimTyCon = Name -> [Role] -> PrimRep -> TyCon
pcPrimTyCon Name
statePrimTyConName [Role
Nominal] PrimRep
VoidRep
realWorldTyCon :: TyCon
realWorldTyCon :: TyCon
realWorldTyCon = Name -> [TyConBinder] -> Kind -> [Role] -> TyCon
mkLiftedPrimTyCon Name
realWorldTyConName [] Kind
liftedTypeKind []
realWorldTy :: Type
realWorldTy :: Kind
realWorldTy = TyCon -> Kind
mkTyConTy TyCon
realWorldTyCon
realWorldStatePrimTy :: Type
realWorldStatePrimTy :: Kind
realWorldStatePrimTy = Kind -> Kind
mkStatePrimTy Kind
realWorldTy
voidPrimTy :: Type
voidPrimTy :: Kind
voidPrimTy = TyCon -> [Kind] -> Kind
TyConApp TyCon
voidPrimTyCon []
voidPrimTyCon :: TyCon
voidPrimTyCon :: TyCon
voidPrimTyCon = Name -> [Role] -> PrimRep -> TyCon
pcPrimTyCon Name
voidPrimTyConName [] PrimRep
VoidRep
mkProxyPrimTy :: Type -> Type -> Type
mkProxyPrimTy :: Kind -> Kind -> Kind
mkProxyPrimTy Kind
k Kind
ty = TyCon -> [Kind] -> Kind
TyConApp TyCon
proxyPrimTyCon [Kind
k, Kind
ty]
proxyPrimTyCon :: TyCon
proxyPrimTyCon :: TyCon
proxyPrimTyCon = Name -> [TyConBinder] -> Kind -> [Role] -> TyCon
mkPrimTyCon Name
proxyPrimTyConName [TyConBinder]
binders Kind
res_kind [Role
Nominal,Role
Phantom]
where
binders :: [TyConBinder]
binders = [Kind] -> ([Kind] -> [Kind]) -> [TyConBinder]
mkTemplateTyConBinders [Kind
liftedTypeKind] [Kind] -> [Kind]
forall a. a -> a
id
res_kind :: Kind
res_kind = [Kind] -> Kind
unboxedTupleKind []
eqPrimTyCon :: TyCon
eqPrimTyCon :: TyCon
eqPrimTyCon = Name -> [TyConBinder] -> Kind -> [Role] -> TyCon
mkPrimTyCon Name
eqPrimTyConName [TyConBinder]
binders Kind
res_kind [Role]
roles
where
binders :: [TyConBinder]
binders = [Kind] -> ([Kind] -> [Kind]) -> [TyConBinder]
mkTemplateTyConBinders [Kind
liftedTypeKind, Kind
liftedTypeKind] [Kind] -> [Kind]
forall a. a -> a
id
res_kind :: Kind
res_kind = [Kind] -> Kind
unboxedTupleKind []
roles :: [Role]
roles = [Role
Nominal, Role
Nominal, Role
Nominal, Role
Nominal]
eqReprPrimTyCon :: TyCon
eqReprPrimTyCon :: TyCon
eqReprPrimTyCon = Name -> [TyConBinder] -> Kind -> [Role] -> TyCon
mkPrimTyCon Name
eqReprPrimTyConName [TyConBinder]
binders Kind
res_kind [Role]
roles
where
binders :: [TyConBinder]
binders = [Kind] -> ([Kind] -> [Kind]) -> [TyConBinder]
mkTemplateTyConBinders [Kind
liftedTypeKind, Kind
liftedTypeKind] [Kind] -> [Kind]
forall a. a -> a
id
res_kind :: Kind
res_kind = [Kind] -> Kind
unboxedTupleKind []
roles :: [Role]
roles = [Role
Nominal, Role
Nominal, Role
Representational, Role
Representational]
eqPhantPrimTyCon :: TyCon
eqPhantPrimTyCon :: TyCon
eqPhantPrimTyCon = Name -> [TyConBinder] -> Kind -> [Role] -> TyCon
mkPrimTyCon Name
eqPhantPrimTyConName [TyConBinder]
binders Kind
res_kind [Role]
roles
where
binders :: [TyConBinder]
binders = [Kind] -> ([Kind] -> [Kind]) -> [TyConBinder]
mkTemplateTyConBinders [Kind
liftedTypeKind, Kind
liftedTypeKind] [Kind] -> [Kind]
forall a. a -> a
id
res_kind :: Kind
res_kind = [Kind] -> Kind
unboxedTupleKind []
roles :: [Role]
roles = [Role
Nominal, Role
Nominal, Role
Phantom, Role
Phantom]
equalityTyCon :: Role -> TyCon
equalityTyCon :: Role -> TyCon
equalityTyCon Role
Nominal = TyCon
eqPrimTyCon
equalityTyCon Role
Representational = TyCon
eqReprPrimTyCon
equalityTyCon Role
Phantom = TyCon
eqPhantPrimTyCon
arrayPrimTyCon, mutableArrayPrimTyCon, mutableByteArrayPrimTyCon,
byteArrayPrimTyCon, arrayArrayPrimTyCon, mutableArrayArrayPrimTyCon,
smallArrayPrimTyCon, smallMutableArrayPrimTyCon :: TyCon
arrayPrimTyCon :: TyCon
arrayPrimTyCon = Name -> [Role] -> PrimRep -> TyCon
pcPrimTyCon Name
arrayPrimTyConName [Role
Representational] PrimRep
UnliftedRep
mutableArrayPrimTyCon :: TyCon
mutableArrayPrimTyCon = Name -> [Role] -> PrimRep -> TyCon
pcPrimTyCon Name
mutableArrayPrimTyConName [Role
Nominal, Role
Representational] PrimRep
UnliftedRep
mutableByteArrayPrimTyCon :: TyCon
mutableByteArrayPrimTyCon = Name -> [Role] -> PrimRep -> TyCon
pcPrimTyCon Name
mutableByteArrayPrimTyConName [Role
Nominal] PrimRep
UnliftedRep
byteArrayPrimTyCon :: TyCon
byteArrayPrimTyCon = Name -> PrimRep -> TyCon
pcPrimTyCon0 Name
byteArrayPrimTyConName PrimRep
UnliftedRep
arrayArrayPrimTyCon :: TyCon
arrayArrayPrimTyCon = Name -> PrimRep -> TyCon
pcPrimTyCon0 Name
arrayArrayPrimTyConName PrimRep
UnliftedRep
mutableArrayArrayPrimTyCon :: TyCon
mutableArrayArrayPrimTyCon = Name -> [Role] -> PrimRep -> TyCon
pcPrimTyCon Name
mutableArrayArrayPrimTyConName [Role
Nominal] PrimRep
UnliftedRep
smallArrayPrimTyCon :: TyCon
smallArrayPrimTyCon = Name -> [Role] -> PrimRep -> TyCon
pcPrimTyCon Name
smallArrayPrimTyConName [Role
Representational] PrimRep
UnliftedRep
smallMutableArrayPrimTyCon :: TyCon
smallMutableArrayPrimTyCon = Name -> [Role] -> PrimRep -> TyCon
pcPrimTyCon Name
smallMutableArrayPrimTyConName [Role
Nominal, Role
Representational] PrimRep
UnliftedRep
mkArrayPrimTy :: Type -> Type
mkArrayPrimTy :: Kind -> Kind
mkArrayPrimTy Kind
elt = TyCon -> [Kind] -> Kind
TyConApp TyCon
arrayPrimTyCon [Kind
elt]
byteArrayPrimTy :: Type
byteArrayPrimTy :: Kind
byteArrayPrimTy = TyCon -> Kind
mkTyConTy TyCon
byteArrayPrimTyCon
mkArrayArrayPrimTy :: Type
mkArrayArrayPrimTy :: Kind
mkArrayArrayPrimTy = TyCon -> Kind
mkTyConTy TyCon
arrayArrayPrimTyCon
mkSmallArrayPrimTy :: Type -> Type
mkSmallArrayPrimTy :: Kind -> Kind
mkSmallArrayPrimTy Kind
elt = TyCon -> [Kind] -> Kind
TyConApp TyCon
smallArrayPrimTyCon [Kind
elt]
mkMutableArrayPrimTy :: Type -> Type -> Type
mkMutableArrayPrimTy :: Kind -> Kind -> Kind
mkMutableArrayPrimTy Kind
s Kind
elt = TyCon -> [Kind] -> Kind
TyConApp TyCon
mutableArrayPrimTyCon [Kind
s, Kind
elt]
mkMutableByteArrayPrimTy :: Type -> Type
mkMutableByteArrayPrimTy :: Kind -> Kind
mkMutableByteArrayPrimTy Kind
s = TyCon -> [Kind] -> Kind
TyConApp TyCon
mutableByteArrayPrimTyCon [Kind
s]
mkMutableArrayArrayPrimTy :: Type -> Type
mkMutableArrayArrayPrimTy :: Kind -> Kind
mkMutableArrayArrayPrimTy Kind
s = TyCon -> [Kind] -> Kind
TyConApp TyCon
mutableArrayArrayPrimTyCon [Kind
s]
mkSmallMutableArrayPrimTy :: Type -> Type -> Type
mkSmallMutableArrayPrimTy :: Kind -> Kind -> Kind
mkSmallMutableArrayPrimTy Kind
s Kind
elt = TyCon -> [Kind] -> Kind
TyConApp TyCon
smallMutableArrayPrimTyCon [Kind
s, Kind
elt]
mutVarPrimTyCon :: TyCon
mutVarPrimTyCon :: TyCon
mutVarPrimTyCon = Name -> [Role] -> PrimRep -> TyCon
pcPrimTyCon Name
mutVarPrimTyConName [Role
Nominal, Role
Representational] PrimRep
UnliftedRep
mkMutVarPrimTy :: Type -> Type -> Type
mkMutVarPrimTy :: Kind -> Kind -> Kind
mkMutVarPrimTy Kind
s Kind
elt = TyCon -> [Kind] -> Kind
TyConApp TyCon
mutVarPrimTyCon [Kind
s, Kind
elt]
mVarPrimTyCon :: TyCon
mVarPrimTyCon :: TyCon
mVarPrimTyCon = Name -> [Role] -> PrimRep -> TyCon
pcPrimTyCon Name
mVarPrimTyConName [Role
Nominal, Role
Representational] PrimRep
UnliftedRep
mkMVarPrimTy :: Type -> Type -> Type
mkMVarPrimTy :: Kind -> Kind -> Kind
mkMVarPrimTy Kind
s Kind
elt = TyCon -> [Kind] -> Kind
TyConApp TyCon
mVarPrimTyCon [Kind
s, Kind
elt]
tVarPrimTyCon :: TyCon
tVarPrimTyCon :: TyCon
tVarPrimTyCon = Name -> [Role] -> PrimRep -> TyCon
pcPrimTyCon Name
tVarPrimTyConName [Role
Nominal, Role
Representational] PrimRep
UnliftedRep
mkTVarPrimTy :: Type -> Type -> Type
mkTVarPrimTy :: Kind -> Kind -> Kind
mkTVarPrimTy Kind
s Kind
elt = TyCon -> [Kind] -> Kind
TyConApp TyCon
tVarPrimTyCon [Kind
s, Kind
elt]
stablePtrPrimTyCon :: TyCon
stablePtrPrimTyCon :: TyCon
stablePtrPrimTyCon = Name -> [Role] -> PrimRep -> TyCon
pcPrimTyCon Name
stablePtrPrimTyConName [Role
Representational] PrimRep
AddrRep
mkStablePtrPrimTy :: Type -> Type
mkStablePtrPrimTy :: Kind -> Kind
mkStablePtrPrimTy Kind
ty = TyCon -> [Kind] -> Kind
TyConApp TyCon
stablePtrPrimTyCon [Kind
ty]
stableNamePrimTyCon :: TyCon
stableNamePrimTyCon :: TyCon
stableNamePrimTyCon = Name -> [Role] -> PrimRep -> TyCon
pcPrimTyCon Name
stableNamePrimTyConName [Role
Phantom] PrimRep
UnliftedRep
mkStableNamePrimTy :: Type -> Type
mkStableNamePrimTy :: Kind -> Kind
mkStableNamePrimTy Kind
ty = TyCon -> [Kind] -> Kind
TyConApp TyCon
stableNamePrimTyCon [Kind
ty]
compactPrimTyCon :: TyCon
compactPrimTyCon :: TyCon
compactPrimTyCon = Name -> PrimRep -> TyCon
pcPrimTyCon0 Name
compactPrimTyConName PrimRep
UnliftedRep
compactPrimTy :: Type
compactPrimTy :: Kind
compactPrimTy = TyCon -> Kind
mkTyConTy TyCon
compactPrimTyCon
bcoPrimTy :: Type
bcoPrimTy :: Kind
bcoPrimTy = TyCon -> Kind
mkTyConTy TyCon
bcoPrimTyCon
bcoPrimTyCon :: TyCon
bcoPrimTyCon :: TyCon
bcoPrimTyCon = Name -> PrimRep -> TyCon
pcPrimTyCon0 Name
bcoPrimTyConName PrimRep
UnliftedRep
weakPrimTyCon :: TyCon
weakPrimTyCon :: TyCon
weakPrimTyCon = Name -> [Role] -> PrimRep -> TyCon
pcPrimTyCon Name
weakPrimTyConName [Role
Representational] PrimRep
UnliftedRep
mkWeakPrimTy :: Type -> Type
mkWeakPrimTy :: Kind -> Kind
mkWeakPrimTy Kind
v = TyCon -> [Kind] -> Kind
TyConApp TyCon
weakPrimTyCon [Kind
v]
threadIdPrimTy :: Type
threadIdPrimTy :: Kind
threadIdPrimTy = TyCon -> Kind
mkTyConTy TyCon
threadIdPrimTyCon
threadIdPrimTyCon :: TyCon
threadIdPrimTyCon :: TyCon
threadIdPrimTyCon = Name -> PrimRep -> TyCon
pcPrimTyCon0 Name
threadIdPrimTyConName PrimRep
UnliftedRep
#include "primop-vector-tys.hs-incl"