diff --git a/clang/lib/Parse/ParseCXXInlineMethods.cpp b/clang/lib/Parse/ParseCXXInlineMethods.cpp index 7ee74ecc7696..8a6e1ce33f3f 100644 --- a/clang/lib/Parse/ParseCXXInlineMethods.cpp +++ b/clang/lib/Parse/ParseCXXInlineMethods.cpp @@ -319,7 +319,11 @@ void Parser::ParseLexedMethodDeclaration(LateParsedMethodDeclaration &LM) { Sema::PotentiallyEvaluatedIfUsed, LM.DefaultArgs[I].Param); - ExprResult DefArgResult(ParseAssignmentExpression()); + ExprResult DefArgResult; + if (Tok.is(tok::l_brace)) + DefArgResult = ParseBraceInitializer(); + else + DefArgResult = ParseAssignmentExpression(); if (DefArgResult.isInvalid()) Actions.ActOnParamDefaultArgumentError(LM.DefaultArgs[I].Param); else { diff --git a/clang/lib/Parse/ParseDecl.cpp b/clang/lib/Parse/ParseDecl.cpp index 31a898cf5a0f..3ff9da035fd9 100644 --- a/clang/lib/Parse/ParseDecl.cpp +++ b/clang/lib/Parse/ParseDecl.cpp @@ -4169,6 +4169,7 @@ void Parser::ParseFunctionDeclaratorIdentifierList( /// parameter-declaration: [C99 6.7.5] /// declaration-specifiers declarator /// [C++] declaration-specifiers declarator '=' assignment-expression +/// [C++11] initializer-clause /// [GNU] declaration-specifiers declarator attributes /// declaration-specifiers abstract-declarator[opt] /// [C++] declaration-specifiers abstract-declarator[opt] @@ -4280,7 +4281,11 @@ void Parser::ParseParameterDeclarationClause( Sema::PotentiallyEvaluatedIfUsed, Param); - ExprResult DefArgResult(ParseAssignmentExpression()); + ExprResult DefArgResult; + if (Tok.is(tok::l_brace)) + DefArgResult = ParseBraceInitializer(); + else + DefArgResult = ParseAssignmentExpression(); if (DefArgResult.isInvalid()) { Actions.ActOnParamDefaultArgumentError(Param); SkipUntil(tok::comma, tok::r_paren, true, true); diff --git a/clang/test/SemaCXX/cxx0x-initializer-scalars.cpp b/clang/test/SemaCXX/cxx0x-initializer-scalars.cpp index 91fbaad8b1e6..627855e96e8c 100644 --- a/clang/test/SemaCXX/cxx0x-initializer-scalars.cpp +++ b/clang/test/SemaCXX/cxx0x-initializer-scalars.cpp @@ -96,6 +96,13 @@ namespace integral { (void) int({0}); // expected-error {{functional-style cast}} new int({0}); // expected-error {{cannot initialize}} } + + void default_argument(int i = {}) { + } + struct DefaultArgument { + void default_argument(int i = {}) { + } + }; } namespace PR12118 {