summaryrefslogtreecommitdiffabout
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--bin/kdepim/kopiemail/germantranslation.txt243
-rw-r--r--bin/kdepim/kopiemail/usertranslation.txt243
-rw-r--r--kmicromail/libmailwrapper/mhwrapper.cpp13
-rw-r--r--kmicromail/libmailwrapper/sendmailprogress.cpp5
-rw-r--r--kmicromail/main.cpp1
-rw-r--r--kmicromail/opiemail.cpp1
-rw-r--r--microkde/kdecore/klocale.cpp62
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
13using namespace Opie::Core; 14using namespace Opie::Core;
14MHwrapper::MHwrapper(const QString & mbox_dir,const QString&mbox_name) 15MHwrapper::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
30void MHwrapper::init_storage() 31void 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
52void MHwrapper::clean_storage() 53void 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
61MHwrapper::~MHwrapper() 62MHwrapper::~MHwrapper()
62{ 63{
63 clean_storage(); 64 clean_storage();
64} 65}
65 66
66void MHwrapper::listMessages(const QString & mailbox, QValueList<Opie::Core::OSmartPointer<RecMail> > &target, int maxSizeInKb ) 67void 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
82QValueList<Opie::Core::OSmartPointer<Folder> >* MHwrapper::listFolders() 83QValueList<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
107void MHwrapper::deleteMail(const RecMailP&mail) 108void 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
124void MHwrapper::answeredMail(const RecMailP&) 125void MHwrapper::answeredMail(const RecMailP&)
125{ 126{
126} 127}
127 128
128RecBodyP MHwrapper::fetchBody( const RecMailP &mail ) 129RecBodyP 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
154void MHwrapper::mbox_progress( size_t current, size_t maximum ) 155void 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
160QString MHwrapper::buildPath(const QString&p) 161QString 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
175int MHwrapper::createMbox(const QString&folder,const FolderP&pfolder,const QString&,bool ) 176int 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
199void MHwrapper::storeMessage(const char*msg,size_t length, const QString&Folder) 200void 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
218encodedString* MHwrapper::fetchRawBody(const RecMailP&mail) 219encodedString* 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
249void MHwrapper::deleteMails(const QString & mailbox,const QValueList<RecMailP> &target) 250void 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
267int MHwrapper::deleteAllMail(const FolderP&tfolder) 268int 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
302int MHwrapper::deleteMbox(const FolderP&tfolder) 303int 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
339void MHwrapper::processEnded(OProcess *p) 340void MHwrapper::processEnded(OProcess *p)
340{ 341{
341 if (p) delete p; 342 if (p) delete p;
342} 343}
343 344
344void MHwrapper::oprocessStderr(OProcess*, char *buffer, int ) 345void 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
351void MHwrapper::statusFolder(folderStat&target_stat,const QString & mailbox) 352void 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
368MAILLIB::ATYPE MHwrapper::getType()const 369MAILLIB::ATYPE MHwrapper::getType()const
369{ 370{
370 return MAILLIB::A_MH; 371 return MAILLIB::A_MH;
371} 372}
372 373
373const QString&MHwrapper::getName()const 374const QString&MHwrapper::getName()const
374{ 375{
375 return MHName; 376 return MHName;
376} 377}
377void MHwrapper::mvcpMail(const RecMailP&mail,const QString&targetFolder,AbstractMail*targetWrapper,bool moveit) 378void 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
405void MHwrapper::mvcpAllMails(const FolderP&fromFolder, 406void 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
5progressMailSend::progressMailSend(QWidget*parent, const char * name) 6progressMailSend::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
10progressMailSend::~progressMailSend() 11progressMailSend::~progressMailSend()
11{ 12{
12} 13}
13 14
14void progressMailSend::setMaxMails(unsigned int aMaxMails) 15void 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
21void progressMailSend::setCurrentMails(unsigned int aCurrent) 22void 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
28void progressMailSend::setSingleMail(unsigned int aCurrent,unsigned int aMax) 29void 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
35void progressMailSend::setSingle() 36void 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
43void progressMailSend::setMails() 44void 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>
23void dumpMissing(); 23void dumpMissing();
24//using namespace Opie::Core; 24//using namespace Opie::Core;
25int main( int argc, char **argv ) { 25int 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
33OpieMail::OpieMail( QWidget *parent, const char *name ) 33OpieMail::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
43OpieMail::~OpieMail() 42OpieMail::~OpieMail()
44{ 43{
45 if (settings) delete settings; 44 if (settings) delete settings;
46} 45}
47 46
48void OpieMail::appMessage(const QCString &msg, const QByteArray &data) 47void OpieMail::appMessage(const QCString &msg, const QByteArray &data)
49{ 48{
50 49
51} 50}
52#include <stdlib.h> 51#include <stdlib.h>
53void OpieMail::message(const QCString &msg, const QByteArray &data) 52void 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}
98void OpieMail::slotExtAppHandler() 97void OpieMail::slotExtAppHandler()
99{ 98{
100 ExternalAppHandler::instance()->appMessage ( mPendingMessage, mPendingData ); 99 ExternalAppHandler::instance()->appMessage ( mPendingMessage, mPendingData );
101} 100}
102void OpieMail::slotwriteMail2(const QString& namemail ) 101void 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}
128void OpieMail::slotwriteMail(const QString&name,const QString&email) 127void 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
149void OpieMail::slotComposeMail() 148void 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
162void OpieMail::slotSendQueued() 161void 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
209void OpieMail::slotSearchMails() 208void OpieMail::slotSearchMails()
210{ 209{
211 qDebug("OpieMail::slotSearchMails():not implemented "); 210 qDebug("OpieMail::slotSearchMails():not implemented ");
212} 211}
213 212
214void OpieMail::slotEditSettings() 213void 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
226void OpieMail::slotEditAccounts() 225void 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
238void OpieMail::displayMail() 237void 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}
259void OpieMail::slotGetAllMail() 258void 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}
267void OpieMail::slotGetMail() 266void 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}
273void OpieMail::slotDeleteMail() 272void 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}
283void OpieMail::slotDeleteAllMail() 282void 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>
10QStringList missingTrans; 10
11//#define COLLECT_TRANSLATION
12
11 13
12QDict<QString> *mLocaleDict = 0; 14QDict<QString> *mLocaleDict = 0;
13void setLocaleDict( QDict<QString> * dict ) 15void setLocaleDict( QDict<QString> * dict )
14{ 16{
15 mLocaleDict = dict; 17 mLocaleDict = dict;
16 18
17} 19}
20
21#ifdef COLLECT_TRANSLATION
22
23QStringList missingTrans;
24QStringList existingTrans1;
25QStringList existingTrans2;
26
18void addMissing(const char *text) 27void 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}
35void 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
30void dumpMissing() 51void 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}
51QString i18n(const char *text) 91QString 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
75QString i18n(const char *,const char *text) 125QString i18n(const char *,const char *text)
76{ 126{
77 return i18n( text ); 127 return i18n( text );
78} 128}
79 129
80QString i18n(const char *text1, const char *textn, int num) 130QString 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
91inline void put_it_in( QChar *buffer, uint& index, const QString &s ) 141inline 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
97inline void put_it_in( QChar *buffer, uint& index, int number ) 147inline 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
103static int readInt(const QString &str, uint &pos) 153static 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
116KLocale::KLocale() : mCalendarSystem( 0 ) 166KLocale::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
165void KLocale::setDateFormat( QString s ) 215void KLocale::setDateFormat( QString s )
166{ 216{
167 mDateFormat = s; 217 mDateFormat = s;
168} 218}
169 219
170void KLocale::setDateFormatShort( QString s ) 220void KLocale::setDateFormatShort( QString s )
171{ 221{
172 mDateFormatShort = s; 222 mDateFormatShort = s;
173} 223}
174 224
175void KLocale::setHore24Format ( bool b ) 225void KLocale::setHore24Format ( bool b )
176{ 226{
177 mHourF24Format = b; 227 mHourF24Format = b;
178} 228}
179void KLocale::setWeekStartMonday( bool b ) 229void KLocale::setWeekStartMonday( bool b )
180{ 230{
181 mWeekStartsMonday = b; 231 mWeekStartsMonday = b;
182} 232}
183 233
184KLocale::IntDateFormat KLocale::getIntDateFormat( ) 234KLocale::IntDateFormat KLocale::getIntDateFormat( )
185{ 235{
186 return mIntDateFormat; 236 return mIntDateFormat;
187 237
188} 238}
189void KLocale::setIntDateFormat( KLocale::IntDateFormat i ) 239void KLocale::setIntDateFormat( KLocale::IntDateFormat i )
190{ 240{
191 mIntDateFormat = i; 241 mIntDateFormat = i;
192} 242}
193KLocale::IntDateFormat KLocale::getIntTimeFormat( ) 243KLocale::IntDateFormat KLocale::getIntTimeFormat( )
194{ 244{
195 return mIntTimeFormat; 245 return mIntTimeFormat;
196 246
197} 247}
198void KLocale::setIntTimeFormat( KLocale::IntDateFormat i ) 248void KLocale::setIntTimeFormat( KLocale::IntDateFormat i )
199{ 249{
200 mIntTimeFormat = i; 250 mIntTimeFormat = i;
201} 251}
202 252
203void KLocale::setLanguage( int i ) 253void KLocale::setLanguage( int i )
204{ 254{
205 mLanguage = i; 255 mLanguage = i;
206} 256}
207int KLocale::language( ) 257int KLocale::language( )
208{ 258{
209 return mLanguage; 259 return mLanguage;
210} 260}
211QString KLocale::translate( const char *index ) const 261QString KLocale::translate( const char *index ) const
212{ 262{
213 return i18n( index ); 263 return i18n( index );
214} 264}
215 265
216QString KLocale::translate( const char *, const char *fallback) const 266QString KLocale::translate( const char *, const char *fallback) const
217{ 267{
218 return i18n( fallback ); 268 return i18n( fallback );
219} 269}
220 270
221QString KLocale::formatTime(const QTime &pTime, bool includeSecs, IntDateFormat intIntDateFormat) const 271QString 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
300QString KLocale::formatDate(const QDate &pDate, bool shortFormat, IntDateFormat intIntDateFormat) const 350QString 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++] = '%';