From: Chris Lattner Date: Sat, 28 Mar 2009 03:29:40 +0000 (+0000) Subject: don't poke at TranslationUnit directly X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=e90778716bdc4ddc351f1d38e41c54f1a36466d1;p=clang don't poke at TranslationUnit directly git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@67900 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/tools/clang-cc/AnalysisConsumer.cpp b/tools/clang-cc/AnalysisConsumer.cpp index f19ff1787e..4594a71492 100644 --- a/tools/clang-cc/AnalysisConsumer.cpp +++ b/tools/clang-cc/AnalysisConsumer.cpp @@ -460,10 +460,14 @@ void AnalysisConsumer::HandleTranslationUnit(TranslationUnit& TU) { (*I)(mgr); } - if (!ObjCImplementationActions.empty()) - for (TranslationUnit::iterator I = TU.begin(), E = TU.end(); I!=E; ++I) + if (!ObjCImplementationActions.empty()) { + TranslationUnitDecl *TUD = TU.getContext().getTranslationUnitDecl(); + + for (DeclContext::decl_iterator I = TUD->decls_begin(),E = TUD->decls_end(); + I != E; ++I) if (ObjCImplementationDecl* ID = dyn_cast(*I)) HandleCode(ID, 0, ObjCImplementationActions); + } // Delete the PathDiagnosticClient here just in case the AnalysisConsumer // object doesn't get released. This will cause any side-effects in the