From: David Greene Date: Thu, 14 May 2009 20:38:52 +0000 (+0000) Subject: Fix PR4207. X-Git-Url: http://plrg.eecs.uci.edu/git/?p=oota-llvm.git;a=commitdiff_plain;h=ccf85ded583167cbdbc20043e698eda8a7c2ed7d Fix PR4207. If we're resolving a list element access and we're given a VarInit, return a new VarListElementInit referencing the VarInit. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@71787 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/utils/TableGen/Record.cpp b/utils/TableGen/Record.cpp index 2e64c838ab7..d420e6338cc 100644 --- a/utils/TableGen/Record.cpp +++ b/utils/TableGen/Record.cpp @@ -639,8 +639,12 @@ Init *VarInit::resolveListElementReference(Record &R, const RecordVal *IRV, RecordVal *RV = R.getValue(getName()); assert(RV && "Reference to a non-existant variable?"); ListInit *LI = dynamic_cast(RV->getValue()); - assert(LI && "Invalid list element!"); - + if (!LI) { + VarInit *VI = dynamic_cast(RV->getValue()); + assert(VI && "Invalid list element!"); + return new VarListElementInit(VI, Elt); + } + if (Elt >= LI->getSize()) return 0; // Out of range reference. Init *E = LI->getElement(Elt);