diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index a175424fcae..c9a0dc63070 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2010-11-06 Iain Sandoe + + * obj-c++.dg/encode-3.mm: Provide a different string check for the + NeXT runtime when the type is READONLY. + 2010-11-06 Uros Bizjak * gcc.target/i386/387-2.c: Skip if -march= is specified. diff --git a/gcc/testsuite/obj-c++.dg/encode-3.mm b/gcc/testsuite/obj-c++.dg/encode-3.mm index 44f288d7de0..1486a652a0d 100644 --- a/gcc/testsuite/obj-c++.dg/encode-3.mm +++ b/gcc/testsuite/obj-c++.dg/encode-3.mm @@ -32,6 +32,15 @@ const char *enc3 = @encode(anonymous); #define L "l" #endif +/* Darwin (at least, as of XCode 3.2.3/Darwin10) does not encode the read-only + attribute on the type. Arguably, this is a bug, but we are compatible + with this when -fnext-runtime is selected. */ +#ifdef __NEXT_RUNTIME__ +#define E3 "{?=f[10d]i" L "q{Vec=cc" L "q}}" +#else +#define E3 "{?=f[10d]i" L "q{Vec=rcrc" L "q}}" +#endif + int main(void) { const char *encode = @encode(long); @@ -44,7 +53,7 @@ int main(void) { if (strcmp (enc2, (const char *)"{Vec=dd" L "q}")) abort (); - if (strcmp (enc3, (const char *)"{?=f[10d]i" L "q{Vec=rcrc" L "q}}")) + if (strcmp (enc3, (const char *) E3)) abort (); return 0;