diff options
author | Chris Lattner <sabre@nondot.org> | 2012-01-26 00:01:10 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2012-01-26 00:01:10 +0000 |
commit | 6e3abaa77f916341ed000b1a3883aec563967a88 (patch) | |
tree | 8787da886968682f2890a0093d8ae3929f725ff4 /lib | |
parent | 83694a984c153a0d78dcfb47d464c9a1561c22ef (diff) | |
download | external_llvm-6e3abaa77f916341ed000b1a3883aec563967a88.zip external_llvm-6e3abaa77f916341ed000b1a3883aec563967a88.tar.gz external_llvm-6e3abaa77f916341ed000b1a3883aec563967a88.tar.bz2 |
Ok, break down and add some cast<>'ing helper methods to the Type class
to reduce the number of cast<>'s we have. This allows someone to use
things like Ty->getVectorNumElements() instead of
cast<VectorType>(Ty)->getNumElements() when you know that a type is a
vector.
It would be a great general cleanup to move the codebase to use these,
I will do so in the code I'm touching.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@148999 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib')
-rw-r--r-- | lib/VMCore/Type.cpp | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/lib/VMCore/Type.cpp b/lib/VMCore/Type.cpp index 7edd9e6..627f645 100644 --- a/lib/VMCore/Type.cpp +++ b/lib/VMCore/Type.cpp @@ -198,6 +198,45 @@ bool Type::isSizedDerivedType() const { } //===----------------------------------------------------------------------===// +// Subclass Helper Methods +//===----------------------------------------------------------------------===// + +unsigned Type::getIntegerBitWidth() const { + return cast<IntegerType>(this)->getBitWidth(); +} + +bool Type::isFunctionVarArg() const { + return cast<FunctionType>(this)->isVarArg(); +} + +Type *Type::getFunctionParamType(unsigned i) const { + return cast<FunctionType>(this)->getParamType(i); +} + +unsigned Type::getFunctionNumParams() const { + return cast<FunctionType>(this)->getNumParams(); +} + +Type *Type::getSequentialElementType() const { + return cast<SequentialType>(this)->getElementType(); +} + +uint64_t Type::getArrayNumElements() const { + return cast<ArrayType>(this)->getNumElements(); +} + +unsigned Type::getVectorNumElements() const { + return cast<VectorType>(this)->getNumElements(); +} + +unsigned Type::getPointerAddressSpace() const { + return cast<PointerType>(this)->getAddressSpace(); +} + + + + +//===----------------------------------------------------------------------===// // Primitive 'Type' data //===----------------------------------------------------------------------===// |