2011-11-15 09:35:18 +08:00
// RUN: %clang_cc1 -std=c++11 -fsyntax-only -verify %s
2011-02-08 10:14:35 +08:00
struct X {
void f() const;
~X();
};
@interface A {
X x_;
}
- (const X&)x;
- (void)setx:(const X&)other;
@end
@implementation A
- (const X&)x { return x_; }
- (void)setx:(const X&)other { x_ = other; }
- (void)method {
self.x.f();
2011-11-15 09:35:18 +08:00
}
2011-02-08 10:14:35 +08:00
@end
2011-11-15 09:35:18 +08:00
// rdar://problem/10444030
@interface Test2
- (void) setY: (int) y;
- (int) z;
@end
void test2(Test2 *a) {
auto y = a.y; // expected-error {{expected getter method not found on object of type 'Test2 *'}} expected-error {{variable 'y' with type 'auto' has incompatible initializer of type}}
auto z = a.z;
}
2012-01-11 08:14:46 +08:00
// rdar://problem/10672108
@interface Test3
- (int) length;
@end
void test3(Test3 *t) {
2012-01-11 09:35:55 +08:00
char vla[t.length] = {}; // expected-error {{variable-sized object may not be initialized}}
char *heaparray = new char[t.length];
2012-01-11 08:14:46 +08:00
}
2012-01-12 08:44:34 +08:00
2012-01-13 00:11:24 +08:00
// <rdar://problem/10672501>
namespace std {
template<typename T> void count();
}
2012-01-14 00:56:26 +08:00
@interface Test4
- (X&) prop;
@end
void test4(Test4 *t) {
(void)const_cast<const X&>(t.prop);
(void)dynamic_cast<X&>(t.prop);
(void)reinterpret_cast<int&>(t.prop);
}
@interface Test5 {
2012-01-13 00:11:24 +08:00
@public
int count;
}
@property int count;
2012-01-12 08:44:34 +08:00
@end
2012-01-13 00:11:24 +08:00
2012-01-14 00:56:26 +08:00
void test5(Test5* t5) {
if (t5.count < 2) { }
if (t5->count < 2) { }
2012-01-12 08:44:34 +08:00
}
2012-01-13 00:11:24 +08:00