From 724dc00277ca01f310bb79bf55cd7098b2ebe7f8 Mon Sep 17 00:00:00 2001 From: dpatel Date: Wed, 21 Aug 2002 01:01:14 +0000 Subject: [PATCH] 2002-08-20 Devang Patel * 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 --- gcc/ChangeLog | 3 +++ gcc/testsuite/ChangeLog | 3 +++ gcc/testsuite/objc.dg/proto-hier-2.m | 49 ++++++++++++++++++++++++++++++++++++ gcc/tree.c | 3 ++- 4 files changed, 57 insertions(+), 1 deletion(-) create mode 100644 gcc/testsuite/objc.dg/proto-hier-2.m 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 + * tree.c (get_qualified_type): Add TYPE_CONTEXT check. + 2002-08-20 Kaveh R. Ghazi * 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 + * objc.dg/proto-hier-2.m: New test. + 2002-08-19 Ziemowit Laski * 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 . */ +/* { dg-do compile } */ + +typedef struct objc_object { struct objc_class *class_pointer; } *id; + +@protocol Bar +@end + +id 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; -- 2.11.0