From 5a11bf70c301d60569e2c56d9741a291e966f563 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Sat, 9 Nov 2002 19:25:27 +0000 Subject: [PATCH] Tighten up array handling llvm-svn: 4655 --- lib/Analysis/DataStructure/DataStructure.cpp | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/lib/Analysis/DataStructure/DataStructure.cpp b/lib/Analysis/DataStructure/DataStructure.cpp index 8b43653b919..6380a4967ee 100644 --- a/lib/Analysis/DataStructure/DataStructure.cpp +++ b/lib/Analysis/DataStructure/DataStructure.cpp @@ -135,10 +135,12 @@ bool DSNode::mergeTypeInfo(const Type *NewTy, unsigned Offset) { // be used anyway. This greatly reduces the size of large static arrays used // as global variables, for example. // + bool WillBeArray = false; while (const ArrayType *AT = dyn_cast(NewTy)) { // FIXME: we might want to keep small arrays, but must be careful about // things like: [2 x [10000 x int*]] NewTy = AT->getElementType(); + WillBeArray = true; } // Figure out how big the new type we're merging in is... @@ -152,8 +154,9 @@ bool DSNode::mergeTypeInfo(const Type *NewTy, unsigned Offset) { // If this is the first type that this node has seen, just accept it without // question.... assert(Offset == 0 && "Cannot have an offset into a void node!"); - assert(Ty.isArray == false && "This shouldn't happen!"); + assert(!Ty.isArray && "This shouldn't happen!"); Ty.Ty = NewTy; + Ty.isArray = WillBeArray; Size = NewTySize; // Calculate the number of outgoing links from this node. @@ -185,6 +188,7 @@ bool DSNode::mergeTypeInfo(const Type *NewTy, unsigned Offset) { // const Type *OldTy = Ty.Ty; Ty.Ty = NewTy; + Ty.isArray = WillBeArray; Size = NewTySize; // Must grow links to be the appropriate size...