summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorNick Lewycky <nicholas@mxc.ca>2013-01-24 02:03:08 +0000
committerNick Lewycky <nicholas@mxc.ca>2013-01-24 02:03:08 +0000
commitd24d5f2b7979087908a59dc35807aba99905536b (patch)
treebd4ce0b022702d1fd3455d509a97a1e7b0844682
parente112151a3582657ed7a441bcb3b874402cb14ffd (diff)
downloadbcm5719-llvm-d24d5f2b7979087908a59dc35807aba99905536b.tar.gz
bcm5719-llvm-d24d5f2b7979087908a59dc35807aba99905536b.zip
Start checking nonnull (as well as format and argument_with_type_tag) on
overloaded binary operators. llvm-svn: 173315
-rw-r--r--clang/lib/Sema/SemaOverload.cpp7
-rw-r--r--clang/test/SemaCXX/attr-nonnull.cpp12
2 files changed, 19 insertions, 0 deletions
diff --git a/clang/lib/Sema/SemaOverload.cpp b/clang/lib/Sema/SemaOverload.cpp
index 91d02dacc82..e1c3d6839d1 100644
--- a/clang/lib/Sema/SemaOverload.cpp
+++ b/clang/lib/Sema/SemaOverload.cpp
@@ -10336,6 +10336,13 @@ Sema::CreateOverloadedBinOp(SourceLocation OpLoc,
FnDecl))
return ExprError();
+ ArrayRef<const Expr *> ArgsArray(Args, 2);
+ // Cut off the implicit 'this'.
+ if (isa<CXXMethodDecl>(FnDecl))
+ ArgsArray = ArgsArray.slice(1);
+ checkCall(FnDecl, ArgsArray, 0, isa<CXXMethodDecl>(FnDecl), OpLoc,
+ TheCall->getSourceRange(), VariadicDoesNotApply);
+
return MaybeBindToTemporary(TheCall);
} else {
// We matched a built-in operator. Convert the arguments, then
diff --git a/clang/test/SemaCXX/attr-nonnull.cpp b/clang/test/SemaCXX/attr-nonnull.cpp
index 76e1b74068c..8af49d9d29e 100644
--- a/clang/test/SemaCXX/attr-nonnull.cpp
+++ b/clang/test/SemaCXX/attr-nonnull.cpp
@@ -40,3 +40,15 @@ void g() {
f(static_cast<char*>(0)); // expected-warning{{null passed}}
}
}
+
+namespace test4 {
+struct X {
+ bool operator!=(const void *) const __attribute__((nonnull(2)));
+};
+bool operator==(const X&, const void *) __attribute__((nonnull(2)));
+
+void test(const X& x) {
+ (void)(x == 0); // expected-warning{{null passed}}
+ (void)(x != 0); // expected-warning{{null passed}}
+}
+}
OpenPOWER on IntegriCloud