Revert failed instantiations ROOT-6070.

This commit is contained in:
Vassil Vassilev 2014-02-27 17:11:08 +01:00 committed by sftnight
parent 71b05e8321
commit 03010a5af1

View File

@ -9,6 +9,7 @@
#include "cling/Interpreter/LookupHelper.h"
#include "ASTNodeEraser.h"
#include "cling/Interpreter/Interpreter.h"
#include "clang/AST/ASTContext.h"
@ -146,7 +147,7 @@ namespace cling {
setResultType = resultType;
*setResultType = 0;
const Decl* TheDecl = 0;
Decl* TheDecl = 0;
//
// Prevent failing on an assert in TryAnnotateCXXScopeToken.
@ -231,8 +232,12 @@ namespace cling {
// Success, type is complete, instantiations have
// been done.
TheDecl = TD->getDefinition();
if (TheDecl->isInvalidDecl())
if (TheDecl->isInvalidDecl()) {
// if the decl is invalid try to clean up
ASTNodeEraser eraser(&S, /*ExecutionEngine*/0);
eraser.RevertDecl(TheDecl);
return 0;
}
} else {
// We cannot instantiate the scope: not a valid decl.
return 0;
@ -442,8 +447,12 @@ namespace cling {
// Forward decl or instantiation failure, we cannot use it.
return 0;
}
if (scopeDecl->isInvalidDecl())
if (scopeDecl->isInvalidDecl()) {
// if the decl is invalid try to clean up
ASTNodeEraser eraser(&S, /*ExecutionEngine*/0);
eraser.RevertDecl(const_cast<Decl*>(scopeDecl));
return 0;
}
return foundDC;
}
@ -606,10 +615,14 @@ namespace cling {
if (TheDecl->isTemplateInstantiation() && !TheDecl->isDefined())
S.InstantiateFunctionDefinition(SourceLocation(), TheDecl,
true /*recursive instantiation*/);
if (TheDecl->isInvalidDecl())
if (TheDecl->isInvalidDecl()) {
// if the decl is invalid try to clean up
ASTNodeEraser eraser(&S, /*ExecutionEngine*/0);
eraser.RevertDecl(const_cast<FunctionDecl*>(TheDecl));
return 0;
}
}
}
return TheDecl;
}
@ -1073,8 +1086,12 @@ namespace cling {
if (!fdecl->isDefined())
S.InstantiateFunctionDefinition(loc, fdecl,
true /*recursive instantiation*/);
if (fdecl->isInvalidDecl())
if (fdecl->isInvalidDecl()) {
// if the decl is invalid try to clean up
ASTNodeEraser eraser(&S, /*ExecutionEngine*/0);
eraser.RevertDecl(fdecl);
return 0;
}
return fdecl;
}
}