summaryrefslogtreecommitdiffstats
path: root/clang/Driver/clang.cpp
diff options
context:
space:
mode:
authorTed Kremenek <kremenek@apple.com>2008-08-08 02:46:37 +0000
committerTed Kremenek <kremenek@apple.com>2008-08-08 02:46:37 +0000
commitdcb5e38927a9ffd7daa82ac205e8a8ee06b8321c (patch)
treee63bc93c5c5dd551415e370b000271ad585d5c9b /clang/Driver/clang.cpp
parent4a35180f6d07bc2af7d8901a04d68d47bfccc8ee (diff)
downloadbcm5719-llvm-dcb5e38927a9ffd7daa82ac205e8a8ee06b8321c.tar.gz
bcm5719-llvm-dcb5e38927a9ffd7daa82ac205e8a8ee06b8321c.zip
ParseAST now never releases the passed ASTConsumer. This is the responsibility of the client.
The motivation is that clients may either: (a) query the ASTConsumer object after AST parsing to collect data/etc. (b) reuse the ASTConsumer. llvm-svn: 54502
Diffstat (limited to 'clang/Driver/clang.cpp')
-rw-r--r--clang/Driver/clang.cpp15
1 files changed, 7 insertions, 8 deletions
diff --git a/clang/Driver/clang.cpp b/clang/Driver/clang.cpp
index 28ec5ffbb78..8bafbd50789 100644
--- a/clang/Driver/clang.cpp
+++ b/clang/Driver/clang.cpp
@@ -1228,14 +1228,14 @@ static ASTConsumer* CreateASTConsumer(const std::string& InFile,
static void ProcessInputFile(Preprocessor &PP, PreprocessorFactory &PPF,
const std::string &InFile) {
- ASTConsumer* Consumer = NULL;
+ llvm::OwningPtr<ASTConsumer> Consumer;
bool ClearSourceMgr = false;
switch (ProgAction) {
default:
- Consumer = CreateASTConsumer(InFile, PP.getDiagnostics(),
- PP.getFileManager(), PP.getLangOptions(), &PP,
- &PPF);
+ Consumer.reset(CreateASTConsumer(InFile, PP.getDiagnostics(),
+ PP.getFileManager(), PP.getLangOptions(),
+ &PP, &PPF));
if (!Consumer) {
fprintf(stderr, "Unexpected program action!\n");
@@ -1283,7 +1283,7 @@ static void ProcessInputFile(Preprocessor &PP, PreprocessorFactory &PPF,
break;
case ParseSyntaxOnly: // -fsyntax-only
- Consumer = new ASTConsumer();
+ Consumer.reset(new ASTConsumer());
break;
case RewriteMacros:
@@ -1294,10 +1294,9 @@ static void ProcessInputFile(Preprocessor &PP, PreprocessorFactory &PPF,
if (Consumer) {
if (VerifyDiagnostics)
- exit(CheckASTConsumer(PP, Consumer));
+ exit(CheckASTConsumer(PP, Consumer.get()));
- // This deletes Consumer.
- ParseAST(PP, Consumer, Stats);
+ ParseAST(PP, Consumer.get(), Stats);
}
if (Stats) {
OpenPOWER on IntegriCloud