Enlightenment CVS committal Author : raster Project : e17 Module : libs/eet
Dir : e17/libs/eet/src/lib Modified Files: eet_data.c Log Message: less allocs! =================================================================== RCS file: /cvsroot/enlightenment/e17/libs/eet/src/lib/eet_data.c,v retrieving revision 1.28 retrieving revision 1.29 diff -u -3 -r1.28 -r1.29 --- eet_data.c 23 Nov 2005 12:55:43 -0000 1.28 +++ eet_data.c 27 Nov 2005 14:32:44 -0000 1.29 @@ -97,6 +97,8 @@ Eet_Data_Descriptor_Hash *buckets; } hash; } elements; + char *strings; + int strings_len; }; struct _Eet_Data_Element @@ -723,14 +725,8 @@ void eet_data_descriptor_free(Eet_Data_Descriptor *edd) { - int i; - _eet_descriptor_hash_free(edd); - for (i = 0; i < edd->elements.num; i++) - { - if (edd->elements.set[i].name) free(edd->elements.set[i].name); - if (edd->elements.set[i].counter_name) free(edd->elements.set[i].counter_name); - } + if (edd->strings) free(edd->strings); if (edd->elements.set) free(edd->elements.set); free(edd); } @@ -743,18 +739,49 @@ Eet_Data_Descriptor *subtype) { Eet_Data_Element *ede; + int l1, l2, p1, p2, i; + char *ps; edd->elements.num++; edd->elements.set = realloc(edd->elements.set, edd->elements.num * sizeof(Eet_Data_Element)); if (!edd->elements.set) return; ede = &(edd->elements.set[edd->elements.num - 1]); - ede->name = strdup(name); + + l1 = strlen(name); + p1 = edd->strings_len; + if (counter_name) + { + l2 = strlen(counter_name); + p2 = p1 + l1 + 1; + } + else l2 = -1; + ps = edd->strings; + edd->strings_len += l1 + 1 + l2 + 1; + edd->strings = realloc(edd->strings, edd->strings_len); + if (!edd->strings) + { + edd->strings = ps; + return; + } + for (i = 0; i < edd->elements.num; i++) + { + edd->elements.set[i].name = + edd->strings + (edd->elements.set[i].name - ps); + if (edd->elements.set[i].counter_name) + edd->elements.set[i].counter_name = + edd->strings + (edd->elements.set[i].counter_name - ps); + } + ede->name = edd->strings + p1; + strcpy(ede->name, name); ede->type = type; ede->group_type = group_type; ede->offset = offset; ede->count = count; if (counter_name) - ede->counter_name = strdup(counter_name); + { + ede->counter_name = edd->strings + p2; + strcpy(ede->counter_name, counter_name); + } else ede->counter_name = NULL; ede->subtype = subtype; } ------------------------------------------------------- This SF.net email is sponsored by: Splunk Inc. Do you grep through log files for problems? Stop! Download the new AJAX search engine that makes searching your log files as easy as surfing the web. DOWNLOAD SPLUNK! http://ads.osdn.com/?ad_id=7637&alloc_id=16865&op=click _______________________________________________ enlightenment-cvs mailing list enlightenment-cvs@lists.sourceforge.net https://lists.sourceforge.net/lists/listinfo/enlightenment-cvs