author | zautrix <zautrix> | 2004-09-08 11:34:38 (UTC) |
---|---|---|
committer | zautrix <zautrix> | 2004-09-08 11:34:38 (UTC) |
commit | 1fcec858408b88bb412af18fbf853b49b6970d8a (patch) (unidiff) | |
tree | 702e94a74f0bb90335b9b193d28e31c1dc392c03 /kmicromail | |
parent | cdff4506a9148c47406af86968da73c0dbfca0ba (diff) | |
download | kdepimpi-1fcec858408b88bb412af18fbf853b49b6970d8a.zip kdepimpi-1fcec858408b88bb412af18fbf853b49b6970d8a.tar.gz kdepimpi-1fcec858408b88bb412af18fbf853b49b6970d8a.tar.bz2 |
Fixed QCOP call problem of kopiemail
-rw-r--r-- | kmicromail/composemail.cpp | 11 | ||||
-rw-r--r-- | kmicromail/opiemail.cpp | 62 | ||||
-rw-r--r-- | kmicromail/opiemail.h | 2 |
3 files changed, 47 insertions, 28 deletions
diff --git a/kmicromail/composemail.cpp b/kmicromail/composemail.cpp index 01dd406..9efa932 100644 --- a/kmicromail/composemail.cpp +++ b/kmicromail/composemail.cpp | |||
@@ -1,300 +1,301 @@ | |||
1 | // CHANGED 2004-08-06 Lutz Rogowski | 1 | // CHANGED 2004-08-06 Lutz Rogowski |
2 | 2 | ||
3 | #include "composemail.h" | 3 | #include "composemail.h" |
4 | 4 | ||
5 | #include <libmailwrapper/smtpwrapper.h> | 5 | #include <libmailwrapper/smtpwrapper.h> |
6 | #include <libmailwrapper/storemail.h> | 6 | #include <libmailwrapper/storemail.h> |
7 | #include <libmailwrapper/abstractmail.h> | 7 | #include <libmailwrapper/abstractmail.h> |
8 | #include <libmailwrapper/mailtypes.h> | 8 | #include <libmailwrapper/mailtypes.h> |
9 | 9 | ||
10 | /* OPIE */ | 10 | /* OPIE */ |
11 | //#include <opie2/ofiledialog.h> | 11 | //#include <opie2/ofiledialog.h> |
12 | //#include <opie2/odebug.h> | 12 | //#include <opie2/odebug.h> |
13 | #include <kfiledialog.h> | 13 | #include <kfiledialog.h> |
14 | //#include <qpe/resource.h> | 14 | //#include <qpe/resource.h> |
15 | #include <qpe/config.h> | 15 | #include <qpe/config.h> |
16 | #include <qpe/global.h> | 16 | #include <qpe/global.h> |
17 | //#include <qpe/contact.h> | 17 | //#include <qpe/contact.h> |
18 | 18 | ||
19 | 19 | ||
20 | #include <qcombobox.h> | 20 | #include <qcombobox.h> |
21 | #include <qcheckbox.h> | 21 | #include <qcheckbox.h> |
22 | #include <qtimer.h> | 22 | #include <qtimer.h> |
23 | #include <qmessagebox.h> | 23 | #include <qmessagebox.h> |
24 | #include <qpushbutton.h> | 24 | #include <qpushbutton.h> |
25 | #include <qmultilineedit.h> | 25 | #include <qmultilineedit.h> |
26 | #include <qlabel.h> | 26 | #include <qlabel.h> |
27 | #include <qtabwidget.h> | 27 | #include <qtabwidget.h> |
28 | #include <qlistview.h> | 28 | #include <qlistview.h> |
29 | #include <kabc/addresseedialog.h> | 29 | #include <kabc/addresseedialog.h> |
30 | #include <kabc/stdaddressbook.h> | 30 | #include <kabc/stdaddressbook.h> |
31 | #include <kabc/addressee.h> | 31 | #include <kabc/addressee.h> |
32 | #ifdef DESKTOP_VERSION | 32 | #ifdef DESKTOP_VERSION |
33 | #include <kabc/addresseedialog.h> | 33 | #include <kabc/addresseedialog.h> |
34 | #else //DESKTOP_VERSION | 34 | #else //DESKTOP_VERSION |
35 | #include <libkdepim/externalapphandler.h> | 35 | #include <libkdepim/externalapphandler.h> |
36 | #endif //DESKTOP_VERSION | 36 | #endif //DESKTOP_VERSION |
37 | 37 | ||
38 | 38 | ||
39 | //using namespace Opie::Core; | 39 | //using namespace Opie::Core; |
40 | //using namespace Opie::Ui; | 40 | //using namespace Opie::Ui; |
41 | ComposeMail::ComposeMail( Settings *s, QWidget *parent, const char *name, bool modal ) | 41 | ComposeMail::ComposeMail( Settings *s, QWidget *parent, const char *name, bool modal ) |
42 | : ComposeMailUI( parent, name, modal ) | 42 | : ComposeMailUI( parent, name, modal ) |
43 | { | 43 | { |
44 | 44 | ||
45 | mPickLineEdit = 0; | 45 | mPickLineEdit = 0; |
46 | connect(ExternalAppHandler::instance(), SIGNAL(receivedNameEmailUidListEvent(const QString&, const QStringList&, const QStringList&, const QStringList&)), | 46 | connect(ExternalAppHandler::instance(), SIGNAL(receivedNameEmailUidListEvent(const QString&, const QStringList&, const QStringList&, const QStringList&)), |
47 | this, SLOT(insertAttendees(const QString&, const QStringList&, const QStringList&, const QStringList&))); | 47 | this, SLOT(insertAttendees(const QString&, const QStringList&, const QStringList&, const QStringList&))); |
48 | settings = s; | 48 | settings = s; |
49 | m_replyid = ""; | 49 | m_replyid = ""; |
50 | KConfig config( locateLocal("config", "kabcrc") ); | 50 | KConfig config( locateLocal("config", "kabcrc") ); |
51 | config.setGroup( "General" ); | 51 | config.setGroup( "General" ); |
52 | QString whoami_uid = config.readEntry( "WhoAmI" ); | 52 | QString whoami_uid = config.readEntry( "WhoAmI" ); |
53 | |||
53 | if ( whoami_uid.isEmpty() ) { | 54 | if ( whoami_uid.isEmpty() ) { |
54 | QMessageBox::information( 0, tr( "Hint" ), | 55 | QMessageBox::information( 0, tr( "Hint" ), |
55 | tr( "Please apply\n\"Set Who Am I\"\nin KA/Pi to get the from\nfield automatically filled out!\n" ), | 56 | tr( "Please apply\n\"Set Who Am I\"\nin KA/Pi to get the from\nfield automatically filled out!\n" ), |
56 | tr( "Ok" ) ); | 57 | tr( "Ok" ) ); |
57 | 58 | ||
58 | } else | 59 | } else |
59 | bool res = ExternalAppHandler::instance()->requestDetailsFromKAPI("", "sendbacklist", whoami_uid); | 60 | ExternalAppHandler::instance()->requestDetailsFromKAPI("", "sendbacklist", whoami_uid); |
61 | |||
62 | |||
60 | #ifdef DESKTOP_VERSION | 63 | #ifdef DESKTOP_VERSION |
61 | KABC::Addressee con = KABC::StdAddressBook::self()->whoAmI( ); | 64 | KABC::Addressee con = KABC::StdAddressBook::self()->whoAmI( ); |
62 | QStringList mails = con.emails(); | 65 | QStringList mails = con.emails(); |
63 | QString defmail = con.preferredEmail(); | 66 | QString defmail = con.preferredEmail(); |
64 | if ( mails.count() == 0) | 67 | if ( mails.count() == 0) |
65 | QMessageBox::information( 0, tr( "Hint" ), | 68 | QMessageBox::information( 0, tr( "Hint" ), |
66 | tr( "Please apply\n\"Set Who Am I\"\nin KA/Pi to get the from\nfield automatically filled out!\n" ), | 69 | tr( "Please apply\n\"Set Who Am I\"\nin KA/Pi to get the from\nfield automatically filled out!\n" ), |
67 | tr( "Ok" ) ); | 70 | tr( "Ok" ) ); |
68 | if (defmail.length()!=0) { | 71 | if (defmail.length()!=0) { |
69 | fromBox->insertItem(defmail); | 72 | fromBox->insertItem(defmail); |
70 | } | 73 | } |
71 | QStringList::ConstIterator sit = mails.begin(); | 74 | QStringList::ConstIterator sit = mails.begin(); |
72 | for (;sit!=mails.end();++sit) { | 75 | for (;sit!=mails.end();++sit) { |
73 | if ( (*sit)==defmail) | 76 | if ( (*sit)==defmail) |
74 | continue; | 77 | continue; |
75 | fromBox->insertItem((*sit)); | 78 | fromBox->insertItem((*sit)); |
76 | } | 79 | } |
77 | senderNameEdit->setText(con.formattedName()); | 80 | senderNameEdit->setText(con.formattedName()); |
78 | #endif | 81 | #endif |
79 | Config cfg( "mail" ); | 82 | Config cfg( "mail" ); |
80 | cfg.setGroup( "Compose" ); | 83 | cfg.setGroup( "Compose" ); |
81 | checkBoxLater->setChecked( cfg.readBoolEntry( "sendLater", false ) ); | 84 | checkBoxLater->setChecked( cfg.readBoolEntry( "sendLater", false ) ); |
82 | 85 | ||
83 | attList->addColumn( tr( "Name" ) ); | 86 | attList->addColumn( tr( "Name" ) ); |
84 | attList->addColumn( tr( "Size" ) ); | 87 | attList->addColumn( tr( "Size" ) ); |
85 | |||
86 | QList<Account> accounts = settings->getAccounts(); | 88 | QList<Account> accounts = settings->getAccounts(); |
87 | 89 | ||
88 | Account *it; | 90 | Account *it; |
89 | for ( it = accounts.first(); it; it = accounts.next() ) { | 91 | for ( it = accounts.first(); it; it = accounts.next() ) { |
90 | if ( it->getType()==MAILLIB::A_SMTP ) { | 92 | if ( it->getType()==MAILLIB::A_SMTP ) { |
91 | SMTPaccount *smtp = static_cast<SMTPaccount *>(it); | 93 | SMTPaccount *smtp = static_cast<SMTPaccount *>(it); |
92 | smtpAccountBox->insertItem( smtp->getAccountName() ); | 94 | smtpAccountBox->insertItem( smtp->getAccountName() ); |
93 | smtpAccounts.append( smtp ); | 95 | smtpAccounts.append( smtp ); |
94 | } | 96 | } |
95 | } | 97 | } |
96 | if ( smtpAccounts.count() > 0 ) { | 98 | if ( smtpAccounts.count() > 0 ) { |
97 | fillValues( smtpAccountBox->currentItem() ); | 99 | fillValues( smtpAccountBox->currentItem() ); |
98 | } else { | 100 | } else { |
99 | QMessageBox::information( 0, tr( "Problem" ), | 101 | QMessageBox::information( 0, tr( "Problem" ), |
100 | tr( "Please create an SMTP account first.\nThe SMTP is needed for sending mail.\n" ), | 102 | tr( "Please create an SMTP account first.\nThe SMTP is needed for sending mail.\n" ), |
101 | tr( "Ok" ) ); | 103 | tr( "Ok" ) ); |
102 | return; | 104 | return; |
103 | } | 105 | } |
104 | connect( smtpAccountBox, SIGNAL( activated(int) ), SLOT( fillValues(int) ) ); | 106 | connect( smtpAccountBox, SIGNAL( activated(int) ), SLOT( fillValues(int) ) ); |
105 | connect( toButton, SIGNAL( clicked() ), SLOT( pickAddressTo() ) ); | 107 | connect( toButton, SIGNAL( clicked() ), SLOT( pickAddressTo() ) ); |
106 | connect( ccButton, SIGNAL( clicked() ), SLOT( pickAddressCC() ) ); | 108 | connect( ccButton, SIGNAL( clicked() ), SLOT( pickAddressCC() ) ); |
107 | connect( bccButton, SIGNAL( clicked() ), SLOT( pickAddressBCC() ) ); | 109 | connect( bccButton, SIGNAL( clicked() ), SLOT( pickAddressBCC() ) ); |
108 | connect( replyButton, SIGNAL( clicked() ), SLOT( pickAddressReply() ) ); | 110 | connect( replyButton, SIGNAL( clicked() ), SLOT( pickAddressReply() ) ); |
109 | connect( addButton, SIGNAL( clicked() ), SLOT( addAttachment() ) ); | 111 | connect( addButton, SIGNAL( clicked() ), SLOT( addAttachment() ) ); |
110 | connect( deleteButton, SIGNAL( clicked() ), SLOT( removeAttachment() ) ); | 112 | connect( deleteButton, SIGNAL( clicked() ), SLOT( removeAttachment() ) ); |
111 | connect( SaveButton, SIGNAL( clicked() ), SLOT( saveAsDraft()) ); | 113 | connect( SaveButton, SIGNAL( clicked() ), SLOT( saveAsDraft()) ); |
112 | mMail = 0; | 114 | mMail = 0; |
113 | warnAttach = true; | 115 | warnAttach = true; |
114 | 116 | ||
115 | } | 117 | } |
116 | 118 | ||
117 | 119 | ||
118 | 120 | ||
119 | void ComposeMail::saveAsDraft() | 121 | void ComposeMail::saveAsDraft() |
120 | { | 122 | { |
121 | 123 | ||
122 | Opie::Core::OSmartPointer<Mail> mail= new Mail(); | 124 | Opie::Core::OSmartPointer<Mail> mail= new Mail(); |
123 | mail->setMail(fromBox->currentText()); | 125 | mail->setMail(fromBox->currentText()); |
124 | mail->setTo( toLine->text() ); | 126 | mail->setTo( toLine->text() ); |
125 | mail->setName(senderNameEdit->text()); | 127 | mail->setName(senderNameEdit->text()); |
126 | mail->setCC( ccLine->text() ); | 128 | mail->setCC( ccLine->text() ); |
127 | mail->setBCC( bccLine->text() ); | 129 | mail->setBCC( bccLine->text() ); |
128 | mail->setReply( replyLine->text() ); | 130 | mail->setReply( replyLine->text() ); |
129 | mail->setSubject( subjectLine->text() ); | 131 | mail->setSubject( subjectLine->text() ); |
130 | if (!m_replyid.isEmpty()) { | 132 | if (!m_replyid.isEmpty()) { |
131 | QStringList ids; | 133 | QStringList ids; |
132 | ids.append(m_replyid); | 134 | ids.append(m_replyid); |
133 | mail->setInreply(ids); | 135 | mail->setInreply(ids); |
134 | } | 136 | } |
135 | QString txt = message->text(); | 137 | QString txt = message->text(); |
136 | if ( !sigMultiLine->text().isEmpty() ) { | 138 | if ( !sigMultiLine->text().isEmpty() ) { |
137 | txt.append( "\n--\n" ); | 139 | txt.append( "\n--\n" ); |
138 | txt.append( sigMultiLine->text() ); | 140 | txt.append( sigMultiLine->text() ); |
139 | } | 141 | } |
140 | mail->setMessage( txt ); | 142 | mail->setMessage( txt ); |
141 | 143 | ||
142 | /* only use the default drafts folder name! */ | 144 | /* only use the default drafts folder name! */ |
143 | Storemail wrapper(AbstractMail::draftFolder()); | 145 | Storemail wrapper(AbstractMail::draftFolder()); |
144 | wrapper.storeMail(mail); | 146 | wrapper.storeMail(mail); |
145 | 147 | ||
146 | AttachViewItem *it = (AttachViewItem *) attList->firstChild(); | 148 | AttachViewItem *it = (AttachViewItem *) attList->firstChild(); |
147 | /* attachments we will ignore! */ | 149 | /* attachments we will ignore! */ |
148 | if ( it != 0 ) { | 150 | if ( it != 0 ) { |
149 | if ( warnAttach ) | 151 | if ( warnAttach ) |
150 | QMessageBox::warning(0,tr("Store message"), | 152 | QMessageBox::warning(0,tr("Store message"), |
151 | tr("<center>Attachments will not be stored in \"Draft\" folder</center>")); | 153 | tr("<center>Attachments will not be stored in \"Draft\" folder</center>")); |
152 | warnAttach = false; | 154 | warnAttach = false; |
153 | } | 155 | } |
154 | setStatus( tr("Mail saved as draft!") ); | 156 | setStatus( tr("Mail saved as draft!") ); |
155 | } | 157 | } |
156 | void ComposeMail::clearStatus() | 158 | void ComposeMail::clearStatus() |
157 | { | 159 | { |
158 | topLevelWidget()->setCaption( tr("Compose mail") ); | 160 | topLevelWidget()->setCaption( tr("Compose mail") ); |
159 | } | 161 | } |
160 | void ComposeMail::setStatus( QString status ) | 162 | void ComposeMail::setStatus( QString status ) |
161 | { | 163 | { |
162 | topLevelWidget()->setCaption( status ); | 164 | topLevelWidget()->setCaption( status ); |
163 | QTimer::singleShot ( 10000, this, SLOT( clearStatus() ) ) ; | 165 | QTimer::singleShot ( 10000, this, SLOT( clearStatus() ) ) ; |
164 | } | 166 | } |
165 | void ComposeMail::pickAddress( ) | 167 | void ComposeMail::pickAddress( ) |
166 | { | 168 | { |
167 | 169 | ||
168 | QLineEdit *line = mPickLineEdit; | 170 | QLineEdit *line = mPickLineEdit; |
169 | if ( line == 0 ) | 171 | if ( line == 0 ) |
170 | return; | 172 | return; |
171 | #ifdef DESKTOP_VERSION | 173 | #ifdef DESKTOP_VERSION |
172 | //qDebug(" ComposeMail::pickAddress "); | 174 | //qDebug(" ComposeMail::pickAddress "); |
173 | QString names ;//= AddressPicker::getNames(); | 175 | QString names ;//= AddressPicker::getNames(); |
174 | 176 | ||
175 | KABC::Addressee::List list = KABC::AddresseeDialog::getAddressees(this); | 177 | KABC::Addressee::List list = KABC::AddresseeDialog::getAddressees(this); |
176 | uint i=0; | 178 | uint i=0; |
177 | for (i=0; i < list.count(); i++) { | 179 | for (i=0; i < list.count(); i++) { |
178 | if ( !list[i].preferredEmail().isEmpty()) { | 180 | if ( !list[i].preferredEmail().isEmpty()) { |
179 | if ( ! names.isEmpty() ) | 181 | if ( ! names.isEmpty() ) |
180 | names+= ","; | 182 | names+= ","; |
181 | names+= "\""+list[i].realName() +"\"<" +list[i].preferredEmail() +">"; | 183 | names+= "\""+list[i].realName() +"\"<" +list[i].preferredEmail() +">"; |
182 | 184 | ||
183 | } | 185 | } |
184 | } | 186 | } |
185 | 187 | ||
186 | 188 | ||
187 | if ( line->text().isEmpty() ) { | 189 | if ( line->text().isEmpty() ) { |
188 | line->setText( names ); | 190 | line->setText( names ); |
189 | } else if ( !names.isEmpty() ) { | 191 | } else if ( !names.isEmpty() ) { |
190 | line->setText( line->text() + ", " + names ); | 192 | line->setText( line->text() + ", " + names ); |
191 | } | 193 | } |
192 | #else | 194 | #else |
193 | bool res = ExternalAppHandler::instance()->requestNameEmailUidListFromKAPI("QPE/Application/ompi", this->name() /* name is here the unique uid*/); | 195 | bool res = ExternalAppHandler::instance()->requestNameEmailUidListFromKAPI("QPE/Application/ompi", this->name() /* name is here the unique uid*/); |
194 | // the result should now arrive through method insertAttendees | 196 | // the result should now arrive through method insertAttendees |
195 | #endif | 197 | #endif |
196 | } | 198 | } |
197 | //the map includes name/email pairs, that comes from Ka/Pi | 199 | //the map includes name/email pairs, that comes from Ka/Pi |
198 | void ComposeMail::insertAttendees(const QString& uid,const QStringList& nameList,const QStringList& emailList,const QStringList& uidList) | 200 | void ComposeMail::insertAttendees(const QString& uid,const QStringList& nameList,const QStringList& emailList,const QStringList& uidList) |
199 | { | 201 | { |
200 | qDebug("ComposeMail::insertAttendees "); | 202 | //qDebug("ComposeMail::insertAttendees "); |
201 | raise(); | 203 | raise(); |
202 | 204 | ||
203 | if ( mPickLineEdit == 0 ) { //whoami received | 205 | if ( mPickLineEdit == 0 ) { //whoami received |
204 | qDebug("returnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnn "); | ||
205 | QString defmail = uidList[0]; | 206 | QString defmail = uidList[0]; |
206 | if ( emailList.count() == 0 ) | 207 | if ( emailList.count() == 0 ) |
207 | QMessageBox::information( 0, tr( "Hint" ), | 208 | QMessageBox::information( 0, tr( "Hint" ), |
208 | tr( "Please apply\n\"Set Who Am I\"\nin KA/Pi to get the from\nfield automatically filled out!\n" ), | 209 | tr( "Please apply\n\"Set Who Am I\"\nin KA/Pi to get the from\nfield automatically filled out!\n" ), |
209 | tr( "Ok" ) ); | 210 | tr( "Ok" ) ); |
210 | if (defmail.length()!=0) { | 211 | if (defmail.length()!=0) { |
211 | fromBox->insertItem(defmail); | 212 | fromBox->insertItem(defmail); |
212 | } | 213 | } |
213 | QStringList::ConstIterator sit = emailList.begin(); | 214 | QStringList::ConstIterator sit = emailList.begin(); |
214 | int pref = 0; | 215 | int pref = 0; |
215 | for (;sit!=emailList.end();++sit) { | 216 | for (;sit!=emailList.end();++sit) { |
216 | if ( (*sit)==defmail) | 217 | if ( (*sit)==defmail) |
217 | continue; | 218 | continue; |
218 | fromBox->insertItem((*sit)); | 219 | fromBox->insertItem((*sit)); |
219 | } | 220 | } |
220 | senderNameEdit->setText(nameList[0]); | 221 | senderNameEdit->setText(nameList[0]); |
221 | return; | 222 | return; |
222 | } | 223 | } |
223 | QString names ; | 224 | QString names ; |
224 | QLineEdit *line = mPickLineEdit; | 225 | QLineEdit *line = mPickLineEdit; |
225 | if (uid == this->name()) | 226 | if (uid == this->name()) |
226 | { | 227 | { |
227 | for ( int i = 0; i < nameList.count(); i++) | 228 | for ( int i = 0; i < nameList.count(); i++) |
228 | { | 229 | { |
229 | QString _name = nameList[i]; | 230 | QString _name = nameList[i]; |
230 | QString _email = emailList[i]; | 231 | QString _email = emailList[i]; |
231 | QString _uid = uidList[i]; | 232 | QString _uid = uidList[i]; |
232 | if ( ! _email.isEmpty() ) { | 233 | if ( ! _email.isEmpty() ) { |
233 | if ( ! names.isEmpty() ) | 234 | if ( ! names.isEmpty() ) |
234 | names+= ","; | 235 | names+= ","; |
235 | names+= "\""+_name +"\"<" +_email +">"; | 236 | names+= "\""+_name +"\"<" +_email +">"; |
236 | } | 237 | } |
237 | } | 238 | } |
238 | } | 239 | } |
239 | if ( line->text().isEmpty() ) { | 240 | if ( line->text().isEmpty() ) { |
240 | line->setText( names ); | 241 | line->setText( names ); |
241 | } else if ( !names.isEmpty() ) { | 242 | } else if ( !names.isEmpty() ) { |
242 | line->setText( line->text() + ", " + names ); | 243 | line->setText( line->text() + ", " + names ); |
243 | } | 244 | } |
244 | } | 245 | } |
245 | 246 | ||
246 | void ComposeMail::setTo( const QString & to ) | 247 | void ComposeMail::setTo( const QString & to ) |
247 | { | 248 | { |
248 | toLine->setText( to ); | 249 | toLine->setText( to ); |
249 | } | 250 | } |
250 | 251 | ||
251 | void ComposeMail::setSubject( const QString & subject ) | 252 | void ComposeMail::setSubject( const QString & subject ) |
252 | { | 253 | { |
253 | subjectLine->setText( subject ); | 254 | subjectLine->setText( subject ); |
254 | } | 255 | } |
255 | 256 | ||
256 | void ComposeMail::setInReplyTo( const QString & messageId ) | 257 | void ComposeMail::setInReplyTo( const QString & messageId ) |
257 | { | 258 | { |
258 | m_replyid = messageId; | 259 | m_replyid = messageId; |
259 | } | 260 | } |
260 | 261 | ||
261 | void ComposeMail::setMessage( const QString & text ) | 262 | void ComposeMail::setMessage( const QString & text ) |
262 | { | 263 | { |
263 | message->setText( text ); | 264 | message->setText( text ); |
264 | } | 265 | } |
265 | 266 | ||
266 | 267 | ||
267 | void ComposeMail::pickAddressTo() | 268 | void ComposeMail::pickAddressTo() |
268 | { | 269 | { |
269 | mPickLineEdit = toLine; | 270 | mPickLineEdit = toLine; |
270 | pickAddress( ); | 271 | pickAddress( ); |
271 | } | 272 | } |
272 | 273 | ||
273 | void ComposeMail::pickAddressCC() | 274 | void ComposeMail::pickAddressCC() |
274 | { | 275 | { |
275 | mPickLineEdit = ccLine; | 276 | mPickLineEdit = ccLine; |
276 | pickAddress( ); | 277 | pickAddress( ); |
277 | } | 278 | } |
278 | 279 | ||
279 | void ComposeMail::pickAddressBCC() | 280 | void ComposeMail::pickAddressBCC() |
280 | { | 281 | { |
281 | mPickLineEdit = bccLine; | 282 | mPickLineEdit = bccLine; |
282 | pickAddress( ); | 283 | pickAddress( ); |
283 | } | 284 | } |
284 | 285 | ||
285 | void ComposeMail::pickAddressReply() | 286 | void ComposeMail::pickAddressReply() |
286 | { | 287 | { |
287 | mPickLineEdit = replyLine; | 288 | mPickLineEdit = replyLine; |
288 | pickAddress( ); | 289 | pickAddress( ); |
289 | } | 290 | } |
290 | 291 | ||
291 | void ComposeMail::fillValues( int ) | 292 | void ComposeMail::fillValues( int ) |
292 | { | 293 | { |
293 | #if 0 | 294 | #if 0 |
294 | SMTPaccount *smtp = smtpAccounts.at( current ); | 295 | SMTPaccount *smtp = smtpAccounts.at( current ); |
295 | ccLine->clear(); | 296 | ccLine->clear(); |
296 | if ( smtp->getUseCC() ) { | 297 | if ( smtp->getUseCC() ) { |
297 | ccLine->setText( smtp->getCC() ); | 298 | ccLine->setText( smtp->getCC() ); |
298 | } | 299 | } |
299 | bccLine->clear(); | 300 | bccLine->clear(); |
300 | if ( smtp->getUseBCC() ) { | 301 | if ( smtp->getUseBCC() ) { |
diff --git a/kmicromail/opiemail.cpp b/kmicromail/opiemail.cpp index 0c581c0..b2119e6 100644 --- a/kmicromail/opiemail.cpp +++ b/kmicromail/opiemail.cpp | |||
@@ -1,231 +1,247 @@ | |||
1 | // CHANGED 2004-09-31 Lutz Rogowski | 1 | // CHANGED 2004-09-31 Lutz Rogowski |
2 | // CHANGED 2004-08-06 Lutz Rogowski | 2 | // CHANGED 2004-08-06 Lutz Rogowski |
3 | 3 | ||
4 | #include "settingsdialog.h" | 4 | #include "settingsdialog.h" |
5 | #include "opiemail.h" | 5 | #include "opiemail.h" |
6 | #include "editaccounts.h" | 6 | #include "editaccounts.h" |
7 | #include "composemail.h" | 7 | #include "composemail.h" |
8 | #include "mailistviewitem.h" | 8 | #include "mailistviewitem.h" |
9 | #include "viewmail.h" | 9 | #include "viewmail.h" |
10 | #include "selectstore.h" | 10 | #include "selectstore.h" |
11 | #include "selectsmtp.h" | 11 | #include "selectsmtp.h" |
12 | 12 | ||
13 | #include <qmessagebox.h> | 13 | #include <qmessagebox.h> |
14 | #include <qtimer.h> | ||
14 | #include <libkdepim/externalapphandler.h> | 15 | #include <libkdepim/externalapphandler.h> |
15 | 16 | ||
16 | #include <qpe/qpeapplication.h> | 17 | #include <qpe/qpeapplication.h> |
17 | #include <libmailwrapper/smtpwrapper.h> | 18 | #include <libmailwrapper/smtpwrapper.h> |
18 | #include <libmailwrapper/mailtypes.h> | 19 | #include <libmailwrapper/mailtypes.h> |
19 | #include <libmailwrapper/abstractmail.h> | 20 | #include <libmailwrapper/abstractmail.h> |
20 | /* OPIE */ | 21 | /* OPIE */ |
21 | //#include <qpe/resource.h> | 22 | //#include <qpe/resource.h> |
22 | //#include <qpe/qpeapplication.h> | 23 | //#include <qpe/qpeapplication.h> |
23 | 24 | ||
24 | /* QT */ | 25 | /* QT */ |
25 | 26 | ||
26 | //using namespace Opie::Core; | 27 | //using namespace Opie::Core; |
27 | 28 | ||
28 | OpieMail::OpieMail( QWidget *parent, const char *name ) | 29 | OpieMail::OpieMail( QWidget *parent, const char *name ) |
29 | : MainWindow( parent, name) //, WStyle_ContextHelp ) | 30 | : MainWindow( parent, name) //, WStyle_ContextHelp ) |
30 | { | 31 | { |
31 | settings = new Settings(); | 32 | settings = new Settings(); |
32 | 33 | ||
33 | folderView->populate( settings->getAccounts() ); | 34 | folderView->populate( settings->getAccounts() ); |
34 | 35 | ||
35 | } | 36 | } |
36 | 37 | ||
37 | OpieMail::~OpieMail() | 38 | OpieMail::~OpieMail() |
38 | { | 39 | { |
39 | if (settings) delete settings; | 40 | if (settings) delete settings; |
40 | } | 41 | } |
41 | 42 | ||
42 | void OpieMail::appMessage(const QCString &msg, const QByteArray &data) | 43 | void OpieMail::appMessage(const QCString &msg, const QByteArray &data) |
43 | { | 44 | { |
44 | 45 | ||
45 | } | 46 | } |
46 | #include <stdlib.h> | 47 | #include <stdlib.h> |
47 | void OpieMail::message(const QCString &msg, const QByteArray &data) | 48 | void OpieMail::message(const QCString &msg, const QByteArray &data) |
48 | { | 49 | { |
49 | // copied from old mail2 | 50 | // copied from old mail2 |
50 | static int ii = 0; | 51 | static int ii = 0; |
51 | qDebug("call ############################# %d ", ii); | 52 | //qDebug("QCOP CALL ############################# %d ", ii); |
52 | // block second call | 53 | //QString mess ( msg ); |
53 | if ( ii < 2 ) { | 54 | //qDebug("Message = %s ",mess.latin1()); |
54 | //++ii; | ||
55 | if ( ii > 1 ) { | ||
56 | qDebug("qcop call blocked "); | ||
57 | //return; | ||
58 | } | ||
59 | } | ||
60 | ++ii; | 55 | ++ii; |
61 | //qDebug("KM:appMessage %d *%s* %x", ii, msg.data(), this); | 56 | //qDebug("KM:appMessage %d *%s* %x", ii, msg.data(), this); |
57 | |||
58 | mPendingEmail = QString::null; | ||
59 | mPendingName = QString::null; | ||
62 | if (msg == "writeMail(QString,QString)") | 60 | if (msg == "writeMail(QString,QString)") |
63 | { | 61 | { |
62 | //qDebug("writeMail(QString,QString) "); | ||
64 | QDataStream stream(data,IO_ReadOnly); | 63 | QDataStream stream(data,IO_ReadOnly); |
65 | QString name, email; | 64 | stream >> mPendingName >> mPendingEmail; |
66 | stream >> name >> email; | ||
67 | // removing the whitespaces at beginning and end is needed! | 65 | // removing the whitespaces at beginning and end is needed! |
68 | slotwriteMail(name.stripWhiteSpace(),email.stripWhiteSpace()); | 66 | QTimer::singleShot ( 50, this, SLOT(slotComposeMail() ) ); |
69 | } | 67 | } |
70 | else if (msg == "newMail()") | 68 | else if (msg == "newMail()") |
71 | { | 69 | { |
72 | slotComposeMail(); | 70 | //qDebug("slotComposeMail() "); |
71 | // we cannot call slotComposeMail(); directly, because may be executing a QCOP call | ||
72 | // and a QCOP call does not like a processevents in his execution | ||
73 | // with the Qtimer we call slotComposeMail() after we reached the main event loop | ||
74 | QTimer::singleShot ( 50, this, SLOT(slotComposeMail() ) ); | ||
75 | // slotComposeMail(); | ||
73 | } | 76 | } |
74 | else if (msg == "newMail(QString)") | 77 | else if (msg == "newMail(QString)") |
75 | { | 78 | { |
79 | //qDebug(" newMail(QString)"); | ||
76 | QDataStream stream(data,IO_ReadOnly); | 80 | QDataStream stream(data,IO_ReadOnly); |
77 | QString nameemail; | 81 | stream >> mPendingName; |
78 | stream >> nameemail; | ||
79 | // the format is | 82 | // the format is |
80 | // NAME <EMAIL>:SUBJECT | 83 | // NAME <EMAIL>:SUBJECT |
81 | //qDebug("message %s ", nameemail.latin1()); | 84 | QTimer::singleShot ( 50, this, SLOT(slotComposeMail() ) ); |
82 | 85 | } else { | |
83 | slotwriteMail2( nameemail ); | 86 | if ( ii == 1 ) { |
84 | } else | 87 | qDebug("Kopiemail::Error:: Initial QCOP call for ExternalAppHandler not supported "); |
85 | ExternalAppHandler::instance()->appMessage ( msg, data); | 88 | return; |
89 | } | ||
90 | ExternalAppHandler::instance()->appMessage ( msg, data); | ||
91 | } | ||
92 | |||
93 | //qDebug("END OpieMail::message "); | ||
86 | } | 94 | } |
87 | void OpieMail::slotwriteMail2(const QString& namemail ) | 95 | void OpieMail::slotwriteMail2(const QString& namemail ) |
88 | { | 96 | { |
89 | // qDebug("OpieMail::slotwriteMail2 "); | 97 | //qDebug("OpieMail::slotwriteMail2 "); |
90 | qApp->processEvents(); | 98 | //qApp->processEvents(); |
91 | ComposeMail compose( settings, this, 0, true ); | 99 | ComposeMail compose( settings, this, 0, true ); |
92 | if ( !namemail.isEmpty() ) { | 100 | if ( !namemail.isEmpty() ) { |
93 | QString to = namemail; | 101 | QString to = namemail; |
94 | if ( namemail.find( " <") > 1 ) { | 102 | if ( namemail.find( " <") > 1 ) { |
95 | to = "\"" +to.replace( QRegExp( " <"), "\" <") ; | 103 | to = "\"" +to.replace( QRegExp( " <"), "\" <") ; |
96 | } else | 104 | } else |
97 | if ( namemail.find( "<") > 1 ) { | 105 | if ( namemail.find( "<") > 1 ) { |
98 | to = "\"" +to.replace( QRegExp( "<"), "\" <") ; | 106 | to = "\"" +to.replace( QRegExp( "<"), "\" <") ; |
99 | } | 107 | } |
100 | int sub = to.find( ">:"); | 108 | int sub = to.find( ">:"); |
101 | if ( sub > 0 ) { | 109 | if ( sub > 0 ) { |
102 | compose.setTo( to.left(sub+1) ); | 110 | compose.setTo( to.left(sub+1) ); |
103 | compose.setSubject( to.mid(sub+2) ); | 111 | compose.setSubject( to.mid(sub+2) ); |
104 | } else | 112 | } else |
105 | compose.setTo( to ); | 113 | compose.setTo( to ); |
106 | } | 114 | } |
107 | compose.slotAdjustColumns(); | 115 | compose.slotAdjustColumns(); |
108 | compose.showMaximized(); | 116 | compose.showMaximized(); |
109 | compose.exec(); | 117 | compose.exec(); |
110 | raise(); | 118 | raise(); |
111 | //qDebug("retttich "); | 119 | //qDebug("retttich "); |
112 | } | 120 | } |
113 | void OpieMail::slotwriteMail(const QString&name,const QString&email) | 121 | void OpieMail::slotwriteMail(const QString&name,const QString&email) |
114 | { | 122 | { |
115 | // qDebug("OpieMail::slotwriteMail "); | 123 | // qDebug("OpieMail::slotwriteMail "); |
116 | ComposeMail compose( settings, this, 0, true ); | 124 | ComposeMail compose( settings, this, 0, true ); |
117 | if (!email.isEmpty()) | 125 | if (!email.isEmpty()) |
118 | { | 126 | { |
119 | if (!name.isEmpty()) | 127 | if (!name.isEmpty()) |
120 | { | 128 | { |
121 | compose.setTo("\"" + name + "\"" + " " + "<"+ email + ">"); | 129 | compose.setTo("\"" + name + "\"" + " " + "<"+ email + ">"); |
122 | } | 130 | } |
123 | else | 131 | else |
124 | { | 132 | { |
125 | compose.setTo(email); | 133 | compose.setTo(email); |
126 | } | 134 | } |
127 | } | 135 | } |
128 | compose.slotAdjustColumns(); | 136 | compose.slotAdjustColumns(); |
129 | compose.showMaximized(); | 137 | compose.showMaximized(); |
130 | compose.exec(); | 138 | compose.exec(); |
139 | raise(); | ||
131 | } | 140 | } |
132 | 141 | ||
133 | void OpieMail::slotComposeMail() | 142 | void OpieMail::slotComposeMail() |
134 | { | 143 | { |
135 | slotwriteMail2( QString () ); | 144 | if ( mPendingEmail == QString::null && mPendingName == QString::null) |
145 | slotwriteMail2( QString () ); | ||
146 | else { | ||
147 | if ( mPendingEmail == QString::null ) | ||
148 | slotwriteMail2( mPendingName ); | ||
149 | else | ||
150 | slotwriteMail( mPendingName, mPendingEmail ); | ||
151 | } | ||
136 | //slotwriteMail(0l,0l); | 152 | //slotwriteMail(0l,0l); |
137 | } | 153 | } |
138 | 154 | ||
139 | void OpieMail::slotSendQueued() | 155 | void OpieMail::slotSendQueued() |
140 | { | 156 | { |
141 | SMTPaccount *smtp = 0; | 157 | SMTPaccount *smtp = 0; |
142 | 158 | ||
143 | QList<Account> list = settings->getAccounts(); | 159 | QList<Account> list = settings->getAccounts(); |
144 | QList<SMTPaccount> smtpList; | 160 | QList<SMTPaccount> smtpList; |
145 | smtpList.setAutoDelete(false); | 161 | smtpList.setAutoDelete(false); |
146 | Account *it; | 162 | Account *it; |
147 | for ( it = list.first(); it; it = list.next() ) | 163 | for ( it = list.first(); it; it = list.next() ) |
148 | { | 164 | { |
149 | if ( it->getType() == MAILLIB::A_SMTP ) | 165 | if ( it->getType() == MAILLIB::A_SMTP ) |
150 | { | 166 | { |
151 | smtp = static_cast<SMTPaccount *>(it); | 167 | smtp = static_cast<SMTPaccount *>(it); |
152 | smtpList.append(smtp); | 168 | smtpList.append(smtp); |
153 | } | 169 | } |
154 | } | 170 | } |
155 | if (smtpList.count()==0) | 171 | if (smtpList.count()==0) |
156 | { | 172 | { |
157 | QMessageBox::information(0,tr("Info"),tr("Define a smtp account first!\n")); | 173 | QMessageBox::information(0,tr("Info"),tr("Define a smtp account first!\n")); |
158 | return; | 174 | return; |
159 | } | 175 | } |
160 | if (smtpList.count()==1) | 176 | if (smtpList.count()==1) |
161 | { | 177 | { |
162 | smtp = smtpList.at(0); | 178 | smtp = smtpList.at(0); |
163 | } | 179 | } |
164 | else | 180 | else |
165 | { | 181 | { |
166 | smtp = 0; | 182 | smtp = 0; |
167 | selectsmtp selsmtp; | 183 | selectsmtp selsmtp; |
168 | selsmtp.setSelectionlist(&smtpList); | 184 | selsmtp.setSelectionlist(&smtpList); |
169 | selsmtp.showMaximized(); | 185 | selsmtp.showMaximized(); |
170 | if ( selsmtp.exec() == QDialog::Accepted ) | 186 | if ( selsmtp.exec() == QDialog::Accepted ) |
171 | { | 187 | { |
172 | smtp = selsmtp.selected_smtp(); | 188 | smtp = selsmtp.selected_smtp(); |
173 | } | 189 | } |
174 | } | 190 | } |
175 | if (smtp) | 191 | if (smtp) |
176 | { | 192 | { |
177 | SMTPwrapper * wrap = new SMTPwrapper(smtp); | 193 | SMTPwrapper * wrap = new SMTPwrapper(smtp); |
178 | if ( wrap->flushOutbox() ) | 194 | if ( wrap->flushOutbox() ) |
179 | { | 195 | { |
180 | QMessageBox::information(0,tr("Info"),tr("Mail queue flushed")); | 196 | QMessageBox::information(0,tr("Info"),tr("Mail queue flushed")); |
181 | } | 197 | } |
182 | delete wrap; | 198 | delete wrap; |
183 | } | 199 | } |
184 | } | 200 | } |
185 | 201 | ||
186 | void OpieMail::slotSearchMails() | 202 | void OpieMail::slotSearchMails() |
187 | { | 203 | { |
188 | qDebug("OpieMail::slotSearchMails():not implemented "); | 204 | qDebug("OpieMail::slotSearchMails():not implemented "); |
189 | } | 205 | } |
190 | 206 | ||
191 | void OpieMail::slotEditSettings() | 207 | void OpieMail::slotEditSettings() |
192 | { | 208 | { |
193 | SettingsDialog settingsDialog( this, 0, true, WStyle_ContextHelp ); | 209 | SettingsDialog settingsDialog( this, 0, true, WStyle_ContextHelp ); |
194 | settingsDialog.showMaximized(); | 210 | settingsDialog.showMaximized(); |
195 | settingsDialog.exec(); | 211 | settingsDialog.exec(); |
196 | } | 212 | } |
197 | 213 | ||
198 | void OpieMail::slotEditAccounts() | 214 | void OpieMail::slotEditAccounts() |
199 | { | 215 | { |
200 | EditAccounts eaDialog( settings, this, 0, true, WStyle_ContextHelp ); | 216 | EditAccounts eaDialog( settings, this, 0, true, WStyle_ContextHelp ); |
201 | eaDialog.slotAdjustColumns(); | 217 | eaDialog.slotAdjustColumns(); |
202 | eaDialog.showMaximized(); | 218 | eaDialog.showMaximized(); |
203 | eaDialog.exec(); | 219 | eaDialog.exec(); |
204 | if ( settings ) delete settings; | 220 | if ( settings ) delete settings; |
205 | settings = new Settings(); | 221 | settings = new Settings(); |
206 | 222 | ||
207 | folderView->populate( settings->getAccounts() ); | 223 | folderView->populate( settings->getAccounts() ); |
208 | } | 224 | } |
209 | 225 | ||
210 | void OpieMail::displayMail() | 226 | void OpieMail::displayMail() |
211 | { | 227 | { |
212 | QListViewItem*item = mailView->currentItem(); | 228 | QListViewItem*item = mailView->currentItem(); |
213 | if (!item) return; | 229 | if (!item) return; |
214 | RecMailP mail = ((MailListViewItem*)item)->data(); | 230 | RecMailP mail = ((MailListViewItem*)item)->data(); |
215 | RecBodyP body = folderView->fetchBody(mail); | 231 | RecBodyP body = folderView->fetchBody(mail); |
216 | ViewMail readMail( this,"", Qt::WType_Modal | WStyle_ContextHelp ); | 232 | ViewMail readMail( this,"", Qt::WType_Modal | WStyle_ContextHelp ); |
217 | readMail.setBody( body ); | 233 | readMail.setBody( body ); |
218 | readMail.setMail( mail ); | 234 | readMail.setMail( mail ); |
219 | readMail.showMaximized(); | 235 | readMail.showMaximized(); |
220 | readMail.exec(); | 236 | readMail.exec(); |
221 | 237 | ||
222 | if ( readMail.deleted ) | 238 | if ( readMail.deleted ) |
223 | { | 239 | { |
224 | folderView->refreshCurrent(); | 240 | folderView->refreshCurrent(); |
225 | } | 241 | } |
226 | else | 242 | else |
227 | { | 243 | { |
228 | ( (MailListViewItem*)item )->setPixmap( 0, QPixmap() ); | 244 | ( (MailListViewItem*)item )->setPixmap( 0, QPixmap() ); |
229 | } | 245 | } |
230 | } | 246 | } |
231 | 247 | ||
diff --git a/kmicromail/opiemail.h b/kmicromail/opiemail.h index 7434e59..1de5f6b 100644 --- a/kmicromail/opiemail.h +++ b/kmicromail/opiemail.h | |||
@@ -1,48 +1,50 @@ | |||
1 | // CHANGED 2004-09-31 Lutz Rogowski | 1 | // CHANGED 2004-09-31 Lutz Rogowski |
2 | #ifndef OPIEMAIL_H | 2 | #ifndef OPIEMAIL_H |
3 | #define OPIEMAIL_H | 3 | #define OPIEMAIL_H |
4 | 4 | ||
5 | #include "mainwindow.h" | 5 | #include "mainwindow.h" |
6 | #include <libmailwrapper/settings.h> | 6 | #include <libmailwrapper/settings.h> |
7 | 7 | ||
8 | #include <opie2/osmartpointer.h> | 8 | #include <opie2/osmartpointer.h> |
9 | #include <libmailwrapper/mailtypes.h> | 9 | #include <libmailwrapper/mailtypes.h> |
10 | 10 | ||
11 | class OpieMail : public MainWindow | 11 | class OpieMail : public MainWindow |
12 | { | 12 | { |
13 | Q_OBJECT | 13 | Q_OBJECT |
14 | 14 | ||
15 | public: | 15 | public: |
16 | OpieMail( QWidget *parent = 0, const char *name = 0 ); | 16 | OpieMail( QWidget *parent = 0, const char *name = 0 ); |
17 | virtual ~OpieMail(); | 17 | virtual ~OpieMail(); |
18 | static QString appName() { return QString::fromLatin1("kopiemail"); } | 18 | static QString appName() { return QString::fromLatin1("kopiemail"); } |
19 | 19 | ||
20 | public slots: | 20 | public slots: |
21 | virtual void slotwriteMail(const QString&name,const QString&email); | 21 | virtual void slotwriteMail(const QString&name,const QString&email); |
22 | virtual void slotwriteMail2(const QString&nameemail); | 22 | virtual void slotwriteMail2(const QString&nameemail); |
23 | virtual void slotComposeMail(); | 23 | virtual void slotComposeMail(); |
24 | virtual void appMessage(const QCString &msg, const QByteArray &data); | 24 | virtual void appMessage(const QCString &msg, const QByteArray &data); |
25 | virtual void message(const QCString &msg, const QByteArray &data); | 25 | virtual void message(const QCString &msg, const QByteArray &data); |
26 | protected slots: | 26 | protected slots: |
27 | virtual void slotSendQueued(); | 27 | virtual void slotSendQueued(); |
28 | virtual void slotSearchMails(); | 28 | virtual void slotSearchMails(); |
29 | virtual void slotEditSettings(); | 29 | virtual void slotEditSettings(); |
30 | virtual void slotEditAccounts(); | 30 | virtual void slotEditAccounts(); |
31 | virtual void displayMail(); | 31 | virtual void displayMail(); |
32 | virtual void slotDeleteMail(); | 32 | virtual void slotDeleteMail(); |
33 | virtual void slotDeleteAllMail(); | 33 | virtual void slotDeleteAllMail(); |
34 | virtual void mailHold(int, QListViewItem *,const QPoint&,int); | 34 | virtual void mailHold(int, QListViewItem *,const QPoint&,int); |
35 | virtual void slotShowFolders( bool show ); | 35 | virtual void slotShowFolders( bool show ); |
36 | virtual void refreshMailView(const QValueList<RecMailP>&); | 36 | virtual void refreshMailView(const QValueList<RecMailP>&); |
37 | virtual void mailLeftClicked( QListViewItem * ); | 37 | virtual void mailLeftClicked( QListViewItem * ); |
38 | virtual void slotMoveCopyMail(); | 38 | virtual void slotMoveCopyMail(); |
39 | virtual void slotMoveCopyAllMail(); | 39 | virtual void slotMoveCopyAllMail(); |
40 | virtual void reEditMail(); | 40 | virtual void reEditMail(); |
41 | void clearSelection(); | 41 | void clearSelection(); |
42 | 42 | ||
43 | private: | 43 | private: |
44 | QString mPendingEmail; | ||
45 | QString mPendingName; | ||
44 | Settings *settings; | 46 | Settings *settings; |
45 | 47 | ||
46 | }; | 48 | }; |
47 | 49 | ||
48 | #endif | 50 | #endif |