llvm-capstone/clang/test/SemaObjC/qualified-protocol-method-conflicts.m
Fariborz Jahanian 3c12dd7675 objective-c: Using existing infrastructure for finding
overridden  methods to diagnose their type mismatch.
This is a general solution for previous fixes
for // rdar://6191214 and // rdar://9352731
and removes lots of duplicate code.

llvm-svn: 137222
2011-08-10 17:16:30 +00:00

40 lines
1.3 KiB
Objective-C

// RUN: %clang_cc1 -Woverriding-method-mismatch -fsyntax-only -verify %s
// rdar://6191214
@protocol Xint
-(void) setX: (int) arg0; // expected-note {{previous declaration is here}}
+(int) C; // expected-note {{previous declaration is here}}
@end
@protocol Xfloat
-(void) setX: (float) arg0; // expected-note 2 {{previous declaration is here}}
+(float) C; // expected-note 2 {{previous declaration is here}}
@end
@interface A <Xint, Xfloat>
@end
@implementation A
-(void) setX: (int) arg0 { } // expected-warning {{conflicting parameter types in declaration of 'setX:': 'float' vs 'int'}}
+(int) C {return 0; } // expected-warning {{conflicting return type in declaration of 'C': 'float' vs 'int'}}
@end
@interface B <Xfloat, Xint>
@end
@implementation B
-(void) setX: (float) arg0 { } // expected-warning {{conflicting parameter types in declaration of 'setX:': 'int' vs 'float'}}
+ (float) C {return 0.0; } // expected-warning {{conflicting return type in declaration of 'C': 'int' vs 'float'}}
@end
@protocol Xint_float<Xint, Xfloat>
@end
@interface C<Xint_float>
@end
@implementation C
-(void) setX: (int) arg0 { } // expected-warning {{conflicting parameter types in declaration of 'setX:': 'float' vs 'int'}}
+ (int) C {return 0;} // expected-warning {{conflicting return type in declaration of 'C': 'float' vs 'int'}}
@end