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:
Eli Friedman 2010-03-07 05:49:51 +00:00
Родитель 96df6cfd12
Коммит d6a9324e9b
2 изменённых файлов: 14 добавлений и 1 удалений

Просмотреть файл

@ -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() {}