зеркало из https://github.com/microsoft/clang.git
Make sure that enumerators show up within the enumeration declaration. Fixes. PR clang/3220
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@61116 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Родитель
e79837aacd
Коммит
45579f5e29
|
@ -107,6 +107,13 @@ void DeclPrinter:: PrintDecl(Decl *D) {
|
|||
Out << D->getNameAsString();
|
||||
}
|
||||
Out << ";\n";
|
||||
} else if (EnumDecl *ED = dyn_cast<EnumDecl>(D)) {
|
||||
Out << "enum " << ED->getNameAsString() << " {\n";
|
||||
for (EnumDecl::enumerator_iterator E = ED->enumerator_begin(),
|
||||
EEnd = ED->enumerator_end();
|
||||
E != EEnd; ++E)
|
||||
Out << " " << (*E)->getNameAsString() << ",\n";
|
||||
Out << "};\n";
|
||||
} else if (TagDecl *TD = dyn_cast<TagDecl>(D)) {
|
||||
Out << "Read top-level tag decl: '" << TD->getNameAsString() << "'\n";
|
||||
} else if (ScopedDecl *SD = dyn_cast<ScopedDecl>(D)) {
|
||||
|
|
|
@ -121,7 +121,6 @@ EnumDecl *EnumDecl::Create(ASTContext &C, DeclContext *DC, SourceLocation L,
|
|||
}
|
||||
|
||||
void EnumDecl::Destroy(ASTContext& C) {
|
||||
DeclContext::DestroyDecls(C);
|
||||
Decl::Destroy(C);
|
||||
}
|
||||
|
||||
|
|
|
@ -3185,6 +3185,12 @@ Sema::DeclTy *Sema::ActOnEnumConstant(Scope *S, DeclTy *theEnumDecl,
|
|||
|
||||
// Register this decl in the current scope stack.
|
||||
PushOnScopeChains(New, S);
|
||||
|
||||
// Add this enumerator into the enum itself.
|
||||
// FIXME: This means that the enumerator is stored in two
|
||||
// DeclContexts. This is not a long-term solution.
|
||||
New->setLexicalDeclContext(TheEnumDecl);
|
||||
TheEnumDecl->addDecl(Context, New, true);
|
||||
return New;
|
||||
}
|
||||
|
||||
|
|
Загрузка…
Ссылка в новой задаче