mirror of
https://github.com/llvm/llvm-project.git
synced 2025-05-09 09:56:06 +00:00

Converting a pointer to an integer whose result cannot represented in the integer type is undefined behavior is C and prohibited in C++. C++ already has a diagnostic when casting. This adds a diagnostic for C. Since this diagnostic uses the range of the conversion it also modifies int-to-pointer-cast diagnostic to use a range. Fixes PR8718: No warning on casting between pointer and non-pointer-sized int Differential Revision: https://reviews.llvm.org/D72231
47 lines
1.5 KiB
Objective-C
47 lines
1.5 KiB
Objective-C
// RUN: %clang_cc1 -fsyntax-only -verify -Wno-pointer-to-int-cast -Wno-objc-root-class %s
|
|
// rdar://5986251
|
|
|
|
@protocol SomeProtocol
|
|
- (void) bar;
|
|
@end
|
|
|
|
void bar();
|
|
void foo(id x) {
|
|
bar((short<SomeProtocol>)x); // expected-error {{expected ')'}} expected-note {{to match this '('}}
|
|
bar((<SomeProtocol>)x); // expected-warning {{protocol has no object type specified; defaults to qualified 'id'}}
|
|
|
|
[(<SomeProtocol>)x bar]; // expected-warning {{protocol has no object type specified; defaults to qualified 'id'}}
|
|
}
|
|
|
|
@protocol MyProtocol
|
|
- (void)doSomething;
|
|
@end
|
|
|
|
@interface MyClass
|
|
- (void)m1:(id <MyProtocol> const)arg1;
|
|
|
|
// FIXME: provide a better diagnostic (no typedef).
|
|
- (void)m2:(id <MyProtocol> short)arg1; // expected-error {{'short type-name' is invalid}}
|
|
@end
|
|
|
|
typedef int NotAnObjCObjectType;
|
|
|
|
// GCC doesn't diagnose this.
|
|
NotAnObjCObjectType <SomeProtocol> *obj; // expected-error {{invalid protocol qualifiers on non-ObjC type}}
|
|
|
|
typedef struct objc_class *Class;
|
|
|
|
Class <SomeProtocol> UnfortunateGCCExtension;
|
|
|
|
// rdar://10238337
|
|
@protocol Broken @end
|
|
@interface Crash @end
|
|
@implementation Crash
|
|
- (void)crashWith:(<Broken>)a { // expected-warning {{protocol has no object type specified; defaults to qualified 'id'}}
|
|
}
|
|
@end
|
|
|
|
typedef <SomeProtocol> id TwoTypeSpecs; // expected-warning{{no object type specified}}
|
|
// expected-error@-1{{typedef redefinition with different types ('id<SomeProtocol>' vs 'id')}}
|
|
// expected-error@-2{{expected ';' after top level declarator}}
|