-rw-r--r-- | noncore/settings/backup/backuprestore.cpp | 2 | ||||
-rw-r--r-- | noncore/settings/backup/main.cpp | 2 | ||||
-rw-r--r-- | noncore/tools/calculator/main.cpp | 1 |
3 files changed, 3 insertions, 2 deletions
diff --git a/noncore/settings/backup/backuprestore.cpp b/noncore/settings/backup/backuprestore.cpp index 164055e..87b7966 100644 --- a/noncore/settings/backup/backuprestore.cpp +++ b/noncore/settings/backup/backuprestore.cpp | |||
@@ -1,454 +1,454 @@ | |||
1 | 1 | ||
2 | #include "backuprestore.h" | 2 | #include "backuprestore.h" |
3 | #include "errordialog.h" | 3 | #include "errordialog.h" |
4 | 4 | ||
5 | /* OPIE */ | 5 | /* OPIE */ |
6 | #include <opie2/ostorageinfo.h> | 6 | #include <opie2/ostorageinfo.h> |
7 | #include <qpe/qpeapplication.h> | 7 | #include <qpe/qpeapplication.h> |
8 | 8 | ||
9 | /* QT */ | 9 | /* QT */ |
10 | #include <qapplication.h> | 10 | #include <qapplication.h> |
11 | #include <qmultilineedit.h> | 11 | #include <qmultilineedit.h> |
12 | #include <qdir.h> | 12 | #include <qdir.h> |
13 | #include <qfile.h> | 13 | #include <qfile.h> |
14 | #include <qfileinfo.h> | 14 | #include <qfileinfo.h> |
15 | #include <qlistview.h> | 15 | #include <qlistview.h> |
16 | #include <qpushbutton.h> | 16 | #include <qpushbutton.h> |
17 | #include <qheader.h> | 17 | #include <qheader.h> |
18 | #include <qpe/resource.h> | 18 | #include <qpe/resource.h> |
19 | #include <qpe/config.h> | 19 | #include <qpe/config.h> |
20 | #include <qmessagebox.h> | 20 | #include <qmessagebox.h> |
21 | #include <qcombobox.h> | 21 | #include <qcombobox.h> |
22 | #include <qlist.h> | 22 | #include <qlist.h> |
23 | #include <stdlib.h> | 23 | #include <stdlib.h> |
24 | #include <qregexp.h> | 24 | #include <qregexp.h> |
25 | #include <qtextstream.h> | 25 | #include <qtextstream.h> |
26 | #include <qtextview.h> | 26 | #include <qtextview.h> |
27 | 27 | ||
28 | /* STD */ | 28 | /* STD */ |
29 | #include <errno.h> | 29 | #include <errno.h> |
30 | #include <stdlib.h> | 30 | #include <stdlib.h> |
31 | #include <unistd.h> | 31 | #include <unistd.h> |
32 | #include <sys/stat.h> | 32 | #include <sys/stat.h> |
33 | #include <dirent.h> | 33 | #include <dirent.h> |
34 | 34 | ||
35 | #define HEADER_NAME 0 | 35 | #define HEADER_NAME 0 |
36 | #define HEADER_BACKUP 1 | 36 | #define HEADER_BACKUP 1 |
37 | #define BACKUP_LOCATION 2 | 37 | #define BACKUP_LOCATION 2 |
38 | 38 | ||
39 | #define EXTENSION ".bck" | 39 | #define EXTENSION ".bck" |
40 | 40 | ||
41 | const QString tempFileName = "/tmp/backup.err"; | 41 | const QString tempFileName = "/tmp/backup.err"; |
42 | 42 | ||
43 | 43 | ||
44 | BackupAndRestore::BackupAndRestore( QWidget* parent, const char* name, WFlags fl) | 44 | BackupAndRestore::BackupAndRestore( QWidget* parent, const char* name, WFlags fl) |
45 | : BackupAndRestoreBase(parent, name, fl) | 45 | : BackupAndRestoreBase(parent, name, fl) |
46 | { | 46 | { |
47 | backupList->header()->hide(); | 47 | backupList->header()->hide(); |
48 | restoreList->header()->hide(); | 48 | restoreList->header()->hide(); |
49 | connect(backupButton, SIGNAL(clicked()), | 49 | connect(backupButton, SIGNAL(clicked()), |
50 | this, SLOT(backup())); | 50 | this, SLOT(backup())); |
51 | connect(restoreButton, SIGNAL(clicked()), | 51 | connect(restoreButton, SIGNAL(clicked()), |
52 | this, SLOT(restore())); | 52 | this, SLOT(restore())); |
53 | connect(backupList, SIGNAL(clicked(QListViewItem*)), | 53 | connect(backupList, SIGNAL(clicked(QListViewItem*)), |
54 | this, SLOT(selectItem(QListViewItem*))); | 54 | this, SLOT(selectItem(QListViewItem*))); |
55 | connect(restoreSource, SIGNAL(activated(int)), | 55 | connect(restoreSource, SIGNAL(activated(int)), |
56 | this, SLOT(sourceDirChanged(int))); | 56 | this, SLOT(sourceDirChanged(int))); |
57 | connect(updateList, SIGNAL(clicked()), | 57 | connect(updateList, SIGNAL(clicked()), |
58 | this, SLOT( fileListUpdate())); | 58 | this, SLOT( fileListUpdate())); |
59 | 59 | ||
60 | //add directorys for backing up | 60 | //add directorys for backing up |
61 | applicationSettings = new QListViewItem(backupList, "Application Settings", "", "Settings/"); | 61 | applicationSettings = new QListViewItem(backupList, "Application Settings", "", "Settings/"); |
62 | selectItem(applicationSettings); | 62 | selectItem(applicationSettings); |
63 | applicationSettings = new QListViewItem(backupList, "Application Data", "", "Applications/"); | 63 | applicationSettings = new QListViewItem(backupList, "Application Data", "", "Applications/"); |
64 | selectItem(applicationSettings); | 64 | selectItem(applicationSettings); |
65 | documents= new QListViewItem(backupList, "Documents", "", "Documents/"); | 65 | documents= new QListViewItem(backupList, "Documents", "", "Documents/"); |
66 | selectItem(documents); | 66 | selectItem(documents); |
67 | 67 | ||
68 | scanForApplicationSettings(); | 68 | scanForApplicationSettings(); |
69 | 69 | ||
70 | OStorageInfo storage; | 70 | Opie::Core::OStorageInfo storage; |
71 | 71 | ||
72 | backupLocations.insert( "Documents", QDir::homeDirPath() + "/Documents" ); | 72 | backupLocations.insert( "Documents", QDir::homeDirPath() + "/Documents" ); |
73 | if ( storage.hasCf() ) | 73 | if ( storage.hasCf() ) |
74 | { | 74 | { |
75 | backupLocations.insert( "CF", storage.cfPath() ); | 75 | backupLocations.insert( "CF", storage.cfPath() ); |
76 | qDebug( "Cf Path: " + storage.cfPath() ); | 76 | qDebug( "Cf Path: " + storage.cfPath() ); |
77 | } | 77 | } |
78 | if ( storage.hasSd() ) | 78 | if ( storage.hasSd() ) |
79 | { | 79 | { |
80 | backupLocations.insert( "SD", storage.sdPath() ); | 80 | backupLocations.insert( "SD", storage.sdPath() ); |
81 | qDebug( " Sd Path: " + storage.sdPath() ); | 81 | qDebug( " Sd Path: " + storage.sdPath() ); |
82 | } | 82 | } |
83 | if ( storage.hasMmc() ) | 83 | if ( storage.hasMmc() ) |
84 | { | 84 | { |
85 | backupLocations.insert( "MMC", storage.mmcPath() ); | 85 | backupLocations.insert( "MMC", storage.mmcPath() ); |
86 | qDebug( "Mmc Path: " + storage.mmcPath() ); | 86 | qDebug( "Mmc Path: " + storage.mmcPath() ); |
87 | } | 87 | } |
88 | 88 | ||
89 | Config config("BackupAndRestore"); | 89 | Config config("BackupAndRestore"); |
90 | //read last locations | 90 | //read last locations |
91 | config.setGroup("LastLocation"); | 91 | config.setGroup("LastLocation"); |
92 | QString lastStoreLocation = config.readEntry( "LastStoreLocation", "" ); | 92 | QString lastStoreLocation = config.readEntry( "LastStoreLocation", "" ); |
93 | QString lastRestoreLocation = config.readEntry( "LastRestoreLocation", "" ); | 93 | QString lastRestoreLocation = config.readEntry( "LastRestoreLocation", "" ); |
94 | int locationIndex = 0; | 94 | int locationIndex = 0; |
95 | 95 | ||
96 | QMap<QString, QString>::Iterator it; | 96 | QMap<QString, QString>::Iterator it; |
97 | for( it = backupLocations.begin(); it != backupLocations.end(); ++it ) | 97 | for( it = backupLocations.begin(); it != backupLocations.end(); ++it ) |
98 | { | 98 | { |
99 | storeToLocation->insertItem(it.key()); | 99 | storeToLocation->insertItem(it.key()); |
100 | restoreSource->insertItem(it.key()); | 100 | restoreSource->insertItem(it.key()); |
101 | 101 | ||
102 | //check for last locations | 102 | //check for last locations |
103 | if ( it.key() == lastStoreLocation ) | 103 | if ( it.key() == lastStoreLocation ) |
104 | storeToLocation->setCurrentItem( locationIndex ); | 104 | storeToLocation->setCurrentItem( locationIndex ); |
105 | if ( it.key() == lastRestoreLocation ) | 105 | if ( it.key() == lastRestoreLocation ) |
106 | restoreSource->setCurrentItem( locationIndex ); | 106 | restoreSource->setCurrentItem( locationIndex ); |
107 | locationIndex++; | 107 | locationIndex++; |
108 | } | 108 | } |
109 | 109 | ||
110 | // Read the list of items to ignore. | 110 | // Read the list of items to ignore. |
111 | QList<QString> dontBackupList; | 111 | QList<QString> dontBackupList; |
112 | dontBackupList.setAutoDelete(true); | 112 | dontBackupList.setAutoDelete(true); |
113 | config.setGroup("DontBackup"); | 113 | config.setGroup("DontBackup"); |
114 | int total = config.readNumEntry("Total", 0); | 114 | int total = config.readNumEntry("Total", 0); |
115 | for(int i = 0; i < total; i++) | 115 | for(int i = 0; i < total; i++) |
116 | { | 116 | { |
117 | dontBackupList.append(new QString(config.readEntry(QString("%1").arg(i), ""))); | 117 | dontBackupList.append(new QString(config.readEntry(QString("%1").arg(i), ""))); |
118 | } | 118 | } |
119 | 119 | ||
120 | QList<QListViewItem> list; | 120 | QList<QListViewItem> list; |
121 | getAllItems(backupList->firstChild(), list); | 121 | getAllItems(backupList->firstChild(), list); |
122 | 122 | ||
123 | for(uint i = 0; i < list.count(); i++) | 123 | for(uint i = 0; i < list.count(); i++) |
124 | { | 124 | { |
125 | QString text = list.at(i)->text(HEADER_NAME); | 125 | QString text = list.at(i)->text(HEADER_NAME); |
126 | for(uint i2 = 0; i2 < dontBackupList.count(); i2++) | 126 | for(uint i2 = 0; i2 < dontBackupList.count(); i2++) |
127 | { | 127 | { |
128 | if(*dontBackupList.at(i2) == text) | 128 | if(*dontBackupList.at(i2) == text) |
129 | { | 129 | { |
130 | selectItem(list.at(i)); | 130 | selectItem(list.at(i)); |
131 | break; | 131 | break; |
132 | } | 132 | } |
133 | } | 133 | } |
134 | } | 134 | } |
135 | QPEApplication::showWidget( this ); | 135 | QPEApplication::showWidget( this ); |
136 | } | 136 | } |
137 | 137 | ||
138 | BackupAndRestore::~BackupAndRestore() | 138 | BackupAndRestore::~BackupAndRestore() |
139 | { | 139 | { |
140 | QList<QListViewItem> list; | 140 | QList<QListViewItem> list; |
141 | getAllItems(backupList->firstChild(), list); | 141 | getAllItems(backupList->firstChild(), list); |
142 | 142 | ||
143 | Config config("BackupAndRestore"); | 143 | Config config("BackupAndRestore"); |
144 | config.setGroup("DontBackup"); | 144 | config.setGroup("DontBackup"); |
145 | config.clearGroup(); | 145 | config.clearGroup(); |
146 | 146 | ||
147 | int count = 0; | 147 | int count = 0; |
148 | for(uint i = 0; i < list.count(); i++) | 148 | for(uint i = 0; i < list.count(); i++) |
149 | { | 149 | { |
150 | if(list.at(i)->text(HEADER_BACKUP) == "") | 150 | if(list.at(i)->text(HEADER_BACKUP) == "") |
151 | { | 151 | { |
152 | config.writeEntry(QString("%1").arg(count), list.at(i)->text(HEADER_NAME)); | 152 | config.writeEntry(QString("%1").arg(count), list.at(i)->text(HEADER_NAME)); |
153 | count++; | 153 | count++; |
154 | } | 154 | } |
155 | } | 155 | } |
156 | config.writeEntry("Total", count); | 156 | config.writeEntry("Total", count); |
157 | 157 | ||
158 | // Remove Temp File | 158 | // Remove Temp File |
159 | if ( QFile::exists( tempFileName ) ) | 159 | if ( QFile::exists( tempFileName ) ) |
160 | QFile::remove( tempFileName ); | 160 | QFile::remove( tempFileName ); |
161 | } | 161 | } |
162 | 162 | ||
163 | QList<QListViewItem> BackupAndRestore::getAllItems(QListViewItem *item, QList<QListViewItem> &list) | 163 | QList<QListViewItem> BackupAndRestore::getAllItems(QListViewItem *item, QList<QListViewItem> &list) |
164 | { | 164 | { |
165 | while(item) | 165 | while(item) |
166 | { | 166 | { |
167 | if(item->childCount() > 0) | 167 | if(item->childCount() > 0) |
168 | getAllItems(item->firstChild(), list); | 168 | getAllItems(item->firstChild(), list); |
169 | list.append(item); | 169 | list.append(item); |
170 | item = item->nextSibling(); | 170 | item = item->nextSibling(); |
171 | } | 171 | } |
172 | return list; | 172 | return list; |
173 | } | 173 | } |
174 | 174 | ||
175 | /** | 175 | /** |
176 | * Selects and unselects the item by setting the HEADER_BACKUP to B or !. | 176 | * Selects and unselects the item by setting the HEADER_BACKUP to B or !. |
177 | * and changing the icon to match | 177 | * and changing the icon to match |
178 | * @param currentItem the item to swich the selection choice. | 178 | * @param currentItem the item to swich the selection choice. |
179 | */ | 179 | */ |
180 | void BackupAndRestore::selectItem(QListViewItem *currentItem) | 180 | void BackupAndRestore::selectItem(QListViewItem *currentItem) |
181 | { | 181 | { |
182 | if(!currentItem) | 182 | if(!currentItem) |
183 | return; | 183 | return; |
184 | 184 | ||
185 | if(currentItem->text(HEADER_BACKUP) == "B") | 185 | if(currentItem->text(HEADER_BACKUP) == "B") |
186 | { | 186 | { |
187 | currentItem->setPixmap(HEADER_NAME, Resource::loadPixmap("backup/null")); | 187 | currentItem->setPixmap(HEADER_NAME, Resource::loadPixmap("backup/null")); |
188 | currentItem->setText(HEADER_BACKUP, ""); | 188 | currentItem->setText(HEADER_BACKUP, ""); |
189 | } | 189 | } |
190 | else | 190 | else |
191 | { | 191 | { |
192 | currentItem->setPixmap(HEADER_NAME, Resource::loadPixmap("backup/check")); | 192 | currentItem->setPixmap(HEADER_NAME, Resource::loadPixmap("backup/check")); |
193 | currentItem->setText(HEADER_BACKUP, "B"); | 193 | currentItem->setText(HEADER_BACKUP, "B"); |
194 | } | 194 | } |
195 | } | 195 | } |
196 | 196 | ||
197 | void BackupAndRestore::scanForApplicationSettings() | 197 | void BackupAndRestore::scanForApplicationSettings() |
198 | { | 198 | { |
199 | QDir d( QDir::homeDirPath() + "/" + QString( applicationSettings->text(BACKUP_LOCATION) ) ); | 199 | QDir d( QDir::homeDirPath() + "/" + QString( applicationSettings->text(BACKUP_LOCATION) ) ); |
200 | d.setFilter( QDir::Dirs | QDir::Files | QDir::NoSymLinks ); | 200 | d.setFilter( QDir::Dirs | QDir::Files | QDir::NoSymLinks ); |
201 | const QFileInfoList *list = d.entryInfoList(); | 201 | const QFileInfoList *list = d.entryInfoList(); |
202 | QFileInfoListIterator it( *list ); | 202 | QFileInfoListIterator it( *list ); |
203 | QFileInfo *fi; | 203 | QFileInfo *fi; |
204 | while ( (fi=it.current()) ) | 204 | while ( (fi=it.current()) ) |
205 | { | 205 | { |
206 | //qDebug((d.path()+"/"+fi->fileName()).latin1()); | 206 | //qDebug((d.path()+"/"+fi->fileName()).latin1()); |
207 | if ( ( fi->fileName() != "." ) && ( fi->fileName() != ".." ) ) | 207 | if ( ( fi->fileName() != "." ) && ( fi->fileName() != ".." ) ) |
208 | { | 208 | { |
209 | QListViewItem *newItem = new QListViewItem(applicationSettings, fi->fileName()); | 209 | QListViewItem *newItem = new QListViewItem(applicationSettings, fi->fileName()); |
210 | selectItem(newItem); | 210 | selectItem(newItem); |
211 | } | 211 | } |
212 | ++it; | 212 | ++it; |
213 | } | 213 | } |
214 | } | 214 | } |
215 | 215 | ||
216 | /** | 216 | /** |
217 | * The "Backup" button has been pressed. Get a list of all of the files that | 217 | * The "Backup" button has been pressed. Get a list of all of the files that |
218 | * should be backed up. If there are no files, emit and error and exit. | 218 | * should be backed up. If there are no files, emit and error and exit. |
219 | * Determine the file name to store the backup in. Backup the file(s) using | 219 | * Determine the file name to store the backup in. Backup the file(s) using |
220 | * tar and gzip --best. Report failure or success | 220 | * tar and gzip --best. Report failure or success |
221 | */ | 221 | */ |
222 | void BackupAndRestore::backup() | 222 | void BackupAndRestore::backup() |
223 | { | 223 | { |
224 | QString backupFiles; | 224 | QString backupFiles; |
225 | if(getBackupFiles(backupFiles, NULL) == 0) | 225 | if(getBackupFiles(backupFiles, NULL) == 0) |
226 | { | 226 | { |
227 | QMessageBox::critical(this, "Message", | 227 | QMessageBox::critical(this, "Message", |
228 | "No items selected.",QString("Ok") ); | 228 | "No items selected.",QString("Ok") ); |
229 | return; | 229 | return; |
230 | } | 230 | } |
231 | 231 | ||
232 | setCaption(tr("Backup and Restore... working...")); | 232 | setCaption(tr("Backup and Restore... working...")); |
233 | QString outputFile = backupLocations[storeToLocation->currentText()]; | 233 | QString outputFile = backupLocations[storeToLocation->currentText()]; |
234 | 234 | ||
235 | QDateTime datetime = QDateTime::currentDateTime(); | 235 | QDateTime datetime = QDateTime::currentDateTime(); |
236 | QString dateString = QString::number( datetime.date().year() ) + QString::number( datetime.date().month() ).rightJustify(2, '0') + | 236 | QString dateString = QString::number( datetime.date().year() ) + QString::number( datetime.date().month() ).rightJustify(2, '0') + |
237 | QString::number( datetime.date().day() ).rightJustify(2, '0'); | 237 | QString::number( datetime.date().day() ).rightJustify(2, '0'); |
238 | 238 | ||
239 | outputFile += "/" + dateString; | 239 | outputFile += "/" + dateString; |
240 | 240 | ||
241 | QString t = outputFile; | 241 | QString t = outputFile; |
242 | int c = 1; | 242 | int c = 1; |
243 | while(QFile::exists(outputFile + EXTENSION)) | 243 | while(QFile::exists(outputFile + EXTENSION)) |
244 | { | 244 | { |
245 | outputFile = t + QString("%1").arg(c); | 245 | outputFile = t + QString("%1").arg(c); |
246 | c++; | 246 | c++; |
247 | } | 247 | } |
248 | 248 | ||
249 | // We execute tar and compressing its output with gzip.. | 249 | // We execute tar and compressing its output with gzip.. |
250 | // The error output will be written into a temp-file which could be provided | 250 | // The error output will be written into a temp-file which could be provided |
251 | // for debugging.. | 251 | // for debugging.. |
252 | qDebug( "Storing file: %s", outputFile.latin1() ); | 252 | qDebug( "Storing file: %s", outputFile.latin1() ); |
253 | outputFile += EXTENSION; | 253 | outputFile += EXTENSION; |
254 | 254 | ||
255 | QString commandLine = QString( "cd %1 && (tar -X %1 -cz %2 -f %3 ) 2> %4" ).arg( QDir::homeDirPath() ) | 255 | QString commandLine = QString( "cd %1 && (tar -X %1 -cz %2 -f %3 ) 2> %4" ).arg( QDir::homeDirPath() ) |
256 | .arg( getExcludeFile() ) | 256 | .arg( getExcludeFile() ) |
257 | .arg( backupFiles ) | 257 | .arg( backupFiles ) |
258 | .arg( outputFile.latin1() ) | 258 | .arg( outputFile.latin1() ) |
259 | .arg( tempFileName.latin1() ); | 259 | .arg( tempFileName.latin1() ); |
260 | 260 | ||
261 | qDebug( commandLine ); | 261 | qDebug( commandLine ); |
262 | 262 | ||
263 | int r = system( commandLine ); | 263 | int r = system( commandLine ); |
264 | 264 | ||
265 | if(r != 0) | 265 | if(r != 0) |
266 | { | 266 | { |
267 | perror("Error: "); | 267 | perror("Error: "); |
268 | QString errorMsg= tr( "Error from System:\n" ) + (QString)strerror( errno ); | 268 | QString errorMsg= tr( "Error from System:\n" ) + (QString)strerror( errno ); |
269 | 269 | ||
270 | switch( QMessageBox::critical(this, tr( "Message" ), tr( "Backup Failed!" ) + "\n" | 270 | switch( QMessageBox::critical(this, tr( "Message" ), tr( "Backup Failed!" ) + "\n" |
271 | + errorMsg, QString( tr( "Ok" ) ), QString( tr( "Details" ) ) ) ) | 271 | + errorMsg, QString( tr( "Ok" ) ), QString( tr( "Details" ) ) ) ) |
272 | { | 272 | { |
273 | 273 | ||
274 | case 1: | 274 | case 1: |
275 | qWarning("Details pressed !"); | 275 | qWarning("Details pressed !"); |
276 | ErrorDialog* pErrDialog = new ErrorDialog( this, NULL, true ); | 276 | ErrorDialog* pErrDialog = new ErrorDialog( this, NULL, true ); |
277 | QFile errorFile( tempFileName ); | 277 | QFile errorFile( tempFileName ); |
278 | if ( errorFile.open(IO_ReadOnly) ) | 278 | if ( errorFile.open(IO_ReadOnly) ) |
279 | { | 279 | { |
280 | QTextStream t( &errorFile ); | 280 | QTextStream t( &errorFile ); |
281 | QString s; | 281 | QString s; |
282 | while ( !t.eof() ) | 282 | while ( !t.eof() ) |
283 | { // until end of file... | 283 | { // until end of file... |
284 | s += t.readLine(); // line of text excluding '\n' | 284 | s += t.readLine(); // line of text excluding '\n' |
285 | } | 285 | } |
286 | errorFile.close(); | 286 | errorFile.close(); |
287 | 287 | ||
288 | pErrDialog->m_textarea->setText( s ); | 288 | pErrDialog->m_textarea->setText( s ); |
289 | } | 289 | } |
290 | else | 290 | else |
291 | { | 291 | { |
292 | pErrDialog->m_textarea->setText( "Unable to open File: /tmp/backup.er" ); | 292 | pErrDialog->m_textarea->setText( "Unable to open File: /tmp/backup.er" ); |
293 | } | 293 | } |
294 | QPEApplication::execDialog( pErrDialog ); | 294 | QPEApplication::execDialog( pErrDialog ); |
295 | delete pErrDialog; | 295 | delete pErrDialog; |
296 | break; | 296 | break; |
297 | } | 297 | } |
298 | setCaption(tr("Backup and Restore.. Failed !!")); | 298 | setCaption(tr("Backup and Restore.. Failed !!")); |
299 | return; | 299 | return; |
300 | } | 300 | } |
301 | else | 301 | else |
302 | { | 302 | { |
303 | QMessageBox::information(this, tr( "Message" ), tr( "Backup Successful." ), QString(tr( "Ok" ) ) ); | 303 | QMessageBox::information(this, tr( "Message" ), tr( "Backup Successful." ), QString(tr( "Ok" ) ) ); |
304 | 304 | ||
305 | } | 305 | } |
306 | 306 | ||
307 | //write store-location | 307 | //write store-location |
308 | Config config( "BackupAndRestore" ); | 308 | Config config( "BackupAndRestore" ); |
309 | config.setGroup( "LastLocation" ); | 309 | config.setGroup( "LastLocation" ); |
310 | config.writeEntry( "LastStoreLocation", storeToLocation->currentText() ); | 310 | config.writeEntry( "LastStoreLocation", storeToLocation->currentText() ); |
311 | 311 | ||
312 | setCaption(tr("Backup and Restore")); | 312 | setCaption(tr("Backup and Restore")); |
313 | } | 313 | } |
314 | 314 | ||
315 | /*** | 315 | /*** |
316 | * Get a list of all of the files to backup. | 316 | * Get a list of all of the files to backup. |
317 | */ | 317 | */ |
318 | int BackupAndRestore::getBackupFiles(QString &backupFiles, QListViewItem *parent) | 318 | int BackupAndRestore::getBackupFiles(QString &backupFiles, QListViewItem *parent) |
319 | { | 319 | { |
320 | QListViewItem * currentItem; | 320 | QListViewItem * currentItem; |
321 | QString currentHome; | 321 | QString currentHome; |
322 | if(!parent) | 322 | if(!parent) |
323 | currentItem = backupList->firstChild(); | 323 | currentItem = backupList->firstChild(); |
324 | else | 324 | else |
325 | { | 325 | { |
326 | currentItem = parent->firstChild(); | 326 | currentItem = parent->firstChild(); |
327 | currentHome = parent->text(BACKUP_LOCATION); | 327 | currentHome = parent->text(BACKUP_LOCATION); |
328 | } | 328 | } |
329 | 329 | ||
330 | uint count = 0; | 330 | uint count = 0; |
331 | while( currentItem != 0 ) | 331 | while( currentItem != 0 ) |
332 | { | 332 | { |
333 | if(currentItem->text(HEADER_BACKUP) == "B" ) | 333 | if(currentItem->text(HEADER_BACKUP) == "B" ) |
334 | { | 334 | { |
335 | if(currentItem->childCount() == 0 ) | 335 | if(currentItem->childCount() == 0 ) |
336 | { | 336 | { |
337 | if(parent == NULL) | 337 | if(parent == NULL) |
338 | backupFiles += currentItem->text(BACKUP_LOCATION); | 338 | backupFiles += currentItem->text(BACKUP_LOCATION); |
339 | else | 339 | else |
340 | backupFiles += currentHome + currentItem->text(HEADER_NAME); | 340 | backupFiles += currentHome + currentItem->text(HEADER_NAME); |
341 | backupFiles += " "; | 341 | backupFiles += " "; |
342 | count++; | 342 | count++; |
343 | } | 343 | } |
344 | else | 344 | else |
345 | { | 345 | { |
346 | count += getBackupFiles(backupFiles, currentItem); | 346 | count += getBackupFiles(backupFiles, currentItem); |
347 | } | 347 | } |
348 | } | 348 | } |
349 | currentItem = currentItem->nextSibling(); | 349 | currentItem = currentItem->nextSibling(); |
350 | } | 350 | } |
351 | return count; | 351 | return count; |
352 | } | 352 | } |
353 | 353 | ||
354 | void BackupAndRestore::sourceDirChanged(int selection) | 354 | void BackupAndRestore::sourceDirChanged(int selection) |
355 | { | 355 | { |
356 | restoreList->clear(); | 356 | restoreList->clear(); |
357 | rescanFolder(backupLocations[restoreSource->text(selection)]); | 357 | rescanFolder(backupLocations[restoreSource->text(selection)]); |
358 | } | 358 | } |
359 | 359 | ||
360 | void BackupAndRestore::fileListUpdate() | 360 | void BackupAndRestore::fileListUpdate() |
361 | { | 361 | { |
362 | qWarning("void BackupAndRestore::fileListUpdate()"); | 362 | qWarning("void BackupAndRestore::fileListUpdate()"); |
363 | restoreList->clear(); | 363 | restoreList->clear(); |
364 | rescanFolder( backupLocations[restoreSource->currentText()] ); | 364 | rescanFolder( backupLocations[restoreSource->currentText()] ); |
365 | } | 365 | } |
366 | 366 | ||
367 | /** | 367 | /** |
368 | * Scans directory for any backup files. Will recursivly go down, | 368 | * Scans directory for any backup files. Will recursivly go down, |
369 | * but will not follow symlinks. | 369 | * but will not follow symlinks. |
370 | * @param directory - the directory to look in. | 370 | * @param directory - the directory to look in. |
371 | */ | 371 | */ |
372 | void BackupAndRestore::rescanFolder(QString directory) | 372 | void BackupAndRestore::rescanFolder(QString directory) |
373 | { | 373 | { |
374 | //qDebug(QString("rescanFolder: ") + directory.latin1()); | 374 | //qDebug(QString("rescanFolder: ") + directory.latin1()); |
375 | QDir d(directory); | 375 | QDir d(directory); |
376 | if(!d.exists()) | 376 | if(!d.exists()) |
377 | return; | 377 | return; |
378 | 378 | ||
379 | d.setFilter( QDir::Files | QDir::Hidden | QDir::Dirs); | 379 | d.setFilter( QDir::Files | QDir::Hidden | QDir::Dirs); |
380 | const QFileInfoList *list = d.entryInfoList(); | 380 | const QFileInfoList *list = d.entryInfoList(); |
381 | QFileInfoListIterator it( *list ); | 381 | QFileInfoListIterator it( *list ); |
382 | QFileInfo *file; | 382 | QFileInfo *file; |
383 | while ( (file=it.current()) ) | 383 | while ( (file=it.current()) ) |
384 | { // for each file... | 384 | { // for each file... |
385 | // If it is a dir and not .. or . then add it as a tab and go down. | 385 | // If it is a dir and not .. or . then add it as a tab and go down. |
386 | if(file->isDir()) | 386 | if(file->isDir()) |
387 | { | 387 | { |
388 | if(file->fileName() != ".." && file->fileName() != ".") | 388 | if(file->fileName() != ".." && file->fileName() != ".") |
389 | { | 389 | { |
390 | rescanFolder(directory + "/" + file->fileName()); | 390 | rescanFolder(directory + "/" + file->fileName()); |
391 | } | 391 | } |
392 | } | 392 | } |
393 | else | 393 | else |
394 | { | 394 | { |
395 | // If it is a backup file add to list. | 395 | // If it is a backup file add to list. |
396 | if(file->fileName().contains(EXTENSION)) | 396 | if(file->fileName().contains(EXTENSION)) |
397 | (void)new QListViewItem(restoreList, file->fileName()); | 397 | (void)new QListViewItem(restoreList, file->fileName()); |
398 | } | 398 | } |
399 | ++it; | 399 | ++it; |
400 | } | 400 | } |
401 | } | 401 | } |
402 | 402 | ||
403 | /** | 403 | /** |
404 | * Restore a backup file. | 404 | * Restore a backup file. |
405 | * Report errors or success | 405 | * Report errors or success |
406 | */ | 406 | */ |
407 | void BackupAndRestore::restore() | 407 | void BackupAndRestore::restore() |
408 | { | 408 | { |
409 | QListViewItem *restoreItem = restoreList->currentItem(); | 409 | QListViewItem *restoreItem = restoreList->currentItem(); |
410 | if(!restoreItem) | 410 | if(!restoreItem) |
411 | { | 411 | { |
412 | QMessageBox::critical(this, tr( "Message" ), | 412 | QMessageBox::critical(this, tr( "Message" ), |
413 | tr( "Please select something to restore." ),QString( tr( "Ok") ) ); | 413 | tr( "Please select something to restore." ),QString( tr( "Ok") ) ); |
414 | return; | 414 | return; |
415 | } | 415 | } |
416 | setCaption(tr("Backup and Restore... working...")); | 416 | setCaption(tr("Backup and Restore... working...")); |
417 | 417 | ||
418 | QString restoreFile = backupLocations[restoreSource->currentText()]; | 418 | QString restoreFile = backupLocations[restoreSource->currentText()]; |
419 | 419 | ||
420 | restoreFile += "/" + restoreItem->text(0); | 420 | restoreFile += "/" + restoreItem->text(0); |
421 | 421 | ||
422 | qDebug( restoreFile ); | 422 | qDebug( restoreFile ); |
423 | 423 | ||
424 | QString commandLine = QString( "cd %1 && tar -zxf %2 2> %3" ).arg( QDir::homeDirPath() ) | 424 | QString commandLine = QString( "cd %1 && tar -zxf %2 2> %3" ).arg( QDir::homeDirPath() ) |
425 | .arg( restoreFile.latin1() ) | 425 | .arg( restoreFile.latin1() ) |
426 | .arg( tempFileName.latin1() ); | 426 | .arg( tempFileName.latin1() ); |
427 | 427 | ||
428 | qDebug( commandLine ); | 428 | qDebug( commandLine ); |
429 | 429 | ||
430 | int r = system( commandLine ); | 430 | int r = system( commandLine ); |
431 | 431 | ||
432 | if(r != 0) | 432 | if(r != 0) |
433 | { | 433 | { |
434 | QString errorMsg= tr( "Error from System:\n" ) + (QString)strerror( errno ); | 434 | QString errorMsg= tr( "Error from System:\n" ) + (QString)strerror( errno ); |
435 | switch( QMessageBox::critical(this, tr( "Message" ), tr( "Restore Failed." ) + "\n" | 435 | switch( QMessageBox::critical(this, tr( "Message" ), tr( "Restore Failed." ) + "\n" |
436 | + errorMsg, QString( tr( "Ok") ), QString( tr( "Details" ) ) ) ) | 436 | + errorMsg, QString( tr( "Ok") ), QString( tr( "Details" ) ) ) ) |
437 | { | 437 | { |
438 | case 1: | 438 | case 1: |
439 | qWarning("Details pressed !"); | 439 | qWarning("Details pressed !"); |
440 | ErrorDialog* pErrDialog = new ErrorDialog( this, NULL, true ); | 440 | ErrorDialog* pErrDialog = new ErrorDialog( this, NULL, true ); |
441 | QFile errorFile( tempFileName ); | 441 | QFile errorFile( tempFileName ); |
442 | if ( errorFile.open(IO_ReadOnly) ) | 442 | if ( errorFile.open(IO_ReadOnly) ) |
443 | { | 443 | { |
444 | QTextStream t( &errorFile ); | 444 | QTextStream t( &errorFile ); |
445 | QString s; | 445 | QString s; |
446 | while ( !t.eof() ) | 446 | while ( !t.eof() ) |
447 | { // until end of file... | 447 | { // until end of file... |
448 | s += t.readLine(); // line of text excluding '\n' | 448 | s += t.readLine(); // line of text excluding '\n' |
449 | } | 449 | } |
450 | errorFile.close(); | 450 | errorFile.close(); |
451 | 451 | ||
452 | pErrDialog->m_textarea->setText( s ); | 452 | pErrDialog->m_textarea->setText( s ); |
453 | } | 453 | } |
454 | else | 454 | else |
diff --git a/noncore/settings/backup/main.cpp b/noncore/settings/backup/main.cpp index 7f03136..c254865 100644 --- a/noncore/settings/backup/main.cpp +++ b/noncore/settings/backup/main.cpp | |||
@@ -1,8 +1,8 @@ | |||
1 | #include "backuprestore.h" | 1 | #include "backuprestore.h" |
2 | #include "qnetworkprotocol.h" | 2 | #include "qnetworkprotocol.h" |
3 | #include <qpe/qpeapplication.h> | 3 | #include <qpe/qpeapplication.h> |
4 | #include <opie2/oapplicationfactory.h> | 4 | #include <opie2/oapplicationfactory.h> |
5 | 5 | ||
6 | 6 | ||
7 | OPIE_EXPORT_APP( OApplicationFactory<BackupAndRestore> ) | 7 | OPIE_EXPORT_APP( Opie::Core::OApplicationFactory<BackupAndRestore> ) |
8 | 8 | ||
diff --git a/noncore/tools/calculator/main.cpp b/noncore/tools/calculator/main.cpp index 145ba38..1e00358 100644 --- a/noncore/tools/calculator/main.cpp +++ b/noncore/tools/calculator/main.cpp | |||
@@ -1,25 +1,26 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2000 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2000 Trolltech AS. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of Qtopia Environment. | 4 | ** This file is part of Qtopia Environment. |
5 | ** | 5 | ** |
6 | ** This file may be distributed and/or modified under the terms of the | 6 | ** This file may be distributed and/or modified under the terms of the |
7 | ** GNU General Public License version 2 as published by the Free Software | 7 | ** GNU General Public License version 2 as published by the Free Software |
8 | ** Foundation and appearing in the file LICENSE.GPL included in the | 8 | ** Foundation and appearing in the file LICENSE.GPL included in the |
9 | ** packaging of this file. | 9 | ** packaging of this file. |
10 | ** | 10 | ** |
11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE | 11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE |
12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. | 12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. |
13 | ** | 13 | ** |
14 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. | 14 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. |
15 | ** | 15 | ** |
16 | ** Contact info@trolltech.com if any conditions of this licensing are | 16 | ** Contact info@trolltech.com if any conditions of this licensing are |
17 | ** not clear to you. | 17 | ** not clear to you. |
18 | ** | 18 | ** |
19 | **********************************************************************/ | 19 | **********************************************************************/ |
20 | 20 | ||
21 | #include "calculatorimpl.h" | 21 | #include "calculatorimpl.h" |
22 | 22 | ||
23 | #include <opie2/oapplicationfactory.h> | 23 | #include <opie2/oapplicationfactory.h> |
24 | 24 | ||
25 | using namespace Opie::Core; | ||
25 | OPIE_EXPORT_APP( OApplicationFactory<CalculatorImpl> ) | 26 | OPIE_EXPORT_APP( OApplicationFactory<CalculatorImpl> ) |