From f9d1e4bc60690386e0b2c658d707b75a77717a9c Mon Sep 17 00:00:00 2001 From: Nuno Lopes Date: Sun, 14 Dec 2008 21:53:25 +0000 Subject: [PATCH] dont call iterator::end() on every cycle and dont read already-deleted memory git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@61015 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/AST/DeclarationName.cpp | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/lib/AST/DeclarationName.cpp b/lib/AST/DeclarationName.cpp index 9535965ecf..044acd71d4 100644 --- a/lib/AST/DeclarationName.cpp +++ b/lib/AST/DeclarationName.cpp @@ -261,10 +261,11 @@ DeclarationNameTable::DeclarationNameTable() { DeclarationNameTable::~DeclarationNameTable() { llvm::FoldingSet *set = static_cast*>(CXXSpecialNamesImpl); - llvm::FoldingSetIterator it = set->begin(); + llvm::FoldingSetIterator I = set->begin(), E = set->end(); - while (it != set->end()) { - delete &*it++; + while (I != E) { + CXXSpecialName *n = &*I++; + delete n; } delete set; -- 2.50.1