From c5f143b6e7d287d0dc3e5c55b3c83a2670ca99f8 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Fri, 2 Jul 2004 23:20:17 +0000 Subject: [PATCH] Fix Type::isSized() to realize that "{ opaque }" is not sized git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@14585 91177308-0d34-0410-b5e6-96231b3b80d8 --- include/llvm/Type.h | 9 +++++++-- lib/VMCore/Type.cpp | 15 +++++++++++++++ 2 files changed, 22 insertions(+), 2 deletions(-) diff --git a/include/llvm/Type.h b/include/llvm/Type.h index e25bfe1e0ff..1598f0b97f0 100644 --- a/include/llvm/Type.h +++ b/include/llvm/Type.h @@ -206,8 +206,8 @@ public: /// TargetData subsystem to do this. /// bool isSized() const { - return ID != VoidTyID && ID != TypeTyID && - ID != FunctionTyID && ID != LabelTyID && ID != OpaqueTyID; + return (ID >= BoolTyID && ID <= DoubleTyID) || ID == PointerTyID || + isSizedDerivedType(); } /// getPrimitiveSize - Return the basic size of this type if it is a primative @@ -306,6 +306,11 @@ public: RefCountIsZero(); } private: + /// isSizedDerivedType - Derived types like structures and arrays are sized + /// iff all of the members of the type are sized as well. Since asking for + /// their size is relatively uncommon, move this operation out of line. + bool isSizedDerivedType() const; + virtual void RefCountIsZero() const { abort(); // only on derived types! } diff --git a/lib/VMCore/Type.cpp b/lib/VMCore/Type.cpp index 77984892424..eefcee98d4e 100644 --- a/lib/VMCore/Type.cpp +++ b/lib/VMCore/Type.cpp @@ -159,6 +159,21 @@ unsigned Type::getPrimitiveSize() const { } } +/// isSizedDerivedType - Derived types like structures and arrays are sized +/// iff all of the members of the type are sized as well. Since asking for +/// their size is relatively uncommon, move this operation out of line. +bool Type::isSizedDerivedType() const { + if (const ArrayType *ATy = dyn_cast(this)) + return ATy->getElementType()->isSized(); + + if (!isa(this)) return false; + + // Okay, our struct is sized if all of the elements are... + for (subtype_iterator I = subtype_begin(), E = subtype_end(); I != E; ++I) + if (!(*I)->isSized()) return false; + + return true; +} /// getForwardedTypeInternal - This method is used to implement the union-find /// algorithm for when a type is being forwarded to another type.