diff options
| author | Douglas Gregor <dgregor@apple.com> | 2010-08-12 22:51:45 +0000 | 
|---|---|---|
| committer | Douglas Gregor <dgregor@apple.com> | 2010-08-12 22:51:45 +0000 | 
| commit | 5c6f10b54cf5771dab0121518084b019b9f0c28d (patch) | |
| tree | 2fb2a3ff0f585f6dfb42b0dddedf00ff8fbb6c12 /clang/lib/Sema/Sema.cpp | |
| parent | f8a9863df942e69d58e34432da3532a4ead650ad (diff) | |
| download | bcm5719-llvm-5c6f10b54cf5771dab0121518084b019b9f0c28d.tar.gz bcm5719-llvm-5c6f10b54cf5771dab0121518084b019b9f0c28d.zip | |
Add a ParseAST overload that takes a Sema object, so that the caller
can create (and hold on to) the Sema object. Also, move Sema-related
initialization/finalization with its various consumers and external
sources into the Sema constructor and destructor, rather than placing
it in ParseAST.
llvm-svn: 110973
Diffstat (limited to 'clang/lib/Sema/Sema.cpp')
| -rw-r--r-- | clang/lib/Sema/Sema.cpp | 29 | 
1 files changed, 26 insertions, 3 deletions
| diff --git a/clang/lib/Sema/Sema.cpp b/clang/lib/Sema/Sema.cpp index e7f5bb4317f..0d05b57b8d7 100644 --- a/clang/lib/Sema/Sema.cpp +++ b/clang/lib/Sema/Sema.cpp @@ -18,7 +18,7 @@  #include "llvm/ADT/SmallSet.h"  #include "llvm/ADT/APFloat.h"  #include "clang/Sema/ExternalSemaSource.h" -#include "clang/AST/ASTConsumer.h" +#include "clang/Sema/SemaConsumer.h"  #include "clang/AST/ASTContext.h"  #include "clang/AST/ASTDiagnostic.h"  #include "clang/AST/DeclObjC.h" @@ -116,7 +116,7 @@ void Sema::ActOnTranslationUnitScope(SourceLocation Loc, Scope *S) {      PushOnScopeChains(ClassTypedef, TUScope);      Context.setObjCClassType(Context.getTypeDeclType(ClassTypedef));      Context.ObjCClassRedefinitionType = Context.getObjCClassType(); -  } +  }    }  Sema::Sema(Preprocessor &pp, ASTContext &ctxt, ASTConsumer &consumer, @@ -142,7 +142,21 @@ Sema::Sema(Preprocessor &pp, ASTContext &ctxt, ASTConsumer &consumer,                                         &Context);    ExprEvalContexts.push_back( -                  ExpressionEvaluationContextRecord(PotentiallyEvaluated, 0)); +                  ExpressionEvaluationContextRecord(PotentiallyEvaluated, 0));   +} + +void Sema::Initialize() { +  // Tell the AST consumer about this Sema object. +  Consumer.Initialize(Context); +   +  // FIXME: Isn't this redundant with the initialization above? +  if (SemaConsumer *SC = dyn_cast<SemaConsumer>(&Consumer)) +    SC->InitializeSema(*this); +   +  // Tell the external Sema source about this Sema object. +  if (ExternalSemaSource *ExternalSema +      = dyn_cast_or_null<ExternalSemaSource>(Context.getExternalSource())) +    ExternalSema->InitializeSema(*this);  }  Sema::~Sema() { @@ -151,6 +165,15 @@ Sema::~Sema() {    delete TheTargetAttributesSema;    while (!FunctionScopes.empty())      PopFunctionOrBlockScope(); +   +  // Tell the SemaConsumer to forget about us; we're going out of scope. +  if (SemaConsumer *SC = dyn_cast<SemaConsumer>(&Consumer)) +    SC->ForgetSema(); + +  // Detach from the external Sema source. +  if (ExternalSemaSource *ExternalSema +      = dyn_cast_or_null<ExternalSemaSource>(Context.getExternalSource())) +    ExternalSema->ForgetSema();  }  /// ImpCastExprToType - If Expr is not of type 'Type', insert an implicit cast. | 

