author | alwin <alwin> | 2004-10-23 19:42:19 (UTC) |
---|---|---|
committer | alwin <alwin> | 2004-10-23 19:42:19 (UTC) |
commit | b3d4cb2af9cd4b3a56b581ba89a4c9fa0d9312af (patch) (unidiff) | |
tree | 993e629f5f8c1dcf66e1c294d840cc4aa0100ae1 | |
parent | b5d111eb79896d02aa13d41a04ce6aa4dbc4aa49 (diff) | |
download | opie-b3d4cb2af9cd4b3a56b581ba89a4c9fa0d9312af.zip opie-b3d4cb2af9cd4b3a56b581ba89a4c9fa0d9312af.tar.gz opie-b3d4cb2af9cd4b3a56b581ba89a4c9fa0d9312af.tar.bz2 |
holla - fixed a wonderfull bug letting opie-mail crash when
accessing some pop3-server
-rw-r--r-- | noncore/net/mail/libmailwrapper/genericwrapper.cpp | 15 |
1 files changed, 7 insertions, 8 deletions
diff --git a/noncore/net/mail/libmailwrapper/genericwrapper.cpp b/noncore/net/mail/libmailwrapper/genericwrapper.cpp index 3e4293b..1caa375 100644 --- a/noncore/net/mail/libmailwrapper/genericwrapper.cpp +++ b/noncore/net/mail/libmailwrapper/genericwrapper.cpp | |||
@@ -116,49 +116,49 @@ QString Genericwrapper::getencoding(mailmime_mechanism*aEnc) | |||
116 | enc = "8bit"; | 116 | enc = "8bit"; |
117 | break; | 117 | break; |
118 | case MAILMIME_MECHANISM_BINARY: | 118 | case MAILMIME_MECHANISM_BINARY: |
119 | enc = "binary"; | 119 | enc = "binary"; |
120 | break; | 120 | break; |
121 | case MAILMIME_MECHANISM_QUOTED_PRINTABLE: | 121 | case MAILMIME_MECHANISM_QUOTED_PRINTABLE: |
122 | enc = "quoted-printable"; | 122 | enc = "quoted-printable"; |
123 | break; | 123 | break; |
124 | case MAILMIME_MECHANISM_BASE64: | 124 | case MAILMIME_MECHANISM_BASE64: |
125 | enc = "base64"; | 125 | enc = "base64"; |
126 | break; | 126 | break; |
127 | case MAILMIME_MECHANISM_TOKEN: | 127 | case MAILMIME_MECHANISM_TOKEN: |
128 | default: | 128 | default: |
129 | if (aEnc->enc_token) { | 129 | if (aEnc->enc_token) { |
130 | enc = QString(aEnc->enc_token); | 130 | enc = QString(aEnc->enc_token); |
131 | } | 131 | } |
132 | break; | 132 | break; |
133 | } | 133 | } |
134 | return enc; | 134 | return enc; |
135 | } | 135 | } |
136 | 136 | ||
137 | void Genericwrapper::traverseBody(RecBodyP&target,mailmessage*message,mailmime*mime,QValueList<int>recList,unsigned int current_rec,int current_count) | 137 | void Genericwrapper::traverseBody(RecBodyP&target,mailmessage*message,mailmime*mime,QValueList<int>recList,unsigned int current_rec,int current_count) |
138 | { | 138 | { |
139 | if (current_rec >= 10) { | 139 | if (current_rec >= 10) { |
140 | odebug << "too deep recursion!" << oendl; | 140 | odebug << "too deep recursion!" << oendl; |
141 | } | 141 | } |
142 | if (!message || !mime) { | 142 | if (!message || !mime) { |
143 | return; | 143 | return; |
144 | } | 144 | } |
145 | int r; | 145 | int r; |
146 | char*data = 0; | 146 | char*data = 0; |
147 | size_t len; | 147 | size_t len; |
148 | clistiter * cur = 0; | 148 | clistiter * cur = 0; |
149 | QString b; | 149 | QString b; |
150 | RecPartP part = new RecPart(); | 150 | RecPartP part = new RecPart(); |
151 | 151 | ||
152 | switch (mime->mm_type) { | 152 | switch (mime->mm_type) { |
153 | case MAILMIME_SINGLE: | 153 | case MAILMIME_SINGLE: |
154 | { | 154 | { |
155 | QValueList<int>countlist = recList; | 155 | QValueList<int>countlist = recList; |
156 | countlist.append(current_count); | 156 | countlist.append(current_count); |
157 | r = mailmessage_fetch_section(message,mime,&data,&len); | 157 | r = mailmessage_fetch_section(message,mime,&data,&len); |
158 | part->setSize(len); | 158 | part->setSize(len); |
159 | part->setPositionlist(countlist); | 159 | part->setPositionlist(countlist); |
160 | b = gen_attachment_id(); | 160 | b = gen_attachment_id(); |
161 | part->setIdentifier(b); | 161 | part->setIdentifier(b); |
162 | fillSingleBody(part,message,mime); | 162 | fillSingleBody(part,message,mime); |
163 | if (part->Type()=="text" && target->Bodytext().isNull()) { | 163 | if (part->Type()=="text" && target->Bodytext().isNull()) { |
164 | encodedString*rs = new encodedString(); | 164 | encodedString*rs = new encodedString(); |
@@ -253,49 +253,49 @@ QString Genericwrapper::parseDateTime( mailimf_date_time *date ) | |||
253 | 253 | ||
254 | QString Genericwrapper::parseAddressList( mailimf_address_list *list ) | 254 | QString Genericwrapper::parseAddressList( mailimf_address_list *list ) |
255 | { | 255 | { |
256 | QString result( "" ); | 256 | QString result( "" ); |
257 | 257 | ||
258 | bool first = true; | 258 | bool first = true; |
259 | if (list == 0) return result; | 259 | if (list == 0) return result; |
260 | for ( clistiter *current = clist_begin( list->ad_list ); current != NULL; current = current->next ) { | 260 | for ( clistiter *current = clist_begin( list->ad_list ); current != NULL; current = current->next ) { |
261 | mailimf_address *addr = (mailimf_address *) current->data; | 261 | mailimf_address *addr = (mailimf_address *) current->data; |
262 | 262 | ||
263 | if ( !first ) { | 263 | if ( !first ) { |
264 | result.append( "," ); | 264 | result.append( "," ); |
265 | } else { | 265 | } else { |
266 | first = false; | 266 | first = false; |
267 | } | 267 | } |
268 | 268 | ||
269 | switch ( addr->ad_type ) { | 269 | switch ( addr->ad_type ) { |
270 | case MAILIMF_ADDRESS_MAILBOX: | 270 | case MAILIMF_ADDRESS_MAILBOX: |
271 | result.append( parseMailbox( addr->ad_data.ad_mailbox ) ); | 271 | result.append( parseMailbox( addr->ad_data.ad_mailbox ) ); |
272 | break; | 272 | break; |
273 | case MAILIMF_ADDRESS_GROUP: | 273 | case MAILIMF_ADDRESS_GROUP: |
274 | result.append( parseGroup( addr->ad_data.ad_group ) ); | 274 | result.append( parseGroup( addr->ad_data.ad_group ) ); |
275 | break; | 275 | break; |
276 | default: | 276 | default: |
277 | odebug << "Generic: unkown mailimf address type" << oendl; | 277 | odebug << "Generic: unkown mailimf address type" << oendl; |
278 | break; | 278 | break; |
279 | } | 279 | } |
280 | } | 280 | } |
281 | 281 | ||
282 | return result; | 282 | return result; |
283 | } | 283 | } |
284 | 284 | ||
285 | QString Genericwrapper::parseGroup( mailimf_group *group ) | 285 | QString Genericwrapper::parseGroup( mailimf_group *group ) |
286 | { | 286 | { |
287 | QString result( "" ); | 287 | QString result( "" ); |
288 | 288 | ||
289 | result.append( group->grp_display_name ); | 289 | result.append( group->grp_display_name ); |
290 | result.append( ": " ); | 290 | result.append( ": " ); |
291 | 291 | ||
292 | if ( group->grp_mb_list != NULL ) { | 292 | if ( group->grp_mb_list != NULL ) { |
293 | result.append( parseMailboxList( group->grp_mb_list ) ); | 293 | result.append( parseMailboxList( group->grp_mb_list ) ); |
294 | } | 294 | } |
295 | 295 | ||
296 | result.append( ";" ); | 296 | result.append( ";" ); |
297 | 297 | ||
298 | return result; | 298 | return result; |
299 | } | 299 | } |
300 | 300 | ||
301 | QString Genericwrapper::parseMailbox( mailimf_mailbox *box ) | 301 | QString Genericwrapper::parseMailbox( mailimf_mailbox *box ) |
@@ -346,132 +346,131 @@ encodedString* Genericwrapper::fetchRawPart(const RecMailP&,const RecPartP&part) | |||
346 | { | 346 | { |
347 | QMap<QString,encodedString*>::ConstIterator it = bodyCache.find(part->Identifier()); | 347 | QMap<QString,encodedString*>::ConstIterator it = bodyCache.find(part->Identifier()); |
348 | if (it==bodyCache.end()) return new encodedString(); | 348 | if (it==bodyCache.end()) return new encodedString(); |
349 | encodedString*t = it.data(); | 349 | encodedString*t = it.data(); |
350 | return t; | 350 | return t; |
351 | } | 351 | } |
352 | 352 | ||
353 | QString Genericwrapper::fetchTextPart(const RecMailP&mail,const RecPartP&part) | 353 | QString Genericwrapper::fetchTextPart(const RecMailP&mail,const RecPartP&part) |
354 | { | 354 | { |
355 | encodedString*t = fetchDecodedPart(mail,part); | 355 | encodedString*t = fetchDecodedPart(mail,part); |
356 | QString text=t->Content(); | 356 | QString text=t->Content(); |
357 | delete t; | 357 | delete t; |
358 | return text; | 358 | return text; |
359 | } | 359 | } |
360 | 360 | ||
361 | void Genericwrapper::cleanMimeCache() | 361 | void Genericwrapper::cleanMimeCache() |
362 | { | 362 | { |
363 | QMap<QString,encodedString*>::Iterator it = bodyCache.begin(); | 363 | QMap<QString,encodedString*>::Iterator it = bodyCache.begin(); |
364 | for (;it!=bodyCache.end();++it) { | 364 | for (;it!=bodyCache.end();++it) { |
365 | encodedString*t = it.data(); | 365 | encodedString*t = it.data(); |
366 | //it.setValue(0); | 366 | //it.setValue(0); |
367 | if (t) delete t; | 367 | if (t) delete t; |
368 | } | 368 | } |
369 | bodyCache.clear(); | 369 | bodyCache.clear(); |
370 | odebug << "Genericwrapper: cache cleaned" << oendl; | 370 | odebug << "Genericwrapper: cache cleaned" << oendl; |
371 | } | 371 | } |
372 | 372 | ||
373 | QStringList Genericwrapper::parseInreplies(mailimf_in_reply_to * in_replies) | 373 | QStringList Genericwrapper::parseInreplies(mailimf_in_reply_to * in_replies) |
374 | { | 374 | { |
375 | QStringList res; | 375 | QStringList res; |
376 | if (!in_replies || !in_replies->mid_list) return res; | 376 | if (!in_replies || !in_replies->mid_list) return res; |
377 | clistiter * current = 0; | 377 | clistiter * current = 0; |
378 | for ( current = clist_begin( in_replies->mid_list ); current != NULL; current = current->next ) { | 378 | for ( current = clist_begin( in_replies->mid_list ); current != NULL; current = current->next ) { |
379 | QString h((char*)current->data); | 379 | QString h((char*)current->data); |
380 | while (h.length()>0 && h[0]=='<') { | 380 | while (h.length()>0 && h[0]=='<') { |
381 | h.remove(0,1); | 381 | h.remove(0,1); |
382 | } | 382 | } |
383 | while (h.length()>0 && h[h.length()-1]=='>') { | 383 | while (h.length()>0 && h[h.length()-1]=='>') { |
384 | h.remove(h.length()-1,1); | 384 | h.remove(h.length()-1,1); |
385 | } | 385 | } |
386 | if (h.length()>0) { | 386 | if (h.length()>0) { |
387 | res.append(h); | 387 | res.append(h); |
388 | } | 388 | } |
389 | } | 389 | } |
390 | return res; | 390 | return res; |
391 | } | 391 | } |
392 | 392 | ||
393 | void Genericwrapper::parseList(QValueList<Opie::Core::OSmartPointer<RecMail> > &target,mailsession*session,const QString&mailbox,bool mbox_as_to) | 393 | void Genericwrapper::parseList(QValueList<Opie::Core::OSmartPointer<RecMail> > &target,mailsession*session,const QString&mailbox,bool mbox_as_to) |
394 | { | 394 | { |
395 | int r; | 395 | int r; |
396 | mailmessage_list * env_list = 0; | 396 | mailmessage_list * env_list = 0; |
397 | r = mailsession_get_messages_list(session,&env_list); | 397 | r = mailsession_get_messages_list(session,&env_list); |
398 | if (r != MAIL_NO_ERROR) { | 398 | if (r != MAIL_NO_ERROR) { |
399 | odebug << "Error message list" << oendl; | 399 | odebug << "Error message list" << oendl; |
400 | return; | 400 | return; |
401 | } | 401 | } |
402 | r = mailsession_get_envelopes_list(session, env_list); | 402 | r = mailsession_get_envelopes_list(session, env_list); |
403 | if (r != MAIL_NO_ERROR) { | 403 | if (r != MAIL_NO_ERROR) { |
404 | odebug << "Error filling message list" << oendl; | 404 | odebug << "Error filling message list" << oendl; |
405 | if (env_list) { | 405 | if (env_list) { |
406 | mailmessage_list_free(env_list); | 406 | mailmessage_list_free(env_list); |
407 | } | 407 | } |
408 | return; | 408 | return; |
409 | } | 409 | } |
410 | mailimf_references * refs = 0; | 410 | mailimf_references * refs = 0; |
411 | mailimf_in_reply_to * in_replies = 0; | 411 | mailimf_in_reply_to * in_replies = 0; |
412 | uint32_t i = 0; | 412 | uint32_t i = 0; |
413 | for(; i < carray_count(env_list->msg_tab) ; ++i) { | 413 | for(; i < carray_count(env_list->msg_tab) ; ++i) { |
414 | mailmessage * msg; | 414 | mailmessage * msg; |
415 | QBitArray mFlags(7); | 415 | QBitArray mFlags(7); |
416 | msg = (mailmessage*)carray_get(env_list->msg_tab, i); | 416 | msg = (mailmessage*)carray_get(env_list->msg_tab, i); |
417 | if (msg->msg_fields == NULL) { | 417 | if (msg->msg_fields == NULL) { |
418 | //odebug << "could not fetch envelope of message " << i << "" << oendl; | 418 | //odebug << "could not fetch envelope of message " << i << "" << oendl; |
419 | continue; | 419 | continue; |
420 | } | 420 | } |
421 | RecMailP mail = new RecMail(); | 421 | RecMailP mail = new RecMail(); |
422 | mail->setWrapper(this); | 422 | mail->setWrapper(this); |
423 | mail_flags * flag_result = 0; | 423 | mail_flags * flag_result = 0; |
424 | r = mailmessage_get_flags(msg,&flag_result); | 424 | r = mailmessage_get_flags(msg,&flag_result); |
425 | if (r == MAIL_ERROR_NOT_IMPLEMENTED) { | 425 | if (r == MAIL_ERROR_NOT_IMPLEMENTED) { |
426 | mFlags.setBit(FLAG_SEEN); | 426 | mFlags.setBit(FLAG_SEEN); |
427 | } | 427 | } |
428 | mailimf_single_fields single_fields; | 428 | mailimf_single_fields single_fields; |
429 | mailimf_single_fields_init(&single_fields, msg->msg_fields); | 429 | mailimf_single_fields_init(&single_fields, msg->msg_fields); |
430 | mail->setMsgsize(msg->msg_size); | 430 | mail->setMsgsize(msg->msg_size); |
431 | mail->setFlags(mFlags); | 431 | mail->setFlags(mFlags); |
432 | mail->setMbox(mailbox); | 432 | mail->setMbox(mailbox); |
433 | mail->setNumber(msg->msg_index); | 433 | mail->setNumber(msg->msg_index); |
434 | if (single_fields.fld_subject) | 434 | if (single_fields.fld_subject) |
435 | mail->setSubject( convert_String(single_fields.fld_subject->sbj_value)); | 435 | mail->setSubject( convert_String(single_fields.fld_subject->sbj_value)); |
436 | if (single_fields.fld_from) | 436 | if (single_fields.fld_from) |
437 | mail->setFrom(parseMailboxList(single_fields.fld_from->frm_mb_list)); | 437 | mail->setFrom(parseMailboxList(single_fields.fld_from->frm_mb_list)); |
438 | if (!mbox_as_to) { | 438 | if (!mbox_as_to) { |
439 | if (single_fields.fld_to) | 439 | if (single_fields.fld_to) |
440 | mail->setTo( parseAddressList( single_fields.fld_to->to_addr_list ) ); | 440 | mail->setTo( parseAddressList( single_fields.fld_to->to_addr_list ) ); |
441 | } else { | 441 | } else { |
442 | mail->setTo(mailbox); | 442 | mail->setTo(mailbox); |
443 | } | 443 | } |
444 | if (single_fields.fld_cc) | 444 | if (single_fields.fld_cc) |
445 | mail->setCC( parseAddressList( single_fields.fld_cc->cc_addr_list ) ); | 445 | mail->setCC( parseAddressList( single_fields.fld_cc->cc_addr_list ) ); |
446 | if (single_fields.fld_bcc) | 446 | if (single_fields.fld_bcc) |
447 | mail->setBcc( parseAddressList( single_fields.fld_bcc->bcc_addr_list ) ); | 447 | mail->setBcc( parseAddressList( single_fields.fld_bcc->bcc_addr_list ) ); |
448 | if (single_fields.fld_orig_date) | 448 | if (single_fields.fld_orig_date) |
449 | mail->setDate( parseDateTime( single_fields.fld_orig_date->dt_date_time ) ); | 449 | mail->setDate( parseDateTime( single_fields.fld_orig_date->dt_date_time ) ); |
450 | // crashes when accessing pop3 account? | 450 | // crashes when accessing pop3 account? |
451 | if (single_fields.fld_message_id->mid_value) { | 451 | if (single_fields.fld_message_id && single_fields.fld_message_id->mid_value) { |
452 | mail->setMsgid(QString(single_fields.fld_message_id->mid_value)); | 452 | mail->setMsgid(QString(single_fields.fld_message_id->mid_value)); |
453 | odebug << "Msgid == " << mail->Msgid().latin1() << "" << oendl; | ||
454 | } | 453 | } |
455 | 454 | ||
456 | if (single_fields.fld_reply_to) { | 455 | if (single_fields.fld_reply_to) { |
457 | QStringList t = parseAddressList(single_fields.fld_reply_to->rt_addr_list); | 456 | QStringList t = parseAddressList(single_fields.fld_reply_to->rt_addr_list); |
458 | if (t.count()>0) { | 457 | if (t.count()>0) { |
459 | mail->setReplyto(t[0]); | 458 | mail->setReplyto(t[0]); |
460 | } | 459 | } |
461 | } | 460 | } |
462 | #if 0 | 461 | #if 0 |
463 | refs = single_fields.fld_references; | 462 | refs = single_fields.fld_references; |
464 | if (refs && refs->mid_list && clist_count(refs->mid_list)) { | 463 | if (refs && refs->mid_list && clist_count(refs->mid_list)) { |
465 | char * text = (char*)refs->mid_list->first->data; | 464 | char * text = (char*)refs->mid_list->first->data; |
466 | mail->setReplyto(QString(text)); | 465 | mail->setReplyto(QString(text)); |
467 | } | 466 | } |
468 | #endif | 467 | #endif |
469 | if (single_fields.fld_in_reply_to && single_fields.fld_in_reply_to->mid_list && | 468 | if (single_fields.fld_in_reply_to && single_fields.fld_in_reply_to->mid_list && |
470 | clist_count(single_fields.fld_in_reply_to->mid_list)) { | 469 | clist_count(single_fields.fld_in_reply_to->mid_list)) { |
471 | mail->setInreply(parseInreplies(single_fields.fld_in_reply_to)); | 470 | mail->setInreply(parseInreplies(single_fields.fld_in_reply_to)); |
472 | } | 471 | } |
473 | target.append(mail); | 472 | target.append(mail); |
474 | } | 473 | } |
475 | if (env_list) { | 474 | if (env_list) { |
476 | mailmessage_list_free(env_list); | 475 | mailmessage_list_free(env_list); |
477 | } | 476 | } |