forked from OSchip/llvm-project
Fixing the build isn't good enough; back out r110956 and r110953.
llvm-svn: 110958
This commit is contained in:
parent
35053747cc
commit
112fd083fa
|
@ -38,10 +38,6 @@ namespace clang {
|
|||
bool CompleteTranslationUnit = true,
|
||||
CodeCompleteConsumer *CompletionConsumer = 0);
|
||||
|
||||
/// \brief Parse the main file known to the preprocessor, producing an
|
||||
/// abstract syntax tree.
|
||||
void ParseAST(Sema &S, bool PrintStats = false);
|
||||
|
||||
} // end namespace clang
|
||||
|
||||
#endif
|
||||
|
|
|
@ -640,9 +640,6 @@ public:
|
|||
Diagnostic &getDiagnostics() const { return Diags; }
|
||||
SourceManager &getSourceManager() const { return SourceMgr; }
|
||||
const TargetAttributesSema &getTargetAttributesSema() const;
|
||||
Preprocessor &getPreprocessor() const { return PP; }
|
||||
ASTContext &getASTContext() const { return Context; }
|
||||
ASTConsumer &getASTConsumer() const { return Consumer; }
|
||||
|
||||
/// \brief Helper class that creates diagnostics with optional
|
||||
/// template instantiation stacks.
|
||||
|
|
|
@ -56,24 +56,31 @@ void clang::ParseAST(Preprocessor &PP, ASTConsumer *Consumer,
|
|||
ASTContext &Ctx, bool PrintStats,
|
||||
bool CompleteTranslationUnit,
|
||||
CodeCompleteConsumer *CompletionConsumer) {
|
||||
Sema S(PP, Ctx, *Consumer, CompleteTranslationUnit, CompletionConsumer);
|
||||
ParseAST(S, PrintStats);
|
||||
}
|
||||
|
||||
void clang::ParseAST(Sema &S, bool PrintStats) {
|
||||
// Collect global stats on Decls/Stmts (until we have a module streamer).
|
||||
if (PrintStats) {
|
||||
Decl::CollectingStats(true);
|
||||
Stmt::CollectingStats(true);
|
||||
}
|
||||
|
||||
ASTConsumer *Consumer = &S.getASTConsumer();
|
||||
Sema S(PP, Ctx, *Consumer, CompleteTranslationUnit, CompletionConsumer);
|
||||
Parser P(PP, S);
|
||||
PP.EnterMainSourceFile();
|
||||
|
||||
Parser P(S.getPreprocessor(), S);
|
||||
S.getPreprocessor().EnterMainSourceFile();
|
||||
// Initialize the parser.
|
||||
P.Initialize();
|
||||
|
||||
Consumer->Initialize(Ctx);
|
||||
|
||||
if (SemaConsumer *SC = dyn_cast<SemaConsumer>(Consumer))
|
||||
SC->InitializeSema(S);
|
||||
|
||||
if (ExternalASTSource *External = Ctx.getExternalSource()) {
|
||||
if (ExternalSemaSource *ExternalSema =
|
||||
dyn_cast<ExternalSemaSource>(External))
|
||||
ExternalSema->InitializeSema(S);
|
||||
|
||||
if (ExternalASTSource *External = S.getASTContext().getExternalSource())
|
||||
External->StartTranslationUnit(Consumer);
|
||||
}
|
||||
|
||||
Parser::DeclGroupPtrTy ADecl;
|
||||
|
||||
|
@ -95,15 +102,22 @@ void clang::ParseAST(Sema &S, bool PrintStats) {
|
|||
Consumer->HandleTopLevelDecl(DeclGroupRef(*I));
|
||||
|
||||
// Dump record layouts, if requested.
|
||||
if (S.getLangOptions().DumpRecordLayouts)
|
||||
DumpRecordLayouts(S.getASTContext());
|
||||
if (PP.getLangOptions().DumpRecordLayouts)
|
||||
DumpRecordLayouts(Ctx);
|
||||
|
||||
Consumer->HandleTranslationUnit(S.getASTContext());
|
||||
Consumer->HandleTranslationUnit(Ctx);
|
||||
|
||||
if (ExternalSemaSource *ESS =
|
||||
dyn_cast_or_null<ExternalSemaSource>(Ctx.getExternalSource()))
|
||||
ESS->ForgetSema();
|
||||
|
||||
if (SemaConsumer *SC = dyn_cast<SemaConsumer>(Consumer))
|
||||
SC->ForgetSema();
|
||||
|
||||
if (PrintStats) {
|
||||
fprintf(stderr, "\nSTATISTICS:\n");
|
||||
P.getActions().PrintStats();
|
||||
S.getASTContext().PrintStats();
|
||||
Ctx.PrintStats();
|
||||
Decl::PrintStats();
|
||||
Stmt::PrintStats();
|
||||
Consumer->PrintStats();
|
||||
|
|
|
@ -18,7 +18,7 @@
|
|||
#include "llvm/ADT/SmallSet.h"
|
||||
#include "llvm/ADT/APFloat.h"
|
||||
#include "clang/Sema/ExternalSemaSource.h"
|
||||
#include "clang/Sema/SemaConsumer.h"
|
||||
#include "clang/AST/ASTConsumer.h"
|
||||
#include "clang/AST/ASTContext.h"
|
||||
#include "clang/AST/ASTDiagnostic.h"
|
||||
#include "clang/AST/DeclObjC.h"
|
||||
|
@ -143,18 +143,6 @@ Sema::Sema(Preprocessor &pp, ASTContext &ctxt, ASTConsumer &consumer,
|
|||
|
||||
ExprEvalContexts.push_back(
|
||||
ExpressionEvaluationContextRecord(PotentiallyEvaluated, 0));
|
||||
|
||||
// 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() {
|
||||
|
@ -163,15 +151,6 @@ 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.
|
||||
|
|
Loading…
Reference in New Issue