зеркало из https://github.com/microsoft/clang-1.git
Fix for PR6294: we should only delay recording nested dynamic classes if they
are lexically nested. Othewise, we never end up recording semantically nested classes. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@97900 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Родитель
96df6cfd12
Коммит
d6a9324e9b
|
@ -5030,7 +5030,7 @@ void Sema::ActOnTagFinishDefinition(Scope *S, DeclPtrTy TagD,
|
|||
// Exit this scope of this tag's definition.
|
||||
PopDeclContext();
|
||||
|
||||
if (isa<CXXRecordDecl>(Tag) && !Tag->getDeclContext()->isRecord())
|
||||
if (isa<CXXRecordDecl>(Tag) && !Tag->getLexicalDeclContext()->isRecord())
|
||||
RecordDynamicClassesWithNoKeyFunction(*this, cast<CXXRecordDecl>(Tag),
|
||||
RBraceLoc);
|
||||
|
||||
|
|
|
@ -0,0 +1,13 @@
|
|||
// RUN: %clang_cc1 %s -emit-llvm-only
|
||||
// PR6294
|
||||
|
||||
class A {
|
||||
virtual ~A();
|
||||
};
|
||||
class B {
|
||||
class C;
|
||||
};
|
||||
class B::C : public A {
|
||||
C();
|
||||
};
|
||||
B::C::C() {}
|
Загрузка…
Ссылка в новой задаче