[llvm-branch-commits] [cfe-branch] r105153 - /cfe/branches/Apple/whitney/lib/Sema/SemaCodeComplete.cpp
Daniel Dunbar
daniel at zuster.org
Sat May 29 23:24:45 PDT 2010
Author: ddunbar
Date: Sun May 30 01:24:45 2010
New Revision: 105153
URL: http://llvm.org/viewvc/llvm-project?rev=105153&view=rev
Log:
Merge r105152:
--
Author: Douglas Gregor <dgregor at apple.com>
Date: Sun May 30 06:10:08 2010 +0000
Teach code-completion for calls to be more careful with a
potentially-NULL "function" argument.
Modified:
cfe/branches/Apple/whitney/lib/Sema/SemaCodeComplete.cpp
Modified: cfe/branches/Apple/whitney/lib/Sema/SemaCodeComplete.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/branches/Apple/whitney/lib/Sema/SemaCodeComplete.cpp?rev=105153&r1=105152&r2=105153&view=diff
==============================================================================
--- cfe/branches/Apple/whitney/lib/Sema/SemaCodeComplete.cpp (original)
+++ cfe/branches/Apple/whitney/lib/Sema/SemaCodeComplete.cpp Sun May 30 01:24:45 2010
@@ -2534,6 +2534,17 @@
};
}
+static bool anyNullArguments(Expr **Args, unsigned NumArgs) {
+ if (NumArgs && !Args)
+ return true;
+
+ for (unsigned I = 0; I != NumArgs; ++I)
+ if (!Args[I])
+ return true;
+
+ return false;
+}
+
void Sema::CodeCompleteCall(Scope *S, ExprTy *FnIn,
ExprTy **ArgsIn, unsigned NumArgs) {
if (!CodeCompleter)
@@ -2548,7 +2559,7 @@
Expr **Args = (Expr **)ArgsIn;
// Ignore type-dependent call expressions entirely.
- if (Fn->isTypeDependent() ||
+ if (!Fn || Fn->isTypeDependent() || anyNullArguments(Args, NumArgs) ||
Expr::hasAnyTypeDependentArguments(Args, NumArgs)) {
CodeCompleteOrdinaryName(S, CCC_Expression);
return;
@@ -2572,7 +2583,8 @@
else if (DeclRefExpr *DRE = dyn_cast<DeclRefExpr>(NakedFn)) {
FunctionDecl *FDecl = dyn_cast<FunctionDecl>(DRE->getDecl());
if (FDecl) {
- if (!FDecl->getType()->getAs<FunctionProtoType>())
+ if (!getLangOptions().CPlusPlus ||
+ !FDecl->getType()->getAs<FunctionProtoType>())
Results.push_back(ResultCandidate(FDecl));
else
// FIXME: access?
More information about the llvm-branch-commits
mailing list