diff options
-rw-r--r-- | camel/ChangeLog | 6 | ||||
-rw-r--r-- | camel/providers/imap4/camel-imap4-search.c | 16 |
2 files changed, 16 insertions, 6 deletions
diff --git a/camel/ChangeLog b/camel/ChangeLog index 763f858ef1..9be670b4a6 100644 --- a/camel/ChangeLog +++ b/camel/ChangeLog @@ -1,3 +1,9 @@ +2004-06-30 Jeffrey Stedfast <fejj@novell.com> + + * providers/imap4/camel-imap4-search.c (imap4_body_contains): Set + the size of the ptrarray to prevent potentially realloc'ing + several times. + 2004-06-29 Jeffrey Stedfast <fejj@novell.com> * providers/imap4/camel-imap4-command.c diff --git a/camel/providers/imap4/camel-imap4-search.c b/camel/providers/imap4/camel-imap4-search.c index 4a23dee83e..0a10ea5139 100644 --- a/camel/providers/imap4/camel-imap4-search.c +++ b/camel/providers/imap4/camel-imap4-search.c @@ -174,9 +174,11 @@ imap4_body_contains (struct _ESExp *f, int argc, struct _ESExpResult **argv, Cam } else { r = e_sexp_result_new (f, ESEXP_RES_ARRAY_PTR); r->value.ptrarray = g_ptr_array_new (); + g_ptr_array_set_size (r->value.ptrarray, summary_set->len); + r->value.ptrarray->len = summary_set->len; for (i = 0; i < summary_set->len; i++) { info = g_ptr_array_index (summary_set, i); - g_ptr_array_add (r->value.ptrarray, (char *) camel_message_info_uid (info)); + r->value.ptrarray->pdata[i] = (char *) camel_message_info_uid (info); } } @@ -211,9 +213,11 @@ imap4_body_contains (struct _ESExp *f, int argc, struct _ESExpResult **argv, Cam } else { r = e_sexp_result_new (f, ESEXP_RES_ARRAY_PTR); r->value.ptrarray = g_ptr_array_new (); + g_ptr_array_set_size (r->value.ptrarray, summary_set->len); + r->value.ptrarray->len = summary_set->len; for (i = 0; i < summary_set->len; i++) { info = g_ptr_array_index (summary_set, i); - g_ptr_array_add (r->value.ptrarray, (char *) camel_message_info_uid (info)); + r->value.ptrarray->pdata[i] = (char *) camel_message_info_uid (info); } } @@ -227,10 +231,10 @@ imap4_body_contains (struct _ESExp *f, int argc, struct _ESExpResult **argv, Cam if (search->current) { g_ptr_array_add (infos, search->current); } else { - for (i = 0; i < summary_set->len; i++) { - info = g_ptr_array_index (summary_set, i); - g_ptr_array_add (infos, info); - } + g_ptr_array_set_size (infos, summary_set->len); + infos->len = summary_set->len; + for (i = 0; i < summary_set->len; i++) + infos->pdata[i] = summary_set->pdata[i]; } retry: |