diff options
author | nicola <nicola@138bc75d-0d04-0410-961f-82ee72b054a4> | 2010-10-13 08:16:42 +0000 |
---|---|---|
committer | nicola <nicola@138bc75d-0d04-0410-961f-82ee72b054a4> | 2010-10-13 08:16:42 +0000 |
commit | 570c5a3d4bf441cde795a9f759d1f4b0c4302688 (patch) | |
tree | 90a905402a30b7ee4f28d659a1e3f13ab50b2d19 /libobjc/init.c | |
parent | 153fc3069d7201e894827104193c903a08401953 (diff) | |
download | gcc-570c5a3d4bf441cde795a9f759d1f4b0c4302688.tar.gz |
In libobjc/:
2010-10-13 Nicola Pero <nicola.pero@meta-innovation.com>
PR libobjc/23214
* init.c (objc_init_statics): Do not skip the initialization of a
statics list if the first object has already been initialized; in
the case of Protocols, while the first one may have been
initialized, some others may not have been initialized yet.
In gcc/testsuite/:
2010-10-13 Nicola Pero <nicola.pero@meta-innovation.com>
PR libobjc/23214
* objc.dg/pr23214.m: New.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@165414 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'libobjc/init.c')
-rw-r--r-- | libobjc/init.c | 36 |
1 files changed, 18 insertions, 18 deletions
diff --git a/libobjc/init.c b/libobjc/init.c index 0f714c40596..87122577829 100644 --- a/libobjc/init.c +++ b/libobjc/init.c @@ -473,28 +473,28 @@ objc_init_statics (void) Class class = objc_lookup_class (statics->class_name); if (! class) - module_initialized = 0; - /* Actually, the static's class_pointer will be NULL when we - haven't been here before. However, the comparison is to be - reminded of taking into account class posing and to think about - possible semantics... */ - else if (class != statics->instances[0]->class_pointer) { + /* It is unfortunate that this will cause all the + statics initialization to be done again (eg, if we + already initialized constant strings, and are now + initializing protocols, setting module_initialized to + 0 would cause constant strings to be initialized + again). It would be good to be able to track if we + have already initialized some of them. */ + module_initialized = 0; + } + else + { + /* Note that if this is a list of Protocol objects, some + of them may have been initialized already (because + they were attached to classes or categories, and the + class/category loading code automatically fixes them + up), and some of them may not. We really need to go + through the whole list to be sure! */ id *inst; for (inst = &statics->instances[0]; *inst; inst++) - { - (*inst)->class_pointer = class; - - /* ??? Make sure the object will not be freed. With - refcounting, invoke `-retain'. Without refcounting, do - nothing and hope that `-free' will never be invoked. */ - - /* ??? Send the object an `-initStatic' or something to - that effect now or later on? What are the semantics of - statically allocated instances, besides the trivial - NXConstantString, anyway? */ - } + (*inst)->class_pointer = class; } } if (module_initialized) |