diff options
author | John McCall <rjmccall@apple.com> | 2010-01-26 06:04:06 +0000 |
---|---|---|
committer | John McCall <rjmccall@apple.com> | 2010-01-26 06:04:06 +0000 |
commit | 91f61fc921e4abcaeb4a85b4e52f1db0cbdf2468 (patch) | |
tree | f14f7e273b91f84f3dad80e3bcdbac6e2fb03b35 /clang/lib/Sema/SemaLookup.cpp | |
parent | 273735bc5a50971a5902bb1695c8f5af279808c5 (diff) | |
download | bcm5719-llvm-91f61fc921e4abcaeb4a85b4e52f1db0cbdf2468.tar.gz bcm5719-llvm-91f61fc921e4abcaeb4a85b4e52f1db0cbdf2468.zip |
Allow ADL to find functions imported by using decls. Leave wordy comment
about interaction between ADL and default arguments. Shrug shoulders, commit.
llvm-svn: 94524
Diffstat (limited to 'clang/lib/Sema/SemaLookup.cpp')
-rw-r--r-- | clang/lib/Sema/SemaLookup.cpp | 24 |
1 files changed, 14 insertions, 10 deletions
diff --git a/clang/lib/Sema/SemaLookup.cpp b/clang/lib/Sema/SemaLookup.cpp index 5b03fa48c32..c61d666c4b0 100644 --- a/clang/lib/Sema/SemaLookup.cpp +++ b/clang/lib/Sema/SemaLookup.cpp @@ -1785,16 +1785,20 @@ void Sema::ArgumentDependentLookup(DeclarationName Name, bool Operator, continue; } - // FIXME: using decls? canonical decls? - - FunctionDecl *Fn; - if (!Operator || !(Fn = dyn_cast<FunctionDecl>(D)) || - IsAcceptableNonMemberOperatorCandidate(Fn, T1, T2, Context)) { - if (isa<FunctionDecl>(D)) - Functions.insert(D); - else if (isa<FunctionTemplateDecl>(D)) - Functions.insert(D); - } + if (isa<UsingShadowDecl>(D)) + D = cast<UsingShadowDecl>(D)->getTargetDecl(); + + // FIXME: canonical decls. + // See comment in AddArgumentDependentLookupCandidates(). + + if (isa<FunctionDecl>(D)) { + if (Operator && + !IsAcceptableNonMemberOperatorCandidate(cast<FunctionDecl>(D), + T1, T2, Context)) + continue; + Functions.insert(D); + } else if (isa<FunctionTemplateDecl>(D)) + Functions.insert(D); } } } |