When adding the underlying declaration of a decl to a lookup-results

set, expand overloaded function declarations. Long-term, this should
actually be done by the name-lookup code rather than here, but this
part of the code (involving using declarations) is getting a makeover
now and the test-case is useful.

llvm-svn: 88846
This commit is contained in:
Douglas Gregor 2009-11-15 08:11:13 +00:00
parent 5ad7e15698
commit 54fdb417fe
2 changed files with 35 additions and 1 deletions

View File

@ -1212,7 +1212,20 @@ public:
/// \brief Add a declaration to these results. /// \brief Add a declaration to these results.
void addDecl(NamedDecl *D) { void addDecl(NamedDecl *D) {
Decls.push_back(D->getUnderlyingDecl()); // "Flatten" overloaded function declarations to get the underlying
// functions.
// FIXME: This may not be necessary with the impending using-declarations
// rewrite (11/09).
if (OverloadedFunctionDecl *Ovl
= dyn_cast<OverloadedFunctionDecl>(D->getUnderlyingDecl())) {
for (OverloadedFunctionDecl::function_iterator
F = Ovl->function_begin(),
FEnd = Ovl->function_end();
F != FEnd; ++F) {
Decls.push_back(*F);
}
} else
Decls.push_back(D->getUnderlyingDecl());
Kind = Found; Kind = Found;
} }

View File

@ -17,3 +17,24 @@ namespace N {
void f(int) { } // expected-error{{redefinition}} void f(int) { } // expected-error{{redefinition}}
} }
namespace N {
void f(double);
void f(long);
}
struct X0 {
void operator()(int);
void operator()(long);
};
struct X1 : X0 {
// FIXME: give this operator() a 'float' parameter to test overloading
// behavior. It currently fails.
void operator()();
using X0::operator();
void test() {
(*this)(1);
}
};