forked from OSchip/llvm-project
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:
parent
5ad7e15698
commit
54fdb417fe
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
Loading…
Reference in New Issue