forked from OSchip/llvm-project
Fixes a bogus error when declaring an extern "C" array.
(fixes radar 7457109). llvm-svn: 90986
This commit is contained in:
parent
493b882f80
commit
26de2e594b
|
@ -759,7 +759,10 @@ private:
|
|||
bool isStartOfFunctionDefinition();
|
||||
DeclGroupPtrTy ParseDeclarationOrFunctionDefinition(AttributeList *Attr,
|
||||
AccessSpecifier AS = AS_none);
|
||||
|
||||
DeclGroupPtrTy ParseDeclarationOrFunctionDefinition(ParsingDeclSpec &DS,
|
||||
AttributeList *Attr,
|
||||
AccessSpecifier AS = AS_none);
|
||||
|
||||
DeclPtrTy ParseFunctionDefinition(ParsingDeclarator &D,
|
||||
const ParsedTemplateInfo &TemplateInfo = ParsedTemplateInfo());
|
||||
void ParseKNRParamDeclarations(Declarator &D);
|
||||
|
@ -1290,7 +1293,7 @@ private:
|
|||
tok::TokenKind *After = 0);
|
||||
|
||||
DeclPtrTy ParseNamespace(unsigned Context, SourceLocation &DeclEnd);
|
||||
DeclPtrTy ParseLinkage(unsigned Context);
|
||||
DeclPtrTy ParseLinkage(ParsingDeclSpec &DS, unsigned Context);
|
||||
DeclPtrTy ParseUsingDirectiveOrDeclaration(unsigned Context,
|
||||
SourceLocation &DeclEnd,
|
||||
CXX0XAttributeList Attrs);
|
||||
|
|
|
@ -161,7 +161,8 @@ Parser::DeclPtrTy Parser::ParseNamespaceAlias(SourceLocation NamespaceLoc,
|
|||
/// 'extern' string-literal '{' declaration-seq[opt] '}'
|
||||
/// 'extern' string-literal declaration
|
||||
///
|
||||
Parser::DeclPtrTy Parser::ParseLinkage(unsigned Context) {
|
||||
Parser::DeclPtrTy Parser::ParseLinkage(ParsingDeclSpec &DS,
|
||||
unsigned Context) {
|
||||
assert(Tok.is(tok::string_literal) && "Not a string literal!");
|
||||
llvm::SmallVector<char, 8> LangBuffer;
|
||||
// LangBuffer is guaranteed to be big enough.
|
||||
|
@ -185,7 +186,7 @@ Parser::DeclPtrTy Parser::ParseLinkage(unsigned Context) {
|
|||
}
|
||||
|
||||
if (Tok.isNot(tok::l_brace)) {
|
||||
ParseDeclarationOrFunctionDefinition(Attr.AttrList);
|
||||
ParseDeclarationOrFunctionDefinition(DS, Attr.AttrList);
|
||||
return Actions.ActOnFinishLinkageSpecification(CurScope, LinkageSpec,
|
||||
SourceLocation());
|
||||
}
|
||||
|
|
|
@ -533,10 +533,10 @@ bool Parser::isStartOfFunctionDefinition() {
|
|||
/// [OMP] threadprivate-directive [TODO]
|
||||
///
|
||||
Parser::DeclGroupPtrTy
|
||||
Parser::ParseDeclarationOrFunctionDefinition(AttributeList *Attr,
|
||||
Parser::ParseDeclarationOrFunctionDefinition(ParsingDeclSpec &DS,
|
||||
AttributeList *Attr,
|
||||
AccessSpecifier AS) {
|
||||
// Parse the common declaration-specifiers piece.
|
||||
ParsingDeclSpec DS(*this);
|
||||
if (Attr)
|
||||
DS.AddAttributes(Attr);
|
||||
|
||||
|
@ -585,13 +585,20 @@ Parser::ParseDeclarationOrFunctionDefinition(AttributeList *Attr,
|
|||
DS.getStorageClassSpec() == DeclSpec::SCS_extern &&
|
||||
DS.getParsedSpecifiers() == DeclSpec::PQ_StorageClassSpecifier) {
|
||||
DS.abort();
|
||||
DeclPtrTy TheDecl = ParseLinkage(Declarator::FileContext);
|
||||
DeclPtrTy TheDecl = ParseLinkage(DS, Declarator::FileContext);
|
||||
return Actions.ConvertDeclToDeclGroup(TheDecl);
|
||||
}
|
||||
|
||||
return ParseDeclGroup(DS, Declarator::FileContext, true);
|
||||
}
|
||||
|
||||
Parser::DeclGroupPtrTy
|
||||
Parser::ParseDeclarationOrFunctionDefinition(AttributeList *Attr,
|
||||
AccessSpecifier AS) {
|
||||
ParsingDeclSpec DS(*this);
|
||||
return ParseDeclarationOrFunctionDefinition(DS, Attr, AS);
|
||||
}
|
||||
|
||||
/// ParseFunctionDefinition - We parsed and verified that the specified
|
||||
/// Declarator is well formed. If this is a K&R-style function, read the
|
||||
/// parameters declaration-list, then start the compound-statement.
|
||||
|
|
|
@ -0,0 +1,7 @@
|
|||
// RUN: clang-cc -fsyntax-only -verify %s
|
||||
|
||||
extern "C" int myarray[];
|
||||
int myarray[12] = {0};
|
||||
|
||||
extern "C" int anotherarray[][3];
|
||||
int anotherarray[2][3] = {1,2,3,4,5,6};
|
Loading…
Reference in New Issue