rather nasty, but I can't think of a better fix off the top of my head.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@67867
91177308-0d34-0410-b5e6-
96231b3b80d8
for (llvm::FoldingSet<NestedNameSpecifier>::iterator
NNS = NestedNameSpecifiers.begin(),
NNSEnd = NestedNameSpecifiers.end();
- NNS != NNSEnd; ++NNS)
- NNS->Destroy(*this);
+ NNS != NNSEnd; ) {
+ // This loop iterates, then destroys so that it doesn't cause invalid
+ // reads.
+ // FIXME: Find a less fragile way to do this!
+ NestedNameSpecifier* N = &*NNS;
+ ++NNS;
+ N->Destroy(*this);
+ }
if (GlobalNestedNameSpecifier)
GlobalNestedNameSpecifier->Destroy(*this);