aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorZiemowit Laski <zlaski@apple.com>2003-04-01 22:11:01 +0000
committerZiemowit Laski <zlaski@gcc.gnu.org>2003-04-01 22:11:01 +0000
commit70ab763c5b138f42662a054941d19fa064ac951c (patch)
tree042494b14378e25a14d5ed0bff846d257a2e7243 /gcc
parentfe0002ee9dd1311b3dc451132198def49a465203 (diff)
downloadgcc-70ab763c5b138f42662a054941d19fa064ac951c.zip
gcc-70ab763c5b138f42662a054941d19fa064ac951c.tar.gz
gcc-70ab763c5b138f42662a054941d19fa064ac951c.tar.bz2
defs.m: New.
2003-04-01 Ziemowit Laski <zlaski@apple.com> * objc.dg/defs.m: New. From-SVN: r65147
Diffstat (limited to 'gcc')
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/objc.dg/defs.m67
2 files changed, 71 insertions, 1 deletions
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index f8cb3ba..c66386e 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,7 +1,10 @@
+2003-04-01 Ziemowit Laski <zlaski@apple.com>
+
+ * objc.dg/defs.m: New.
+
2003-04-01 Aldy Hernandez <aldyh@redhat.com>
* g++.dg/eh/simd-1.C: New.
-
* g++.dg/eh/simd-2.C: New.
2003-03-01 Aldy Hernandez <aldyh@redhat.com>
diff --git a/gcc/testsuite/objc.dg/defs.m b/gcc/testsuite/objc.dg/defs.m
new file mode 100644
index 0000000..e8d8c2c
--- /dev/null
+++ b/gcc/testsuite/objc.dg/defs.m
@@ -0,0 +1,67 @@
+/* Check if the @defs() construct preserves the correct
+ offsets of ivars. */
+/* Contributed by Ziemowit Laski <zlaski@apple.com>. */
+/* { dg-options "-lobjc" } */
+/* { dg-do run } */
+
+#include <objc/objc.h>
+#include <objc/Object.h>
+
+extern void abort(void);
+
+#define CHECK_IF(expr) if(!(expr)) abort();
+
+@interface Base: Object {
+@public
+ int a;
+ float b;
+ char c;
+}
+@end
+
+@interface Derived: Base {
+@public
+ double d;
+ unsigned e;
+ id f;
+}
+- init;
+@end
+
+struct Derived_defs {
+ @defs(Derived);
+};
+
+@implementation Base
+@end
+@implementation Derived
+- init {
+ [super init];
+ a = 123;
+ b = 1.23;
+ c = 'c';
+ d = 123.456;
+ e = 456;
+ f = isa;
+ return self;
+}
+@end
+
+int main(void) {
+ Derived *derived = [[Derived alloc] init];
+ struct Derived_defs *derived_defs = (struct Derived_defs *)derived;
+
+ CHECK_IF(derived->a == derived_defs->a && derived_defs->a == 123);
+ CHECK_IF(derived->b == derived_defs->b && derived_defs->b == (float)1.23);
+ CHECK_IF(derived->c == derived_defs->c && derived_defs->c == 'c');
+ CHECK_IF(derived->d == derived_defs->d && derived_defs->d == (double)123.456);
+ CHECK_IF(derived->e == derived_defs->e && derived_defs->e == 456);
+ CHECK_IF(derived->f == derived_defs->f && derived_defs->f == derived_defs->isa);
+
+ /* Try out the "inline" notation as well. */
+ CHECK_IF(((struct { @defs(Derived); } *)derived)->a == 123);
+ CHECK_IF(((struct { @defs(Derived); } *)derived)->c == 'c');
+ CHECK_IF(((struct { @defs(Derived); } *)derived)->e == 456);
+
+ return 0;
+}