From 1bc5aee63eb72b341f506ad058502cd0361f0d10 Mon Sep 17 00:00:00 2001 From: Ben Cheng Date: Tue, 25 Mar 2014 22:37:19 -0700 Subject: Initial checkin of GCC 4.9.0 from trunk (r208799). Change-Id: I48a3c08bb98542aa215912a75f03c0890e497dba --- gcc-4.9/gcc/testsuite/objc.dg/isa-field-1.m | 64 +++++++++++++++++++++++++++++ 1 file changed, 64 insertions(+) create mode 100644 gcc-4.9/gcc/testsuite/objc.dg/isa-field-1.m (limited to 'gcc-4.9/gcc/testsuite/objc.dg/isa-field-1.m') diff --git a/gcc-4.9/gcc/testsuite/objc.dg/isa-field-1.m b/gcc-4.9/gcc/testsuite/objc.dg/isa-field-1.m new file mode 100644 index 000000000..4501d01a1 --- /dev/null +++ b/gcc-4.9/gcc/testsuite/objc.dg/isa-field-1.m @@ -0,0 +1,64 @@ +/* Ensure there are no bizarre difficulties with accessing the 'isa' field of objects. */ +/* { dg-do compile } */ + +#include "../objc-obj-c++-shared/TestsuiteObject.h" +#include "../objc-obj-c++-shared/runtime.h" + +@interface TestsuiteObject (Test) +- (Class) test1: (id)object; +@end + +@interface Derived: TestsuiteObject +- (Class) test2: (id)object; +@end + +@implementation TestsuiteObject (Test) + +Class test1(id object) { +#ifdef __NEXT_RUNTIME__ + Class cls = object->isa; +#else + Class cls = object->class_pointer; +#endif + return cls; +} +- (Class) test1: (id)object { +#ifdef __NEXT_RUNTIME__ + Class cls = object->isa; +#else + Class cls = object->class_pointer; +#endif + return cls; +} + +@end + +@implementation Derived + +Class test2(id object) { +#ifdef __NEXT_RUNTIME__ + Class cls = object->isa; +#else + Class cls = object->class_pointer; +#endif + return cls; +} +- (Class) test2: (id)object { +#ifdef __NEXT_RUNTIME__ + Class cls = object->isa; +#else + Class cls = object->class_pointer; +#endif + return cls; +} + +@end + +Class test3(id object) { +#ifdef __NEXT_RUNTIME__ + Class cls = object->isa; +#else + Class cls = object->class_pointer; +#endif + return cls; +} -- cgit v1.2.3