forked from OSchip/llvm-project
Fix a problem with the diagnostics of invalid arithmetic with function
pointers I found while working on the NULL arithmetic warning. We here always assuming the LHS was the pointer, instead of using the selected pointer expression. llvm-svn: 133428
This commit is contained in:
parent
2889f0c75b
commit
5f380da06f
|
@ -7218,13 +7218,13 @@ QualType Sema::CheckAdditionOperands( // C99 6.5.6
|
|||
} else if (PointeeTy->isFunctionType()) {
|
||||
if (getLangOptions().CPlusPlus) {
|
||||
Diag(Loc, diag::err_typecheck_pointer_arith_function_type)
|
||||
<< lex.get()->getType() << lex.get()->getSourceRange();
|
||||
<< PExp->getType() << PExp->getSourceRange();
|
||||
return QualType();
|
||||
}
|
||||
|
||||
// GNU extension: arithmetic on pointer to function
|
||||
Diag(Loc, diag::ext_gnu_ptr_func_arith)
|
||||
<< lex.get()->getType() << lex.get()->getSourceRange();
|
||||
<< PExp->getType() << PExp->getSourceRange();
|
||||
} else {
|
||||
// Check if we require a complete type.
|
||||
if (((PExp->getType()->isPointerType() &&
|
||||
|
|
|
@ -14,7 +14,8 @@ void a(S* b, void* c) {
|
|||
/* The next couple tests are only pedantic warnings in gcc */
|
||||
void (*d)(S*,void*) = a;
|
||||
d += 1; // expected-warning {{arithmetic on pointer to function type 'void (*)(S *, void *)' is a GNU extension}}
|
||||
d++; // expected-warning {{arithmetic on pointer to function type 'void (*)(S *, void *)' is a GNU extension}}}
|
||||
d++; // expected-warning {{arithmetic on pointer to function type 'void (*)(S *, void *)' is a GNU extension}}
|
||||
d--; // expected-warning {{arithmetic on pointer to function type 'void (*)(S *, void *)' is a GNU extension}}
|
||||
d -= 1; // expected-warning {{arithmetic on pointer to function type 'void (*)(S *, void *)' is a GNU extension}}
|
||||
(void)(1 + d); // expected-warning {{arithmetic on pointer to function type 'void (*)(S *, void *)' is a GNU extension}}
|
||||
}
|
||||
|
|
|
@ -33,7 +33,7 @@ void f() {
|
|||
v = 0 ? NULL + d : d + NULL; // \
|
||||
expected-error {{invalid operands to binary expression ('long' and 'void (X::*)()')}} \
|
||||
expected-error {{invalid operands to binary expression ('void (X::*)()' and 'long')}}
|
||||
v = 0 ? NULL + e : e + NULL; // expected-error 2{{arithmetic on pointer to function type}}
|
||||
v = 0 ? NULL + e : e + NULL; // expected-error 2{{arithmetic on pointer to function type 'void (*)()'}}
|
||||
v = 0 ? NULL + f : f + NULL; // expected-warning 2{{use of NULL in arithmetic operation}}
|
||||
v = 0 ? NULL + "f" : "f" + NULL; // expected-warning 2{{use of NULL in arithmetic operation}}
|
||||
|
||||
|
|
Loading…
Reference in New Issue