From 1d85d2903b07e036f16e2f73f6eda89bdf50712c Mon Sep 17 00:00:00 2001 From: Douglas Gregor Date: Tue, 2 Mar 2010 01:29:43 +0000 Subject: 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 --- clang/test/SemaCXX/local-classes.cpp | 15 +++++++++++++++ 1 file changed, 15 insertions(+) (limited to 'clang/test/SemaCXX/local-classes.cpp') diff --git a/clang/test/SemaCXX/local-classes.cpp b/clang/test/SemaCXX/local-classes.cpp index 3c216d0863e..6799e58e954 100644 --- a/clang/test/SemaCXX/local-classes.cpp +++ b/clang/test/SemaCXX/local-classes.cpp @@ -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); + } +} -- cgit v1.2.3