summaryrefslogtreecommitdiffstats
path: root/clang/lib/Sema/SemaLookup.cpp
diff options
context:
space:
mode:
authorJohn McCall <rjmccall@apple.com>2010-01-26 06:04:06 +0000
committerJohn McCall <rjmccall@apple.com>2010-01-26 06:04:06 +0000
commit91f61fc921e4abcaeb4a85b4e52f1db0cbdf2468 (patch)
treef14f7e273b91f84f3dad80e3bcdbac6e2fb03b35 /clang/lib/Sema/SemaLookup.cpp
parent273735bc5a50971a5902bb1695c8f5af279808c5 (diff)
downloadbcm5719-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.cpp24
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);
}
}
}
OpenPOWER on IntegriCloud