summaryrefslogtreecommitdiff
authoralwin <alwin>2003-12-13 12:49:27 (UTC)
committer alwin <alwin>2003-12-13 12:49:27 (UTC)
commit865b023c57f657c8eff26baa670fc76bbcd548e4 (patch) (unidiff)
tree1d40c66d0b4e571277be77db1692791688569c9f
parentcb7b0d2e509d5fc1759fee7c8c855e259e44ed95 (diff)
downloadopie-865b023c57f657c8eff26baa670fc76bbcd548e4.zip
opie-865b023c57f657c8eff26baa670fc76bbcd548e4.tar.gz
opie-865b023c57f657c8eff26baa670fc76bbcd548e4.tar.bz2
try to solve the problems with slow imap-server
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/net/mail/imapwrapper.cpp3
-rw-r--r--noncore/net/mail/libmailwrapper/imapwrapper.cpp3
2 files changed, 4 insertions, 2 deletions
diff --git a/noncore/net/mail/imapwrapper.cpp b/noncore/net/mail/imapwrapper.cpp
index 11bf3b8..48e476b 100644
--- a/noncore/net/mail/imapwrapper.cpp
+++ b/noncore/net/mail/imapwrapper.cpp
@@ -1,224 +1,225 @@
1 1
2#include <stdlib.h> 2#include <stdlib.h>
3 3
4#include "imapwrapper.h" 4#include "imapwrapper.h"
5#include "mailtypes.h" 5#include "mailtypes.h"
6#include <libetpan/mailimap.h> 6#include <libetpan/mailimap.h>
7 7
8IMAPwrapper::IMAPwrapper( IMAPaccount *a ) 8IMAPwrapper::IMAPwrapper( IMAPaccount *a )
9{ 9{
10 account = a; 10 account = a;
11 m_imap = 0; 11 m_imap = 0;
12} 12}
13 13
14IMAPwrapper::~IMAPwrapper() 14IMAPwrapper::~IMAPwrapper()
15{ 15{
16 logout(); 16 logout();
17} 17}
18 18
19void IMAPwrapper::imap_progress( size_t current, size_t maximum ) 19void IMAPwrapper::imap_progress( size_t current, size_t maximum )
20{ 20{
21 qDebug( "IMAP: %i of %i", current, maximum ); 21 qDebug( "IMAP: %i of %i", current, maximum );
22} 22}
23 23
24void IMAPwrapper::login() 24void IMAPwrapper::login()
25{ 25{
26 const char *server, *user, *pass; 26 const char *server, *user, *pass;
27 uint16_t port; 27 uint16_t port;
28 int err = MAILIMAP_NO_ERROR; 28 int err = MAILIMAP_NO_ERROR;
29 29
30 /* we are connected this moment */ 30 /* we are connected this moment */
31 /* TODO: setup a timer holding the line or if connection closed - delete the value */ 31 /* TODO: setup a timer holding the line or if connection closed - delete the value */
32 if (m_imap) { 32 if (m_imap) {
33 mailstream_flush(m_imap->imap_stream);
33 return; 34 return;
34 } 35 }
35 server = account->getServer().latin1(); 36 server = account->getServer().latin1();
36 port = account->getPort().toUInt(); 37 port = account->getPort().toUInt();
37 user = account->getUser().latin1(); 38 user = account->getUser().latin1();
38 pass = account->getPassword().latin1(); 39 pass = account->getPassword().latin1();
39 40
40 m_imap = mailimap_new( 20, &imap_progress ); 41 m_imap = mailimap_new( 20, &imap_progress );
41 /* connect */ 42 /* connect */
42 if (account->getSSL()) { 43 if (account->getSSL()) {
43 err = mailimap_ssl_connect( m_imap, (char*)server, port ); 44 err = mailimap_ssl_connect( m_imap, (char*)server, port );
44 } else { 45 } else {
45 err = mailimap_socket_connect( m_imap, (char*)server, port ); 46 err = mailimap_socket_connect( m_imap, (char*)server, port );
46 } 47 }
47 48
48 if ( err != MAILIMAP_NO_ERROR && 49 if ( err != MAILIMAP_NO_ERROR &&
49 err != MAILIMAP_NO_ERROR_AUTHENTICATED && 50 err != MAILIMAP_NO_ERROR_AUTHENTICATED &&
50 err != MAILIMAP_NO_ERROR_NON_AUTHENTICATED ) { 51 err != MAILIMAP_NO_ERROR_NON_AUTHENTICATED ) {
51 qDebug("error connecting server: %s",m_imap->imap_response); 52 qDebug("error connecting server: %s",m_imap->imap_response);
52 mailimap_free( m_imap ); 53 mailimap_free( m_imap );
53 m_imap = 0; 54 m_imap = 0;
54 return; 55 return;
55 } 56 }
56 57
57 /* login */ 58 /* login */
58 err = mailimap_login_simple( m_imap, (char*)user, (char*)pass ); 59 err = mailimap_login_simple( m_imap, (char*)user, (char*)pass );
59 if ( err != MAILIMAP_NO_ERROR ) { 60 if ( err != MAILIMAP_NO_ERROR ) {
60 qDebug("error logging in imap: %s",m_imap->imap_response); 61 qDebug("error logging in imap: %s",m_imap->imap_response);
61 err = mailimap_close( m_imap ); 62 err = mailimap_close( m_imap );
62 mailimap_free( m_imap ); 63 mailimap_free( m_imap );
63 m_imap = 0; 64 m_imap = 0;
64 } 65 }
65} 66}
66 67
67void IMAPwrapper::logout() 68void IMAPwrapper::logout()
68{ 69{
69 int err = MAILIMAP_NO_ERROR; 70 int err = MAILIMAP_NO_ERROR;
70 if (!m_imap) return; 71 if (!m_imap) return;
71 err = mailimap_logout( m_imap ); 72 err = mailimap_logout( m_imap );
72 err = mailimap_close( m_imap ); 73 err = mailimap_close( m_imap );
73 mailimap_free( m_imap ); 74 mailimap_free( m_imap );
74 m_imap = 0; 75 m_imap = 0;
75} 76}
76 77
77void IMAPwrapper::listMessages(const QString&mailbox,QList<RecMail> &target ) 78void IMAPwrapper::listMessages(const QString&mailbox,QList<RecMail> &target )
78{ 79{
79 const char *mb; 80 const char *mb;
80 int err = MAILIMAP_NO_ERROR; 81 int err = MAILIMAP_NO_ERROR;
81 clist *result; 82 clist *result;
82 clistcell *current; 83 clistcell *current;
83// mailimap_fetch_att *fetchAtt,*fetchAttFlags,*fetchAttDate,*fetchAttSize; 84// mailimap_fetch_att *fetchAtt,*fetchAttFlags,*fetchAttDate,*fetchAttSize;
84 mailimap_fetch_type *fetchType; 85 mailimap_fetch_type *fetchType;
85 mailimap_set *set; 86 mailimap_set *set;
86 87
87 mb = mailbox.latin1(); 88 mb = mailbox.latin1();
88 login(); 89 login();
89 if (!m_imap) { 90 if (!m_imap) {
90 return; 91 return;
91 } 92 }
92 /* select mailbox READONLY for operations */ 93 /* select mailbox READONLY for operations */
93 err = mailimap_examine( m_imap, (char*)mb); 94 err = mailimap_examine( m_imap, (char*)mb);
94 if ( err != MAILIMAP_NO_ERROR ) { 95 if ( err != MAILIMAP_NO_ERROR ) {
95 qDebug("error selecting mailbox: %s",m_imap->imap_response); 96 qDebug("error selecting mailbox: %s",m_imap->imap_response);
96 return; 97 return;
97 } 98 }
98 99
99 int last = m_imap->imap_selection_info->sel_exists; 100 int last = m_imap->imap_selection_info->sel_exists;
100 101
101 if (last == 0) { 102 if (last == 0) {
102 qDebug("mailbox has no mails"); 103 qDebug("mailbox has no mails");
103 return; 104 return;
104 } 105 }
105 106
106 result = clist_new(); 107 result = clist_new();
107 /* the range has to start at 1!!! not with 0!!!! */ 108 /* the range has to start at 1!!! not with 0!!!! */
108 set = mailimap_set_new_interval( 1, last ); 109 set = mailimap_set_new_interval( 1, last );
109 fetchType = mailimap_fetch_type_new_fetch_att_list_empty(); 110 fetchType = mailimap_fetch_type_new_fetch_att_list_empty();
110 mailimap_fetch_type_new_fetch_att_list_add(fetchType,mailimap_fetch_att_new_envelope()); 111 mailimap_fetch_type_new_fetch_att_list_add(fetchType,mailimap_fetch_att_new_envelope());
111 mailimap_fetch_type_new_fetch_att_list_add(fetchType,mailimap_fetch_att_new_flags()); 112 mailimap_fetch_type_new_fetch_att_list_add(fetchType,mailimap_fetch_att_new_flags());
112 mailimap_fetch_type_new_fetch_att_list_add(fetchType,mailimap_fetch_att_new_internaldate()); 113 mailimap_fetch_type_new_fetch_att_list_add(fetchType,mailimap_fetch_att_new_internaldate());
113 mailimap_fetch_type_new_fetch_att_list_add(fetchType,mailimap_fetch_att_new_rfc822_size()); 114 mailimap_fetch_type_new_fetch_att_list_add(fetchType,mailimap_fetch_att_new_rfc822_size());
114 115
115 err = mailimap_fetch( m_imap, set, fetchType, &result ); 116 err = mailimap_fetch( m_imap, set, fetchType, &result );
116 mailimap_set_free( set ); 117 mailimap_set_free( set );
117 mailimap_fetch_type_free( fetchType ); 118 mailimap_fetch_type_free( fetchType );
118 119
119 QString date,subject,from; 120 QString date,subject,from;
120 121
121 if ( err == MAILIMAP_NO_ERROR ) { 122 if ( err == MAILIMAP_NO_ERROR ) {
122 123
123 mailimap_msg_att * msg_att; 124 mailimap_msg_att * msg_att;
124 int i = 0; 125 int i = 0;
125 for (current = clist_begin(result); current != 0; current=clist_next(current)) { 126 for (current = clist_begin(result); current != 0; current=clist_next(current)) {
126 ++i; 127 ++i;
127 msg_att = (mailimap_msg_att*)current->data; 128 msg_att = (mailimap_msg_att*)current->data;
128 RecMail*m = parse_list_result(msg_att); 129 RecMail*m = parse_list_result(msg_att);
129 if (m) { 130 if (m) {
130 m->setNumber(i); 131 m->setNumber(i);
131 m->setMbox(mailbox); 132 m->setMbox(mailbox);
132 target.append(m); 133 target.append(m);
133 } 134 }
134 } 135 }
135 } else { 136 } else {
136 qDebug("Error fetching headers: %s",m_imap->imap_response); 137 qDebug("Error fetching headers: %s",m_imap->imap_response);
137 } 138 }
138 mailimap_fetch_list_free(result); 139 mailimap_fetch_list_free(result);
139} 140}
140 141
141QList<IMAPFolder>* IMAPwrapper::listFolders() 142QList<IMAPFolder>* IMAPwrapper::listFolders()
142{ 143{
143 const char *path, *mask; 144 const char *path, *mask;
144 int err = MAILIMAP_NO_ERROR; 145 int err = MAILIMAP_NO_ERROR;
145 clist *result; 146 clist *result;
146 clistcell *current; 147 clistcell *current;
147 148
148 QList<IMAPFolder> * folders = new QList<IMAPFolder>(); 149 QList<IMAPFolder> * folders = new QList<IMAPFolder>();
149 folders->setAutoDelete( true ); 150 folders->setAutoDelete( true );
150 login(); 151 login();
151 if (!m_imap) { 152 if (!m_imap) {
152 return folders; 153 return folders;
153 } 154 }
154 155
155/* 156/*
156 * First we have to check for INBOX 'cause it sometimes it's not inside the path. 157 * First we have to check for INBOX 'cause it sometimes it's not inside the path.
157 * We must not forget to filter them out in next loop! 158 * We must not forget to filter them out in next loop!
158 * it seems like ugly code. and yes - it is ugly code. but the best way. 159 * it seems like ugly code. and yes - it is ugly code. but the best way.
159 */ 160 */
160 QString temp; 161 QString temp;
161 mask = "INBOX" ; 162 mask = "INBOX" ;
162 result = clist_new(); 163 result = clist_new();
163 mailimap_mailbox_list *list; 164 mailimap_mailbox_list *list;
164 err = mailimap_list( m_imap, (char*)"", (char*)mask, &result ); 165 err = mailimap_list( m_imap, (char*)"", (char*)mask, &result );
165 if ( err == MAILIMAP_NO_ERROR ) { 166 if ( err == MAILIMAP_NO_ERROR ) {
166 current = result->first; 167 current = result->first;
167 for ( int i = result->count; i > 0; i-- ) { 168 for ( int i = result->count; i > 0; i-- ) {
168 list = (mailimap_mailbox_list *) current->data; 169 list = (mailimap_mailbox_list *) current->data;
169 // it is better use the deep copy mechanism of qt itself 170 // it is better use the deep copy mechanism of qt itself
170 // instead of using strdup! 171 // instead of using strdup!
171 temp = list->mb_name; 172 temp = list->mb_name;
172 folders->append( new IMAPFolder(temp)); 173 folders->append( new IMAPFolder(temp));
173 current = current->next; 174 current = current->next;
174 } 175 }
175 } else { 176 } else {
176 qDebug("error fetching folders: %s",m_imap->imap_response); 177 qDebug("error fetching folders: %s",m_imap->imap_response);
177 } 178 }
178 mailimap_list_result_free( result ); 179 mailimap_list_result_free( result );
179 180
180/* 181/*
181 * second stage - get the other then inbox folders 182 * second stage - get the other then inbox folders
182 */ 183 */
183 mask = "*" ; 184 mask = "*" ;
184 path = account->getPrefix().latin1(); 185 path = account->getPrefix().latin1();
185 if (!path) path = ""; 186 if (!path) path = "";
186 result = clist_new(); 187 result = clist_new();
187 qDebug(path); 188 qDebug(path);
188 err = mailimap_list( m_imap, (char*)path, (char*)mask, &result ); 189 err = mailimap_list( m_imap, (char*)path, (char*)mask, &result );
189 if ( err == MAILIMAP_NO_ERROR ) { 190 if ( err == MAILIMAP_NO_ERROR ) {
190 current = result->first; 191 current = result->first;
191 for ( int i = result->count; i > 0; i-- ) { 192 for ( int i = result->count; i > 0; i-- ) {
192 list = (mailimap_mailbox_list *) current->data; 193 list = (mailimap_mailbox_list *) current->data;
193 // it is better use the deep copy mechanism of qt itself 194 // it is better use the deep copy mechanism of qt itself
194 // instead of using strdup! 195 // instead of using strdup!
195 temp = list->mb_name; 196 temp = list->mb_name;
196 current = current->next; 197 current = current->next;
197 if (temp.lower()=="inbox") 198 if (temp.lower()=="inbox")
198 continue; 199 continue;
199 folders->append(new IMAPFolder(temp)); 200 folders->append(new IMAPFolder(temp));
200 201
201 } 202 }
202 } else { 203 } else {
203 qDebug("error fetching folders %s",m_imap->imap_response); 204 qDebug("error fetching folders %s",m_imap->imap_response);
204 } 205 }
205 mailimap_list_result_free( result ); 206 mailimap_list_result_free( result );
206 return folders; 207 return folders;
207} 208}
208 209
209RecMail*IMAPwrapper::parse_list_result(mailimap_msg_att* m_att) 210RecMail*IMAPwrapper::parse_list_result(mailimap_msg_att* m_att)
210{ 211{
211 RecMail * m = 0; 212 RecMail * m = 0;
212 mailimap_msg_att_item *item=0; 213 mailimap_msg_att_item *item=0;
213 clistcell *current,*c,*cf; 214 clistcell *current,*c,*cf;
214 mailimap_msg_att_dynamic*flist; 215 mailimap_msg_att_dynamic*flist;
215 mailimap_flag_fetch*cflag; 216 mailimap_flag_fetch*cflag;
216 int size; 217 int size;
217 QBitArray mFlags(7); 218 QBitArray mFlags(7);
218 QStringList addresslist; 219 QStringList addresslist;
219 220
220 if (!m_att) { 221 if (!m_att) {
221 return m; 222 return m;
222 } 223 }
223 m = new RecMail(); 224 m = new RecMail();
224 for (c = clist_begin(m_att->att_list); c!=NULL;c=clist_next(c) ) { 225 for (c = clist_begin(m_att->att_list); c!=NULL;c=clist_next(c) ) {
diff --git a/noncore/net/mail/libmailwrapper/imapwrapper.cpp b/noncore/net/mail/libmailwrapper/imapwrapper.cpp
index 11bf3b8..48e476b 100644
--- a/noncore/net/mail/libmailwrapper/imapwrapper.cpp
+++ b/noncore/net/mail/libmailwrapper/imapwrapper.cpp
@@ -1,224 +1,225 @@
1 1
2#include <stdlib.h> 2#include <stdlib.h>
3 3
4#include "imapwrapper.h" 4#include "imapwrapper.h"
5#include "mailtypes.h" 5#include "mailtypes.h"
6#include <libetpan/mailimap.h> 6#include <libetpan/mailimap.h>
7 7
8IMAPwrapper::IMAPwrapper( IMAPaccount *a ) 8IMAPwrapper::IMAPwrapper( IMAPaccount *a )
9{ 9{
10 account = a; 10 account = a;
11 m_imap = 0; 11 m_imap = 0;
12} 12}
13 13
14IMAPwrapper::~IMAPwrapper() 14IMAPwrapper::~IMAPwrapper()
15{ 15{
16 logout(); 16 logout();
17} 17}
18 18
19void IMAPwrapper::imap_progress( size_t current, size_t maximum ) 19void IMAPwrapper::imap_progress( size_t current, size_t maximum )
20{ 20{
21 qDebug( "IMAP: %i of %i", current, maximum ); 21 qDebug( "IMAP: %i of %i", current, maximum );
22} 22}
23 23
24void IMAPwrapper::login() 24void IMAPwrapper::login()
25{ 25{
26 const char *server, *user, *pass; 26 const char *server, *user, *pass;
27 uint16_t port; 27 uint16_t port;
28 int err = MAILIMAP_NO_ERROR; 28 int err = MAILIMAP_NO_ERROR;
29 29
30 /* we are connected this moment */ 30 /* we are connected this moment */
31 /* TODO: setup a timer holding the line or if connection closed - delete the value */ 31 /* TODO: setup a timer holding the line or if connection closed - delete the value */
32 if (m_imap) { 32 if (m_imap) {
33 mailstream_flush(m_imap->imap_stream);
33 return; 34 return;
34 } 35 }
35 server = account->getServer().latin1(); 36 server = account->getServer().latin1();
36 port = account->getPort().toUInt(); 37 port = account->getPort().toUInt();
37 user = account->getUser().latin1(); 38 user = account->getUser().latin1();
38 pass = account->getPassword().latin1(); 39 pass = account->getPassword().latin1();
39 40
40 m_imap = mailimap_new( 20, &imap_progress ); 41 m_imap = mailimap_new( 20, &imap_progress );
41 /* connect */ 42 /* connect */
42 if (account->getSSL()) { 43 if (account->getSSL()) {
43 err = mailimap_ssl_connect( m_imap, (char*)server, port ); 44 err = mailimap_ssl_connect( m_imap, (char*)server, port );
44 } else { 45 } else {
45 err = mailimap_socket_connect( m_imap, (char*)server, port ); 46 err = mailimap_socket_connect( m_imap, (char*)server, port );
46 } 47 }
47 48
48 if ( err != MAILIMAP_NO_ERROR && 49 if ( err != MAILIMAP_NO_ERROR &&
49 err != MAILIMAP_NO_ERROR_AUTHENTICATED && 50 err != MAILIMAP_NO_ERROR_AUTHENTICATED &&
50 err != MAILIMAP_NO_ERROR_NON_AUTHENTICATED ) { 51 err != MAILIMAP_NO_ERROR_NON_AUTHENTICATED ) {
51 qDebug("error connecting server: %s",m_imap->imap_response); 52 qDebug("error connecting server: %s",m_imap->imap_response);
52 mailimap_free( m_imap ); 53 mailimap_free( m_imap );
53 m_imap = 0; 54 m_imap = 0;
54 return; 55 return;
55 } 56 }
56 57
57 /* login */ 58 /* login */
58 err = mailimap_login_simple( m_imap, (char*)user, (char*)pass ); 59 err = mailimap_login_simple( m_imap, (char*)user, (char*)pass );
59 if ( err != MAILIMAP_NO_ERROR ) { 60 if ( err != MAILIMAP_NO_ERROR ) {
60 qDebug("error logging in imap: %s",m_imap->imap_response); 61 qDebug("error logging in imap: %s",m_imap->imap_response);
61 err = mailimap_close( m_imap ); 62 err = mailimap_close( m_imap );
62 mailimap_free( m_imap ); 63 mailimap_free( m_imap );
63 m_imap = 0; 64 m_imap = 0;
64 } 65 }
65} 66}
66 67
67void IMAPwrapper::logout() 68void IMAPwrapper::logout()
68{ 69{
69 int err = MAILIMAP_NO_ERROR; 70 int err = MAILIMAP_NO_ERROR;
70 if (!m_imap) return; 71 if (!m_imap) return;
71 err = mailimap_logout( m_imap ); 72 err = mailimap_logout( m_imap );
72 err = mailimap_close( m_imap ); 73 err = mailimap_close( m_imap );
73 mailimap_free( m_imap ); 74 mailimap_free( m_imap );
74 m_imap = 0; 75 m_imap = 0;
75} 76}
76 77
77void IMAPwrapper::listMessages(const QString&mailbox,QList<RecMail> &target ) 78void IMAPwrapper::listMessages(const QString&mailbox,QList<RecMail> &target )
78{ 79{
79 const char *mb; 80 const char *mb;
80 int err = MAILIMAP_NO_ERROR; 81 int err = MAILIMAP_NO_ERROR;
81 clist *result; 82 clist *result;
82 clistcell *current; 83 clistcell *current;
83// mailimap_fetch_att *fetchAtt,*fetchAttFlags,*fetchAttDate,*fetchAttSize; 84// mailimap_fetch_att *fetchAtt,*fetchAttFlags,*fetchAttDate,*fetchAttSize;
84 mailimap_fetch_type *fetchType; 85 mailimap_fetch_type *fetchType;
85 mailimap_set *set; 86 mailimap_set *set;
86 87
87 mb = mailbox.latin1(); 88 mb = mailbox.latin1();
88 login(); 89 login();
89 if (!m_imap) { 90 if (!m_imap) {
90 return; 91 return;
91 } 92 }
92 /* select mailbox READONLY for operations */ 93 /* select mailbox READONLY for operations */
93 err = mailimap_examine( m_imap, (char*)mb); 94 err = mailimap_examine( m_imap, (char*)mb);
94 if ( err != MAILIMAP_NO_ERROR ) { 95 if ( err != MAILIMAP_NO_ERROR ) {
95 qDebug("error selecting mailbox: %s",m_imap->imap_response); 96 qDebug("error selecting mailbox: %s",m_imap->imap_response);
96 return; 97 return;
97 } 98 }
98 99
99 int last = m_imap->imap_selection_info->sel_exists; 100 int last = m_imap->imap_selection_info->sel_exists;
100 101
101 if (last == 0) { 102 if (last == 0) {
102 qDebug("mailbox has no mails"); 103 qDebug("mailbox has no mails");
103 return; 104 return;
104 } 105 }
105 106
106 result = clist_new(); 107 result = clist_new();
107 /* the range has to start at 1!!! not with 0!!!! */ 108 /* the range has to start at 1!!! not with 0!!!! */
108 set = mailimap_set_new_interval( 1, last ); 109 set = mailimap_set_new_interval( 1, last );
109 fetchType = mailimap_fetch_type_new_fetch_att_list_empty(); 110 fetchType = mailimap_fetch_type_new_fetch_att_list_empty();
110 mailimap_fetch_type_new_fetch_att_list_add(fetchType,mailimap_fetch_att_new_envelope()); 111 mailimap_fetch_type_new_fetch_att_list_add(fetchType,mailimap_fetch_att_new_envelope());
111 mailimap_fetch_type_new_fetch_att_list_add(fetchType,mailimap_fetch_att_new_flags()); 112 mailimap_fetch_type_new_fetch_att_list_add(fetchType,mailimap_fetch_att_new_flags());
112 mailimap_fetch_type_new_fetch_att_list_add(fetchType,mailimap_fetch_att_new_internaldate()); 113 mailimap_fetch_type_new_fetch_att_list_add(fetchType,mailimap_fetch_att_new_internaldate());
113 mailimap_fetch_type_new_fetch_att_list_add(fetchType,mailimap_fetch_att_new_rfc822_size()); 114 mailimap_fetch_type_new_fetch_att_list_add(fetchType,mailimap_fetch_att_new_rfc822_size());
114 115
115 err = mailimap_fetch( m_imap, set, fetchType, &result ); 116 err = mailimap_fetch( m_imap, set, fetchType, &result );
116 mailimap_set_free( set ); 117 mailimap_set_free( set );
117 mailimap_fetch_type_free( fetchType ); 118 mailimap_fetch_type_free( fetchType );
118 119
119 QString date,subject,from; 120 QString date,subject,from;
120 121
121 if ( err == MAILIMAP_NO_ERROR ) { 122 if ( err == MAILIMAP_NO_ERROR ) {
122 123
123 mailimap_msg_att * msg_att; 124 mailimap_msg_att * msg_att;
124 int i = 0; 125 int i = 0;
125 for (current = clist_begin(result); current != 0; current=clist_next(current)) { 126 for (current = clist_begin(result); current != 0; current=clist_next(current)) {
126 ++i; 127 ++i;
127 msg_att = (mailimap_msg_att*)current->data; 128 msg_att = (mailimap_msg_att*)current->data;
128 RecMail*m = parse_list_result(msg_att); 129 RecMail*m = parse_list_result(msg_att);
129 if (m) { 130 if (m) {
130 m->setNumber(i); 131 m->setNumber(i);
131 m->setMbox(mailbox); 132 m->setMbox(mailbox);
132 target.append(m); 133 target.append(m);
133 } 134 }
134 } 135 }
135 } else { 136 } else {
136 qDebug("Error fetching headers: %s",m_imap->imap_response); 137 qDebug("Error fetching headers: %s",m_imap->imap_response);
137 } 138 }
138 mailimap_fetch_list_free(result); 139 mailimap_fetch_list_free(result);
139} 140}
140 141
141QList<IMAPFolder>* IMAPwrapper::listFolders() 142QList<IMAPFolder>* IMAPwrapper::listFolders()
142{ 143{
143 const char *path, *mask; 144 const char *path, *mask;
144 int err = MAILIMAP_NO_ERROR; 145 int err = MAILIMAP_NO_ERROR;
145 clist *result; 146 clist *result;
146 clistcell *current; 147 clistcell *current;
147 148
148 QList<IMAPFolder> * folders = new QList<IMAPFolder>(); 149 QList<IMAPFolder> * folders = new QList<IMAPFolder>();
149 folders->setAutoDelete( true ); 150 folders->setAutoDelete( true );
150 login(); 151 login();
151 if (!m_imap) { 152 if (!m_imap) {
152 return folders; 153 return folders;
153 } 154 }
154 155
155/* 156/*
156 * First we have to check for INBOX 'cause it sometimes it's not inside the path. 157 * First we have to check for INBOX 'cause it sometimes it's not inside the path.
157 * We must not forget to filter them out in next loop! 158 * We must not forget to filter them out in next loop!
158 * it seems like ugly code. and yes - it is ugly code. but the best way. 159 * it seems like ugly code. and yes - it is ugly code. but the best way.
159 */ 160 */
160 QString temp; 161 QString temp;
161 mask = "INBOX" ; 162 mask = "INBOX" ;
162 result = clist_new(); 163 result = clist_new();
163 mailimap_mailbox_list *list; 164 mailimap_mailbox_list *list;
164 err = mailimap_list( m_imap, (char*)"", (char*)mask, &result ); 165 err = mailimap_list( m_imap, (char*)"", (char*)mask, &result );
165 if ( err == MAILIMAP_NO_ERROR ) { 166 if ( err == MAILIMAP_NO_ERROR ) {
166 current = result->first; 167 current = result->first;
167 for ( int i = result->count; i > 0; i-- ) { 168 for ( int i = result->count; i > 0; i-- ) {
168 list = (mailimap_mailbox_list *) current->data; 169 list = (mailimap_mailbox_list *) current->data;
169 // it is better use the deep copy mechanism of qt itself 170 // it is better use the deep copy mechanism of qt itself
170 // instead of using strdup! 171 // instead of using strdup!
171 temp = list->mb_name; 172 temp = list->mb_name;
172 folders->append( new IMAPFolder(temp)); 173 folders->append( new IMAPFolder(temp));
173 current = current->next; 174 current = current->next;
174 } 175 }
175 } else { 176 } else {
176 qDebug("error fetching folders: %s",m_imap->imap_response); 177 qDebug("error fetching folders: %s",m_imap->imap_response);
177 } 178 }
178 mailimap_list_result_free( result ); 179 mailimap_list_result_free( result );
179 180
180/* 181/*
181 * second stage - get the other then inbox folders 182 * second stage - get the other then inbox folders
182 */ 183 */
183 mask = "*" ; 184 mask = "*" ;
184 path = account->getPrefix().latin1(); 185 path = account->getPrefix().latin1();
185 if (!path) path = ""; 186 if (!path) path = "";
186 result = clist_new(); 187 result = clist_new();
187 qDebug(path); 188 qDebug(path);
188 err = mailimap_list( m_imap, (char*)path, (char*)mask, &result ); 189 err = mailimap_list( m_imap, (char*)path, (char*)mask, &result );
189 if ( err == MAILIMAP_NO_ERROR ) { 190 if ( err == MAILIMAP_NO_ERROR ) {
190 current = result->first; 191 current = result->first;
191 for ( int i = result->count; i > 0; i-- ) { 192 for ( int i = result->count; i > 0; i-- ) {
192 list = (mailimap_mailbox_list *) current->data; 193 list = (mailimap_mailbox_list *) current->data;
193 // it is better use the deep copy mechanism of qt itself 194 // it is better use the deep copy mechanism of qt itself
194 // instead of using strdup! 195 // instead of using strdup!
195 temp = list->mb_name; 196 temp = list->mb_name;
196 current = current->next; 197 current = current->next;
197 if (temp.lower()=="inbox") 198 if (temp.lower()=="inbox")
198 continue; 199 continue;
199 folders->append(new IMAPFolder(temp)); 200 folders->append(new IMAPFolder(temp));
200 201
201 } 202 }
202 } else { 203 } else {
203 qDebug("error fetching folders %s",m_imap->imap_response); 204 qDebug("error fetching folders %s",m_imap->imap_response);
204 } 205 }
205 mailimap_list_result_free( result ); 206 mailimap_list_result_free( result );
206 return folders; 207 return folders;
207} 208}
208 209
209RecMail*IMAPwrapper::parse_list_result(mailimap_msg_att* m_att) 210RecMail*IMAPwrapper::parse_list_result(mailimap_msg_att* m_att)
210{ 211{
211 RecMail * m = 0; 212 RecMail * m = 0;
212 mailimap_msg_att_item *item=0; 213 mailimap_msg_att_item *item=0;
213 clistcell *current,*c,*cf; 214 clistcell *current,*c,*cf;
214 mailimap_msg_att_dynamic*flist; 215 mailimap_msg_att_dynamic*flist;
215 mailimap_flag_fetch*cflag; 216 mailimap_flag_fetch*cflag;
216 int size; 217 int size;
217 QBitArray mFlags(7); 218 QBitArray mFlags(7);
218 QStringList addresslist; 219 QStringList addresslist;
219 220
220 if (!m_att) { 221 if (!m_att) {
221 return m; 222 return m;
222 } 223 }
223 m = new RecMail(); 224 m = new RecMail();
224 for (c = clist_begin(m_att->att_list); c!=NULL;c=clist_next(c) ) { 225 for (c = clist_begin(m_att->att_list); c!=NULL;c=clist_next(c) ) {