forked from OSchip/llvm-project
Fix an amusing typo that completely the re-introduction of parameters
for the purposes of parsing default arguments. In effect, we would re-introduce the parameter with a default argument N times (where N is the number of parameters preceding the parameter with a default argument). This showed up when a defaulted parameter of a member function of a local class shadowed a parameter of the enclosing function. Fixes PR6383. llvm-svn: 97534
This commit is contained in:
parent
d0fa304dc7
commit
1d85d2903b
|
@ -1143,7 +1143,7 @@ void Parser::HandleMemberFunctionDefaultArgs(Declarator& DeclaratorInfo,
|
|||
LateMethod->DefaultArgs.reserve(FTI.NumArgs);
|
||||
for (unsigned I = 0; I < ParamIdx; ++I)
|
||||
LateMethod->DefaultArgs.push_back(
|
||||
LateParsedDefaultArgument(FTI.ArgInfo[ParamIdx].Param));
|
||||
LateParsedDefaultArgument(FTI.ArgInfo[I].Param));
|
||||
}
|
||||
|
||||
// Add this parameter to the list of parameters (it or may
|
||||
|
|
|
@ -15,3 +15,18 @@ namespace PR6382 {
|
|||
return -1;
|
||||
}
|
||||
}
|
||||
|
||||
namespace PR6383 {
|
||||
void test (bool gross)
|
||||
{
|
||||
struct compare_and_set
|
||||
{
|
||||
void operator() (const bool inner, const bool gross = false)
|
||||
{
|
||||
// the code
|
||||
}
|
||||
} compare_and_set2;
|
||||
|
||||
compare_and_set2 (false, gross);
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue