forked from OSchip/llvm-project
Handle some more fallout with the conversion of using PointerType for
Objective-C pointers to using ObjCObjectPointerType. Now the checking for 'attribute ((nonnull))' in Sema doesn't emit an error when trying to apply that attribute to a parameter that is an Objective-C pointer (this is a regression). To prevent this regression from occuring in the future, the 'nonnull.c' test was moved to test/SemaObjC and renamed 'nonnull.m'. I also enhanced the tests to show that function calls involved a NULL Objective-C pointer constant does not trigger a warning. This is consistent with GCC, but should likely be fixed. llvm-svn: 75856
This commit is contained in:
parent
24d2383a19
commit
d4adebbbd6
|
@ -352,7 +352,7 @@ static void HandleNonNullAttr(Decl *d, const AttributeList &Attr, Sema &S) {
|
|||
|
||||
// Is the function argument a pointer type?
|
||||
QualType T = getFunctionOrMethodArgType(d, x);
|
||||
if (!T->isPointerType() && !T->isBlockPointerType()) {
|
||||
if (!T->isAnyPointerType() && !T->isBlockPointerType()) {
|
||||
// FIXME: Should also highlight argument in decl.
|
||||
S.Diag(Attr.getLoc(), diag::err_nonnull_pointers_only)
|
||||
<< "nonnull" << Ex->getSourceRange();
|
||||
|
@ -367,7 +367,7 @@ static void HandleNonNullAttr(Decl *d, const AttributeList &Attr, Sema &S) {
|
|||
if (NonNullArgs.empty()) {
|
||||
for (unsigned I = 0, E = getFunctionOrMethodNumArgs(d); I != E; ++I) {
|
||||
QualType T = getFunctionOrMethodArgType(d, I);
|
||||
if (T->isPointerType() || T->isBlockPointerType())
|
||||
if (T->isAnyPointerType() || T->isBlockPointerType())
|
||||
NonNullArgs.push_back(I);
|
||||
}
|
||||
|
||||
|
|
|
@ -1,10 +1,15 @@
|
|||
// RUN: clang-cc -fblocks -fsyntax-only -verify %s
|
||||
|
||||
@class NSObject;
|
||||
|
||||
int f1(int x) __attribute__((nonnull)); // expected-warning{{'nonnull' attribute applied to function with no pointer arguments}}
|
||||
int f2(int *x) __attribute__ ((nonnull (1)));
|
||||
int f3(int *x) __attribute__ ((nonnull (0))); // expected-error {{'nonnull' attribute parameter 1 is out of bounds}}
|
||||
int f4(int *x, int *y) __attribute__ ((nonnull (1,2)));
|
||||
int f5(int *x, int *y) __attribute__ ((nonnull (2,1)));
|
||||
int f6(NSObject *x) __attribute__ ((nonnull (1))); // no-warning
|
||||
int f7(NSObject *x) __attribute__ ((nonnull)); // no-warning
|
||||
|
||||
|
||||
extern void func1 (void (^block1)(), void (^block2)(), int) __attribute__((nonnull));
|
||||
|
||||
|
@ -29,4 +34,9 @@ foo (int i1, int i2, int i3, void (^cp1)(), void (^cp2)(), void (^cp3)())
|
|||
|
||||
func4(0, cp1); // expected-warning {{null passed to a callee which requires a non-null argument}}
|
||||
func4(cp1, 0); // expected-warning {{null passed to a callee which requires a non-null argument}}
|
||||
|
||||
// Shouldn't these emit warnings? Clang doesn't, and neither does GCC. It
|
||||
// seems that the checking should handle Objective-C pointers.
|
||||
func6((NSObject*) 0); // no-warning
|
||||
func7((NSObject*) 0); // no-warning
|
||||
}
|
Loading…
Reference in New Issue