diff options
author | dpatel <dpatel@138bc75d-0d04-0410-961f-82ee72b054a4> | 2002-08-21 01:01:14 +0000 |
---|---|---|
committer | dpatel <dpatel@138bc75d-0d04-0410-961f-82ee72b054a4> | 2002-08-21 01:01:14 +0000 |
commit | 724dc00277ca01f310bb79bf55cd7098b2ebe7f8 (patch) | |
tree | 487ede87395d20bb36a115837b7d1c9b31422c63 /gcc | |
parent | 805892cfda9b76da114ec4fc44bce5a5a763991b (diff) | |
download | gcc-724dc00277ca01f310bb79bf55cd7098b2ebe7f8.tar.gz |
2002-08-20 Devang Patel <dpatel@apple.com>
* tree.c (get_qualified_type): Add TYPE_CONTEXT check.
testsuite:
* objc.dg/proto-hier-2.m: New test.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@56475 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/ChangeLog | 3 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 3 | ||||
-rw-r--r-- | gcc/testsuite/objc.dg/proto-hier-2.m | 49 | ||||
-rw-r--r-- | gcc/tree.c | 3 |
4 files changed, 57 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 62df30ae85a..00e4f4293e3 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,6 @@ +2002-08-20 Devang Patel <dpatel@apple.com> + * tree.c (get_qualified_type): Add TYPE_CONTEXT check. + 2002-08-20 Kaveh R. Ghazi <ghazi@caip.rutgers.edu> * arc.c (output_shift): Use stdio instead of asm_fprintf. diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 775dcb0e016..b682ab19329 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,6 @@ +2002-08-20 Devang Patel <dpatel@apple.com> + * objc.dg/proto-hier-2.m: New test. + 2002-08-19 Ziemowit Laski <zlaski@apple.com> * objc.dg/bitfield-1.m: New test. diff --git a/gcc/testsuite/objc.dg/proto-hier-2.m b/gcc/testsuite/objc.dg/proto-hier-2.m new file mode 100644 index 00000000000..453de89e5bf --- /dev/null +++ b/gcc/testsuite/objc.dg/proto-hier-2.m @@ -0,0 +1,49 @@ +/* Test protocol warning. */ +/* Contributed by Devang Patel <dpatel@apple.com>. */ +/* { dg-do compile } */ + +typedef struct objc_object { struct objc_class *class_pointer; } *id; + +@protocol Bar +@end + +id <Bar> Foo_Bar () { } + +typedef struct +{ + int i; +} MyStruct; + +@interface Foo +{ + id _mainData; + MyStruct *_anotherData; +} + +-(id) mainDataSource; +-(id) anotherDataSource; +-(id) my_method: (int) i; +@end + +@implementation Foo +-(id) anotherDataSource +{ + return (id)_anotherData; +} + +-(id) mainDataSource +{ + return _mainData; +} + +-(id) my_method: (int) i +{ + id one = [self anotherDataSource]; + + i = i - 1; + // Do not issue warning about my_method not implemented by protocol + return [(one ? [self mainDataSource] : one) my_method:i]; +} + +@end + diff --git a/gcc/tree.c b/gcc/tree.c index 9e725db7958..2c56b95f94e 100644 --- a/gcc/tree.c +++ b/gcc/tree.c @@ -2832,7 +2832,8 @@ get_qualified_type (type, type_quals) like the one we need to have. If so, use that existing one. We must preserve the TYPE_NAME, since there is code that depends on this. */ for (t = TYPE_MAIN_VARIANT (type); t; t = TYPE_NEXT_VARIANT (t)) - if (TYPE_QUALS (t) == type_quals && TYPE_NAME (t) == TYPE_NAME (type)) + if (TYPE_QUALS (t) == type_quals && TYPE_NAME (t) == TYPE_NAME (type) + && TYPE_CONTEXT (t) == TYPE_CONTEXT (type)) return t; return NULL_TREE; |