-rw-r--r-- | bin/kdepim/kopiemail/germantranslation.txt | 243 | ||||
-rw-r--r-- | bin/kdepim/kopiemail/usertranslation.txt | 243 | ||||
-rw-r--r-- | kmicromail/libmailwrapper/mhwrapper.cpp | 13 | ||||
-rw-r--r-- | kmicromail/libmailwrapper/sendmailprogress.cpp | 5 | ||||
-rw-r--r-- | kmicromail/main.cpp | 1 | ||||
-rw-r--r-- | kmicromail/opiemail.cpp | 1 | ||||
-rw-r--r-- | microkde/kdecore/klocale.cpp | 62 |
7 files changed, 553 insertions, 15 deletions
diff --git a/bin/kdepim/kopiemail/germantranslation.txt b/bin/kdepim/kopiemail/germantranslation.txt new file mode 100644 index 0000000..7a53d36 --- a/dev/null +++ b/bin/kdepim/kopiemail/germantranslation.txt | |||
@@ -0,0 +1,243 @@ | |||
1 | { " Local Time"," Locale Zeit" }, | ||
2 | { "Preferences","Vorlieben" }, | ||
3 | { "Ok","Ok" }, | ||
4 | { "Default","Standard" }, | ||
5 | { "Cancel","Abbrechen" }, | ||
6 | { "Global","Global" }, | ||
7 | { "Email","Email" }, | ||
8 | { "Phone","Phone" }, | ||
9 | { "SMS","SMS" }, | ||
10 | { "Fax","Fax" }, | ||
11 | { "Pager","Pager" }, | ||
12 | { "SIP","SIP" }, | ||
13 | { "Language:(needs restart)","Sprache (Neustart!)" }, | ||
14 | { "English","Englisch" }, | ||
15 | { "German","Deutsch" }, | ||
16 | { "French","Französich" }, | ||
17 | { "Italian","Italienisch" }, | ||
18 | { "User defined (usertranslation.txt)","Benutzerdefiniert (usertranslation.txt)" }, | ||
19 | { "Time Format(nr):","Zeit Format(Neustart!)" }, | ||
20 | { "24:00","24:00" }, | ||
21 | { "12:00am","12:00am" }, | ||
22 | { "Week starts on Sunday","Woche beginnt Sonntags" }, | ||
23 | { "Locale","Localisation" }, | ||
24 | { "Date Format:","Datums Format:" }, | ||
25 | { "24.03.2004 (%d.%m.%Y|%A %d %B %Y)","24.03.2004 (%d.%m.%Y|%A %d %B %Y)" }, | ||
26 | { "03.24.2004 (%m.%d.%Y|%A %B %d %Y)","03.24.2004 (%m.%d.%Y|%A %B %d %Y)" }, | ||
27 | { "2004-03-24 (%Y-%m-%d|%A %Y %B %d)","2004-03-24 (%Y-%m-%d|%A %Y %B %d)" }, | ||
28 | { "User defined","Benutzerdefiniert" }, | ||
29 | { "User long date:","Format langes Datum:" }, | ||
30 | { "User short date:","Format kurzes Datum:" }, | ||
31 | { "Monday 19 April 2004: %A %d %B %Y","Montag 19 April 2004: %A %d %B %Y" }, | ||
32 | { "Mon 19.04.04: %a %d.%m.%y","Mon 19.04.04: %a %d.%m.%y" }, | ||
33 | { "Mon, 19.Apr.04: %a, %d.%b.%y","Mon, 19.Apr.04: %a, %d.%b.%y" }, | ||
34 | { "Date Format","Datums Format" }, | ||
35 | { "Timezone:","Zeitzone:" }, | ||
36 | { "Add 30 min (+00:30) to selected Timezone","Addiere 30 min zur selektierten Zeitzone" }, | ||
37 | { "Timezone has daylight saving","Zeitzone hat Sommerzeit" }, | ||
38 | { "Actual start and end is the\nsunday before this date.","Tatsächlicher Beginn/Ende ist der Sonntag\nvor diesem Datum!" }, | ||
39 | { "The year in the date is ignored.","Das Jahr vom Datum wird ignoriert." }, | ||
40 | { "Daylight start:","Sommerzeit Beginn:" }, | ||
41 | { "Mon","Mo" }, | ||
42 | { "Tue","Di" }, | ||
43 | { "Wed","Mi" }, | ||
44 | { "Thu","Do" }, | ||
45 | { "Fri","Fr" }, | ||
46 | { "Sat","Sa" }, | ||
47 | { "Sun","So" }, | ||
48 | { "January","Januar" }, | ||
49 | { "February","Februar" }, | ||
50 | { "March","März" }, | ||
51 | { "April","April" }, | ||
52 | { "May","Mai" }, | ||
53 | { "June","Juni" }, | ||
54 | { "July","Juli" }, | ||
55 | { "August","August" }, | ||
56 | { "September","September" }, | ||
57 | { "October","Oktober" }, | ||
58 | { "November","November" }, | ||
59 | { "December","Dezember" }, | ||
60 | { "tomorrow","morgen" }, | ||
61 | { "today","heute" }, | ||
62 | { "yesterday","gestern" }, | ||
63 | { "Monday","Montag" }, | ||
64 | { "Tuesday","Dienstag" }, | ||
65 | { "Wednesday","Mittwoch" }, | ||
66 | { "Thursday","Donnerstag" }, | ||
67 | { "Friday","Freitag" }, | ||
68 | { "Saturday","Samstag" }, | ||
69 | { "Sunday","Sonntag" }, | ||
70 | { "Daylight end:","Sommerzeit Ende:" }, | ||
71 | { "Time Zone","Zeitzone" }, | ||
72 | { "Used Mail Client","Benutzter Mail Client" }, | ||
73 | { "Channel:","Channel:" }, | ||
74 | { "Message:","Message:" }, | ||
75 | { "Parameters:","Parameter:" }, | ||
76 | { "HINT: Delimiter=; Name=%1,Email=%2","Hinweis: Begrenzer=; Name=%1,Email=%2" }, | ||
77 | { "extra Message:","extra Message:" }, | ||
78 | { "extra Parameters:","extra Parameter:" }, | ||
79 | { "HINT: Emails=%1,Attachments=%2","Hinweis: Emails=%1,Attachments=%2" }, | ||
80 | { "External Apps.","Externe Appl." }, | ||
81 | { "General","Allgemein" }, | ||
82 | { "Full &name:","Vor- und &Nachname:" }, | ||
83 | { "E&mail address:","E&mail Adresse:" }, | ||
84 | { "Fonts","Schriftart" }, | ||
85 | { "Choose...","Wähle..." }, | ||
86 | { "Used %1 Client","Benutzter %1 Client" }, | ||
87 | { "No email client installed","Kein Email Klient installiert" }, | ||
88 | { "Userdefined email client","Benutzerdef. Email Klient" }, | ||
89 | { "OM/Pi email client","OM/Pi Email Klient" }, | ||
90 | { "Delete","Löschen" }, | ||
91 | { "New","Neu" }, | ||
92 | { "Edit","Bearbeite" }, | ||
93 | { "Close","Schließen" }, | ||
94 | { "Size","Größe" }, | ||
95 | { "Date","Datum" }, | ||
96 | { "Please set at","Bitte einstellen in" }, | ||
97 | { "Settings@General TAB","Einstellungen@Allgemein TAB" }, | ||
98 | { "KOpieMail/Pi","KOpieMail/Pi" }, | ||
99 | { "Mail","Mail" }, | ||
100 | { "Settings","Einstellungen" }, | ||
101 | { "Get all new mails","Hole alle neuen Mails" }, | ||
102 | { "Get new messages","Hole neue mails" }, | ||
103 | { "Compose new mail","Schreibe neue Mail" }, | ||
104 | { "Send queued mails","Sende gespeicherte Mails" }, | ||
105 | { "Show/Hide folders","Zeige Verzeichnisse" }, | ||
106 | { "Delete Mail","Lösche Mail" }, | ||
107 | { "Edit settings","Ändere Einstellungen" }, | ||
108 | { "Configure accounts","Konfiguriere Zugänge" }, | ||
109 | { "Mailbox","Mailbox" }, | ||
110 | { "Subject","Betreff" }, | ||
111 | { "Sender","Sender" }, | ||
112 | { "Size","Größe" }, | ||
113 | { "Date","Datum" }, | ||
114 | { "Close","Schliessen" }, | ||
115 | { "Help","Hilfe" }, | ||
116 | { "About","Über" }, | ||
117 | { "Licence","Lizenz" }, | ||
118 | { "LibEtPan Licence","LibEtPan Lizenz" }, | ||
119 | { "Settings - some need a restart (nr)","Einstellungen - manche benötigen einen Neustart (nr)" }, | ||
120 | { "HINT: Separate multiple\neMail addresses by ";"","Hinweis: Trenne mehrere Addressen mit einem ";"" }, | ||
121 | { "Ignore above settings and\nuse KA/Pi "Who am I" instead!","Ignoriere obige Einstellungen und\nbenutze KA/Pi "Wer bin ich" stattdessen!" }, | ||
122 | { "View mail as html","Zeige Mails als html" }, | ||
123 | { "Send mails later","Sende Mails später" }, | ||
124 | { "Application(nr)","Applikation(nr)" }, | ||
125 | { "OK","OK" }, | ||
126 | { "Compose mail:","Verfasse Mail:" }, | ||
127 | { "Dear Mr.","Hallo Herr" }, | ||
128 | { "Read mail:","Lese Mail:" }, | ||
129 | { "Hello","Hallo" }, | ||
130 | { "Configure Accounts","Konfigure Zugänge" }, | ||
131 | { "Name of the Account","Name des Zugangs" }, | ||
132 | { "News","News" }, | ||
133 | { "Account","Zugang" }, | ||
134 | { "Type","Typ" }, | ||
135 | { "<p>Please select an account.</p>","<p>Bitte wähle einen Zugang.</p>" }, | ||
136 | { "Error","Fehler" }, | ||
137 | { "Configure NNTP","Konfiguriere News" }, | ||
138 | { "Port","Port" }, | ||
139 | { "Server","Server" }, | ||
140 | { "Use SSL","Benutze SSL" }, | ||
141 | { "User","Benutzer" }, | ||
142 | { "Password","Passwort" }, | ||
143 | { "Use Login","Benutze Login" }, | ||
144 | { "Newsgroup","Newsgroup" }, | ||
145 | { "Get newsgroup list from server","Hole Newsgroup Liste vom Server" }, | ||
146 | { "Filter:","Filter:" }, | ||
147 | { "Show subscribed","Zeige abbonnierte" }, | ||
148 | { "Groups","NewsGroups" }, | ||
149 | { "Configure IMAP","Konfiguriere IMAP" }, | ||
150 | { "Use secure sockets:","Benutze sichere Verbindung:" }, | ||
151 | { "ssh $SERVER exec","ssh $SERVER exec" }, | ||
152 | { "Prefix","Prefix" }, | ||
153 | { "Local storage folder:","Lokales Verzeichnis:" }, | ||
154 | { "Get only messages smaller","Hole nur Nachrichten kleiner" }, | ||
155 | { "kB","kB" }, | ||
156 | { "Leave Messages on Server","Belasse Nachrichten auf dem Server" }, | ||
157 | { "Configure POP3","Konfiguriere POP3" }, | ||
158 | { "ssh $SERVER exec imapd","ssh $SERVER exec imapd" }, | ||
159 | { "Configure SMTP","Konfiguriere SMTP" }, | ||
160 | { "Name of the SMTP Server","Name des SMTP Servers" }, | ||
161 | { "Port of the SMTP Server","Port des SMTP Servers" }, | ||
162 | { "Fetching folder list","Hole Verzeichnis Liste" }, | ||
163 | { "Fetch ","Hole " }, | ||
164 | { "Fetching header list","Hole Titel Liste" }, | ||
165 | { "Mailbox has %1 mails","Mailbox hat %1 Mails" }, | ||
166 | { "Read this mail","Lies diese Mail" }, | ||
167 | { "Move/Copy this mail","Verschiebe/kopiere diese Mail" }, | ||
168 | { "Delete this mail","Lösche diese Mail" }, | ||
169 | { "Move/Copy all selected mail","Verschiebe/kopiere selektierte Mails" }, | ||
170 | { "Delete all selected mails","Lösche alle selektierten Mails" }, | ||
171 | { "Clear selection","Selektion aufheben" }, | ||
172 | { "Reply","Antworten" }, | ||
173 | { "Forward","Weiterleiten" }, | ||
174 | { "Attachments","Anhang" }, | ||
175 | { "Show Html","Zeige in html" }, | ||
176 | { "Description","Beschreibung" }, | ||
177 | { "Filename","Dateiname" }, | ||
178 | { "E-Mail by %1","E-Mail von %1" }, | ||
179 | { "Cc","Kopie" }, | ||
180 | { "To","An" }, | ||
181 | { "From","Von" }, | ||
182 | { "<p>Do you really want to delete this mail? <br><br>","<p>Wollen Sie diese Mail wirklich löschen? <br><br>" }, | ||
183 | { "Mailbox has %1 mail(s)","Mailbox hat %1 Mail(s)" }, | ||
184 | { "Move/Copie all mails","Verschiebe/kopiere alle Mails" }, | ||
185 | { "Delete all mails","Lösche alle Mails" }, | ||
186 | { "Create new subfolder","Neues Unterverzeichnis" }, | ||
187 | { "Delete folder","Lösche Verzeichnis" }, | ||
188 | { "Refresh folder list","Aktualisiere Verzeichnis Liste" }, | ||
189 | { "Create new folder","Neues Verzeichnis" }, | ||
190 | { "Disconnect","Disconnect" }, | ||
191 | { "Set offline","Gehe offline" }, | ||
192 | { "Select target box","Wähle Ziel Box" }, | ||
193 | { "<b>Store mail(s) to</b>","<b>Speichere Mail(s) nach</b>" }, | ||
194 | { "Folder:","Verzeichnis:" }, | ||
195 | { "Account:","Zugang:" }, | ||
196 | { "Prefix will prepend, no need to enter it!","Prefix wird vorangestellt, braucht nicht eingegeben zu werden!" }, | ||
197 | { "Move mail(s)","Verschiebe Mail(s)" }, | ||
198 | { "apply only to mails smaller","wende nur auf Mails an, kleiner als" }, | ||
199 | { " kB"," kB" }, | ||
200 | { " message %1 of %2"," Nachricht %1 von %2" }, | ||
201 | { "Copying...","Am Kopieren..." }, | ||
202 | { "Copy message %1 of %2","Kopiere Nachricht %1 von %2" }, | ||
203 | { "Do you really want to delete\nall selected mails?","Wollen Sie wirklich alle\nselektierten Mails Löschen?" }, | ||
204 | { "Delete All Mails","Lösche alle Mails" }, | ||
205 | { "Deleting ...","Am Löschen..." }, | ||
206 | { "Delete message %1 of %2","Lösche Nachricht %1 von %2" }, | ||
207 | { "Compose Message","Verfasse Nachricht" }, | ||
208 | { "Reply-To","Antwort-An" }, | ||
209 | { "BCC","BCC" }, | ||
210 | { "Signature","Signatur" }, | ||
211 | { "CC","Kopie" }, | ||
212 | { "Options","Optionen" }, | ||
213 | { "Delete File","Lösche Datei" }, | ||
214 | { "Add File","Füge Datei hinzu" }, | ||
215 | { "Attachment","Anhang" }, | ||
216 | { "send later","sende später" }, | ||
217 | { "use:","via:" }, | ||
218 | { "Save","Speichern" }, | ||
219 | { "Name","Name" }, | ||
220 | { "No Receiver spezified","Kein Empfänger angegeben" }, | ||
221 | { "Sending mail","Sende Mail" }, | ||
222 | { "No","Nein" }, | ||
223 | { "Yes","Ja" }, | ||
224 | { "Store message into drafts?\n","Speichere Nachricht in Entwürfe?\n" }, | ||
225 | { "Store message?","Nachricht speichern?" }, | ||
226 | { "Select Type","Selektiere Typ" }, | ||
227 | { "Select Account Type","Wähle Art des Zugangs" }, | ||
228 | { "IMAP","IMAP (online lesen)" }, | ||
229 | { "POP3","POP3 (holen)" }, | ||
230 | { "SMTP","SMTP (senden)" }, | ||
231 | { "<p>Do you really want to delete the selected Account?</p>","<p>Möchten Sie wirklich den ausgewählten Account löschen?</p>" }, | ||
232 | { "Question","Eine Frage..." }, | ||
233 | { "Send this message?","Nachricht wirklich senden?" }, | ||
234 | { "Stop editing message","Stop editing message" }, | ||
235 | { "Sending mail %1 of %2","Sende Mail %1 von %2" }, | ||
236 | { "%1 of %2 bytes send","%1 von %2 Bytes gesendet" }, | ||
237 | { "Refresh header list","Aktualisiere Titel Liste" }, | ||
238 | { "","" }, | ||
239 | { "","" }, | ||
240 | { "","" }, | ||
241 | { "","" }, | ||
242 | { "","" }, | ||
243 | { "","" }, | ||
diff --git a/bin/kdepim/kopiemail/usertranslation.txt b/bin/kdepim/kopiemail/usertranslation.txt new file mode 100644 index 0000000..7a53d36 --- a/dev/null +++ b/bin/kdepim/kopiemail/usertranslation.txt | |||
@@ -0,0 +1,243 @@ | |||
1 | { " Local Time"," Locale Zeit" }, | ||
2 | { "Preferences","Vorlieben" }, | ||
3 | { "Ok","Ok" }, | ||
4 | { "Default","Standard" }, | ||
5 | { "Cancel","Abbrechen" }, | ||
6 | { "Global","Global" }, | ||
7 | { "Email","Email" }, | ||
8 | { "Phone","Phone" }, | ||
9 | { "SMS","SMS" }, | ||
10 | { "Fax","Fax" }, | ||
11 | { "Pager","Pager" }, | ||
12 | { "SIP","SIP" }, | ||
13 | { "Language:(needs restart)","Sprache (Neustart!)" }, | ||
14 | { "English","Englisch" }, | ||
15 | { "German","Deutsch" }, | ||
16 | { "French","Französich" }, | ||
17 | { "Italian","Italienisch" }, | ||
18 | { "User defined (usertranslation.txt)","Benutzerdefiniert (usertranslation.txt)" }, | ||
19 | { "Time Format(nr):","Zeit Format(Neustart!)" }, | ||
20 | { "24:00","24:00" }, | ||
21 | { "12:00am","12:00am" }, | ||
22 | { "Week starts on Sunday","Woche beginnt Sonntags" }, | ||
23 | { "Locale","Localisation" }, | ||
24 | { "Date Format:","Datums Format:" }, | ||
25 | { "24.03.2004 (%d.%m.%Y|%A %d %B %Y)","24.03.2004 (%d.%m.%Y|%A %d %B %Y)" }, | ||
26 | { "03.24.2004 (%m.%d.%Y|%A %B %d %Y)","03.24.2004 (%m.%d.%Y|%A %B %d %Y)" }, | ||
27 | { "2004-03-24 (%Y-%m-%d|%A %Y %B %d)","2004-03-24 (%Y-%m-%d|%A %Y %B %d)" }, | ||
28 | { "User defined","Benutzerdefiniert" }, | ||
29 | { "User long date:","Format langes Datum:" }, | ||
30 | { "User short date:","Format kurzes Datum:" }, | ||
31 | { "Monday 19 April 2004: %A %d %B %Y","Montag 19 April 2004: %A %d %B %Y" }, | ||
32 | { "Mon 19.04.04: %a %d.%m.%y","Mon 19.04.04: %a %d.%m.%y" }, | ||
33 | { "Mon, 19.Apr.04: %a, %d.%b.%y","Mon, 19.Apr.04: %a, %d.%b.%y" }, | ||
34 | { "Date Format","Datums Format" }, | ||
35 | { "Timezone:","Zeitzone:" }, | ||
36 | { "Add 30 min (+00:30) to selected Timezone","Addiere 30 min zur selektierten Zeitzone" }, | ||
37 | { "Timezone has daylight saving","Zeitzone hat Sommerzeit" }, | ||
38 | { "Actual start and end is the\nsunday before this date.","Tatsächlicher Beginn/Ende ist der Sonntag\nvor diesem Datum!" }, | ||
39 | { "The year in the date is ignored.","Das Jahr vom Datum wird ignoriert." }, | ||
40 | { "Daylight start:","Sommerzeit Beginn:" }, | ||
41 | { "Mon","Mo" }, | ||
42 | { "Tue","Di" }, | ||
43 | { "Wed","Mi" }, | ||
44 | { "Thu","Do" }, | ||
45 | { "Fri","Fr" }, | ||
46 | { "Sat","Sa" }, | ||
47 | { "Sun","So" }, | ||
48 | { "January","Januar" }, | ||
49 | { "February","Februar" }, | ||
50 | { "March","März" }, | ||
51 | { "April","April" }, | ||
52 | { "May","Mai" }, | ||
53 | { "June","Juni" }, | ||
54 | { "July","Juli" }, | ||
55 | { "August","August" }, | ||
56 | { "September","September" }, | ||
57 | { "October","Oktober" }, | ||
58 | { "November","November" }, | ||
59 | { "December","Dezember" }, | ||
60 | { "tomorrow","morgen" }, | ||
61 | { "today","heute" }, | ||
62 | { "yesterday","gestern" }, | ||
63 | { "Monday","Montag" }, | ||
64 | { "Tuesday","Dienstag" }, | ||
65 | { "Wednesday","Mittwoch" }, | ||
66 | { "Thursday","Donnerstag" }, | ||
67 | { "Friday","Freitag" }, | ||
68 | { "Saturday","Samstag" }, | ||
69 | { "Sunday","Sonntag" }, | ||
70 | { "Daylight end:","Sommerzeit Ende:" }, | ||
71 | { "Time Zone","Zeitzone" }, | ||
72 | { "Used Mail Client","Benutzter Mail Client" }, | ||
73 | { "Channel:","Channel:" }, | ||
74 | { "Message:","Message:" }, | ||
75 | { "Parameters:","Parameter:" }, | ||
76 | { "HINT: Delimiter=; Name=%1,Email=%2","Hinweis: Begrenzer=; Name=%1,Email=%2" }, | ||
77 | { "extra Message:","extra Message:" }, | ||
78 | { "extra Parameters:","extra Parameter:" }, | ||
79 | { "HINT: Emails=%1,Attachments=%2","Hinweis: Emails=%1,Attachments=%2" }, | ||
80 | { "External Apps.","Externe Appl." }, | ||
81 | { "General","Allgemein" }, | ||
82 | { "Full &name:","Vor- und &Nachname:" }, | ||
83 | { "E&mail address:","E&mail Adresse:" }, | ||
84 | { "Fonts","Schriftart" }, | ||
85 | { "Choose...","Wähle..." }, | ||
86 | { "Used %1 Client","Benutzter %1 Client" }, | ||
87 | { "No email client installed","Kein Email Klient installiert" }, | ||
88 | { "Userdefined email client","Benutzerdef. Email Klient" }, | ||
89 | { "OM/Pi email client","OM/Pi Email Klient" }, | ||
90 | { "Delete","Löschen" }, | ||
91 | { "New","Neu" }, | ||
92 | { "Edit","Bearbeite" }, | ||
93 | { "Close","Schließen" }, | ||
94 | { "Size","Größe" }, | ||
95 | { "Date","Datum" }, | ||
96 | { "Please set at","Bitte einstellen in" }, | ||
97 | { "Settings@General TAB","Einstellungen@Allgemein TAB" }, | ||
98 | { "KOpieMail/Pi","KOpieMail/Pi" }, | ||
99 | { "Mail","Mail" }, | ||
100 | { "Settings","Einstellungen" }, | ||
101 | { "Get all new mails","Hole alle neuen Mails" }, | ||
102 | { "Get new messages","Hole neue mails" }, | ||
103 | { "Compose new mail","Schreibe neue Mail" }, | ||
104 | { "Send queued mails","Sende gespeicherte Mails" }, | ||
105 | { "Show/Hide folders","Zeige Verzeichnisse" }, | ||
106 | { "Delete Mail","Lösche Mail" }, | ||
107 | { "Edit settings","Ändere Einstellungen" }, | ||
108 | { "Configure accounts","Konfiguriere Zugänge" }, | ||
109 | { "Mailbox","Mailbox" }, | ||
110 | { "Subject","Betreff" }, | ||
111 | { "Sender","Sender" }, | ||
112 | { "Size","Größe" }, | ||
113 | { "Date","Datum" }, | ||
114 | { "Close","Schliessen" }, | ||
115 | { "Help","Hilfe" }, | ||
116 | { "About","Über" }, | ||
117 | { "Licence","Lizenz" }, | ||
118 | { "LibEtPan Licence","LibEtPan Lizenz" }, | ||
119 | { "Settings - some need a restart (nr)","Einstellungen - manche benötigen einen Neustart (nr)" }, | ||
120 | { "HINT: Separate multiple\neMail addresses by ";"","Hinweis: Trenne mehrere Addressen mit einem ";"" }, | ||
121 | { "Ignore above settings and\nuse KA/Pi "Who am I" instead!","Ignoriere obige Einstellungen und\nbenutze KA/Pi "Wer bin ich" stattdessen!" }, | ||
122 | { "View mail as html","Zeige Mails als html" }, | ||
123 | { "Send mails later","Sende Mails später" }, | ||
124 | { "Application(nr)","Applikation(nr)" }, | ||
125 | { "OK","OK" }, | ||
126 | { "Compose mail:","Verfasse Mail:" }, | ||
127 | { "Dear Mr.","Hallo Herr" }, | ||
128 | { "Read mail:","Lese Mail:" }, | ||
129 | { "Hello","Hallo" }, | ||
130 | { "Configure Accounts","Konfigure Zugänge" }, | ||
131 | { "Name of the Account","Name des Zugangs" }, | ||
132 | { "News","News" }, | ||
133 | { "Account","Zugang" }, | ||
134 | { "Type","Typ" }, | ||
135 | { "<p>Please select an account.</p>","<p>Bitte wähle einen Zugang.</p>" }, | ||
136 | { "Error","Fehler" }, | ||
137 | { "Configure NNTP","Konfiguriere News" }, | ||
138 | { "Port","Port" }, | ||
139 | { "Server","Server" }, | ||
140 | { "Use SSL","Benutze SSL" }, | ||
141 | { "User","Benutzer" }, | ||
142 | { "Password","Passwort" }, | ||
143 | { "Use Login","Benutze Login" }, | ||
144 | { "Newsgroup","Newsgroup" }, | ||
145 | { "Get newsgroup list from server","Hole Newsgroup Liste vom Server" }, | ||
146 | { "Filter:","Filter:" }, | ||
147 | { "Show subscribed","Zeige abbonnierte" }, | ||
148 | { "Groups","NewsGroups" }, | ||
149 | { "Configure IMAP","Konfiguriere IMAP" }, | ||
150 | { "Use secure sockets:","Benutze sichere Verbindung:" }, | ||
151 | { "ssh $SERVER exec","ssh $SERVER exec" }, | ||
152 | { "Prefix","Prefix" }, | ||
153 | { "Local storage folder:","Lokales Verzeichnis:" }, | ||
154 | { "Get only messages smaller","Hole nur Nachrichten kleiner" }, | ||
155 | { "kB","kB" }, | ||
156 | { "Leave Messages on Server","Belasse Nachrichten auf dem Server" }, | ||
157 | { "Configure POP3","Konfiguriere POP3" }, | ||
158 | { "ssh $SERVER exec imapd","ssh $SERVER exec imapd" }, | ||
159 | { "Configure SMTP","Konfiguriere SMTP" }, | ||
160 | { "Name of the SMTP Server","Name des SMTP Servers" }, | ||
161 | { "Port of the SMTP Server","Port des SMTP Servers" }, | ||
162 | { "Fetching folder list","Hole Verzeichnis Liste" }, | ||
163 | { "Fetch ","Hole " }, | ||
164 | { "Fetching header list","Hole Titel Liste" }, | ||
165 | { "Mailbox has %1 mails","Mailbox hat %1 Mails" }, | ||
166 | { "Read this mail","Lies diese Mail" }, | ||
167 | { "Move/Copy this mail","Verschiebe/kopiere diese Mail" }, | ||
168 | { "Delete this mail","Lösche diese Mail" }, | ||
169 | { "Move/Copy all selected mail","Verschiebe/kopiere selektierte Mails" }, | ||
170 | { "Delete all selected mails","Lösche alle selektierten Mails" }, | ||
171 | { "Clear selection","Selektion aufheben" }, | ||
172 | { "Reply","Antworten" }, | ||
173 | { "Forward","Weiterleiten" }, | ||
174 | { "Attachments","Anhang" }, | ||
175 | { "Show Html","Zeige in html" }, | ||
176 | { "Description","Beschreibung" }, | ||
177 | { "Filename","Dateiname" }, | ||
178 | { "E-Mail by %1","E-Mail von %1" }, | ||
179 | { "Cc","Kopie" }, | ||
180 | { "To","An" }, | ||
181 | { "From","Von" }, | ||
182 | { "<p>Do you really want to delete this mail? <br><br>","<p>Wollen Sie diese Mail wirklich löschen? <br><br>" }, | ||
183 | { "Mailbox has %1 mail(s)","Mailbox hat %1 Mail(s)" }, | ||
184 | { "Move/Copie all mails","Verschiebe/kopiere alle Mails" }, | ||
185 | { "Delete all mails","Lösche alle Mails" }, | ||
186 | { "Create new subfolder","Neues Unterverzeichnis" }, | ||
187 | { "Delete folder","Lösche Verzeichnis" }, | ||
188 | { "Refresh folder list","Aktualisiere Verzeichnis Liste" }, | ||
189 | { "Create new folder","Neues Verzeichnis" }, | ||
190 | { "Disconnect","Disconnect" }, | ||
191 | { "Set offline","Gehe offline" }, | ||
192 | { "Select target box","Wähle Ziel Box" }, | ||
193 | { "<b>Store mail(s) to</b>","<b>Speichere Mail(s) nach</b>" }, | ||
194 | { "Folder:","Verzeichnis:" }, | ||
195 | { "Account:","Zugang:" }, | ||
196 | { "Prefix will prepend, no need to enter it!","Prefix wird vorangestellt, braucht nicht eingegeben zu werden!" }, | ||
197 | { "Move mail(s)","Verschiebe Mail(s)" }, | ||
198 | { "apply only to mails smaller","wende nur auf Mails an, kleiner als" }, | ||
199 | { " kB"," kB" }, | ||
200 | { " message %1 of %2"," Nachricht %1 von %2" }, | ||
201 | { "Copying...","Am Kopieren..." }, | ||
202 | { "Copy message %1 of %2","Kopiere Nachricht %1 von %2" }, | ||
203 | { "Do you really want to delete\nall selected mails?","Wollen Sie wirklich alle\nselektierten Mails Löschen?" }, | ||
204 | { "Delete All Mails","Lösche alle Mails" }, | ||
205 | { "Deleting ...","Am Löschen..." }, | ||
206 | { "Delete message %1 of %2","Lösche Nachricht %1 von %2" }, | ||
207 | { "Compose Message","Verfasse Nachricht" }, | ||
208 | { "Reply-To","Antwort-An" }, | ||
209 | { "BCC","BCC" }, | ||
210 | { "Signature","Signatur" }, | ||
211 | { "CC","Kopie" }, | ||
212 | { "Options","Optionen" }, | ||
213 | { "Delete File","Lösche Datei" }, | ||
214 | { "Add File","Füge Datei hinzu" }, | ||
215 | { "Attachment","Anhang" }, | ||
216 | { "send later","sende später" }, | ||
217 | { "use:","via:" }, | ||
218 | { "Save","Speichern" }, | ||
219 | { "Name","Name" }, | ||
220 | { "No Receiver spezified","Kein Empfänger angegeben" }, | ||
221 | { "Sending mail","Sende Mail" }, | ||
222 | { "No","Nein" }, | ||
223 | { "Yes","Ja" }, | ||
224 | { "Store message into drafts?\n","Speichere Nachricht in Entwürfe?\n" }, | ||
225 | { "Store message?","Nachricht speichern?" }, | ||
226 | { "Select Type","Selektiere Typ" }, | ||
227 | { "Select Account Type","Wähle Art des Zugangs" }, | ||
228 | { "IMAP","IMAP (online lesen)" }, | ||
229 | { "POP3","POP3 (holen)" }, | ||
230 | { "SMTP","SMTP (senden)" }, | ||
231 | { "<p>Do you really want to delete the selected Account?</p>","<p>Möchten Sie wirklich den ausgewählten Account löschen?</p>" }, | ||
232 | { "Question","Eine Frage..." }, | ||
233 | { "Send this message?","Nachricht wirklich senden?" }, | ||
234 | { "Stop editing message","Stop editing message" }, | ||
235 | { "Sending mail %1 of %2","Sende Mail %1 von %2" }, | ||
236 | { "%1 of %2 bytes send","%1 von %2 Bytes gesendet" }, | ||
237 | { "Refresh header list","Aktualisiere Titel Liste" }, | ||
238 | { "","" }, | ||
239 | { "","" }, | ||
240 | { "","" }, | ||
241 | { "","" }, | ||
242 | { "","" }, | ||
243 | { "","" }, | ||
diff --git a/kmicromail/libmailwrapper/mhwrapper.cpp b/kmicromail/libmailwrapper/mhwrapper.cpp index 641d4d9..f4133c0 100644 --- a/kmicromail/libmailwrapper/mhwrapper.cpp +++ b/kmicromail/libmailwrapper/mhwrapper.cpp | |||
@@ -1,446 +1,447 @@ | |||
1 | // CHANGED 2004-09-31 Lutz Rogowski | 1 | // CHANGED 2004-09-31 Lutz Rogowski |
2 | #include "mhwrapper.h" | 2 | #include "mhwrapper.h" |
3 | #include "mailtypes.h" | 3 | #include "mailtypes.h" |
4 | #include "mailwrapper.h" | 4 | #include "mailwrapper.h" |
5 | #include <libetpan/libetpan.h> | 5 | #include <libetpan/libetpan.h> |
6 | #include <qdir.h> | 6 | #include <qdir.h> |
7 | #include <qmessagebox.h> | 7 | #include <qmessagebox.h> |
8 | #include <stdlib.h> | 8 | #include <stdlib.h> |
9 | #include <qpe/global.h> | 9 | #include <qpe/global.h> |
10 | #include <oprocess.h> | 10 | #include <oprocess.h> |
11 | #include <klocale.h> | ||
11 | //#include <opie2/odebug.h> | 12 | //#include <opie2/odebug.h> |
12 | 13 | ||
13 | using namespace Opie::Core; | 14 | using namespace Opie::Core; |
14 | MHwrapper::MHwrapper(const QString & mbox_dir,const QString&mbox_name) | 15 | MHwrapper::MHwrapper(const QString & mbox_dir,const QString&mbox_name) |
15 | : Genericwrapper(),MHPath(mbox_dir),MHName(mbox_name) | 16 | : Genericwrapper(),MHPath(mbox_dir),MHName(mbox_name) |
16 | { | 17 | { |
17 | if (MHPath.length()>0) { | 18 | if (MHPath.length()>0) { |
18 | if (MHPath[MHPath.length()-1]=='/') { | 19 | if (MHPath[MHPath.length()-1]=='/') { |
19 | MHPath=MHPath.left(MHPath.length()-1); | 20 | MHPath=MHPath.left(MHPath.length()-1); |
20 | } | 21 | } |
21 | //odebug << MHPath << oendl; | 22 | //odebug << MHPath << oendl; |
22 | QDir dir(MHPath); | 23 | QDir dir(MHPath); |
23 | if (!dir.exists()) { | 24 | if (!dir.exists()) { |
24 | dir.mkdir(MHPath); | 25 | dir.mkdir(MHPath); |
25 | } | 26 | } |
26 | init_storage(); | 27 | init_storage(); |
27 | } | 28 | } |
28 | } | 29 | } |
29 | 30 | ||
30 | void MHwrapper::init_storage() | 31 | void MHwrapper::init_storage() |
31 | { | 32 | { |
32 | int r; | 33 | int r; |
33 | QString pre = MHPath; | 34 | QString pre = MHPath; |
34 | if (!m_storage) { | 35 | if (!m_storage) { |
35 | m_storage = mailstorage_new(NULL); | 36 | m_storage = mailstorage_new(NULL); |
36 | r = mh_mailstorage_init(m_storage,(char*)pre.latin1(),0,0,0); | 37 | r = mh_mailstorage_init(m_storage,(char*)pre.latin1(),0,0,0); |
37 | if (r != MAIL_NO_ERROR) { | 38 | if (r != MAIL_NO_ERROR) { |
38 | qDebug(" error init storage "); | 39 | qDebug(" error init storage "); |
39 | mailstorage_free(m_storage); | 40 | mailstorage_free(m_storage); |
40 | m_storage = 0; | 41 | m_storage = 0; |
41 | return; | 42 | return; |
42 | } | 43 | } |
43 | } | 44 | } |
44 | r = mailstorage_connect(m_storage); | 45 | r = mailstorage_connect(m_storage); |
45 | if (r!=MAIL_NO_ERROR) { | 46 | if (r!=MAIL_NO_ERROR) { |
46 | qDebug("error connecting storage "); | 47 | qDebug("error connecting storage "); |
47 | mailstorage_free(m_storage); | 48 | mailstorage_free(m_storage); |
48 | m_storage = 0; | 49 | m_storage = 0; |
49 | } | 50 | } |
50 | } | 51 | } |
51 | 52 | ||
52 | void MHwrapper::clean_storage() | 53 | void MHwrapper::clean_storage() |
53 | { | 54 | { |
54 | if (m_storage) { | 55 | if (m_storage) { |
55 | mailstorage_disconnect(m_storage); | 56 | mailstorage_disconnect(m_storage); |
56 | mailstorage_free(m_storage); | 57 | mailstorage_free(m_storage); |
57 | m_storage = 0; | 58 | m_storage = 0; |
58 | } | 59 | } |
59 | } | 60 | } |
60 | 61 | ||
61 | MHwrapper::~MHwrapper() | 62 | MHwrapper::~MHwrapper() |
62 | { | 63 | { |
63 | clean_storage(); | 64 | clean_storage(); |
64 | } | 65 | } |
65 | 66 | ||
66 | void MHwrapper::listMessages(const QString & mailbox, QValueList<Opie::Core::OSmartPointer<RecMail> > &target, int maxSizeInKb ) | 67 | void MHwrapper::listMessages(const QString & mailbox, QValueList<Opie::Core::OSmartPointer<RecMail> > &target, int maxSizeInKb ) |
67 | { | 68 | { |
68 | init_storage(); | 69 | init_storage(); |
69 | if (!m_storage) { | 70 | if (!m_storage) { |
70 | return; | 71 | return; |
71 | } | 72 | } |
72 | QString f = buildPath(mailbox); | 73 | QString f = buildPath(mailbox); |
73 | int r = mailsession_select_folder(m_storage->sto_session,(char*)f.latin1()); | 74 | int r = mailsession_select_folder(m_storage->sto_session,(char*)f.latin1()); |
74 | if (r!=MAIL_NO_ERROR) { | 75 | if (r!=MAIL_NO_ERROR) { |
75 | qDebug("listMessages: error selecting folder! "); | 76 | qDebug("listMessages: error selecting folder! "); |
76 | return; | 77 | return; |
77 | } | 78 | } |
78 | parseList(target,m_storage->sto_session,f, false, maxSizeInKb ); | 79 | parseList(target,m_storage->sto_session,f, false, maxSizeInKb ); |
79 | Global::statusMessage(tr("Mailbox has %1 mail(s)").arg(target.count())); | 80 | Global::statusMessage(i18n("Mailbox has %1 mail(s)").arg(target.count())); |
80 | } | 81 | } |
81 | 82 | ||
82 | QValueList<Opie::Core::OSmartPointer<Folder> >* MHwrapper::listFolders() | 83 | QValueList<Opie::Core::OSmartPointer<Folder> >* MHwrapper::listFolders() |
83 | { | 84 | { |
84 | QValueList<Opie::Core::OSmartPointer<Folder> >* folders = new QValueList<Opie::Core::OSmartPointer<Folder> >(); | 85 | QValueList<Opie::Core::OSmartPointer<Folder> >* folders = new QValueList<Opie::Core::OSmartPointer<Folder> >(); |
85 | /* this is needed! */ | 86 | /* this is needed! */ |
86 | if (m_storage) mailstorage_disconnect(m_storage); | 87 | if (m_storage) mailstorage_disconnect(m_storage); |
87 | init_storage(); | 88 | init_storage(); |
88 | if (!m_storage) { | 89 | if (!m_storage) { |
89 | return folders; | 90 | return folders; |
90 | } | 91 | } |
91 | mail_list*flist = 0; | 92 | mail_list*flist = 0; |
92 | clistcell*current=0; | 93 | clistcell*current=0; |
93 | int r = mailsession_list_folders(m_storage->sto_session,NULL,&flist); | 94 | int r = mailsession_list_folders(m_storage->sto_session,NULL,&flist); |
94 | if (r != MAIL_NO_ERROR || !flist) { | 95 | if (r != MAIL_NO_ERROR || !flist) { |
95 | qDebug("error getting folder list "); | 96 | qDebug("error getting folder list "); |
96 | return folders; | 97 | return folders; |
97 | } | 98 | } |
98 | for (current=clist_begin(flist->mb_list);current!=0;current=clist_next(current)) { | 99 | for (current=clist_begin(flist->mb_list);current!=0;current=clist_next(current)) { |
99 | QString t = (char*)current->data; | 100 | QString t = (char*)current->data; |
100 | t.replace(0,MHPath.length(),""); | 101 | t.replace(0,MHPath.length(),""); |
101 | folders->append(new MHFolder(t,MHPath)); | 102 | folders->append(new MHFolder(t,MHPath)); |
102 | } | 103 | } |
103 | mail_list_free(flist); | 104 | mail_list_free(flist); |
104 | return folders; | 105 | return folders; |
105 | } | 106 | } |
106 | 107 | ||
107 | void MHwrapper::deleteMail(const RecMailP&mail) | 108 | void MHwrapper::deleteMail(const RecMailP&mail) |
108 | { | 109 | { |
109 | init_storage(); | 110 | init_storage(); |
110 | if (!m_storage) { | 111 | if (!m_storage) { |
111 | return; | 112 | return; |
112 | } | 113 | } |
113 | int r = mailsession_select_folder(m_storage->sto_session,(char*)mail->getMbox().latin1()); | 114 | int r = mailsession_select_folder(m_storage->sto_session,(char*)mail->getMbox().latin1()); |
114 | if (r!=MAIL_NO_ERROR) { | 115 | if (r!=MAIL_NO_ERROR) { |
115 | qDebug("error selecting folder! "); | 116 | qDebug("error selecting folder! "); |
116 | return; | 117 | return; |
117 | } | 118 | } |
118 | r = mailsession_remove_message(m_storage->sto_session,mail->getNumber()); | 119 | r = mailsession_remove_message(m_storage->sto_session,mail->getNumber()); |
119 | if (r != MAIL_NO_ERROR) { | 120 | if (r != MAIL_NO_ERROR) { |
120 | qDebug("error deleting mail "); | 121 | qDebug("error deleting mail "); |
121 | } | 122 | } |
122 | } | 123 | } |
123 | 124 | ||
124 | void MHwrapper::answeredMail(const RecMailP&) | 125 | void MHwrapper::answeredMail(const RecMailP&) |
125 | { | 126 | { |
126 | } | 127 | } |
127 | 128 | ||
128 | RecBodyP MHwrapper::fetchBody( const RecMailP &mail ) | 129 | RecBodyP MHwrapper::fetchBody( const RecMailP &mail ) |
129 | { | 130 | { |
130 | RecBodyP body = new RecBody(); | 131 | RecBodyP body = new RecBody(); |
131 | init_storage(); | 132 | init_storage(); |
132 | if (!m_storage) { | 133 | if (!m_storage) { |
133 | return body; | 134 | return body; |
134 | } | 135 | } |
135 | mailmessage * msg; | 136 | mailmessage * msg; |
136 | char*data=0; | 137 | char*data=0; |
137 | 138 | ||
138 | /* mail should hold the complete path! */ | 139 | /* mail should hold the complete path! */ |
139 | int r = mailsession_select_folder(m_storage->sto_session,(char*)mail->getMbox().latin1()); | 140 | int r = mailsession_select_folder(m_storage->sto_session,(char*)mail->getMbox().latin1()); |
140 | if (r != MAIL_NO_ERROR) { | 141 | if (r != MAIL_NO_ERROR) { |
141 | return body; | 142 | return body; |
142 | } | 143 | } |
143 | r = mailsession_get_message(m_storage->sto_session, mail->getNumber(), &msg); | 144 | r = mailsession_get_message(m_storage->sto_session, mail->getNumber(), &msg); |
144 | if (r != MAIL_NO_ERROR) { | 145 | if (r != MAIL_NO_ERROR) { |
145 | qDebug("Error fetching mail "); | 146 | qDebug("Error fetching mail "); |
146 | 147 | ||
147 | return body; | 148 | return body; |
148 | } | 149 | } |
149 | body = parseMail(msg); | 150 | body = parseMail(msg); |
150 | mailmessage_fetch_result_free(msg,data); | 151 | mailmessage_fetch_result_free(msg,data); |
151 | return body; | 152 | return body; |
152 | } | 153 | } |
153 | 154 | ||
154 | void MHwrapper::mbox_progress( size_t current, size_t maximum ) | 155 | void MHwrapper::mbox_progress( size_t current, size_t maximum ) |
155 | { | 156 | { |
156 | qDebug("MBox Progress %d of %d",current,maximum ); | 157 | qDebug("MBox Progress %d of %d",current,maximum ); |
157 | //odebug << "MH " << current << " von " << maximum << "" << oendl; | 158 | //odebug << "MH " << current << " von " << maximum << "" << oendl; |
158 | } | 159 | } |
159 | 160 | ||
160 | QString MHwrapper::buildPath(const QString&p) | 161 | QString MHwrapper::buildPath(const QString&p) |
161 | { | 162 | { |
162 | QString f=""; | 163 | QString f=""; |
163 | if (p.length()==0||p=="/") | 164 | if (p.length()==0||p=="/") |
164 | return MHPath; | 165 | return MHPath; |
165 | if (!p.startsWith(MHPath)) { | 166 | if (!p.startsWith(MHPath)) { |
166 | f+=MHPath; | 167 | f+=MHPath; |
167 | } | 168 | } |
168 | if (!p.startsWith("/")) { | 169 | if (!p.startsWith("/")) { |
169 | f+="/"; | 170 | f+="/"; |
170 | } | 171 | } |
171 | f+=p; | 172 | f+=p; |
172 | return f; | 173 | return f; |
173 | } | 174 | } |
174 | 175 | ||
175 | int MHwrapper::createMbox(const QString&folder,const FolderP&pfolder,const QString&,bool ) | 176 | int MHwrapper::createMbox(const QString&folder,const FolderP&pfolder,const QString&,bool ) |
176 | { | 177 | { |
177 | init_storage(); | 178 | init_storage(); |
178 | if (!m_storage) { | 179 | if (!m_storage) { |
179 | return 0; | 180 | return 0; |
180 | } | 181 | } |
181 | QString f; | 182 | QString f; |
182 | if (!pfolder) { | 183 | if (!pfolder) { |
183 | // toplevel folder | 184 | // toplevel folder |
184 | f = buildPath(folder); | 185 | f = buildPath(folder); |
185 | } else { | 186 | } else { |
186 | f = pfolder->getName(); | 187 | f = pfolder->getName(); |
187 | f+="/"; | 188 | f+="/"; |
188 | f+=folder; | 189 | f+=folder; |
189 | } | 190 | } |
190 | 191 | ||
191 | int r = mailsession_create_folder(m_storage->sto_session,(char*)f.latin1()); | 192 | int r = mailsession_create_folder(m_storage->sto_session,(char*)f.latin1()); |
192 | if (r != MAIL_NO_ERROR) { | 193 | if (r != MAIL_NO_ERROR) { |
193 | qDebug("error creating folder "); | 194 | qDebug("error creating folder "); |
194 | return 0; | 195 | return 0; |
195 | } | 196 | } |
196 | return 1; | 197 | return 1; |
197 | } | 198 | } |
198 | 199 | ||
199 | void MHwrapper::storeMessage(const char*msg,size_t length, const QString&Folder) | 200 | void MHwrapper::storeMessage(const char*msg,size_t length, const QString&Folder) |
200 | { | 201 | { |
201 | init_storage(); | 202 | init_storage(); |
202 | if (!m_storage) { | 203 | if (!m_storage) { |
203 | return; | 204 | return; |
204 | } | 205 | } |
205 | QString f = buildPath(Folder); | 206 | QString f = buildPath(Folder); |
206 | int r = mailsession_select_folder(m_storage->sto_session,(char*)f.latin1()); | 207 | int r = mailsession_select_folder(m_storage->sto_session,(char*)f.latin1()); |
207 | if (r!=MAIL_NO_ERROR) { | 208 | if (r!=MAIL_NO_ERROR) { |
208 | qDebug("error selecting folder! "); | 209 | qDebug("error selecting folder! "); |
209 | return; | 210 | return; |
210 | } | 211 | } |
211 | r = mailsession_append_message(m_storage->sto_session,(char*)msg,length); | 212 | r = mailsession_append_message(m_storage->sto_session,(char*)msg,length); |
212 | if (r!=MAIL_NO_ERROR) { | 213 | if (r!=MAIL_NO_ERROR) { |
213 | qDebug("error storing mail "); | 214 | qDebug("error storing mail "); |
214 | } | 215 | } |
215 | return; | 216 | return; |
216 | } | 217 | } |
217 | 218 | ||
218 | encodedString* MHwrapper::fetchRawBody(const RecMailP&mail) | 219 | encodedString* MHwrapper::fetchRawBody(const RecMailP&mail) |
219 | { | 220 | { |
220 | encodedString*result = 0; | 221 | encodedString*result = 0; |
221 | init_storage(); | 222 | init_storage(); |
222 | if (!m_storage) { | 223 | if (!m_storage) { |
223 | return result; | 224 | return result; |
224 | } | 225 | } |
225 | mailmessage * msg = 0; | 226 | mailmessage * msg = 0; |
226 | char*data=0; | 227 | char*data=0; |
227 | size_t size; | 228 | size_t size; |
228 | int r = mailsession_select_folder(m_storage->sto_session,(char*)mail->getMbox().latin1()); | 229 | int r = mailsession_select_folder(m_storage->sto_session,(char*)mail->getMbox().latin1()); |
229 | if (r!=MAIL_NO_ERROR) { | 230 | if (r!=MAIL_NO_ERROR) { |
230 | qDebug("error selecting folder! "); | 231 | qDebug("error selecting folder! "); |
231 | return result; | 232 | return result; |
232 | } | 233 | } |
233 | r = mailsession_get_message(m_storage->sto_session, mail->getNumber(), &msg); | 234 | r = mailsession_get_message(m_storage->sto_session, mail->getNumber(), &msg); |
234 | if (r != MAIL_NO_ERROR) { | 235 | if (r != MAIL_NO_ERROR) { |
235 | Global::statusMessage(tr("Error fetching mail %i").arg(mail->getNumber())); | 236 | Global::statusMessage(i18n("Error fetching mail %i").arg(mail->getNumber())); |
236 | return 0; | 237 | return 0; |
237 | } | 238 | } |
238 | r = mailmessage_fetch(msg,&data,&size); | 239 | r = mailmessage_fetch(msg,&data,&size); |
239 | if (r != MAIL_NO_ERROR) { | 240 | if (r != MAIL_NO_ERROR) { |
240 | Global::statusMessage(tr("Error fetching mail %i").arg(mail->getNumber())); | 241 | Global::statusMessage(i18n("Error fetching mail %i").arg(mail->getNumber())); |
241 | if (msg) mailmessage_free(msg); | 242 | if (msg) mailmessage_free(msg); |
242 | return 0; | 243 | return 0; |
243 | } | 244 | } |
244 | result = new encodedString(data,size); | 245 | result = new encodedString(data,size); |
245 | if (msg) mailmessage_free(msg); | 246 | if (msg) mailmessage_free(msg); |
246 | return result; | 247 | return result; |
247 | } | 248 | } |
248 | 249 | ||
249 | void MHwrapper::deleteMails(const QString & mailbox,const QValueList<RecMailP> &target) | 250 | void MHwrapper::deleteMails(const QString & mailbox,const QValueList<RecMailP> &target) |
250 | { | 251 | { |
251 | QString f = buildPath(mailbox); | 252 | QString f = buildPath(mailbox); |
252 | int r = mailsession_select_folder(m_storage->sto_session,(char*)f.latin1()); | 253 | int r = mailsession_select_folder(m_storage->sto_session,(char*)f.latin1()); |
253 | if (r!=MAIL_NO_ERROR) { | 254 | if (r!=MAIL_NO_ERROR) { |
254 | qDebug("deleteMails: error selecting folder! "); | 255 | qDebug("deleteMails: error selecting folder! "); |
255 | return; | 256 | return; |
256 | } | 257 | } |
257 | QValueList<RecMailP>::ConstIterator it; | 258 | QValueList<RecMailP>::ConstIterator it; |
258 | for (it=target.begin(); it!=target.end();++it) { | 259 | for (it=target.begin(); it!=target.end();++it) { |
259 | r = mailsession_remove_message(m_storage->sto_session,(*it)->getNumber()); | 260 | r = mailsession_remove_message(m_storage->sto_session,(*it)->getNumber()); |
260 | if (r != MAIL_NO_ERROR) { | 261 | if (r != MAIL_NO_ERROR) { |
261 | qDebug("error deleting mail "); | 262 | qDebug("error deleting mail "); |
262 | break; | 263 | break; |
263 | } | 264 | } |
264 | } | 265 | } |
265 | } | 266 | } |
266 | 267 | ||
267 | int MHwrapper::deleteAllMail(const FolderP&tfolder) | 268 | int MHwrapper::deleteAllMail(const FolderP&tfolder) |
268 | { | 269 | { |
269 | init_storage(); | 270 | init_storage(); |
270 | if (!m_storage) { | 271 | if (!m_storage) { |
271 | return 0; | 272 | return 0; |
272 | } | 273 | } |
273 | int res = 1; | 274 | int res = 1; |
274 | if (!tfolder) return 0; | 275 | if (!tfolder) return 0; |
275 | int r = mailsession_select_folder(m_storage->sto_session,(char*)tfolder->getName().latin1()); | 276 | int r = mailsession_select_folder(m_storage->sto_session,(char*)tfolder->getName().latin1()); |
276 | if (r!=MAIL_NO_ERROR) { | 277 | if (r!=MAIL_NO_ERROR) { |
277 | qDebug("error selecting folder! "); | 278 | qDebug("error selecting folder! "); |
278 | return 0; | 279 | return 0; |
279 | } | 280 | } |
280 | mailmessage_list*l=0; | 281 | mailmessage_list*l=0; |
281 | r = mailsession_get_messages_list(m_storage->sto_session,&l); | 282 | r = mailsession_get_messages_list(m_storage->sto_session,&l); |
282 | if (r != MAIL_NO_ERROR) { | 283 | if (r != MAIL_NO_ERROR) { |
283 | qDebug("Error message list "); | 284 | qDebug("Error message list "); |
284 | res = 0; | 285 | res = 0; |
285 | } | 286 | } |
286 | unsigned j = 0; | 287 | unsigned j = 0; |
287 | for(unsigned int i = 0 ; l!= 0 && res==1 && i < carray_count(l->msg_tab) ; ++i) { | 288 | for(unsigned int i = 0 ; l!= 0 && res==1 && i < carray_count(l->msg_tab) ; ++i) { |
288 | mailmessage * msg; | 289 | mailmessage * msg; |
289 | msg = (mailmessage*)carray_get(l->msg_tab, i); | 290 | msg = (mailmessage*)carray_get(l->msg_tab, i); |
290 | j = msg->msg_index; | 291 | j = msg->msg_index; |
291 | r = mailsession_remove_message(m_storage->sto_session,j); | 292 | r = mailsession_remove_message(m_storage->sto_session,j); |
292 | if (r != MAIL_NO_ERROR) { | 293 | if (r != MAIL_NO_ERROR) { |
293 | Global::statusMessage(tr("Error deleting mail %1").arg(i+1)); | 294 | Global::statusMessage(i18n("Error deleting mail %1").arg(i+1)); |
294 | res = 0; | 295 | res = 0; |
295 | break; | 296 | break; |
296 | } | 297 | } |
297 | } | 298 | } |
298 | if (l) mailmessage_list_free(l); | 299 | if (l) mailmessage_list_free(l); |
299 | return res; | 300 | return res; |
300 | } | 301 | } |
301 | 302 | ||
302 | int MHwrapper::deleteMbox(const FolderP&tfolder) | 303 | int MHwrapper::deleteMbox(const FolderP&tfolder) |
303 | { | 304 | { |
304 | init_storage(); | 305 | init_storage(); |
305 | if (!m_storage) { | 306 | if (!m_storage) { |
306 | return 0; | 307 | return 0; |
307 | } | 308 | } |
308 | if (!tfolder) return 0; | 309 | if (!tfolder) return 0; |
309 | if (tfolder->getName()=="/" || tfolder->getName().isEmpty()) return 0; | 310 | if (tfolder->getName()=="/" || tfolder->getName().isEmpty()) return 0; |
310 | 311 | ||
311 | int r = mailsession_delete_folder(m_storage->sto_session,(char*)tfolder->getName().latin1()); | 312 | int r = mailsession_delete_folder(m_storage->sto_session,(char*)tfolder->getName().latin1()); |
312 | 313 | ||
313 | if (r != MAIL_NO_ERROR) { | 314 | if (r != MAIL_NO_ERROR) { |
314 | qDebug("error deleting mail box "); | 315 | qDebug("error deleting mail box "); |
315 | return 0; | 316 | return 0; |
316 | } | 317 | } |
317 | QString cmd = "rm -rf "+tfolder->getName(); | 318 | QString cmd = "rm -rf "+tfolder->getName(); |
318 | QStringList command; | 319 | QStringList command; |
319 | command << "/bin/sh"; | 320 | command << "/bin/sh"; |
320 | command << "-c"; | 321 | command << "-c"; |
321 | command << cmd.latin1(); | 322 | command << cmd.latin1(); |
322 | OProcess *process = new OProcess(); | 323 | OProcess *process = new OProcess(); |
323 | 324 | ||
324 | connect(process, SIGNAL(processExited(Opie::Core::OProcess*)), | 325 | connect(process, SIGNAL(processExited(Opie::Core::OProcess*)), |
325 | this, SLOT( processEnded(Opie::Core::OProcess*))); | 326 | this, SLOT( processEnded(Opie::Core::OProcess*))); |
326 | connect(process, SIGNAL( receivedStderr(Opie::Core::OProcess*,char*,int)), | 327 | connect(process, SIGNAL( receivedStderr(Opie::Core::OProcess*,char*,int)), |
327 | this, SLOT( oprocessStderr(Opie::Core::OProcess*,char*,int))); | 328 | this, SLOT( oprocessStderr(Opie::Core::OProcess*,char*,int))); |
328 | 329 | ||
329 | *process << command; | 330 | *process << command; |
330 | removeMboxfailed = false; | 331 | removeMboxfailed = false; |
331 | if(!process->start(OProcess::Block, OProcess::All) ) { | 332 | if(!process->start(OProcess::Block, OProcess::All) ) { |
332 | qDebug("could not start process "); | 333 | qDebug("could not start process "); |
333 | return 0; | 334 | return 0; |
334 | } | 335 | } |
335 | qDebug("mail box deleted "); | 336 | qDebug("mail box deleted "); |
336 | return 1; | 337 | return 1; |
337 | } | 338 | } |
338 | 339 | ||
339 | void MHwrapper::processEnded(OProcess *p) | 340 | void MHwrapper::processEnded(OProcess *p) |
340 | { | 341 | { |
341 | if (p) delete p; | 342 | if (p) delete p; |
342 | } | 343 | } |
343 | 344 | ||
344 | void MHwrapper::oprocessStderr(OProcess*, char *buffer, int ) | 345 | void MHwrapper::oprocessStderr(OProcess*, char *buffer, int ) |
345 | { | 346 | { |
346 | QString lineStr = buffer; | 347 | QString lineStr = buffer; |
347 | QMessageBox::warning( 0, tr("Error"), lineStr ,tr("Ok") ); | 348 | QMessageBox::warning( 0, i18n("Error"), lineStr ,i18n("Ok") ); |
348 | removeMboxfailed = true; | 349 | removeMboxfailed = true; |
349 | } | 350 | } |
350 | 351 | ||
351 | void MHwrapper::statusFolder(folderStat&target_stat,const QString & mailbox) | 352 | void MHwrapper::statusFolder(folderStat&target_stat,const QString & mailbox) |
352 | { | 353 | { |
353 | init_storage(); | 354 | init_storage(); |
354 | if (!m_storage) { | 355 | if (!m_storage) { |
355 | return; | 356 | return; |
356 | } | 357 | } |
357 | target_stat.message_count = 0; | 358 | target_stat.message_count = 0; |
358 | target_stat.message_unseen = 0; | 359 | target_stat.message_unseen = 0; |
359 | target_stat.message_recent = 0; | 360 | target_stat.message_recent = 0; |
360 | QString f = buildPath(mailbox); | 361 | QString f = buildPath(mailbox); |
361 | int r = mailsession_status_folder(m_storage->sto_session,(char*)f.latin1(),&target_stat.message_count, | 362 | int r = mailsession_status_folder(m_storage->sto_session,(char*)f.latin1(),&target_stat.message_count, |
362 | &target_stat.message_recent,&target_stat.message_unseen); | 363 | &target_stat.message_recent,&target_stat.message_unseen); |
363 | if (r != MAIL_NO_ERROR) { | 364 | if (r != MAIL_NO_ERROR) { |
364 | Global::statusMessage(tr("Error retrieving status")); | 365 | Global::statusMessage(i18n("Error retrieving status")); |
365 | } | 366 | } |
366 | } | 367 | } |
367 | 368 | ||
368 | MAILLIB::ATYPE MHwrapper::getType()const | 369 | MAILLIB::ATYPE MHwrapper::getType()const |
369 | { | 370 | { |
370 | return MAILLIB::A_MH; | 371 | return MAILLIB::A_MH; |
371 | } | 372 | } |
372 | 373 | ||
373 | const QString&MHwrapper::getName()const | 374 | const QString&MHwrapper::getName()const |
374 | { | 375 | { |
375 | return MHName; | 376 | return MHName; |
376 | } | 377 | } |
377 | void MHwrapper::mvcpMail(const RecMailP&mail,const QString&targetFolder,AbstractMail*targetWrapper,bool moveit) | 378 | void MHwrapper::mvcpMail(const RecMailP&mail,const QString&targetFolder,AbstractMail*targetWrapper,bool moveit) |
378 | { | 379 | { |
379 | init_storage(); | 380 | init_storage(); |
380 | if (!m_storage) { | 381 | if (!m_storage) { |
381 | return; | 382 | return; |
382 | } | 383 | } |
383 | if (targetWrapper != this) { | 384 | if (targetWrapper != this) { |
384 | qDebug("Using generic "); | 385 | qDebug("Using generic "); |
385 | Genericwrapper::mvcpMail(mail,targetFolder,targetWrapper,moveit); | 386 | Genericwrapper::mvcpMail(mail,targetFolder,targetWrapper,moveit); |
386 | return; | 387 | return; |
387 | } | 388 | } |
388 | qDebug("Using internal routines for move/copy "); | 389 | qDebug("Using internal routines for move/copy "); |
389 | QString tf = buildPath(targetFolder); | 390 | QString tf = buildPath(targetFolder); |
390 | int r = mailsession_select_folder(m_storage->sto_session,(char*)mail->getMbox().latin1()); | 391 | int r = mailsession_select_folder(m_storage->sto_session,(char*)mail->getMbox().latin1()); |
391 | if (r != MAIL_NO_ERROR) { | 392 | if (r != MAIL_NO_ERROR) { |
392 | qDebug("Error selecting source mailbox "); | 393 | qDebug("Error selecting source mailbox "); |
393 | return; | 394 | return; |
394 | } | 395 | } |
395 | if (moveit) { | 396 | if (moveit) { |
396 | r = mailsession_move_message(m_storage->sto_session,mail->getNumber(),(char*)tf.latin1()); | 397 | r = mailsession_move_message(m_storage->sto_session,mail->getNumber(),(char*)tf.latin1()); |
397 | } else { | 398 | } else { |
398 | r = mailsession_copy_message(m_storage->sto_session,mail->getNumber(),(char*)tf.latin1()); | 399 | r = mailsession_copy_message(m_storage->sto_session,mail->getNumber(),(char*)tf.latin1()); |
399 | } | 400 | } |
400 | if (r != MAIL_NO_ERROR) { | 401 | if (r != MAIL_NO_ERROR) { |
401 | qDebug("Error copy/moving mail internal "); | 402 | qDebug("Error copy/moving mail internal "); |
402 | } | 403 | } |
403 | } | 404 | } |
404 | 405 | ||
405 | void MHwrapper::mvcpAllMails(const FolderP&fromFolder, | 406 | void MHwrapper::mvcpAllMails(const FolderP&fromFolder, |
406 | const QString&targetFolder,AbstractMail*targetWrapper,bool moveit) | 407 | const QString&targetFolder,AbstractMail*targetWrapper,bool moveit) |
407 | { | 408 | { |
408 | init_storage(); | 409 | init_storage(); |
409 | if (!m_storage) { | 410 | if (!m_storage) { |
410 | return; | 411 | return; |
411 | } | 412 | } |
412 | if (targetWrapper != this) { | 413 | if (targetWrapper != this) { |
413 | qDebug("Using generic "); | 414 | qDebug("Using generic "); |
414 | Genericwrapper::mvcpAllMails(fromFolder,targetFolder,targetWrapper,moveit); | 415 | Genericwrapper::mvcpAllMails(fromFolder,targetFolder,targetWrapper,moveit); |
415 | return; | 416 | return; |
416 | } | 417 | } |
417 | if (!fromFolder) return; | 418 | if (!fromFolder) return; |
418 | int r = mailsession_select_folder(m_storage->sto_session,(char*)fromFolder->getName().latin1()); | 419 | int r = mailsession_select_folder(m_storage->sto_session,(char*)fromFolder->getName().latin1()); |
419 | if (r!=MAIL_NO_ERROR) { | 420 | if (r!=MAIL_NO_ERROR) { |
420 | qDebug("error selecting source folder! "); | 421 | qDebug("error selecting source folder! "); |
421 | return; | 422 | return; |
422 | } | 423 | } |
423 | QString tf = buildPath(targetFolder); | 424 | QString tf = buildPath(targetFolder); |
424 | mailmessage_list*l=0; | 425 | mailmessage_list*l=0; |
425 | r = mailsession_get_messages_list(m_storage->sto_session,&l); | 426 | r = mailsession_get_messages_list(m_storage->sto_session,&l); |
426 | if (r != MAIL_NO_ERROR) { | 427 | if (r != MAIL_NO_ERROR) { |
427 | qDebug("Error message list "); | 428 | qDebug("Error message list "); |
428 | } | 429 | } |
429 | unsigned j = 0; | 430 | unsigned j = 0; |
430 | for(unsigned int i = 0 ; l!= 0 && i < carray_count(l->msg_tab) ; ++i) { | 431 | for(unsigned int i = 0 ; l!= 0 && i < carray_count(l->msg_tab) ; ++i) { |
431 | mailmessage * msg; | 432 | mailmessage * msg; |
432 | msg = (mailmessage*)carray_get(l->msg_tab, i); | 433 | msg = (mailmessage*)carray_get(l->msg_tab, i); |
433 | j = msg->msg_index; | 434 | j = msg->msg_index; |
434 | if (moveit) { | 435 | if (moveit) { |
435 | r = mailsession_move_message(m_storage->sto_session,j,(char*)tf.latin1()); | 436 | r = mailsession_move_message(m_storage->sto_session,j,(char*)tf.latin1()); |
436 | } else { | 437 | } else { |
437 | r = mailsession_copy_message(m_storage->sto_session,j,(char*)tf.latin1()); | 438 | r = mailsession_copy_message(m_storage->sto_session,j,(char*)tf.latin1()); |
438 | } | 439 | } |
439 | if (r != MAIL_NO_ERROR) { | 440 | if (r != MAIL_NO_ERROR) { |
440 | qDebug("Error copy/moving mail interna "); | 441 | qDebug("Error copy/moving mail interna "); |
441 | 442 | ||
442 | break; | 443 | break; |
443 | } | 444 | } |
444 | } | 445 | } |
445 | if (l) mailmessage_list_free(l); | 446 | if (l) mailmessage_list_free(l); |
446 | } | 447 | } |
diff --git a/kmicromail/libmailwrapper/sendmailprogress.cpp b/kmicromail/libmailwrapper/sendmailprogress.cpp index dc0c75a..20dfe9b 100644 --- a/kmicromail/libmailwrapper/sendmailprogress.cpp +++ b/kmicromail/libmailwrapper/sendmailprogress.cpp | |||
@@ -1,47 +1,48 @@ | |||
1 | #include "sendmailprogress.h" | 1 | #include "sendmailprogress.h" |
2 | #include <qprogressbar.h> | 2 | #include <qprogressbar.h> |
3 | #include <qlabel.h> | 3 | #include <qlabel.h> |
4 | #include <klocale.h> | ||
4 | 5 | ||
5 | progressMailSend::progressMailSend(QWidget*parent, const char * name) | 6 | progressMailSend::progressMailSend(QWidget*parent, const char * name) |
6 | :progressMailSendUI(parent,name,true),m_current_mail(0),m_current_single(0),m_max_mail(0),m_max_single(0) | 7 | :progressMailSendUI(parent,name,true),m_current_mail(0),m_current_single(0),m_max_mail(0),m_max_single(0) |
7 | { | 8 | { |
8 | } | 9 | } |
9 | 10 | ||
10 | progressMailSend::~progressMailSend() | 11 | progressMailSend::~progressMailSend() |
11 | { | 12 | { |
12 | } | 13 | } |
13 | 14 | ||
14 | void progressMailSend::setMaxMails(unsigned int aMaxMails) | 15 | void progressMailSend::setMaxMails(unsigned int aMaxMails) |
15 | { | 16 | { |
16 | m_max_mail = aMaxMails; | 17 | m_max_mail = aMaxMails; |
17 | allMailProgressBar->setTotalSteps(aMaxMails); | 18 | allMailProgressBar->setTotalSteps(aMaxMails); |
18 | setMails(); | 19 | setMails(); |
19 | } | 20 | } |
20 | 21 | ||
21 | void progressMailSend::setCurrentMails(unsigned int aCurrent) | 22 | void progressMailSend::setCurrentMails(unsigned int aCurrent) |
22 | { | 23 | { |
23 | m_current_mail = aCurrent; | 24 | m_current_mail = aCurrent; |
24 | allMailProgressBar->setProgress(aCurrent); | 25 | allMailProgressBar->setProgress(aCurrent); |
25 | setMails(); | 26 | setMails(); |
26 | } | 27 | } |
27 | 28 | ||
28 | void progressMailSend::setSingleMail(unsigned int aCurrent,unsigned int aMax) | 29 | void progressMailSend::setSingleMail(unsigned int aCurrent,unsigned int aMax) |
29 | { | 30 | { |
30 | m_current_single = aCurrent; | 31 | m_current_single = aCurrent; |
31 | m_max_single = aMax; | 32 | m_max_single = aMax; |
32 | setSingle(); | 33 | setSingle(); |
33 | } | 34 | } |
34 | 35 | ||
35 | void progressMailSend::setSingle() | 36 | void progressMailSend::setSingle() |
36 | { | 37 | { |
37 | QString text = QString(tr("%1 of %2 bytes send")).arg(m_current_single).arg(m_max_single); | 38 | QString text = QString(i18n("%1 of %2 bytes send")).arg(m_current_single).arg(m_max_single); |
38 | singleMailLabel->setText(text); | 39 | singleMailLabel->setText(text); |
39 | singleMailProgressBar->setTotalSteps(m_max_single); | 40 | singleMailProgressBar->setTotalSteps(m_max_single); |
40 | singleMailProgressBar->setProgress(m_current_single); | 41 | singleMailProgressBar->setProgress(m_current_single); |
41 | } | 42 | } |
42 | 43 | ||
43 | void progressMailSend::setMails() | 44 | void progressMailSend::setMails() |
44 | { | 45 | { |
45 | QString text = QString(tr("Sending mail %1 of %2")).arg(m_current_mail+1).arg(m_max_mail); | 46 | QString text = QString(i18n("Sending mail %1 of %2")).arg(m_current_mail+1).arg(m_max_mail); |
46 | allMailLabel->setText(text); | 47 | allMailLabel->setText(text); |
47 | } | 48 | } |
diff --git a/kmicromail/main.cpp b/kmicromail/main.cpp index 8341c5a..006390c 100644 --- a/kmicromail/main.cpp +++ b/kmicromail/main.cpp | |||
@@ -1,66 +1,67 @@ | |||
1 | // CHANGED 2004-08-06 Lutz Rogowski | 1 | // CHANGED 2004-08-06 Lutz Rogowski |
2 | 2 | ||
3 | 3 | ||
4 | #ifndef DESKTOP_VERSION | 4 | #ifndef DESKTOP_VERSION |
5 | #include <qpe/qpeapplication.h> | 5 | #include <qpe/qpeapplication.h> |
6 | #include <libkdepim/externalapphandler.h> | 6 | #include <libkdepim/externalapphandler.h> |
7 | #include <stdlib.h> | 7 | #include <stdlib.h> |
8 | #else | 8 | #else |
9 | #include <qapplication.h> | 9 | #include <qapplication.h> |
10 | #include <qstring.h> | 10 | #include <qstring.h> |
11 | #include <qwindowsstyle.h> | 11 | #include <qwindowsstyle.h> |
12 | #include <qplatinumstyle.h> | 12 | #include <qplatinumstyle.h> |
13 | #include <qsgistyle.h> | 13 | #include <qsgistyle.h> |
14 | #endif | 14 | #endif |
15 | #include "opiemail.h" | 15 | #include "opiemail.h" |
16 | #include <qdir.h> | 16 | #include <qdir.h> |
17 | #include <kstandarddirs.h> | 17 | #include <kstandarddirs.h> |
18 | #include <kglobal.h> | 18 | #include <kglobal.h> |
19 | #include <stdio.h> | 19 | #include <stdio.h> |
20 | #include "mainwindow.h" | 20 | #include "mainwindow.h" |
21 | #include "koprefs.h" | 21 | #include "koprefs.h" |
22 | #include <libkdepim/kpimglobalprefs.h> | 22 | #include <libkdepim/kpimglobalprefs.h> |
23 | void dumpMissing(); | 23 | void dumpMissing(); |
24 | //using namespace Opie::Core; | 24 | //using namespace Opie::Core; |
25 | int main( int argc, char **argv ) { | 25 | int main( int argc, char **argv ) { |
26 | 26 | ||
27 | #ifndef DESKTOP_VERSION | 27 | #ifndef DESKTOP_VERSION |
28 | QPEApplication a( argc, argv ); | 28 | QPEApplication a( argc, argv ); |
29 | a.setKeepRunning (); | 29 | a.setKeepRunning (); |
30 | #else | 30 | #else |
31 | QApplication a( argc, argv ); | 31 | QApplication a( argc, argv ); |
32 | QApplication::setStyle( new QPlatinumStyle ()); | 32 | QApplication::setStyle( new QPlatinumStyle ()); |
33 | #endif | 33 | #endif |
34 | a.setFont( KOPrefs::instance()->mAppFont ); | 34 | a.setFont( KOPrefs::instance()->mAppFont ); |
35 | KGlobal::setAppName( "kopiemail" ); | 35 | KGlobal::setAppName( "kopiemail" ); |
36 | QString fileName ; | 36 | QString fileName ; |
37 | #ifndef DESKTOP_VERSION | 37 | #ifndef DESKTOP_VERSION |
38 | fileName = getenv("QPEDIR"); | 38 | fileName = getenv("QPEDIR"); |
39 | if ( QApplication::desktop()->width() > 320 ) | 39 | if ( QApplication::desktop()->width() > 320 ) |
40 | KGlobal::iconLoader()->setIconPath( fileName +"/pics/kdepim/kopiemail/icons22/"); | 40 | KGlobal::iconLoader()->setIconPath( fileName +"/pics/kdepim/kopiemail/icons22/"); |
41 | else | 41 | else |
42 | KGlobal::iconLoader()->setIconPath( fileName +"/pics/kdepim/kopiemail/"); | 42 | KGlobal::iconLoader()->setIconPath( fileName +"/pics/kdepim/kopiemail/"); |
43 | #else | 43 | #else |
44 | fileName = qApp->applicationDirPath () + "/kdepim/kopiemail/"; | 44 | fileName = qApp->applicationDirPath () + "/kdepim/kopiemail/"; |
45 | KGlobal::iconLoader()->setIconPath(QDir::convertSeparators(fileName)); | 45 | KGlobal::iconLoader()->setIconPath(QDir::convertSeparators(fileName)); |
46 | #endif | 46 | #endif |
47 | KStandardDirs::setAppDir( QDir::convertSeparators(locateLocal("data", "kopiemail"))); | 47 | KStandardDirs::setAppDir( QDir::convertSeparators(locateLocal("data", "kopiemail"))); |
48 | KPimGlobalPrefs::instance()->setGlobalConfig(); | ||
48 | OpieMail mw; | 49 | OpieMail mw; |
49 | #ifndef DESKTOP_VERSION | 50 | #ifndef DESKTOP_VERSION |
50 | //qDebug("CONNECT "); | 51 | //qDebug("CONNECT "); |
51 | QObject::connect( &a, SIGNAL (appMessage ( const QCString &, const QByteArray & )),&mw, SLOT(message( const QCString&, const QByteArray& ))); | 52 | QObject::connect( &a, SIGNAL (appMessage ( const QCString &, const QByteArray & )),&mw, SLOT(message( const QCString&, const QByteArray& ))); |
52 | // QObject::connect(&a, SIGNAL (appMessage ( const QCString &, const QByteArray & )), ExternalAppHandler::instance(), SLOT (appMessage ( const QCString &, const QByteArray & ))); | 53 | // QObject::connect(&a, SIGNAL (appMessage ( const QCString &, const QByteArray & )), ExternalAppHandler::instance(), SLOT (appMessage ( const QCString &, const QByteArray & ))); |
53 | a.showMainWidget(&mw ); | 54 | a.showMainWidget(&mw ); |
54 | #else | 55 | #else |
55 | a.setMainWidget(&mw ); | 56 | a.setMainWidget(&mw ); |
56 | mw.show(); | 57 | mw.show(); |
57 | //m.resize( 800, 600 ); | 58 | //m.resize( 800, 600 ); |
58 | QObject::connect(&a, SIGNAL(lastWindowClosed()), &a, SLOT(quit())); | 59 | QObject::connect(&a, SIGNAL(lastWindowClosed()), &a, SLOT(quit())); |
59 | #endif | 60 | #endif |
60 | int rv = a.exec(); | 61 | int rv = a.exec(); |
61 | dumpMissing(); | 62 | dumpMissing(); |
62 | 63 | ||
63 | KPimGlobalPrefs::instance()->writeConfig(); | 64 | KPimGlobalPrefs::instance()->writeConfig(); |
64 | return rv; | 65 | return rv; |
65 | 66 | ||
66 | } | 67 | } |
diff --git a/kmicromail/opiemail.cpp b/kmicromail/opiemail.cpp index 3aa7905..a32983c 100644 --- a/kmicromail/opiemail.cpp +++ b/kmicromail/opiemail.cpp | |||
@@ -1,293 +1,292 @@ | |||
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 | #include "accountitem.h" | 12 | #include "accountitem.h" |
13 | #include "koprefsdialog.h" | 13 | #include "koprefsdialog.h" |
14 | #include "klocale.h" | 14 | #include "klocale.h" |
15 | 15 | ||
16 | #include <qmessagebox.h> | 16 | #include <qmessagebox.h> |
17 | #include <qtimer.h> | 17 | #include <qtimer.h> |
18 | #include <libkdepim/externalapphandler.h> | 18 | #include <libkdepim/externalapphandler.h> |
19 | #include <libkdepim/kpimglobalprefs.h> | 19 | #include <libkdepim/kpimglobalprefs.h> |
20 | 20 | ||
21 | #include <qpe/qpeapplication.h> | 21 | #include <qpe/qpeapplication.h> |
22 | #include <libmailwrapper/smtpwrapper.h> | 22 | #include <libmailwrapper/smtpwrapper.h> |
23 | #include <libmailwrapper/mailtypes.h> | 23 | #include <libmailwrapper/mailtypes.h> |
24 | #include <libmailwrapper/abstractmail.h> | 24 | #include <libmailwrapper/abstractmail.h> |
25 | /* OPIE */ | 25 | /* OPIE */ |
26 | //#include <qpe/resource.h> | 26 | //#include <qpe/resource.h> |
27 | //#include <qpe/qpeapplication.h> | 27 | //#include <qpe/qpeapplication.h> |
28 | 28 | ||
29 | /* QT */ | 29 | /* QT */ |
30 | 30 | ||
31 | //using namespace Opie::Core; | 31 | //using namespace Opie::Core; |
32 | 32 | ||
33 | OpieMail::OpieMail( QWidget *parent, const char *name ) | 33 | OpieMail::OpieMail( QWidget *parent, const char *name ) |
34 | : MainWindow( parent, name) //, WStyle_ContextHelp ) | 34 | : MainWindow( parent, name) //, WStyle_ContextHelp ) |
35 | { | 35 | { |
36 | settings = new Settings(); | 36 | settings = new Settings(); |
37 | KPimGlobalPrefs::instance()->setGlobalConfig(); | ||
38 | 37 | ||
39 | folderView->populate( settings->getAccounts() ); | 38 | folderView->populate( settings->getAccounts() ); |
40 | 39 | ||
41 | } | 40 | } |
42 | 41 | ||
43 | OpieMail::~OpieMail() | 42 | OpieMail::~OpieMail() |
44 | { | 43 | { |
45 | if (settings) delete settings; | 44 | if (settings) delete settings; |
46 | } | 45 | } |
47 | 46 | ||
48 | void OpieMail::appMessage(const QCString &msg, const QByteArray &data) | 47 | void OpieMail::appMessage(const QCString &msg, const QByteArray &data) |
49 | { | 48 | { |
50 | 49 | ||
51 | } | 50 | } |
52 | #include <stdlib.h> | 51 | #include <stdlib.h> |
53 | void OpieMail::message(const QCString &msg, const QByteArray &data) | 52 | void OpieMail::message(const QCString &msg, const QByteArray &data) |
54 | { | 53 | { |
55 | // copied from old mail2 | 54 | // copied from old mail2 |
56 | static int ii = 0; | 55 | static int ii = 0; |
57 | //qDebug("QCOP CALL ############################# %d ", ii); | 56 | //qDebug("QCOP CALL ############################# %d ", ii); |
58 | //QString mess ( msg ); | 57 | //QString mess ( msg ); |
59 | //qDebug("Message = %s ",mess.latin1()); | 58 | //qDebug("Message = %s ",mess.latin1()); |
60 | ++ii; | 59 | ++ii; |
61 | //qDebug("KM:appMessage %d *%s* %x", ii, msg.data(), this); | 60 | //qDebug("KM:appMessage %d *%s* %x", ii, msg.data(), this); |
62 | 61 | ||
63 | mPendingEmail = QString::null; | 62 | mPendingEmail = QString::null; |
64 | mPendingName = QString::null; | 63 | mPendingName = QString::null; |
65 | if (msg == "writeMail(QString,QString)") | 64 | if (msg == "writeMail(QString,QString)") |
66 | { | 65 | { |
67 | //qDebug("writeMail(QString,QString) "); | 66 | //qDebug("writeMail(QString,QString) "); |
68 | QDataStream stream(data,IO_ReadOnly); | 67 | QDataStream stream(data,IO_ReadOnly); |
69 | stream >> mPendingName >> mPendingEmail; | 68 | stream >> mPendingName >> mPendingEmail; |
70 | // removing the whitespaces at beginning and end is needed! | 69 | // removing the whitespaces at beginning and end is needed! |
71 | QTimer::singleShot ( 50, this, SLOT(slotComposeMail() ) ); | 70 | QTimer::singleShot ( 50, this, SLOT(slotComposeMail() ) ); |
72 | } | 71 | } |
73 | else if (msg == "newMail()") | 72 | else if (msg == "newMail()") |
74 | { | 73 | { |
75 | //qDebug("slotComposeMail() "); | 74 | //qDebug("slotComposeMail() "); |
76 | // we cannot call slotComposeMail(); directly, because may be executing a QCOP call | 75 | // we cannot call slotComposeMail(); directly, because may be executing a QCOP call |
77 | // and a QCOP call does not like a processevents in his execution | 76 | // and a QCOP call does not like a processevents in his execution |
78 | // with the Qtimer we call slotComposeMail() after we reached the main event loop | 77 | // with the Qtimer we call slotComposeMail() after we reached the main event loop |
79 | QTimer::singleShot ( 50, this, SLOT(slotComposeMail() ) ); | 78 | QTimer::singleShot ( 50, this, SLOT(slotComposeMail() ) ); |
80 | // slotComposeMail(); | 79 | // slotComposeMail(); |
81 | } | 80 | } |
82 | else if (msg == "newMail(QString)") | 81 | else if (msg == "newMail(QString)") |
83 | { | 82 | { |
84 | //qDebug(" newMail(QString)"); | 83 | //qDebug(" newMail(QString)"); |
85 | QDataStream stream(data,IO_ReadOnly); | 84 | QDataStream stream(data,IO_ReadOnly); |
86 | stream >> mPendingName; | 85 | stream >> mPendingName; |
87 | // the format is | 86 | // the format is |
88 | // NAME <EMAIL>:SUBJECT | 87 | // NAME <EMAIL>:SUBJECT |
89 | QTimer::singleShot ( 50, this, SLOT(slotComposeMail() ) ); | 88 | QTimer::singleShot ( 50, this, SLOT(slotComposeMail() ) ); |
90 | } else { | 89 | } else { |
91 | mPendingData = data; | 90 | mPendingData = data; |
92 | mPendingMessage = msg; | 91 | mPendingMessage = msg; |
93 | QTimer::singleShot ( 50, this, SLOT(slotExtAppHandler() ) ); | 92 | QTimer::singleShot ( 50, this, SLOT(slotExtAppHandler() ) ); |
94 | } | 93 | } |
95 | 94 | ||
96 | //qDebug("END OpieMail::message "); | 95 | //qDebug("END OpieMail::message "); |
97 | } | 96 | } |
98 | void OpieMail::slotExtAppHandler() | 97 | void OpieMail::slotExtAppHandler() |
99 | { | 98 | { |
100 | ExternalAppHandler::instance()->appMessage ( mPendingMessage, mPendingData ); | 99 | ExternalAppHandler::instance()->appMessage ( mPendingMessage, mPendingData ); |
101 | } | 100 | } |
102 | void OpieMail::slotwriteMail2(const QString& namemail ) | 101 | void OpieMail::slotwriteMail2(const QString& namemail ) |
103 | { | 102 | { |
104 | //qDebug("OpieMail::slotwriteMail2 "); | 103 | //qDebug("OpieMail::slotwriteMail2 "); |
105 | //qApp->processEvents(); | 104 | //qApp->processEvents(); |
106 | ComposeMail compose( settings, this, 0, true ); | 105 | ComposeMail compose( settings, this, 0, true ); |
107 | if ( !namemail.isEmpty() ) { | 106 | if ( !namemail.isEmpty() ) { |
108 | QString to = namemail; | 107 | QString to = namemail; |
109 | if ( namemail.find( " <") > 1 ) { | 108 | if ( namemail.find( " <") > 1 ) { |
110 | to = "\"" +to.replace( QRegExp( " <"), "\" <") ; | 109 | to = "\"" +to.replace( QRegExp( " <"), "\" <") ; |
111 | } else | 110 | } else |
112 | if ( namemail.find( "<") > 1 ) { | 111 | if ( namemail.find( "<") > 1 ) { |
113 | to = "\"" +to.replace( QRegExp( "<"), "\" <") ; | 112 | to = "\"" +to.replace( QRegExp( "<"), "\" <") ; |
114 | } | 113 | } |
115 | int sub = to.find( ">:"); | 114 | int sub = to.find( ">:"); |
116 | if ( sub > 0 ) { | 115 | if ( sub > 0 ) { |
117 | compose.setTo( to.left(sub+1) ); | 116 | compose.setTo( to.left(sub+1) ); |
118 | compose.setSubject( to.mid(sub+2) ); | 117 | compose.setSubject( to.mid(sub+2) ); |
119 | } else | 118 | } else |
120 | compose.setTo( to ); | 119 | compose.setTo( to ); |
121 | } | 120 | } |
122 | compose.slotAdjustColumns(); | 121 | compose.slotAdjustColumns(); |
123 | compose.showMaximized(); | 122 | compose.showMaximized(); |
124 | compose.exec(); | 123 | compose.exec(); |
125 | raise(); | 124 | raise(); |
126 | //qDebug("retttich "); | 125 | //qDebug("retttich "); |
127 | } | 126 | } |
128 | void OpieMail::slotwriteMail(const QString&name,const QString&email) | 127 | void OpieMail::slotwriteMail(const QString&name,const QString&email) |
129 | { | 128 | { |
130 | // qDebug("OpieMail::slotwriteMail "); | 129 | // qDebug("OpieMail::slotwriteMail "); |
131 | ComposeMail compose( settings, this, 0, true ); | 130 | ComposeMail compose( settings, this, 0, true ); |
132 | if (!email.isEmpty()) | 131 | if (!email.isEmpty()) |
133 | { | 132 | { |
134 | if (!name.isEmpty()) | 133 | if (!name.isEmpty()) |
135 | { | 134 | { |
136 | compose.setTo("\"" + name + "\"" + " " + "<"+ email + ">"); | 135 | compose.setTo("\"" + name + "\"" + " " + "<"+ email + ">"); |
137 | } | 136 | } |
138 | else | 137 | else |
139 | { | 138 | { |
140 | compose.setTo(email); | 139 | compose.setTo(email); |
141 | } | 140 | } |
142 | } | 141 | } |
143 | compose.slotAdjustColumns(); | 142 | compose.slotAdjustColumns(); |
144 | compose.showMaximized(); | 143 | compose.showMaximized(); |
145 | compose.exec(); | 144 | compose.exec(); |
146 | raise(); | 145 | raise(); |
147 | } | 146 | } |
148 | 147 | ||
149 | void OpieMail::slotComposeMail() | 148 | void OpieMail::slotComposeMail() |
150 | { | 149 | { |
151 | if ( mPendingEmail == QString::null && mPendingName == QString::null) | 150 | if ( mPendingEmail == QString::null && mPendingName == QString::null) |
152 | slotwriteMail2( QString () ); | 151 | slotwriteMail2( QString () ); |
153 | else { | 152 | else { |
154 | if ( mPendingEmail == QString::null ) | 153 | if ( mPendingEmail == QString::null ) |
155 | slotwriteMail2( mPendingName ); | 154 | slotwriteMail2( mPendingName ); |
156 | else | 155 | else |
157 | slotwriteMail( mPendingName, mPendingEmail ); | 156 | slotwriteMail( mPendingName, mPendingEmail ); |
158 | } | 157 | } |
159 | //slotwriteMail(0l,0l); | 158 | //slotwriteMail(0l,0l); |
160 | } | 159 | } |
161 | 160 | ||
162 | void OpieMail::slotSendQueued() | 161 | void OpieMail::slotSendQueued() |
163 | { | 162 | { |
164 | SMTPaccount *smtp = 0; | 163 | SMTPaccount *smtp = 0; |
165 | 164 | ||
166 | QList<Account> list = settings->getAccounts(); | 165 | QList<Account> list = settings->getAccounts(); |
167 | QList<SMTPaccount> smtpList; | 166 | QList<SMTPaccount> smtpList; |
168 | smtpList.setAutoDelete(false); | 167 | smtpList.setAutoDelete(false); |
169 | Account *it; | 168 | Account *it; |
170 | for ( it = list.first(); it; it = list.next() ) | 169 | for ( it = list.first(); it; it = list.next() ) |
171 | { | 170 | { |
172 | if ( it->getType() == MAILLIB::A_SMTP ) | 171 | if ( it->getType() == MAILLIB::A_SMTP ) |
173 | { | 172 | { |
174 | smtp = static_cast<SMTPaccount *>(it); | 173 | smtp = static_cast<SMTPaccount *>(it); |
175 | smtpList.append(smtp); | 174 | smtpList.append(smtp); |
176 | } | 175 | } |
177 | } | 176 | } |
178 | if (smtpList.count()==0) | 177 | if (smtpList.count()==0) |
179 | { | 178 | { |
180 | QMessageBox::information(0,i18n("Info"),i18n("Define a smtp account first!\n")); | 179 | QMessageBox::information(0,i18n("Info"),i18n("Define a smtp account first!\n")); |
181 | return; | 180 | return; |
182 | } | 181 | } |
183 | if (smtpList.count()==1) | 182 | if (smtpList.count()==1) |
184 | { | 183 | { |
185 | smtp = smtpList.at(0); | 184 | smtp = smtpList.at(0); |
186 | } | 185 | } |
187 | else | 186 | else |
188 | { | 187 | { |
189 | smtp = 0; | 188 | smtp = 0; |
190 | selectsmtp selsmtp; | 189 | selectsmtp selsmtp; |
191 | selsmtp.setSelectionlist(&smtpList); | 190 | selsmtp.setSelectionlist(&smtpList); |
192 | selsmtp.showMaximized(); | 191 | selsmtp.showMaximized(); |
193 | if ( selsmtp.exec() == QDialog::Accepted ) | 192 | if ( selsmtp.exec() == QDialog::Accepted ) |
194 | { | 193 | { |
195 | smtp = selsmtp.selected_smtp(); | 194 | smtp = selsmtp.selected_smtp(); |
196 | } | 195 | } |
197 | } | 196 | } |
198 | if (smtp) | 197 | if (smtp) |
199 | { | 198 | { |
200 | SMTPwrapper * wrap = new SMTPwrapper(smtp); | 199 | SMTPwrapper * wrap = new SMTPwrapper(smtp); |
201 | if ( wrap->flushOutbox() ) | 200 | if ( wrap->flushOutbox() ) |
202 | { | 201 | { |
203 | QMessageBox::information(0,i18n("Info"),i18n("Mail queue flushed")); | 202 | QMessageBox::information(0,i18n("Info"),i18n("Mail queue flushed")); |
204 | } | 203 | } |
205 | delete wrap; | 204 | delete wrap; |
206 | } | 205 | } |
207 | } | 206 | } |
208 | 207 | ||
209 | void OpieMail::slotSearchMails() | 208 | void OpieMail::slotSearchMails() |
210 | { | 209 | { |
211 | qDebug("OpieMail::slotSearchMails():not implemented "); | 210 | qDebug("OpieMail::slotSearchMails():not implemented "); |
212 | } | 211 | } |
213 | 212 | ||
214 | void OpieMail::slotEditSettings() | 213 | void OpieMail::slotEditSettings() |
215 | { | 214 | { |
216 | #if 0 | 215 | #if 0 |
217 | SettingsDialog settingsDialog( this, 0, true, WStyle_ContextHelp ); | 216 | SettingsDialog settingsDialog( this, 0, true, WStyle_ContextHelp ); |
218 | settingsDialog.showMaximized(); | 217 | settingsDialog.showMaximized(); |
219 | settingsDialog.exec(); | 218 | settingsDialog.exec(); |
220 | #endif | 219 | #endif |
221 | KOPrefsDialog settingsDialog( this, "koprefs", true ); | 220 | KOPrefsDialog settingsDialog( this, "koprefs", true ); |
222 | settingsDialog.showMaximized(); | 221 | settingsDialog.showMaximized(); |
223 | settingsDialog.exec(); | 222 | settingsDialog.exec(); |
224 | } | 223 | } |
225 | 224 | ||
226 | void OpieMail::slotEditAccounts() | 225 | void OpieMail::slotEditAccounts() |
227 | { | 226 | { |
228 | EditAccounts eaDialog( settings, this, 0, true ); | 227 | EditAccounts eaDialog( settings, this, 0, true ); |
229 | eaDialog.slotAdjustColumns(); | 228 | eaDialog.slotAdjustColumns(); |
230 | eaDialog.showMaximized(); | 229 | eaDialog.showMaximized(); |
231 | eaDialog.exec(); | 230 | eaDialog.exec(); |
232 | if ( settings ) delete settings; | 231 | if ( settings ) delete settings; |
233 | settings = new Settings(); | 232 | settings = new Settings(); |
234 | 233 | ||
235 | folderView->populate( settings->getAccounts() ); | 234 | folderView->populate( settings->getAccounts() ); |
236 | } | 235 | } |
237 | 236 | ||
238 | void OpieMail::displayMail() | 237 | void OpieMail::displayMail() |
239 | { | 238 | { |
240 | QListViewItem*item = mailView->currentItem(); | 239 | QListViewItem*item = mailView->currentItem(); |
241 | if (!item) return; | 240 | if (!item) return; |
242 | RecMailP mail = ((MailListViewItem*)item)->data(); | 241 | RecMailP mail = ((MailListViewItem*)item)->data(); |
243 | RecBodyP body = folderView->fetchBody(mail); | 242 | RecBodyP body = folderView->fetchBody(mail); |
244 | ViewMail readMail( this,"", Qt::WType_Modal ); | 243 | ViewMail readMail( this,"", Qt::WType_Modal ); |
245 | readMail.setBody( body ); | 244 | readMail.setBody( body ); |
246 | readMail.setMail( mail ); | 245 | readMail.setMail( mail ); |
247 | readMail.showMaximized(); | 246 | readMail.showMaximized(); |
248 | readMail.exec(); | 247 | readMail.exec(); |
249 | 248 | ||
250 | if ( readMail.deleted ) | 249 | if ( readMail.deleted ) |
251 | { | 250 | { |
252 | folderView->refreshCurrent(); | 251 | folderView->refreshCurrent(); |
253 | } | 252 | } |
254 | else | 253 | else |
255 | { | 254 | { |
256 | ( (MailListViewItem*)item )->setPixmap( 0, QPixmap() ); | 255 | ( (MailListViewItem*)item )->setPixmap( 0, QPixmap() ); |
257 | } | 256 | } |
258 | } | 257 | } |
259 | void OpieMail::slotGetAllMail() | 258 | void OpieMail::slotGetAllMail() |
260 | { | 259 | { |
261 | QListViewItem * item = folderView->firstChild(); | 260 | QListViewItem * item = folderView->firstChild(); |
262 | while ( item ){ | 261 | while ( item ){ |
263 | ((AccountViewItem *)item)->contextMenuSelected( 101 ); | 262 | ((AccountViewItem *)item)->contextMenuSelected( 101 ); |
264 | item = item->nextSibling (); | 263 | item = item->nextSibling (); |
265 | } | 264 | } |
266 | } | 265 | } |
267 | void OpieMail::slotGetMail() | 266 | void OpieMail::slotGetMail() |
268 | { | 267 | { |
269 | QListViewItem * item = folderView->currentItem(); | 268 | QListViewItem * item = folderView->currentItem(); |
270 | if ( ! item ) return; | 269 | if ( ! item ) return; |
271 | ((AccountViewItem *)item)->contextMenuSelected( 101 ); | 270 | ((AccountViewItem *)item)->contextMenuSelected( 101 ); |
272 | } | 271 | } |
273 | void OpieMail::slotDeleteMail() | 272 | void OpieMail::slotDeleteMail() |
274 | { | 273 | { |
275 | if (!mailView->currentItem()) return; | 274 | if (!mailView->currentItem()) return; |
276 | RecMailP mail = ((MailListViewItem*)mailView->currentItem() )->data(); | 275 | RecMailP mail = ((MailListViewItem*)mailView->currentItem() )->data(); |
277 | if ( QMessageBox::warning(this, i18n("Delete Mail"), QString( i18n("<p>Do you really want to delete this mail? <br><br>" ) + mail->getFrom() + " - " + mail->getSubject() ) , QMessageBox::Yes, QMessageBox::No ) == QMessageBox::Yes ) | 276 | if ( QMessageBox::warning(this, i18n("Delete Mail"), QString( i18n("<p>Do you really want to delete this mail? <br><br>" ) + mail->getFrom() + " - " + mail->getSubject() ) , QMessageBox::Yes, QMessageBox::No ) == QMessageBox::Yes ) |
278 | { | 277 | { |
279 | mail->Wrapper()->deleteMail( mail ); | 278 | mail->Wrapper()->deleteMail( mail ); |
280 | folderView->refreshCurrent(); | 279 | folderView->refreshCurrent(); |
281 | } | 280 | } |
282 | } | 281 | } |
283 | void OpieMail::slotDeleteAllMail() | 282 | void OpieMail::slotDeleteAllMail() |
284 | { | 283 | { |
285 | 284 | ||
286 | QValueList<RecMailP> t; | 285 | QValueList<RecMailP> t; |
287 | if ( QMessageBox::warning(this, i18n("Delete All Mails"), i18n("Do you really want to delete\nall selected mails?" ) , QMessageBox::Yes, QMessageBox::No ) == QMessageBox::Yes ) | 286 | if ( QMessageBox::warning(this, i18n("Delete All Mails"), i18n("Do you really want to delete\nall selected mails?" ) , QMessageBox::Yes, QMessageBox::No ) == QMessageBox::Yes ) |
288 | { | 287 | { |
289 | MailListViewItem* item = (MailListViewItem*)mailView->firstChild (); | 288 | MailListViewItem* item = (MailListViewItem*)mailView->firstChild (); |
290 | while ( item ) { | 289 | while ( item ) { |
291 | if ( item->isSelected() ) { | 290 | if ( item->isSelected() ) { |
292 | t.append( item->data() ); | 291 | t.append( item->data() ); |
293 | } | 292 | } |
diff --git a/microkde/kdecore/klocale.cpp b/microkde/kdecore/klocale.cpp index d3b04dc..1da1e99 100644 --- a/microkde/kdecore/klocale.cpp +++ b/microkde/kdecore/klocale.cpp | |||
@@ -1,325 +1,375 @@ | |||
1 | #include <qregexp.h> | 1 | #include <qregexp.h> |
2 | #include <qapplication.h> | 2 | #include <qapplication.h> |
3 | 3 | ||
4 | #include "kdebug.h" | 4 | #include "kdebug.h" |
5 | #include "kcalendarsystemgregorian.h" | 5 | #include "kcalendarsystemgregorian.h" |
6 | 6 | ||
7 | #include "klocale.h" | 7 | #include "klocale.h" |
8 | 8 | ||
9 | #include <qstringlist.h> | 9 | #include <qstringlist.h> |
10 | QStringList missingTrans; | 10 | |
11 | //#define COLLECT_TRANSLATION | ||
12 | |||
11 | 13 | ||
12 | QDict<QString> *mLocaleDict = 0; | 14 | QDict<QString> *mLocaleDict = 0; |
13 | void setLocaleDict( QDict<QString> * dict ) | 15 | void setLocaleDict( QDict<QString> * dict ) |
14 | { | 16 | { |
15 | mLocaleDict = dict; | 17 | mLocaleDict = dict; |
16 | 18 | ||
17 | } | 19 | } |
20 | |||
21 | #ifdef COLLECT_TRANSLATION | ||
22 | |||
23 | QStringList missingTrans; | ||
24 | QStringList existingTrans1; | ||
25 | QStringList existingTrans2; | ||
26 | |||
18 | void addMissing(const char *text) | 27 | void addMissing(const char *text) |
19 | { | 28 | { |
20 | return; | 29 | |
21 | QString mis ( text ); | 30 | QString mis ( text ); |
22 | if ( !missingTrans.contains( mis ) ) | 31 | if ( !missingTrans.contains( mis ) ) |
23 | missingTrans.append(mis); | 32 | missingTrans.append(mis); |
24 | 33 | ||
25 | } | 34 | } |
35 | void addExist(const char *text,QString trans ) | ||
36 | { | ||
37 | //return; | ||
38 | QString mis ( text ); | ||
39 | if ( !existingTrans1.contains( mis ) ) { | ||
40 | existingTrans1.append(mis); | ||
41 | existingTrans2.append(trans); | ||
42 | |||
43 | } | ||
44 | |||
45 | } | ||
26 | 46 | ||
27 | #include <qfile.h> | 47 | #include <qfile.h> |
28 | #include <qtextstream.h> | 48 | #include <qtextstream.h> |
29 | #include <qtextcodec.h> | 49 | #include <qtextcodec.h> |
50 | #endif | ||
30 | void dumpMissing() | 51 | void dumpMissing() |
31 | { | 52 | { |
32 | return; | 53 | #ifdef COLLECT_TRANSLATION |
33 | QString fileName = "/tmp/usertrans.txt"; | 54 | QString fileName = "/tmp/usernewtrans.txt"; |
34 | QFile file( fileName ); | 55 | QFile file( fileName ); |
35 | if (!file.open( IO_WriteOnly ) ) { | 56 | if (!file.open( IO_WriteOnly ) ) { |
36 | return ; | 57 | return ; |
37 | } | 58 | } |
38 | QTextStream ts( &file ); | 59 | QTextStream ts( &file ); |
39 | ts.setCodec( QTextCodec::codecForName("utf8") ); | 60 | ts.setCodec( QTextCodec::codecForName("utf8") ); |
40 | 61 | ||
41 | int i; | 62 | int i; |
42 | for ( i = 0; i< missingTrans.count(); ++i ) { | 63 | for ( i = 0; i< missingTrans.count(); ++i ) { |
43 | 64 | ||
44 | QString text = missingTrans[i].replace( QRegExp("\n"),"\\n" ); | 65 | QString text = missingTrans[i].replace( QRegExp("\n"),"\\n" ); |
45 | ts << "{ \""<<text<< "\",\""<< text <<"\" },\n"; | 66 | ts << "{ \""<<text<< "\",\""<< text <<"\" },\n"; |
46 | 67 | ||
47 | } | 68 | } |
48 | file.close(); | 69 | file.close(); |
49 | } | 70 | { |
71 | QString fileName = "/tmp/usertrans.txt"; | ||
72 | QFile file( fileName ); | ||
73 | if (!file.open( IO_WriteOnly ) ) { | ||
74 | return ; | ||
75 | } | ||
76 | QTextStream ts( &file ); | ||
77 | ts.setCodec( QTextCodec::codecForName("utf8") ); | ||
78 | |||
79 | int i; | ||
80 | for ( i = 0; i< existingTrans1.count(); ++i ) { | ||
81 | |||
82 | QString text = existingTrans1[i].replace( QRegExp("\n"),"\\n" ); | ||
83 | QString text2 = existingTrans2[i].replace( QRegExp("\n"),"\\n" ); | ||
84 | ts << "{ \""<<text<< "\",\""<< text2 <<"\" },\n"; | ||
50 | 85 | ||
86 | } | ||
87 | file.close(); | ||
88 | } | ||
89 | #endif | ||
90 | } | ||
51 | QString i18n(const char *text) | 91 | QString i18n(const char *text) |
52 | { | 92 | { |
53 | if ( ! mLocaleDict ) { | 93 | if ( ! mLocaleDict ) { |
94 | #ifdef COLLECT_TRANSLATION | ||
54 | addMissing( text ); | 95 | addMissing( text ); |
96 | #endif | ||
55 | return QString( text ); | 97 | return QString( text ); |
56 | } | 98 | } |
57 | else { | 99 | else { |
58 | QString* ret = mLocaleDict->find(QString(text)) ; | 100 | QString* ret = mLocaleDict->find(QString(text)) ; |
59 | if ( ret == 0 ) { | 101 | if ( ret == 0 ) { |
102 | #ifdef COLLECT_TRANSLATION | ||
60 | addMissing( text ); | 103 | addMissing( text ); |
104 | #endif | ||
61 | return QString( text ); | 105 | return QString( text ); |
62 | } | 106 | } |
63 | else { | 107 | else { |
64 | if ( (*ret).isEmpty() ) { | 108 | if ( (*ret).isEmpty() ) { |
109 | #ifdef COLLECT_TRANSLATION | ||
65 | addMissing( text ); | 110 | addMissing( text ); |
111 | #endif | ||
66 | return QString( text ); | 112 | return QString( text ); |
67 | } | 113 | } |
68 | else | 114 | else { |
115 | #ifdef COLLECT_TRANSLATION | ||
116 | addExist( text, *ret ); | ||
117 | #endif | ||
69 | return (*ret); | 118 | return (*ret); |
119 | } | ||
70 | } | 120 | } |
71 | } | 121 | } |
72 | 122 | ||
73 | } | 123 | } |
74 | 124 | ||
75 | QString i18n(const char *,const char *text) | 125 | QString i18n(const char *,const char *text) |
76 | { | 126 | { |
77 | return i18n( text ); | 127 | return i18n( text ); |
78 | } | 128 | } |
79 | 129 | ||
80 | QString i18n(const char *text1, const char *textn, int num) | 130 | QString i18n(const char *text1, const char *textn, int num) |
81 | { | 131 | { |
82 | if ( num == 1 ) return i18n( text1 ); | 132 | if ( num == 1 ) return i18n( text1 ); |
83 | else { | 133 | else { |
84 | QString text = i18n( textn ); | 134 | QString text = i18n( textn ); |
85 | int pos = text.find( "%n" ); | 135 | int pos = text.find( "%n" ); |
86 | if ( pos >= 0 ) text.replace( pos, 2, QString::number( num ) ); | 136 | if ( pos >= 0 ) text.replace( pos, 2, QString::number( num ) ); |
87 | return text; | 137 | return text; |
88 | } | 138 | } |
89 | } | 139 | } |
90 | 140 | ||
91 | inline void put_it_in( QChar *buffer, uint& index, const QString &s ) | 141 | inline void put_it_in( QChar *buffer, uint& index, const QString &s ) |
92 | { | 142 | { |
93 | for ( uint l = 0; l < s.length(); l++ ) | 143 | for ( uint l = 0; l < s.length(); l++ ) |
94 | buffer[index++] = s.at( l ); | 144 | buffer[index++] = s.at( l ); |
95 | } | 145 | } |
96 | 146 | ||
97 | inline void put_it_in( QChar *buffer, uint& index, int number ) | 147 | inline void put_it_in( QChar *buffer, uint& index, int number ) |
98 | { | 148 | { |
99 | buffer[index++] = number / 10 + '0'; | 149 | buffer[index++] = number / 10 + '0'; |
100 | buffer[index++] = number % 10 + '0'; | 150 | buffer[index++] = number % 10 + '0'; |
101 | } | 151 | } |
102 | 152 | ||
103 | static int readInt(const QString &str, uint &pos) | 153 | static int readInt(const QString &str, uint &pos) |
104 | { | 154 | { |
105 | if (!str.at(pos).isDigit()) return -1; | 155 | if (!str.at(pos).isDigit()) return -1; |
106 | int result = 0; | 156 | int result = 0; |
107 | for (; str.length() > pos && str.at(pos).isDigit(); pos++) | 157 | for (; str.length() > pos && str.at(pos).isDigit(); pos++) |
108 | { | 158 | { |
109 | result *= 10; | 159 | result *= 10; |
110 | result += str.at(pos).digitValue(); | 160 | result += str.at(pos).digitValue(); |
111 | } | 161 | } |
112 | 162 | ||
113 | return result; | 163 | return result; |
114 | } | 164 | } |
115 | 165 | ||
116 | KLocale::KLocale() : mCalendarSystem( 0 ) | 166 | KLocale::KLocale() : mCalendarSystem( 0 ) |
117 | { | 167 | { |
118 | 168 | ||
119 | m_decimalSymbol = "."; | 169 | m_decimalSymbol = "."; |
120 | m_positiveSign = ""; | 170 | m_positiveSign = ""; |
121 | m_negativeSign = "-"; | 171 | m_negativeSign = "-"; |
122 | m_thousandsSeparator = ","; | 172 | m_thousandsSeparator = ","; |
123 | 173 | ||
124 | 174 | ||
125 | 175 | ||
126 | 176 | ||
127 | mWeekStartsMonday = true; | 177 | mWeekStartsMonday = true; |
128 | mHourF24Format = true; | 178 | mHourF24Format = true; |
129 | mIntDateFormat = Default; | 179 | mIntDateFormat = Default; |
130 | mIntTimeFormat = Default; | 180 | mIntTimeFormat = Default; |
131 | mLanguage = 0; | 181 | mLanguage = 0; |
132 | mDateFormat = "%a %Y %b %d"; | 182 | mDateFormat = "%a %Y %b %d"; |
133 | mDateFormatShort = "%Y-%m-%d"; | 183 | mDateFormatShort = "%Y-%m-%d"; |
134 | mTimeZoneList << ("-11:00 US/Samoa") | 184 | mTimeZoneList << ("-11:00 US/Samoa") |
135 | << ("-10:00 US/Hawaii") | 185 | << ("-10:00 US/Hawaii") |
136 | << ("-09:00 US/Alaska") | 186 | << ("-09:00 US/Alaska") |
137 | << ("-08:00 US/Pacific") | 187 | << ("-08:00 US/Pacific") |
138 | << ("-07:00 US/Mountain") | 188 | << ("-07:00 US/Mountain") |
139 | << ("-06:00 US/Central") | 189 | << ("-06:00 US/Central") |
140 | << ("-05:00 US/Eastern") | 190 | << ("-05:00 US/Eastern") |
141 | << ("-04:00 Brazil/West") | 191 | << ("-04:00 Brazil/West") |
142 | << ("-03:00 Brazil/East") | 192 | << ("-03:00 Brazil/East") |
143 | << ("-02:00 Brazil/DeNoronha") | 193 | << ("-02:00 Brazil/DeNoronha") |
144 | << ("-01:00 Atlantic/Azores") | 194 | << ("-01:00 Atlantic/Azores") |
145 | << (" 00:00 Europe/London(UTC)") | 195 | << (" 00:00 Europe/London(UTC)") |
146 | << ("+01:00 Europe/Oslo(CET)") | 196 | << ("+01:00 Europe/Oslo(CET)") |
147 | << ("+02:00 Europe/Helsinki") | 197 | << ("+02:00 Europe/Helsinki") |
148 | << ("+03:00 Europe/Moscow") | 198 | << ("+03:00 Europe/Moscow") |
149 | << ("+04:00 Indian/Mauritius") | 199 | << ("+04:00 Indian/Mauritius") |
150 | << ("+05:00 Indian/Maldives") | 200 | << ("+05:00 Indian/Maldives") |
151 | << ("+06:00 Indian/Chagos") | 201 | << ("+06:00 Indian/Chagos") |
152 | << ("+07:00 Asia/Bangkok") | 202 | << ("+07:00 Asia/Bangkok") |
153 | << ("+08:00 Asia/Hongkong") | 203 | << ("+08:00 Asia/Hongkong") |
154 | << ("+09:00 Asia/Tokyo") | 204 | << ("+09:00 Asia/Tokyo") |
155 | << ("+10:00 Asia/Vladivostok") | 205 | << ("+10:00 Asia/Vladivostok") |
156 | << ("+11:00 Asia/Magadan") | 206 | << ("+11:00 Asia/Magadan") |
157 | << ("+12:00 Asia/Kamchatka") | 207 | << ("+12:00 Asia/Kamchatka") |
158 | // << (" xx:xx User defined offset") | 208 | // << (" xx:xx User defined offset") |
159 | << i18n (" Local Time"); | 209 | << i18n (" Local Time"); |
160 | mSouthDaylight = false; | 210 | mSouthDaylight = false; |
161 | mTimeZoneOffset = 0; | 211 | mTimeZoneOffset = 0; |
162 | daylightEnabled = false; | 212 | daylightEnabled = false; |
163 | } | 213 | } |
164 | 214 | ||
165 | void KLocale::setDateFormat( QString s ) | 215 | void KLocale::setDateFormat( QString s ) |
166 | { | 216 | { |
167 | mDateFormat = s; | 217 | mDateFormat = s; |
168 | } | 218 | } |
169 | 219 | ||
170 | void KLocale::setDateFormatShort( QString s ) | 220 | void KLocale::setDateFormatShort( QString s ) |
171 | { | 221 | { |
172 | mDateFormatShort = s; | 222 | mDateFormatShort = s; |
173 | } | 223 | } |
174 | 224 | ||
175 | void KLocale::setHore24Format ( bool b ) | 225 | void KLocale::setHore24Format ( bool b ) |
176 | { | 226 | { |
177 | mHourF24Format = b; | 227 | mHourF24Format = b; |
178 | } | 228 | } |
179 | void KLocale::setWeekStartMonday( bool b ) | 229 | void KLocale::setWeekStartMonday( bool b ) |
180 | { | 230 | { |
181 | mWeekStartsMonday = b; | 231 | mWeekStartsMonday = b; |
182 | } | 232 | } |
183 | 233 | ||
184 | KLocale::IntDateFormat KLocale::getIntDateFormat( ) | 234 | KLocale::IntDateFormat KLocale::getIntDateFormat( ) |
185 | { | 235 | { |
186 | return mIntDateFormat; | 236 | return mIntDateFormat; |
187 | 237 | ||
188 | } | 238 | } |
189 | void KLocale::setIntDateFormat( KLocale::IntDateFormat i ) | 239 | void KLocale::setIntDateFormat( KLocale::IntDateFormat i ) |
190 | { | 240 | { |
191 | mIntDateFormat = i; | 241 | mIntDateFormat = i; |
192 | } | 242 | } |
193 | KLocale::IntDateFormat KLocale::getIntTimeFormat( ) | 243 | KLocale::IntDateFormat KLocale::getIntTimeFormat( ) |
194 | { | 244 | { |
195 | return mIntTimeFormat; | 245 | return mIntTimeFormat; |
196 | 246 | ||
197 | } | 247 | } |
198 | void KLocale::setIntTimeFormat( KLocale::IntDateFormat i ) | 248 | void KLocale::setIntTimeFormat( KLocale::IntDateFormat i ) |
199 | { | 249 | { |
200 | mIntTimeFormat = i; | 250 | mIntTimeFormat = i; |
201 | } | 251 | } |
202 | 252 | ||
203 | void KLocale::setLanguage( int i ) | 253 | void KLocale::setLanguage( int i ) |
204 | { | 254 | { |
205 | mLanguage = i; | 255 | mLanguage = i; |
206 | } | 256 | } |
207 | int KLocale::language( ) | 257 | int KLocale::language( ) |
208 | { | 258 | { |
209 | return mLanguage; | 259 | return mLanguage; |
210 | } | 260 | } |
211 | QString KLocale::translate( const char *index ) const | 261 | QString KLocale::translate( const char *index ) const |
212 | { | 262 | { |
213 | return i18n( index ); | 263 | return i18n( index ); |
214 | } | 264 | } |
215 | 265 | ||
216 | QString KLocale::translate( const char *, const char *fallback) const | 266 | QString KLocale::translate( const char *, const char *fallback) const |
217 | { | 267 | { |
218 | return i18n( fallback ); | 268 | return i18n( fallback ); |
219 | } | 269 | } |
220 | 270 | ||
221 | QString KLocale::formatTime(const QTime &pTime, bool includeSecs, IntDateFormat intIntDateFormat) const | 271 | QString KLocale::formatTime(const QTime &pTime, bool includeSecs, IntDateFormat intIntDateFormat) const |
222 | { | 272 | { |
223 | const QString rst = timeFormat(intIntDateFormat); | 273 | const QString rst = timeFormat(intIntDateFormat); |
224 | 274 | ||
225 | // only "pm/am" here can grow, the rest shrinks, but | 275 | // only "pm/am" here can grow, the rest shrinks, but |
226 | // I'm rather safe than sorry | 276 | // I'm rather safe than sorry |
227 | QChar *buffer = new QChar[rst.length() * 3 / 2 + 30]; | 277 | QChar *buffer = new QChar[rst.length() * 3 / 2 + 30]; |
228 | 278 | ||
229 | uint index = 0; | 279 | uint index = 0; |
230 | bool escape = false; | 280 | bool escape = false; |
231 | int number = 0; | 281 | int number = 0; |
232 | 282 | ||
233 | for ( uint format_index = 0; format_index < rst.length(); format_index++ ) | 283 | for ( uint format_index = 0; format_index < rst.length(); format_index++ ) |
234 | { | 284 | { |
235 | if ( !escape ) | 285 | if ( !escape ) |
236 | { | 286 | { |
237 | if ( rst.at( format_index ).unicode() == '%' ) | 287 | if ( rst.at( format_index ).unicode() == '%' ) |
238 | escape = true; | 288 | escape = true; |
239 | else | 289 | else |
240 | buffer[index++] = rst.at( format_index ); | 290 | buffer[index++] = rst.at( format_index ); |
241 | } | 291 | } |
242 | else | 292 | else |
243 | { | 293 | { |
244 | switch ( rst.at( format_index ).unicode() ) | 294 | switch ( rst.at( format_index ).unicode() ) |
245 | { | 295 | { |
246 | case '%': | 296 | case '%': |
247 | buffer[index++] = '%'; | 297 | buffer[index++] = '%'; |
248 | break; | 298 | break; |
249 | case 'H': | 299 | case 'H': |
250 | put_it_in( buffer, index, pTime.hour() ); | 300 | put_it_in( buffer, index, pTime.hour() ); |
251 | break; | 301 | break; |
252 | case 'I': | 302 | case 'I': |
253 | put_it_in( buffer, index, ( pTime.hour() + 11) % 12 + 1 ); | 303 | put_it_in( buffer, index, ( pTime.hour() + 11) % 12 + 1 ); |
254 | break; | 304 | break; |
255 | case 'M': | 305 | case 'M': |
256 | put_it_in( buffer, index, pTime.minute() ); | 306 | put_it_in( buffer, index, pTime.minute() ); |
257 | break; | 307 | break; |
258 | case 'S': | 308 | case 'S': |
259 | if (includeSecs) | 309 | if (includeSecs) |
260 | put_it_in( buffer, index, pTime.second() ); | 310 | put_it_in( buffer, index, pTime.second() ); |
261 | else | 311 | else |
262 | { | 312 | { |
263 | // we remove the seperator sign before the seconds and | 313 | // we remove the seperator sign before the seconds and |
264 | // assume that works everywhere | 314 | // assume that works everywhere |
265 | --index; | 315 | --index; |
266 | break; | 316 | break; |
267 | } | 317 | } |
268 | break; | 318 | break; |
269 | case 'k': | 319 | case 'k': |
270 | number = pTime.hour(); | 320 | number = pTime.hour(); |
271 | case 'l': | 321 | case 'l': |
272 | // to share the code | 322 | // to share the code |
273 | if ( rst.at( format_index ).unicode() == 'l' ) | 323 | if ( rst.at( format_index ).unicode() == 'l' ) |
274 | number = (pTime.hour() + 11) % 12 + 1; | 324 | number = (pTime.hour() + 11) % 12 + 1; |
275 | if ( number / 10 ) | 325 | if ( number / 10 ) |
276 | buffer[index++] = number / 10 + '0'; | 326 | buffer[index++] = number / 10 + '0'; |
277 | buffer[index++] = number % 10 + '0'; | 327 | buffer[index++] = number % 10 + '0'; |
278 | break; | 328 | break; |
279 | case 'p': | 329 | case 'p': |
280 | { | 330 | { |
281 | QString s; | 331 | QString s; |
282 | if ( pTime.hour() >= 12 ) | 332 | if ( pTime.hour() >= 12 ) |
283 | put_it_in( buffer, index, i18n("pm") ); | 333 | put_it_in( buffer, index, i18n("pm") ); |
284 | else | 334 | else |
285 | put_it_in( buffer, index, i18n("am") ); | 335 | put_it_in( buffer, index, i18n("am") ); |
286 | break; | 336 | break; |
287 | } | 337 | } |
288 | default: | 338 | default: |
289 | buffer[index++] = rst.at( format_index ); | 339 | buffer[index++] = rst.at( format_index ); |
290 | break; | 340 | break; |
291 | } | 341 | } |
292 | escape = false; | 342 | escape = false; |
293 | } | 343 | } |
294 | } | 344 | } |
295 | QString ret( buffer, index ); | 345 | QString ret( buffer, index ); |
296 | delete [] buffer; | 346 | delete [] buffer; |
297 | return ret; | 347 | return ret; |
298 | } | 348 | } |
299 | 349 | ||
300 | QString KLocale::formatDate(const QDate &pDate, bool shortFormat, IntDateFormat intIntDateFormat) const | 350 | QString KLocale::formatDate(const QDate &pDate, bool shortFormat, IntDateFormat intIntDateFormat) const |
301 | { | 351 | { |
302 | const QString rst = shortFormat?dateFormatShort(intIntDateFormat):dateFormat(intIntDateFormat); | 352 | const QString rst = shortFormat?dateFormatShort(intIntDateFormat):dateFormat(intIntDateFormat); |
303 | 353 | ||
304 | // I'm rather safe than sorry | 354 | // I'm rather safe than sorry |
305 | QChar *buffer = new QChar[rst.length() * 3 / 2 + 50]; | 355 | QChar *buffer = new QChar[rst.length() * 3 / 2 + 50]; |
306 | 356 | ||
307 | unsigned int index = 0; | 357 | unsigned int index = 0; |
308 | bool escape = false; | 358 | bool escape = false; |
309 | int number = 0; | 359 | int number = 0; |
310 | 360 | ||
311 | for ( uint format_index = 0; format_index < rst.length(); ++format_index ) | 361 | for ( uint format_index = 0; format_index < rst.length(); ++format_index ) |
312 | { | 362 | { |
313 | if ( !escape ) | 363 | if ( !escape ) |
314 | { | 364 | { |
315 | if ( rst.at( format_index ).unicode() == '%' ) | 365 | if ( rst.at( format_index ).unicode() == '%' ) |
316 | escape = true; | 366 | escape = true; |
317 | else | 367 | else |
318 | buffer[index++] = rst.at( format_index ); | 368 | buffer[index++] = rst.at( format_index ); |
319 | } | 369 | } |
320 | else | 370 | else |
321 | { | 371 | { |
322 | switch ( rst.at( format_index ).unicode() ) | 372 | switch ( rst.at( format_index ).unicode() ) |
323 | { | 373 | { |
324 | case '%': | 374 | case '%': |
325 | buffer[index++] = '%'; | 375 | buffer[index++] = '%'; |