summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--ChangeLog1
-rw-r--r--noncore/settings/backup/backuprestore.cpp5
2 files changed, 6 insertions, 0 deletions
diff --git a/ChangeLog b/ChangeLog
index 8ac976d..218aacf 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,223 +1,224 @@
1 2005-??-??Opie 1.2.0 1 2005-??-??Opie 1.2.0
2 2
3 New Features 3 New Features
4 ------------ 4 ------------
5 * Launcher: Support a static background pixmap (mickeyl) 5 * Launcher: Support a static background pixmap (mickeyl)
6 * LauncherSettings: Choose whether to have a static background pixmap (mickeyl) 6 * LauncherSettings: Choose whether to have a static background pixmap (mickeyl)
7 7
8 Fixed Bugs 8 Fixed Bugs
9 ---------- 9 ----------
10 * #1236 - VCards contained empty home and work address entries causing Palms to crash (eilers) 10 * #1236 - VCards contained empty home and work address entries causing Palms to crash (eilers)
11 * #1474 - Implement GUI for Scrollbars on the Left in Appearance (zecke) 11 * #1474 - Implement GUI for Scrollbars on the Left in Appearance (zecke)
12 * #1482 - Fix double '/' in paths (zecke) 12 * #1482 - Fix double '/' in paths (zecke)
13 * #1536 - Autosave of custom locations in opie backup (ar) 13 * #1536 - Autosave of custom locations in opie backup (ar)
14 * #1539 - Fixed displaying too long path in the delete dialog in opie-eye (zecke) 14 * #1539 - Fixed displaying too long path in the delete dialog in opie-eye (zecke)
15 * #1540 - Implemented deletion of DocLnks in opie-eye (zecke) 15 * #1540 - Implemented deletion of DocLnks in opie-eye (zecke)
16 * #1542 - Fix Todo crash when priority < 1 or > 5 (drw) 16 * #1542 - Fix Todo crash when priority < 1 or > 5 (drw)
17 * #1554 - Fixed Opie-Console name in .desktop file (mickeyl) 17 * #1554 - Fixed Opie-Console name in .desktop file (mickeyl)
18 * #1556 - Start to look for sound files in /opt/QtPalmtop/sounds (zecke) 18 * #1556 - Start to look for sound files in /opt/QtPalmtop/sounds (zecke)
19 * #1558 - Fixed opie-login breaking opie startup (mickeyl) 19 * #1558 - Fixed opie-login breaking opie startup (mickeyl)
20 * #1570 - Confirmation needed befor Restore a backup and overwrite local data (ar)
20 * n.a. - PackageManager - fixed where last package in status file was not shown as installed when it should be (drw) 21 * n.a. - PackageManager - fixed where last package in status file was not shown as installed when it should be (drw)
21 22
22 Internal 23 Internal
23 -------- 24 --------
24 * Work around bug in Qt/Embedded 2.3.10: qt_version() returns 231 (mickeyl) 25 * Work around bug in Qt/Embedded 2.3.10: qt_version() returns 231 (mickeyl)
25 * Killed the need for weak symbols in QtE (zecke) 26 * Killed the need for weak symbols in QtE (zecke)
26 27
27 2005-02-03Opie 1.1.9 28 2005-02-03Opie 1.1.9
28 29
29 New Features 30 New Features
30 ------------ 31 ------------
31 * Number of icon columns in Launcher is customizable through Launcher.conf (hrw,zecke,mickeyl) 32 * Number of icon columns in Launcher is customizable through Launcher.conf (hrw,zecke,mickeyl)
32 * Number of icon columns in Launcher is customizable through LauncherSettings (mickeyl) 33 * Number of icon columns in Launcher is customizable through LauncherSettings (mickeyl)
33 * Usability enhancements in OpieIRC (skyhusker) 34 * Usability enhancements in OpieIRC (skyhusker)
34 35
35 Fixed Bugs 36 Fixed Bugs
36 ---------- 37 ----------
37 * #1501 - Fixed bug in todo sql backend (eilers) 38 * #1501 - Fixed bug in todo sql backend (eilers)
38 * #1505 - Added more Swap sizes in memoryapplet (mickeyl) 39 * #1505 - Added more Swap sizes in memoryapplet (mickeyl)
39 * #1525 - Hopefully fixed double alarms and not removing alarms set with the Clock application (zecke) 40 * #1525 - Hopefully fixed double alarms and not removing alarms set with the Clock application (zecke)
40 * #1533 - Security Owner Dialog (shown in case of unsuccessfull authentiacation) wasn't able to display information in non latin1 encoding (zecke) 41 * #1533 - Security Owner Dialog (shown in case of unsuccessfull authentiacation) wasn't able to display information in non latin1 encoding (zecke)
41 * n.a. - Removed hard coded font sizes in a couple of inputmethods (mickeyl) 42 * n.a. - Removed hard coded font sizes in a couple of inputmethods (mickeyl)
42 * n.a. - Removed MediumDlg appearing prior to FirstUsage wizard (i.e. calibration) (mickeyl) 43 * n.a. - Removed MediumDlg appearing prior to FirstUsage wizard (i.e. calibration) (mickeyl)
43 * n.a. - Fixed numerous buglets in OpieIRC (skyhusker) 44 * n.a. - Fixed numerous buglets in OpieIRC (skyhusker)
44 45
45 Internal 46 Internal
46 -------- 47 --------
47 * Added the Qtopia 1.7 SDK macros for quick-apps to easa compilation of 3rd party apps against our headers (mickeyl) 48 * Added the Qtopia 1.7 SDK macros for quick-apps to easa compilation of 3rd party apps against our headers (mickeyl)
48 * You can now use the Opie build system in combination with a OpenEmbedded staging area which makes a nice cross development environment (mickeyl) 49 * You can now use the Opie build system in combination with a OpenEmbedded staging area which makes a nice cross development environment (mickeyl)
49 * Made Opie compilable with Qt/Embedded 2.3.10 (ar) 50 * Made Opie compilable with Qt/Embedded 2.3.10 (ar)
50 * Changed Launcher to get default orientation from ODevice w/ QWS_DISPLAY overriding (mickeyl) 51 * Changed Launcher to get default orientation from ODevice w/ QWS_DISPLAY overriding (mickeyl)
51 * Build tree cleanups (mickeyl) 52 * Build tree cleanups (mickeyl)
52 53
53 2004-11-26Opie 1.1.8 54 2004-11-26Opie 1.1.8
54 55
55 New Features 56 New Features
56 ------------ 57 ------------
57 * PackageManager supports installation of local ipkg files (drw) 58 * PackageManager supports installation of local ipkg files (drw)
58 * PackageManager supports linking of applications to root (drw) 59 * PackageManager supports linking of applications to root (drw)
59 * PackageManager supports src/gz feeds (drw,wimpie) 60 * PackageManager supports src/gz feeds (drw,wimpie)
60 * Added a syslog information tab to sysinfo (mickeyl) 61 * Added a syslog information tab to sysinfo (mickeyl)
61 * Added new, more consistent, PIM icons + a GIMP teplate (ar) 62 * Added new, more consistent, PIM icons + a GIMP teplate (ar)
62 63
63 Fixed Bugs 64 Fixed Bugs
64 ---------- 65 ----------
65 * #1017 - Tetrix doesn't display correctly for high resolution screens (drw) 66 * #1017 - Tetrix doesn't display correctly for high resolution screens (drw)
66 * #1269 - VCards were imported into personal area if it was activated (eilers) 67 * #1269 - VCards were imported into personal area if it was activated (eilers)
67 * #1464 - Packagemanager dont set active filter after install a package (drw) 68 * #1464 - Packagemanager dont set active filter after install a package (drw)
68 * #1479 - Improved VCard-Parser to import VCards created by Evolution 2 and Apple Addressbook (eilers) 69 * #1479 - Improved VCard-Parser to import VCards created by Evolution 2 and Apple Addressbook (eilers)
69 * #1493 - Fixed one column layout bug of the launcher (hrw) 70 * #1493 - Fixed one column layout bug of the launcher (hrw)
70 * n.a. - PackageManager - (Minor UI tweak) in filter dialog, when option is enabled, set focus to widget that corresponds to that option (drw) 71 * n.a. - PackageManager - (Minor UI tweak) in filter dialog, when option is enabled, set focus to widget that corresponds to that option (drw)
71 * n.a. - PackageManager - (Minor UI tweak) fix double entry in source feed configuration when adding a new feed (drw) 72 * n.a. - PackageManager - (Minor UI tweak) fix double entry in source feed configuration when adding a new feed (drw)
72 * n.a. - Battery Applet - fix sizing of battery info popup (drw,mickeyl) 73 * n.a. - Battery Applet - fix sizing of battery info popup (drw,mickeyl)
73 74
74 Internal 75 Internal
75 -------- 76 --------
76 * Moved libopie1 to unsupported (mickeyl) 77 * Moved libopie1 to unsupported (mickeyl)
77 * Implemented generic queryByExample() with incremental searching. A lot of internal changes of the Pim2-library (eilers) 78 * Implemented generic queryByExample() with incremental searching. A lot of internal changes of the Pim2-library (eilers)
78 * Added fast and full featured and incremental sorted() for SQL addressbook backend (eilers) 79 * Added fast and full featured and incremental sorted() for SQL addressbook backend (eilers)
79 80
80 2004-11-14Opie 1.1.7 81 2004-11-14Opie 1.1.7
81 82
82 New Features 83 New Features
83 ------------ 84 ------------
84 * libOpieDB now uses SQLite V3 instead V2. Remember to upgrade your database files! (eilers) 85 * libOpieDB now uses SQLite V3 instead V2. Remember to upgrade your database files! (eilers)
85 * Backup now uses the busy indicator when backing up and restore (ar) 86 * Backup now uses the busy indicator when backing up and restore (ar)
86 * OpiePlayer2 gained adding of Directories to the playlist (zecke) 87 * OpiePlayer2 gained adding of Directories to the playlist (zecke)
87 * OpiePlayer2 better error handling (zecke) 88 * OpiePlayer2 better error handling (zecke)
88 * OpiePlayer2 progress indication while streaming (zecke) 89 * OpiePlayer2 progress indication while streaming (zecke)
89 * OpiePlayer2 ported to use libxine 1.0.0-rc6a (brad,zecke) 90 * OpiePlayer2 ported to use libxine 1.0.0-rc6a (brad,zecke)
90 * Ported brightnessapplet from Qtopia 1.7 (mickeyl) 91 * Ported brightnessapplet from Qtopia 1.7 (mickeyl)
91 * Opie-Eye got a Digital Camera File Backend (alwin,zecke) 92 * Opie-Eye got a Digital Camera File Backend (alwin,zecke)
92 * Support for Tuxpad1 of Tradesquare.NL (mickeyl,zecke) 93 * Support for Tuxpad1 of Tradesquare.NL (mickeyl,zecke)
93 * Opie-Console use Custom Font and Size in a Profile (harlekin) 94 * Opie-Console use Custom Font and Size in a Profile (harlekin)
94 * Opie-Console transparently log the Output and Input to a file (harlekin) 95 * Opie-Console transparently log the Output and Input to a file (harlekin)
95 * Added new O-menu icon to lock the PDA immediately: opie-lockapplet (clem) 96 * Added new O-menu icon to lock the PDA immediately: opie-lockapplet (clem)
96 * Opie-Security now hides the plugin-based authentication tabs if no auth. plugin package is installed (clem) 97 * Opie-Security now hides the plugin-based authentication tabs if no auth. plugin package is installed (clem)
97 * Opie-Security gained a 'test authentication' button (clem) 98 * Opie-Security gained a 'test authentication' button (clem)
98 * Opie-Eye got a more unique layout (menubar), a slideshow, user can setup some defaults 99 * Opie-Eye got a more unique layout (menubar), a slideshow, user can setup some defaults
99 * Opie-Mail improve the handling of POP mail boxes (alwin) 100 * Opie-Mail improve the handling of POP mail boxes (alwin)
100 * Both Opie-Eye and Opie-Mail were greatly improved due the hard work of Rajko Albrecht(alwin) 101 * Both Opie-Eye and Opie-Mail were greatly improved due the hard work of Rajko Albrecht(alwin)
101 * Opie IRC - backports of the 'NeIRC fork' (zecke) 102 * Opie IRC - backports of the 'NeIRC fork' (zecke)
102 103
103 Fixed Bugs 104 Fixed Bugs
104 ---------- 105 ----------
105 * #501 - Pickboard is able to show 'Umlaute' (TT,zecke) 106 * #501 - Pickboard is able to show 'Umlaute' (TT,zecke)
106 * #608 - Make Opie usable for left handed users (zecke) 107 * #608 - Make Opie usable for left handed users (zecke)
107 * #957 - Import of VCards/VTodos/VEvents with BASE64 encoding (ljp,zecke) 108 * #957 - Import of VCards/VTodos/VEvents with BASE64 encoding (ljp,zecke)
108 * #1245 - Opie-Go 'paused' (zecke) 109 * #1245 - Opie-Go 'paused' (zecke)
109 * #1358 - DocTab didn't show any MimeTypes (was fixed earlier) (zecke) 110 * #1358 - DocTab didn't show any MimeTypes (was fixed earlier) (zecke)
110 * #1380 - QDateBookAccess::remove() doesn't remove entries (eilers, zecke) 111 * #1380 - QDateBookAccess::remove() doesn't remove entries (eilers, zecke)
111 * #1395 - Build VNC Backend with gcc3.4 112 * #1395 - Build VNC Backend with gcc3.4
112 * #1440 - The icon of opie-mobilemsg is missing (CoreDump) 113 * #1440 - The icon of opie-mobilemsg is missing (CoreDump)
113 * #1426 - Add missing opie-bartender Icon (CoreDump) 114 * #1426 - Add missing opie-bartender Icon (CoreDump)
114 * #1445 - Opie-Sheet Has No Icon (CoreDump) 115 * #1445 - Opie-Sheet Has No Icon (CoreDump)
115 * #1448 - Brightness Applet added (mickeyl) 116 * #1448 - Brightness Applet added (mickeyl)
116 * #1450 - ZSame didn't clear the bonus item after winning a game (zecke) 117 * #1450 - ZSame didn't clear the bonus item after winning a game (zecke)
117 * #1482 - Fix OFileSelector to be able to sort by size (zecke) 118 * #1482 - Fix OFileSelector to be able to sort by size (zecke)
118 * n.a. - Opie-mail: fixed some crasher, some layout-problems 119 * n.a. - Opie-mail: fixed some crasher, some layout-problems
119 * n.a. - Converted applications to not hardcode /opt/QtPalmtop but to use QPEApplication::qpeDir (zecke) 120 * n.a. - Converted applications to not hardcode /opt/QtPalmtop but to use QPEApplication::qpeDir (zecke)
120 * n.a. - Converted usage of qpeDir() not to include a '/' as first charachter of the string (zecke) 121 * n.a. - Converted usage of qpeDir() not to include a '/' as first charachter of the string (zecke)
121 * n.a. - Build system: Enable distcc and ccache when crosscompiling too, and use them everywhere we can (clem) 122 * n.a. - Build system: Enable distcc and ccache when crosscompiling too, and use them everywhere we can (clem)
122 * n.a. - Build system: Fix deps in several config.in (and fix scripts/deps.pl too) to stop breaking builds, especially with make -j highNumber (clem) 123 * n.a. - Build system: Fix deps in several config.in (and fix scripts/deps.pl too) to stop breaking builds, especially with make -j highNumber (clem)
123 * n.a. - Removed hardcoded icon size in a couple of applets (mickeyl) 124 * n.a. - Removed hardcoded icon size in a couple of applets (mickeyl)
124 125
125 Internal 126 Internal
126 -------- 127 --------
127 * Opie-Qashmoney has been moved to unsupported (mickeyl) 128 * Opie-Qashmoney has been moved to unsupported (mickeyl)
128 * Opie-Ubrowser has been moved to unsupported (mickeyl) 129 * Opie-Ubrowser has been moved to unsupported (mickeyl)
129 130
130 2004-09-17Opie 1.1.6 131 2004-09-17Opie 1.1.6
131 132
132 New Features 133 New Features
133 ------------ 134 ------------
134 * Fifteen gained configurable number of items (zecke) 135 * Fifteen gained configurable number of items (zecke)
135 * Fifteen can have custom background images (zecke) 136 * Fifteen can have custom background images (zecke)
136 * Added daemonizing capabilities to QWS Server [via Qt/Embedded] (mickeyl) 137 * Added daemonizing capabilities to QWS Server [via Qt/Embedded] (mickeyl)
137 * Integrated the new security framework into libopie2 (zecke,clem) 138 * Integrated the new security framework into libopie2 (zecke,clem)
138 * Converted the launcher to use the new security framework (zecke) 139 * Converted the launcher to use the new security framework (zecke)
139 * Backup can now handle custom locations for backup and restore (ar) 140 * Backup can now handle custom locations for backup and restore (ar)
140 * Implemented right-on-hold feedback (wimpie,zecke) 141 * Implemented right-on-hold feedback (wimpie,zecke)
141 * Lots of new features in opie-reader (tim,pohly) 142 * Lots of new features in opie-reader (tim,pohly)
142 * Build system cleanups (schurig) 143 * Build system cleanups (schurig)
143 144
144 Fixed Bugs 145 Fixed Bugs
145 -------- 146 --------
146 * #1005 - Fixed backup to CompactFlash (ar) 147 * #1005 - Fixed backup to CompactFlash (ar)
147 * #1167 - Fixed Opie write crashing on more text than one page (ar) 148 * #1167 - Fixed Opie write crashing on more text than one page (ar)
148 * #1225 - Fixed repeated light flashing on Zaurus with keyz (mickeyl) 149 * #1225 - Fixed repeated light flashing on Zaurus with keyz (mickeyl)
149 * #1359 - Fixed bookmarks in Gutenbrowser (ljp) 150 * #1359 - Fixed bookmarks in Gutenbrowser (ljp)
150 * #1361 - Fixed auto upercase in Opie-Addressbook (eilers) 151 * #1361 - Fixed auto upercase in Opie-Addressbook (eilers)
151 * #1370 - Pimconverter now reacts on cancel key (eilers) 152 * #1370 - Pimconverter now reacts on cancel key (eilers)
152 * #1376 - Bring back the capslock/numlock display (zecke) 153 * #1376 - Bring back the capslock/numlock display (zecke)
153 * #1383 - Language settings now warns about losing open apps (Markus Litz) 154 * #1383 - Language settings now warns about losing open apps (Markus Litz)
154 * #1393 - Fixed line wrap issues in opie-console for the default profile (mickeyl) 155 * #1393 - Fixed line wrap issues in opie-console for the default profile (mickeyl)
155 * #1394 - Fixed oversized headline in opie-login (coredump) 156 * #1394 - Fixed oversized headline in opie-login (coredump)
156 * #1396 - Opie-console captures the escape key and vim is working (zecke) 157 * #1396 - Opie-console captures the escape key and vim is working (zecke)
157 * #1401 - Scrollbar is now only visible if necessary in DocTab (mickeyl) 158 * #1401 - Scrollbar is now only visible if necessary in DocTab (mickeyl)
158 159
159 2004-07-06Opie 1.1.4 160 2004-07-06Opie 1.1.4
160 161
161 New Features 162 New Features
162 ------------ 163 ------------
163 * Added four themes courtesy Robert Griebl (http://www.softforge.de/zstyle) 164 * Added four themes courtesy Robert Griebl (http://www.softforge.de/zstyle)
164 * Added Conversion tool for pim-data (eilers) 165 * Added Conversion tool for pim-data (eilers)
165 * Introduced new OPimAccessFactory and OBackendFactory which simplyfies database access (eilers) 166 * Introduced new OPimAccessFactory and OBackendFactory which simplyfies database access (eilers)
166 * Modified the PIM API for providing generic use of OPimRecords (eilers) 167 * Modified the PIM API for providing generic use of OPimRecords (eilers)
167 * Clicking on the application symbol now iterates over the application's top level widgets if already raised (zecke) 168 * Clicking on the application symbol now iterates over the application's top level widgets if already raised (zecke)
168 169
169 Fixed Bugs 170 Fixed Bugs
170 -------- 171 --------
171 * #1068 - Country Drop Down Box Off Screen 172 * #1068 - Country Drop Down Box Off Screen
172 * #1291 - Opie tinykate does not open .desktop files (ar) 173 * #1291 - Opie tinykate does not open .desktop files (ar)
173 * #1291 - Opie sheet not saving correctly (ar) 174 * #1291 - Opie sheet not saving correctly (ar)
174 * #1294 - Opie does not know about British Summer Time 175 * #1294 - Opie does not know about British Summer Time
175 * #1314 - Drawpad initialization (mickeyl) 176 * #1314 - Drawpad initialization (mickeyl)
176 * #1317 - Packagemanager crashes on hold-down or install (chicken) 177 * #1317 - Packagemanager crashes on hold-down or install (chicken)
177 * #1321 - Batteryapplet graphic glitch (harlekin) 178 * #1321 - Batteryapplet graphic glitch (harlekin)
178 * #1324 - ZSafe not starting up (mickeyl) 179 * #1324 - ZSafe not starting up (mickeyl)
179 * #1328 - Personal Home Address fields is trimmed to 1char (eilers) 180 * #1328 - Personal Home Address fields is trimmed to 1char (eilers)
180 * #1327 - Opie-mail ipk does not depend on libopiedb2 (chicken) 181 * #1327 - Opie-mail ipk does not depend on libopiedb2 (chicken)
181 * #1345 - Networksettingsplugin wlan plugin dependency on libpcap0 (mickeyl) 182 * #1345 - Networksettingsplugin wlan plugin dependency on libpcap0 (mickeyl)
182 * #1348 - Datebook dependency on libopiedb2 (chicken) 183 * #1348 - Datebook dependency on libopiedb2 (chicken)
183 * #1328 - Switched SQLDatabase and VCards char encoding from latin1 to unicode (eilers) 184 * #1328 - Switched SQLDatabase and VCards char encoding from latin1 to unicode (eilers)
184 185
185 2004-04-25Opie 1.1.3 186 2004-04-25Opie 1.1.3
186 187
187 * Introduced first implementation of SQL-Support using SQLite (eilers) 188 * Introduced first implementation of SQL-Support using SQLite (eilers)
188 * Added a new Gutenberg Project reader app - opie-gutenbrowser (ljp) 189 * Added a new Gutenberg Project reader app - opie-gutenbrowser (ljp)
189 * Added a real system graffiti character set (brad) 190 * Added a real system graffiti character set (brad)
190 * Added Generic Keyconfig Widget (zecke) 191 * Added Generic Keyconfig Widget (zecke)
191 * Improved Screenshotapplet and Drawpad integration. You can now open a screenshot in drawpad and take notes (zecke) 192 * Improved Screenshotapplet and Drawpad integration. You can now open a screenshot in drawpad and take notes (zecke)
192 * Added new Bible reader app - opie-dagger (drw) 193 * Added new Bible reader app - opie-dagger (drw)
193 * Added a new Image Viewer. Work is ongoing (zecke,alwin) 194 * Added a new Image Viewer. Work is ongoing (zecke,alwin)
194 * Added namespace usage in libopie2 and everywhere (zecke,alwin) 195 * Added namespace usage in libopie2 and everywhere (zecke,alwin)
195 * Enabled the possibility to pass command line arguments to applications (mickeyl) 196 * Enabled the possibility to pass command line arguments to applications (mickeyl)
196 * Added an about applet showing some credits and information about Opie (mickeyl) 197 * Added an about applet showing some credits and information about Opie (mickeyl)
197 * Added benchmarking functionality to sysinfo (mickeyl) 198 * Added benchmarking functionality to sysinfo (mickeyl)
198 * Added applet and configuration application for switching hardware keyboard layouts (alwin) 199 * Added applet and configuration application for switching hardware keyboard layouts (alwin)
199 * Ported applications from libopie1 to libopie2* (drw,ar,alwin) 200 * Ported applications from libopie1 to libopie2* (drw,ar,alwin)
200 * Imported fullscreen and font improvements from the Qkonsole fork to embeddedkonsole (waspe) 201 * Imported fullscreen and font improvements from the Qkonsole fork to embeddedkonsole (waspe)
201 * Clean-up of package information in control files (drw) 202 * Clean-up of package information in control files (drw)
202 * Repaired mediummount which was broken since integrating the quicklauncher (alwin) 203 * Repaired mediummount which was broken since integrating the quicklauncher (alwin)
203 * Improved big-screen support (zecke,ar) 204 * Improved big-screen support (zecke,ar)
204 * Improved multikeyboard support, added keyboard layout switching applet (mouse) 205 * Improved multikeyboard support, added keyboard layout switching applet (mouse)
205 * Added a new mail client based on libetpan (harlekin,alwin,jgf) 206 * Added a new mail client based on libetpan (harlekin,alwin,jgf)
206 * Added new package manager - opie-packagemanager (drw) 207 * Added new package manager - opie-packagemanager (drw)
207 * Improved light-n-power for C7x0 (mickeyl) 208 * Improved light-n-power for C7x0 (mickeyl)
208 * Added automatic rotation support for C7x0 (treke) 209 * Added automatic rotation support for C7x0 (treke)
209 * Split libopie1 up into a set of smaller - functionally grouped - libraries (mickeyl) 210 * Split libopie1 up into a set of smaller - functionally grouped - libraries (mickeyl)
210 * Added scanning the wireless network neighbourhood to networksettings (mickeyl) 211 * Added scanning the wireless network neighbourhood to networksettings (mickeyl)
211 212
212 2003-11-29Opie 1.0.3 213 2003-11-29Opie 1.0.3
213 214
214 * Released as Version 1.0.3 215 * Released as Version 1.0.3
215 * Improved i18n (various contributors) 216 * Improved i18n (various contributors)
216 * Reduced application startup time by integrating the TT quicklauncher (zecke,harlekin) 217 * Reduced application startup time by integrating the TT quicklauncher (zecke,harlekin)
217 * Made the Documents Tab optional (mickeyl) 218 * Made the Documents Tab optional (mickeyl)
218 * Integrated basic support for HP iPAQ 54xx and the Jornada 5xx (chicken) 219 * Integrated basic support for HP iPAQ 54xx and the Jornada 5xx (chicken)
219 220
220 2003-08-04Opie 1.0.0 221 2003-08-04Opie 1.0.0
221 222
222 * Released as Version 1.0.0 223 * Released as Version 1.0.0
223 * Including a PPP module for easy dial up (tille,harlekin,zecke) 224 * Including a PPP module for easy dial up (tille,harlekin,zecke)
diff --git a/noncore/settings/backup/backuprestore.cpp b/noncore/settings/backup/backuprestore.cpp
index 8928cda..180980a 100644
--- a/noncore/settings/backup/backuprestore.cpp
+++ b/noncore/settings/backup/backuprestore.cpp
@@ -334,434 +334,439 @@ void BackupAndRestore::backupRootFs()
334 QTextStream procmtd( &procmtdf ); 334 QTextStream procmtd( &procmtdf );
335 for ( int i = 0; i <= rootmtd; ++i ) procmtd.readLine(); // skip uninteresting things 335 for ( int i = 0; i <= rootmtd; ++i ) procmtd.readLine(); // skip uninteresting things
336 QString dev; 336 QString dev;
337 QString size; 337 QString size;
338 QString erasesize; 338 QString erasesize;
339 QString devname; 339 QString devname;
340 procmtd >> dev >> size >> erasesize >> devname; 340 procmtd >> dev >> size >> erasesize >> devname;
341 341
342 odebug << "device " << dev << " size = " << size << ", erase size = " << erasesize << ", name = " << devname << "\"" << oendl; 342 odebug << "device " << dev << " size = " << size << ", erase size = " << erasesize << ", name = " << devname << "\"" << oendl;
343 343
344 // compute pad 344 // compute pad
345 QString pad = "--pad"; 345 QString pad = "--pad";
346 switch ( ODevice::inst()->model() ) 346 switch ( ODevice::inst()->model() )
347 { 347 {
348 case Model_Zaurus_SL5000: pad = "--pad=14680064"; break; 348 case Model_Zaurus_SL5000: pad = "--pad=14680064"; break;
349 case Model_Zaurus_SL5500: pad = "--pad=14680064"; break; 349 case Model_Zaurus_SL5500: pad = "--pad=14680064"; break;
350 // FIXME: Add Beagle and SIMpad 350 // FIXME: Add Beagle and SIMpad
351 } 351 }
352 352
353 // compute eraseblock 353 // compute eraseblock
354 QString eraseblock = "--eraseblock=0x" + erasesize; 354 QString eraseblock = "--eraseblock=0x" + erasesize;
355 355
356 // compute output 356 // compute output
357 QString outputFile = "--output=" + backupLocations[storeToLocation->currentText()]; 357 QString outputFile = "--output=" + backupLocations[storeToLocation->currentText()];
358 QDateTime datetime = QDateTime::currentDateTime(); 358 QDateTime datetime = QDateTime::currentDateTime();
359 QString dateString = QString::number( datetime.date().year() ) + QString::number( datetime.date().month() ).rightJustify(2, '0') + 359 QString dateString = QString::number( datetime.date().year() ) + QString::number( datetime.date().month() ).rightJustify(2, '0') +
360 QString::number( datetime.date().day() ).rightJustify(2, '0'); 360 QString::number( datetime.date().day() ).rightJustify(2, '0');
361 outputFile += "/initrd.bin-" + dateString; 361 outputFile += "/initrd.bin-" + dateString;
362 362
363 // call mkfs.jffs2 to create the backup 363 // call mkfs.jffs2 to create the backup
364 QString cmdline = QString( "mkfs.jffs2 --faketime --root=/ %1 --little-endian %2 %3 -n" ).arg( outputFile ).arg( pad ).arg( eraseblock ); 364 QString cmdline = QString( "mkfs.jffs2 --faketime --root=/ %1 --little-endian %2 %3 -n" ).arg( outputFile ).arg( pad ).arg( eraseblock );
365 cmdline.append( " --ignore=/tmp --ignore=/mnt --ignore=/var --ignore=/proc" ); 365 cmdline.append( " --ignore=/tmp --ignore=/mnt --ignore=/var --ignore=/proc" );
366 owarn << "Calling '" << cmdline << "'" << oendl; 366 owarn << "Calling '" << cmdline << "'" << oendl;
367 367
368 OWait *owait = new OWait(); 368 OWait *owait = new OWait();
369 Global::statusMessage( tr( "Backing up..." ) ); 369 Global::statusMessage( tr( "Backing up..." ) );
370 owait->show(); 370 owait->show();
371 qApp->processEvents(); 371 qApp->processEvents();
372 372
373 int r = ::system( cmdline ); 373 int r = ::system( cmdline );
374 374
375 owait->hide(); 375 owait->hide();
376 delete owait; 376 delete owait;
377 377
378 if ( r != 0 ) 378 if ( r != 0 )
379 { 379 {
380 perror("Error: "); 380 perror("Error: ");
381 QString errorMsg = QString( tr( "<qt>%1</qt>" ).arg( strerror( errno ) ) ); 381 QString errorMsg = QString( tr( "<qt>%1</qt>" ).arg( strerror( errno ) ) );
382 QMessageBox::critical(this, tr( "Backup Failed!" ), errorMsg, QString( tr( "Ok" ) ) ); 382 QMessageBox::critical(this, tr( "Backup Failed!" ), errorMsg, QString( tr( "Ok" ) ) );
383 } 383 }
384 384
385 // FIXME: Add image postprocessing for C7x0 and C8x0, for Beagle, for SIMpad 385 // FIXME: Add image postprocessing for C7x0 and C8x0, for Beagle, for SIMpad
386} 386}
387 387
388void BackupAndRestore::backupUserData() 388void BackupAndRestore::backupUserData()
389{ 389{
390 QString backupFiles; 390 QString backupFiles;
391 if(getBackupFiles(backupFiles, NULL) == 0) 391 if(getBackupFiles(backupFiles, NULL) == 0)
392 { 392 {
393 QMessageBox::critical(this, "Message", 393 QMessageBox::critical(this, "Message",
394 "No items selected.",QString("Ok") ); 394 "No items selected.",QString("Ok") );
395 return; 395 return;
396 } 396 }
397 397
398 OWait *owait = new OWait(); 398 OWait *owait = new OWait();
399 Global::statusMessage( tr( "Backing up..." ) ); 399 Global::statusMessage( tr( "Backing up..." ) );
400 owait->show(); 400 owait->show();
401 qApp->processEvents(); 401 qApp->processEvents();
402 402
403 QString outputFile = backupLocations[storeToLocation->currentText()]; 403 QString outputFile = backupLocations[storeToLocation->currentText()];
404 404
405 QDateTime datetime = QDateTime::currentDateTime(); 405 QDateTime datetime = QDateTime::currentDateTime();
406 QString dateString = QString::number( datetime.date().year() ) + QString::number( datetime.date().month() ).rightJustify(2, '0') + 406 QString dateString = QString::number( datetime.date().year() ) + QString::number( datetime.date().month() ).rightJustify(2, '0') +
407 QString::number( datetime.date().day() ).rightJustify(2, '0'); 407 QString::number( datetime.date().day() ).rightJustify(2, '0');
408 408
409 outputFile += "/" + dateString; 409 outputFile += "/" + dateString;
410 410
411 QString t = outputFile; 411 QString t = outputFile;
412 int c = 1; 412 int c = 1;
413 while(QFile::exists(outputFile + EXTENSION)) 413 while(QFile::exists(outputFile + EXTENSION))
414 { 414 {
415 outputFile = t + QString("%1").arg(c); 415 outputFile = t + QString("%1").arg(c);
416 c++; 416 c++;
417 } 417 }
418 418
419 // We execute tar and compressing its output with gzip.. 419 // We execute tar and compressing its output with gzip..
420 // The error output will be written into a temp-file which could be provided 420 // The error output will be written into a temp-file which could be provided
421 // for debugging.. 421 // for debugging..
422 odebug << "Storing file: " << outputFile.latin1() << "" << oendl; 422 odebug << "Storing file: " << outputFile.latin1() << "" << oendl;
423 outputFile += EXTENSION; 423 outputFile += EXTENSION;
424 424
425 QString commandLine = QString( "cd %1 && (tar -X %1 -cz %2 Applications/backup/exclude -f %3 ) 2> %4" ).arg( QDir::homeDirPath() ) 425 QString commandLine = QString( "cd %1 && (tar -X %1 -cz %2 Applications/backup/exclude -f %3 ) 2> %4" ).arg( QDir::homeDirPath() )
426 .arg( getExcludeFile() ) 426 .arg( getExcludeFile() )
427 .arg( backupFiles ) 427 .arg( backupFiles )
428 .arg( outputFile.latin1() ) 428 .arg( outputFile.latin1() )
429 .arg( tempFileName.latin1() ); 429 .arg( tempFileName.latin1() );
430 430
431 odebug << commandLine << oendl; 431 odebug << commandLine << oendl;
432 432
433 int r = system( commandLine ); 433 int r = system( commandLine );
434 434
435 owait->hide(); 435 owait->hide();
436 delete owait; 436 delete owait;
437 437
438 //Error-Handling 438 //Error-Handling
439 if(r != 0) 439 if(r != 0)
440 { 440 {
441 perror("Error: "); 441 perror("Error: ");
442 QString errorMsg= tr( "Error from System:\n" ) + (QString)strerror( errno ); 442 QString errorMsg= tr( "Error from System:\n" ) + (QString)strerror( errno );
443 443
444 switch( QMessageBox::critical(this, tr( "Message" ), tr( "Backup Failed!" ) + "\n" 444 switch( QMessageBox::critical(this, tr( "Message" ), tr( "Backup Failed!" ) + "\n"
445 + errorMsg, QString( tr( "Ok" ) ), QString( tr( "Details" ) ) ) ) 445 + errorMsg, QString( tr( "Ok" ) ), QString( tr( "Details" ) ) ) )
446 { 446 {
447 447
448 case 1: 448 case 1:
449 owarn << "Details pressed !" << oendl; 449 owarn << "Details pressed !" << oendl;
450 ErrorDialog* pErrDialog = new ErrorDialog( this, NULL, true ); 450 ErrorDialog* pErrDialog = new ErrorDialog( this, NULL, true );
451 QFile errorFile( tempFileName ); 451 QFile errorFile( tempFileName );
452 if ( errorFile.open(IO_ReadOnly) ) 452 if ( errorFile.open(IO_ReadOnly) )
453 { 453 {
454 QTextStream t( &errorFile ); 454 QTextStream t( &errorFile );
455 QString s; 455 QString s;
456 while ( !t.eof() ) 456 while ( !t.eof() )
457 { // until end of file... 457 { // until end of file...
458 s += t.readLine(); // line of text excluding '\n' 458 s += t.readLine(); // line of text excluding '\n'
459 } 459 }
460 errorFile.close(); 460 errorFile.close();
461 461
462 pErrDialog->m_textarea->setText( s ); 462 pErrDialog->m_textarea->setText( s );
463 } 463 }
464 else 464 else
465 { 465 {
466 pErrDialog->m_textarea->setText( "Unable to open File: /tmp/backup.er" ); 466 pErrDialog->m_textarea->setText( "Unable to open File: /tmp/backup.er" );
467 } 467 }
468 QPEApplication::execDialog( pErrDialog ); 468 QPEApplication::execDialog( pErrDialog );
469 delete pErrDialog; 469 delete pErrDialog;
470 break; 470 break;
471 } 471 }
472 setCaption(tr("Backup and Restore.. Failed !!")); 472 setCaption(tr("Backup and Restore.. Failed !!"));
473 return; 473 return;
474 } 474 }
475 else 475 else
476 { 476 {
477 QMessageBox::information(this, tr( "Message" ), tr( "Backup Successful." ), QString(tr( "Ok" ) ) ); 477 QMessageBox::information(this, tr( "Message" ), tr( "Backup Successful." ), QString(tr( "Ok" ) ) );
478 } 478 }
479 479
480 //write store-location 480 //write store-location
481 Config config( "BackupAndRestore" ); 481 Config config( "BackupAndRestore" );
482 config.setGroup( "LastLocation" ); 482 config.setGroup( "LastLocation" );
483 config.writeEntry( "LastStoreLocation", storeToLocation->currentText() ); 483 config.writeEntry( "LastStoreLocation", storeToLocation->currentText() );
484 484
485 setCaption(tr("Backup and Restore")); 485 setCaption(tr("Backup and Restore"));
486} 486}
487 487
488/*** 488/***
489 * Get a list of all of the files to backup. 489 * Get a list of all of the files to backup.
490 */ 490 */
491int BackupAndRestore::getBackupFiles(QString &backupFiles, QListViewItem *parent) 491int BackupAndRestore::getBackupFiles(QString &backupFiles, QListViewItem *parent)
492{ 492{
493 QListViewItem * currentItem; 493 QListViewItem * currentItem;
494 QString currentHome; 494 QString currentHome;
495 if(!parent) 495 if(!parent)
496 currentItem = backupList->firstChild(); 496 currentItem = backupList->firstChild();
497 else 497 else
498 { 498 {
499 currentItem = parent->firstChild(); 499 currentItem = parent->firstChild();
500 currentHome = parent->text(BACKUP_LOCATION); 500 currentHome = parent->text(BACKUP_LOCATION);
501 } 501 }
502 502
503 uint count = 0; 503 uint count = 0;
504 while( currentItem != 0 ) 504 while( currentItem != 0 )
505 { 505 {
506 if(currentItem->text(HEADER_BACKUP) == "B" ) 506 if(currentItem->text(HEADER_BACKUP) == "B" )
507 { 507 {
508 if(currentItem->childCount() == 0 ) 508 if(currentItem->childCount() == 0 )
509 { 509 {
510 if(parent == NULL) 510 if(parent == NULL)
511 backupFiles += currentItem->text(BACKUP_LOCATION); 511 backupFiles += currentItem->text(BACKUP_LOCATION);
512 else 512 else
513 backupFiles += currentHome + currentItem->text(HEADER_NAME); 513 backupFiles += currentHome + currentItem->text(HEADER_NAME);
514 backupFiles += " "; 514 backupFiles += " ";
515 count++; 515 count++;
516 } 516 }
517 else 517 else
518 { 518 {
519 count += getBackupFiles(backupFiles, currentItem); 519 count += getBackupFiles(backupFiles, currentItem);
520 } 520 }
521 } 521 }
522 currentItem = currentItem->nextSibling(); 522 currentItem = currentItem->nextSibling();
523 } 523 }
524 return count; 524 return count;
525} 525}
526 526
527void BackupAndRestore::sourceDirChanged(int selection) 527void BackupAndRestore::sourceDirChanged(int selection)
528{ 528{
529 restoreList->clear(); 529 restoreList->clear();
530 rescanFolder(backupLocations[restoreSource->text(selection)]); 530 rescanFolder(backupLocations[restoreSource->text(selection)]);
531} 531}
532 532
533void BackupAndRestore::fileListUpdate() 533void BackupAndRestore::fileListUpdate()
534{ 534{
535 owarn << "void BackupAndRestore::fileListUpdate()" << oendl; 535 owarn << "void BackupAndRestore::fileListUpdate()" << oendl;
536 restoreList->clear(); 536 restoreList->clear();
537 rescanFolder( backupLocations[restoreSource->currentText()] ); 537 rescanFolder( backupLocations[restoreSource->currentText()] );
538} 538}
539 539
540/** 540/**
541 * Scans directory for any backup files. Will recursivly go down, 541 * Scans directory for any backup files. Will recursivly go down,
542 * but will not follow symlinks. 542 * but will not follow symlinks.
543 * @param directory - the directory to look in. 543 * @param directory - the directory to look in.
544 */ 544 */
545void BackupAndRestore::rescanFolder(QString directory) 545void BackupAndRestore::rescanFolder(QString directory)
546{ 546{
547 //odebug << QString("rescanFolder: ") + directory.latin1() << oendl; 547 //odebug << QString("rescanFolder: ") + directory.latin1() << oendl;
548 QDir d(directory); 548 QDir d(directory);
549 if(!d.exists()) 549 if(!d.exists())
550 return; 550 return;
551 551
552 d.setFilter( QDir::Files | QDir::Hidden | QDir::Dirs); 552 d.setFilter( QDir::Files | QDir::Hidden | QDir::Dirs);
553 const QFileInfoList *list = d.entryInfoList(); 553 const QFileInfoList *list = d.entryInfoList();
554 QFileInfoListIterator it( *list ); 554 QFileInfoListIterator it( *list );
555 QFileInfo *file; 555 QFileInfo *file;
556 while ( (file=it.current()) ) 556 while ( (file=it.current()) )
557 { // for each file... 557 { // for each file...
558 // If it is a dir and not .. or . then add it as a tab and go down. 558 // If it is a dir and not .. or . then add it as a tab and go down.
559 if(file->isDir()) 559 if(file->isDir())
560 { 560 {
561 if(file->fileName() != ".." && file->fileName() != ".") 561 if(file->fileName() != ".." && file->fileName() != ".")
562 { 562 {
563 rescanFolder(directory + "/" + file->fileName()); 563 rescanFolder(directory + "/" + file->fileName());
564 } 564 }
565 } 565 }
566 else 566 else
567 { 567 {
568 // If it is a backup file add to list. 568 // If it is a backup file add to list.
569 if(file->fileName().contains(EXTENSION)) 569 if(file->fileName().contains(EXTENSION))
570 (void)new QListViewItem(restoreList, file->fileName()); 570 (void)new QListViewItem(restoreList, file->fileName());
571 } 571 }
572 ++it; 572 ++it;
573 } 573 }
574} 574}
575 575
576/** 576/**
577 * Restore a backup file. 577 * Restore a backup file.
578 * Report errors or success 578 * Report errors or success
579 */ 579 */
580void BackupAndRestore::restore() 580void BackupAndRestore::restore()
581{ 581{
582 QListViewItem *restoreItem = restoreList->currentItem(); 582 QListViewItem *restoreItem = restoreList->currentItem();
583 if(!restoreItem) 583 if(!restoreItem)
584 { 584 {
585 QMessageBox::critical(this, tr( "Message" ), 585 QMessageBox::critical(this, tr( "Message" ),
586 tr( "Please select something to restore." ),QString( tr( "Ok") ) ); 586 tr( "Please select something to restore." ),QString( tr( "Ok") ) );
587 return; 587 return;
588 } 588 }
589 589
590 if ( QMessageBox::warning( this, tr( "Restore" ),
591 tr( "Would you really overwrite your local data?" ),
592 tr( "Yes" ), tr( "No" ), "", 1 ) == 1 )
593 return;
594
590 OWait *owait = new OWait(); 595 OWait *owait = new OWait();
591 Global::statusMessage( tr( "Restore Backup..." ) ); 596 Global::statusMessage( tr( "Restore Backup..." ) );
592 owait->show(); 597 owait->show();
593 qApp->processEvents(); 598 qApp->processEvents();
594 599
595 QString restoreFile = backupLocations[restoreSource->currentText()]; 600 QString restoreFile = backupLocations[restoreSource->currentText()];
596 601
597 restoreFile += "/" + restoreItem->text(0); 602 restoreFile += "/" + restoreItem->text(0);
598 603
599 odebug << restoreFile << oendl; 604 odebug << restoreFile << oendl;
600 605
601 //check if backup file come from opie 1.0.x 606 //check if backup file come from opie 1.0.x
602 607
603 QString commandLine = QString( "tar -tzf %1 | grep Applications/backup/exclude" ).arg( restoreFile.latin1() ); 608 QString commandLine = QString( "tar -tzf %1 | grep Applications/backup/exclude" ).arg( restoreFile.latin1() );
604 609
605 int r = system( commandLine ); 610 int r = system( commandLine );
606 611
607 QString startDir; 612 QString startDir;
608 613
609 if( r != 0 ) //Applications/backup/exclude not found - old backup file 614 if( r != 0 ) //Applications/backup/exclude not found - old backup file
610 { 615 {
611 startDir = QString( "/" ); 616 startDir = QString( "/" );
612 } else 617 } else
613 { 618 {
614 startDir = QDir::homeDirPath(); 619 startDir = QDir::homeDirPath();
615 } 620 }
616 621
617 //unpack backup file 622 //unpack backup file
618 commandLine = QString( "cd %1 && tar -zxf %2 2> %3" ).arg( startDir ) 623 commandLine = QString( "cd %1 && tar -zxf %2 2> %3" ).arg( startDir )
619 .arg( restoreFile.latin1() ) 624 .arg( restoreFile.latin1() )
620 .arg( tempFileName.latin1() ); 625 .arg( tempFileName.latin1() );
621 626
622 odebug << commandLine << oendl; 627 odebug << commandLine << oendl;
623 628
624 r = system( commandLine ); 629 r = system( commandLine );
625 630
626 owait->hide(); 631 owait->hide();
627 delete owait; 632 delete owait;
628 633
629 //error handling 634 //error handling
630 if(r != 0) 635 if(r != 0)
631 { 636 {
632 QString errorMsg= tr( "Error from System:\n" ) + (QString)strerror( errno ); 637 QString errorMsg= tr( "Error from System:\n" ) + (QString)strerror( errno );
633 switch( QMessageBox::critical(this, tr( "Message" ), tr( "Restore Failed." ) + "\n" 638 switch( QMessageBox::critical(this, tr( "Message" ), tr( "Restore Failed." ) + "\n"
634 + errorMsg, QString( tr( "Ok") ), QString( tr( "Details" ) ) ) ) 639 + errorMsg, QString( tr( "Ok") ), QString( tr( "Details" ) ) ) )
635 { 640 {
636 case 1: 641 case 1:
637 owarn << "Details pressed !" << oendl; 642 owarn << "Details pressed !" << oendl;
638 ErrorDialog* pErrDialog = new ErrorDialog( this, NULL, true ); 643 ErrorDialog* pErrDialog = new ErrorDialog( this, NULL, true );
639 QFile errorFile( tempFileName ); 644 QFile errorFile( tempFileName );
640 if ( errorFile.open(IO_ReadOnly) ) 645 if ( errorFile.open(IO_ReadOnly) )
641 { 646 {
642 QTextStream t( &errorFile ); 647 QTextStream t( &errorFile );
643 QString s; 648 QString s;
644 while ( !t.eof() ) 649 while ( !t.eof() )
645 { // until end of file... 650 { // until end of file...
646 s += t.readLine(); // line of text excluding '\n' 651 s += t.readLine(); // line of text excluding '\n'
647 } 652 }
648 errorFile.close(); 653 errorFile.close();
649 654
650 pErrDialog->m_textarea->setText( s ); 655 pErrDialog->m_textarea->setText( s );
651 } 656 }
652 else 657 else
653 { 658 {
654 pErrDialog->m_textarea->setText( tr( "Unable to open File: %1" ).arg( "/tmp/backup.er" ) ); 659 pErrDialog->m_textarea->setText( tr( "Unable to open File: %1" ).arg( "/tmp/backup.er" ) );
655 } 660 }
656 QPEApplication::execDialog( pErrDialog ); 661 QPEApplication::execDialog( pErrDialog );
657 delete pErrDialog; 662 delete pErrDialog;
658 663
659 setCaption(tr("Backup and Restore.. Failed !!")); 664 setCaption(tr("Backup and Restore.. Failed !!"));
660 return; 665 return;
661 666
662 break; 667 break;
663 668
664 } 669 }
665 } 670 }
666 else 671 else
667 { 672 {
668 QMessageBox::information(this, tr( "Message" ), tr( "Restore Successful." ), QString( tr( "Ok") ) ); 673 QMessageBox::information(this, tr( "Message" ), tr( "Restore Successful." ), QString( tr( "Ok") ) );
669 } 674 }
670 675
671 //write restore-location 676 //write restore-location
672 Config config( "BackupAndRestore" ); 677 Config config( "BackupAndRestore" );
673 config.setGroup( "LastLocation" ); 678 config.setGroup( "LastLocation" );
674 config.writeEntry( "LastRestoreLocation", restoreSource->currentText() ); 679 config.writeEntry( "LastRestoreLocation", restoreSource->currentText() );
675 680
676 setCaption(tr("Backup and Restore")); 681 setCaption(tr("Backup and Restore"));
677} 682}
678 683
679/** 684/**
680 * Check for exclude in Applications/backup 685 * Check for exclude in Applications/backup
681 * If it does not exist, the function will create the file with *.bck as content 686 * If it does not exist, the function will create the file with *.bck as content
682 * The exclude_files is read by tar and will provide to exclude special files out from backup. 687 * The exclude_files is read by tar and will provide to exclude special files out from backup.
683 * e.g. alle *.bck files (backup-files) will not be backed up by default 688 * e.g. alle *.bck files (backup-files) will not be backed up by default
684 */ 689 */
685 690
686QString BackupAndRestore::getExcludeFile() 691QString BackupAndRestore::getExcludeFile()
687{ 692{
688 QString excludeFileName = Global::applicationFileName( "backup", "exclude" ); 693 QString excludeFileName = Global::applicationFileName( "backup", "exclude" );
689 if ( !QFile::exists( excludeFileName ) ) 694 if ( !QFile::exists( excludeFileName ) )
690 { 695 {
691 QFile excludeFile( excludeFileName); 696 QFile excludeFile( excludeFileName);
692 if ( excludeFile.open( IO_WriteOnly ) == true ) 697 if ( excludeFile.open( IO_WriteOnly ) == true )
693 { 698 {
694 QTextStream writeStream( &excludeFile ); 699 QTextStream writeStream( &excludeFile );
695 writeStream << "*.bck" << "\n"; 700 writeStream << "*.bck" << "\n";
696 excludeFile.close(); 701 excludeFile.close();
697 } 702 }
698 else 703 else
699 { 704 {
700 return QString::null; 705 return QString::null;
701 } 706 }
702 } 707 }
703 708
704 return excludeFileName; 709 return excludeFileName;
705} 710}
706 711
707void BackupAndRestore::refreshLocations() 712void BackupAndRestore::refreshLocations()
708{ 713{
709 locationList->clear(); 714 locationList->clear();
710 715
711 //todo: implement add locations 716 //todo: implement add locations
712 Config config( "BackupAndRestore" ); 717 Config config( "BackupAndRestore" );
713 config.setGroup( "Locations" ); 718 config.setGroup( "Locations" );
714 719
715 QStringList locations( config.readListEntry( "locations", '|' ) ); 720 QStringList locations( config.readListEntry( "locations", '|' ) );
716 721
717 for ( QStringList::Iterator it = locations.begin(); it != locations.end(); ++it ) { 722 for ( QStringList::Iterator it = locations.begin(); it != locations.end(); ++it ) {
718 (void) new QListViewItem( locationList, *it ); 723 (void) new QListViewItem( locationList, *it );
719 } 724 }
720} 725}
721 726
722void BackupAndRestore::addLocation() 727void BackupAndRestore::addLocation()
723{ 728{
724 if ( ( !locationEdit->text().isEmpty() ) && 729 if ( ( !locationEdit->text().isEmpty() ) &&
725 ( QDir( locationEdit->text() ).exists() ) ) 730 ( QDir( locationEdit->text() ).exists() ) )
726 { 731 {
727 (void) new QListViewItem( locationList, locationEdit->text() ); 732 (void) new QListViewItem( locationList, locationEdit->text() );
728 locationEdit->setText( "" ); 733 locationEdit->setText( "" );
729 saveLocations(); 734 saveLocations();
730 } 735 }
731} 736}
732 737
733void BackupAndRestore::removeLocation() 738void BackupAndRestore::removeLocation()
734{ 739{
735 if ( locationList->selectedItem() ) 740 if ( locationList->selectedItem() )
736 { 741 {
737 delete( locationList->selectedItem() ); 742 delete( locationList->selectedItem() );
738 saveLocations(); 743 saveLocations();
739 } 744 }
740} 745}
741 746
742void BackupAndRestore::saveLocations() 747void BackupAndRestore::saveLocations()
743{ 748{
744 Config config("BackupAndRestore"); 749 Config config("BackupAndRestore");
745 config.setGroup("Locations"); 750 config.setGroup("Locations");
746 751
747 QStringList locations; 752 QStringList locations;
748 for ( QListViewItemIterator it( locationList ); it.current(); ++it ) 753 for ( QListViewItemIterator it( locationList ); it.current(); ++it )
749 { 754 {
750 locations.append( it.current()->text( 0 ) ); 755 locations.append( it.current()->text( 0 ) );
751 } 756 }
752 config.writeEntry( "locations", locations, '|' ); 757 config.writeEntry( "locations", locations, '|' );
753 758
754 refreshBackupLocations(); 759 refreshBackupLocations();
755} 760}
756 761
757void BackupAndRestore::selectLocation() 762void BackupAndRestore::selectLocation()
758{ 763{
759 QString location = OFileDialog::getDirectory( OFileSelector::DIRECTORYSELECTOR ); 764 QString location = OFileDialog::getDirectory( OFileSelector::DIRECTORYSELECTOR );
760 if ( !location.isEmpty() ) 765 if ( !location.isEmpty() )
761 { 766 {
762 locationEdit->setText( location ); 767 locationEdit->setText( location );
763 } 768 }
764} 769}
765 770
766// backuprestore.cpp 771// backuprestore.cpp
767 772