module LLVM.AST.Global where
import LLVM.Prelude
import LLVM.AST.Name
import LLVM.AST.Type
import LLVM.AST.Constant (Constant)
import LLVM.AST.AddrSpace
import LLVM.AST.Instruction (Named, Instruction, Terminator)
import qualified LLVM.AST.Linkage as L
import qualified LLVM.AST.Visibility as V
import qualified LLVM.AST.DLL as DLL
import qualified LLVM.AST.CallingConvention as CC
import qualified LLVM.AST.ThreadLocalStorage as TLS
import qualified LLVM.AST.Attribute as A
data Global
= GlobalVariable {
name :: Name,
linkage :: L.Linkage,
visibility :: V.Visibility,
dllStorageClass :: Maybe DLL.StorageClass,
threadLocalMode :: Maybe TLS.Model,
addrSpace :: AddrSpace,
unnamedAddr :: Maybe UnnamedAddr,
isConstant :: Bool,
type' :: Type,
initializer :: Maybe Constant,
section :: Maybe String,
comdat :: Maybe String,
alignment :: Word32
}
| GlobalAlias {
name :: Name,
linkage :: L.Linkage,
visibility :: V.Visibility,
dllStorageClass :: Maybe DLL.StorageClass,
threadLocalMode :: Maybe TLS.Model,
unnamedAddr :: Maybe UnnamedAddr,
type' :: Type,
aliasee :: Constant
}
| Function {
linkage :: L.Linkage,
visibility :: V.Visibility,
dllStorageClass :: Maybe DLL.StorageClass,
callingConvention :: CC.CallingConvention,
returnAttributes :: [A.ParameterAttribute],
returnType :: Type,
name :: Name,
parameters :: ([Parameter],Bool),
functionAttributes :: [Either A.GroupID A.FunctionAttribute],
section :: Maybe String,
comdat :: Maybe String,
alignment :: Word32,
garbageCollectorName :: Maybe String,
prefix :: Maybe Constant,
basicBlocks :: [BasicBlock],
personalityFunction :: Maybe Constant
}
deriving (Eq, Read, Show, Typeable, Data)
data Parameter = Parameter Type Name [A.ParameterAttribute]
deriving (Eq, Read, Show, Typeable, Data)
data BasicBlock = BasicBlock Name [Named Instruction] (Named Terminator)
deriving (Eq, Read, Show, Typeable, Data)
data UnnamedAddr = LocalAddr | GlobalAddr
deriving (Eq, Read, Show, Typeable, Data)
globalVariableDefaults :: Global
globalVariableDefaults =
GlobalVariable {
name = error "global variable name not defined",
linkage = L.External,
visibility = V.Default,
dllStorageClass = Nothing,
threadLocalMode = Nothing,
addrSpace = AddrSpace 0,
unnamedAddr = Nothing,
isConstant = False,
type' = error "global variable type not defined",
initializer = Nothing,
section = Nothing,
comdat = Nothing,
alignment = 0
}
globalAliasDefaults :: Global
globalAliasDefaults =
GlobalAlias {
name = error "global alias name not defined",
linkage = L.External,
visibility = V.Default,
dllStorageClass = Nothing,
threadLocalMode = Nothing,
unnamedAddr = Nothing,
type' = error "global alias type not defined",
aliasee = error "global alias aliasee not defined"
}
functionDefaults :: Global
functionDefaults =
Function {
linkage = L.External,
visibility = V.Default,
dllStorageClass = Nothing,
callingConvention = CC.C,
returnAttributes = [],
returnType = error "function return type not defined",
name = error "function name not defined",
parameters = ([], False),
functionAttributes = [],
section = Nothing,
comdat = Nothing,
alignment = 0,
garbageCollectorName = Nothing,
prefix = Nothing,
basicBlocks = [],
personalityFunction = Nothing
}