ASTUnit: Explicitly track whether the ASTUnit came from an actual AST or not.

llvm-svn: 90349
This commit is contained in:
Daniel Dunbar 2009-12-02 21:47:43 +00:00
parent 4897349a79
commit a18f9580e4
2 changed files with 14 additions and 6 deletions

View File

@ -53,7 +53,10 @@ class ASTUnit {
// that come from the AST itself, not from included precompiled headers.
// FIXME: This is temporary; eventually, CIndex will always do this.
bool OnlyLocalDecls;
// Track whether the main file was loaded from an AST or not.
bool MainFileIsAST;
/// The name of the original source file used to generate this ASTUnit.
std::string OriginalSourceFile;
@ -64,9 +67,11 @@ class ASTUnit {
ASTUnit &operator=(const ASTUnit &); // DO NOT IMPLEMENT
public:
ASTUnit(DiagnosticClient *diagClient = NULL);
ASTUnit(bool MainFileIsAST, DiagnosticClient *diagClient = NULL);
~ASTUnit();
bool isMainFileAST() const { return MainFileIsAST; }
const SourceManager &getSourceManager() const { return SourceMgr; }
SourceManager &getSourceManager() { return SourceMgr; }

View File

@ -34,7 +34,10 @@
#include "llvm/System/Path.h"
using namespace clang;
ASTUnit::ASTUnit(DiagnosticClient *diagClient) : tempFile(false) {
ASTUnit::ASTUnit(bool _MainFileIsAST,
DiagnosticClient *diagClient)
: tempFile(false), MainFileIsAST(_MainFileIsAST)
{
Diags.setClient(diagClient ? diagClient : new TextDiagnosticBuffer());
}
ASTUnit::~ASTUnit() {
@ -99,7 +102,7 @@ const std::string &ASTUnit::getOriginalSourceFileName() {
}
const std::string &ASTUnit::getPCHFileName() {
assert(Ctx->getExternalSource() && "Not an ASTUnit from a PCH file!");
assert(isMainFileAST() && "Not an ASTUnit from a PCH file!");
return dyn_cast<PCHReader>(Ctx->getExternalSource())->getFileName();
}
@ -108,7 +111,7 @@ ASTUnit *ASTUnit::LoadFromPCHFile(const std::string &Filename,
DiagnosticClient *diagClient,
bool OnlyLocalDecls,
bool UseBumpAllocator) {
llvm::OwningPtr<ASTUnit> AST(new ASTUnit(diagClient));
llvm::OwningPtr<ASTUnit> AST(new ASTUnit(true, diagClient));
AST->OnlyLocalDecls = OnlyLocalDecls;
AST->HeaderInfo.reset(new HeaderSearch(AST->getFileManager()));
@ -230,7 +233,7 @@ ASTUnit *ASTUnit::LoadFromCompilerInvocation(const CompilerInvocation &CI,
// Create the AST unit.
//
// FIXME: Use the provided diagnostic client.
AST.reset(new ASTUnit());
AST.reset(new ASTUnit(false));
AST->OnlyLocalDecls = OnlyLocalDecls;
AST->OriginalSourceFile = Clang.getFrontendOpts().Inputs[0].second;