author | mickeyl <mickeyl> | 2005-01-31 22:29:55 (UTC) |
---|---|---|
committer | mickeyl <mickeyl> | 2005-01-31 22:29:55 (UTC) |
commit | 9fb5fc66d59a91bfd4840ff17dc8338c34fce90c (patch) (unidiff) | |
tree | 9d377a3028d66b0d6d57268e840d990f3eb7154c | |
parent | e92a75664daf9df85a358a42ff2b66f6779c998f (diff) | |
download | opie-9fb5fc66d59a91bfd4840ff17dc8338c34fce90c.zip opie-9fb5fc66d59a91bfd4840ff17dc8338c34fce90c.tar.gz opie-9fb5fc66d59a91bfd4840ff17dc8338c34fce90c.tar.bz2 |
enable clone for SL5000 and SL5500 - it's not fully working yet due to
Mr. RAM Hog 'mkfs.jffs2' getting SIGTERMed by the OOM :/
-rw-r--r-- | noncore/settings/backup/backuprestore.cpp | 51 | ||||
-rw-r--r-- | share/backup/device_table-minimal.txt | 20 |
2 files changed, 55 insertions, 16 deletions
diff --git a/noncore/settings/backup/backuprestore.cpp b/noncore/settings/backup/backuprestore.cpp index 869c1b8..d028379 100644 --- a/noncore/settings/backup/backuprestore.cpp +++ b/noncore/settings/backup/backuprestore.cpp | |||
@@ -155,341 +155,360 @@ BackupAndRestore::~BackupAndRestore() | |||
155 | if ( QFile::exists( tempFileName ) ) | 155 | if ( QFile::exists( tempFileName ) ) |
156 | QFile::remove( tempFileName ); | 156 | QFile::remove( tempFileName ); |
157 | } | 157 | } |
158 | 158 | ||
159 | void BackupAndRestore::refreshBackupLocations() | 159 | void BackupAndRestore::refreshBackupLocations() |
160 | { | 160 | { |
161 | backupLocations.clear(); | 161 | backupLocations.clear(); |
162 | // Add cards | 162 | // Add cards |
163 | Opie::Core::OStorageInfo storage; | 163 | Opie::Core::OStorageInfo storage; |
164 | backupLocations.insert( "Documents", QDir::homeDirPath() + "/Documents" ); | 164 | backupLocations.insert( "Documents", QDir::homeDirPath() + "/Documents" ); |
165 | if ( storage.hasCf() ) | 165 | if ( storage.hasCf() ) |
166 | { | 166 | { |
167 | backupLocations.insert( "CF", storage.cfPath() ); | 167 | backupLocations.insert( "CF", storage.cfPath() ); |
168 | odebug << "Cf Path: " + storage.cfPath() << oendl; | 168 | odebug << "Cf Path: " + storage.cfPath() << oendl; |
169 | } | 169 | } |
170 | if ( storage.hasSd() ) | 170 | if ( storage.hasSd() ) |
171 | { | 171 | { |
172 | backupLocations.insert( "SD", storage.sdPath() ); | 172 | backupLocations.insert( "SD", storage.sdPath() ); |
173 | odebug << " Sd Path: " + storage.sdPath() << oendl; | 173 | odebug << " Sd Path: " + storage.sdPath() << oendl; |
174 | } | 174 | } |
175 | if ( storage.hasMmc() ) | 175 | if ( storage.hasMmc() ) |
176 | { | 176 | { |
177 | backupLocations.insert( "MMC", storage.mmcPath() ); | 177 | backupLocations.insert( "MMC", storage.mmcPath() ); |
178 | odebug << "Mmc Path: " + storage.mmcPath() << oendl; | 178 | odebug << "Mmc Path: " + storage.mmcPath() << oendl; |
179 | } | 179 | } |
180 | 180 | ||
181 | for ( QListViewItemIterator it( locationList ); it.current(); ++it ) | 181 | for ( QListViewItemIterator it( locationList ); it.current(); ++it ) |
182 | { | 182 | { |
183 | backupLocations.insert( it.current()->text( 0 ), it.current()->text( 0 ) ); | 183 | backupLocations.insert( it.current()->text( 0 ), it.current()->text( 0 ) ); |
184 | } | 184 | } |
185 | 185 | ||
186 | //update QComboBox | 186 | //update QComboBox |
187 | storeToLocation->clear(); | 187 | storeToLocation->clear(); |
188 | restoreSource->clear(); | 188 | restoreSource->clear(); |
189 | 189 | ||
190 | //read last locations | 190 | //read last locations |
191 | Config config("BackupAndRestore"); | 191 | Config config("BackupAndRestore"); |
192 | config.setGroup("LastLocation"); | 192 | config.setGroup("LastLocation"); |
193 | QString lastStoreLocation = config.readEntry( "LastStoreLocation", "" ); | 193 | QString lastStoreLocation = config.readEntry( "LastStoreLocation", "" ); |
194 | QString lastRestoreLocation = config.readEntry( "LastRestoreLocation", "" ); | 194 | QString lastRestoreLocation = config.readEntry( "LastRestoreLocation", "" ); |
195 | int locationIndex = 0; | 195 | int locationIndex = 0; |
196 | 196 | ||
197 | //fill QComboBox | 197 | //fill QComboBox |
198 | QMap<QString, QString>::Iterator it; | 198 | QMap<QString, QString>::Iterator it; |
199 | for( it = backupLocations.begin(); it != backupLocations.end(); ++it ) | 199 | for( it = backupLocations.begin(); it != backupLocations.end(); ++it ) |
200 | { | 200 | { |
201 | storeToLocation->insertItem(it.key()); | 201 | storeToLocation->insertItem(it.key()); |
202 | restoreSource->insertItem(it.key()); | 202 | restoreSource->insertItem(it.key()); |
203 | 203 | ||
204 | //check for last locations | 204 | //check for last locations |
205 | if ( it.key() == lastStoreLocation ) | 205 | if ( it.key() == lastStoreLocation ) |
206 | storeToLocation->setCurrentItem( locationIndex ); | 206 | storeToLocation->setCurrentItem( locationIndex ); |
207 | if ( it.key() == lastRestoreLocation ) | 207 | if ( it.key() == lastRestoreLocation ) |
208 | restoreSource->setCurrentItem( locationIndex ); | 208 | restoreSource->setCurrentItem( locationIndex ); |
209 | locationIndex++; | 209 | locationIndex++; |
210 | } | 210 | } |
211 | } | 211 | } |
212 | 212 | ||
213 | QList<QListViewItem> BackupAndRestore::getAllItems(QListViewItem *item, QList<QListViewItem> &list) | 213 | QList<QListViewItem> BackupAndRestore::getAllItems(QListViewItem *item, QList<QListViewItem> &list) |
214 | { | 214 | { |
215 | while(item) | 215 | while(item) |
216 | { | 216 | { |
217 | if(item->childCount() > 0) | 217 | if(item->childCount() > 0) |
218 | getAllItems(item->firstChild(), list); | 218 | getAllItems(item->firstChild(), list); |
219 | list.append(item); | 219 | list.append(item); |
220 | item = item->nextSibling(); | 220 | item = item->nextSibling(); |
221 | } | 221 | } |
222 | return list; | 222 | return list; |
223 | } | 223 | } |
224 | 224 | ||
225 | /** | 225 | /** |
226 | * Selects and unselects the item by setting the HEADER_BACKUP to B or !. | 226 | * Selects and unselects the item by setting the HEADER_BACKUP to B or !. |
227 | * and changing the icon to match | 227 | * and changing the icon to match |
228 | * @param currentItem the item to swich the selection choice. | 228 | * @param currentItem the item to swich the selection choice. |
229 | */ | 229 | */ |
230 | void BackupAndRestore::selectItem(QListViewItem *currentItem) | 230 | void BackupAndRestore::selectItem(QListViewItem *currentItem) |
231 | { | 231 | { |
232 | if(!currentItem) | 232 | if(!currentItem) |
233 | return; | 233 | return; |
234 | 234 | ||
235 | if(currentItem->text(HEADER_BACKUP) == "B") | 235 | if(currentItem->text(HEADER_BACKUP) == "B") |
236 | { | 236 | { |
237 | currentItem->setPixmap(HEADER_NAME, Resource::loadPixmap("backup/null")); | 237 | currentItem->setPixmap(HEADER_NAME, Resource::loadPixmap("backup/null")); |
238 | currentItem->setText(HEADER_BACKUP, ""); | 238 | currentItem->setText(HEADER_BACKUP, ""); |
239 | } | 239 | } |
240 | else | 240 | else |
241 | { | 241 | { |
242 | currentItem->setPixmap(HEADER_NAME, Resource::loadPixmap("backup/check")); | 242 | currentItem->setPixmap(HEADER_NAME, Resource::loadPixmap("backup/check")); |
243 | currentItem->setText(HEADER_BACKUP, "B"); | 243 | currentItem->setText(HEADER_BACKUP, "B"); |
244 | } | 244 | } |
245 | } | 245 | } |
246 | 246 | ||
247 | void BackupAndRestore::scanForApplicationSettings() | 247 | void BackupAndRestore::scanForApplicationSettings() |
248 | { | 248 | { |
249 | QDir d( QDir::homeDirPath() + "/" + QString( applicationSettings->text(BACKUP_LOCATION) ) ); | 249 | QDir d( QDir::homeDirPath() + "/" + QString( applicationSettings->text(BACKUP_LOCATION) ) ); |
250 | d.setFilter( QDir::Dirs | QDir::Files | QDir::NoSymLinks ); | 250 | d.setFilter( QDir::Dirs | QDir::Files | QDir::NoSymLinks ); |
251 | const QFileInfoList *list = d.entryInfoList(); | 251 | const QFileInfoList *list = d.entryInfoList(); |
252 | QFileInfoListIterator it( *list ); | 252 | QFileInfoListIterator it( *list ); |
253 | QFileInfo *fi; | 253 | QFileInfo *fi; |
254 | while ( (fi=it.current()) ) | 254 | while ( (fi=it.current()) ) |
255 | { | 255 | { |
256 | //odebug << (d.path()+"/"+fi->fileName()).latin1() << oendl; | 256 | //odebug << (d.path()+"/"+fi->fileName()).latin1() << oendl; |
257 | if ( ( fi->fileName() != "." ) && ( fi->fileName() != ".." ) ) | 257 | if ( ( fi->fileName() != "." ) && ( fi->fileName() != ".." ) ) |
258 | { | 258 | { |
259 | QListViewItem *newItem = new QListViewItem(applicationSettings, fi->fileName()); | 259 | QListViewItem *newItem = new QListViewItem(applicationSettings, fi->fileName()); |
260 | selectItem(newItem); | 260 | selectItem(newItem); |
261 | } | 261 | } |
262 | ++it; | 262 | ++it; |
263 | } | 263 | } |
264 | } | 264 | } |
265 | 265 | ||
266 | /** | 266 | /** |
267 | * The "Backup" button has been pressed. Get a list of all of the files that | 267 | * The "Backup" button has been pressed. Get a list of all of the files that |
268 | * should be backed up. If there are no files, emit and error and exit. | 268 | * should be backed up. If there are no files, emit and error and exit. |
269 | * Determine the file name to store the backup in. Backup the file(s) using | 269 | * Determine the file name to store the backup in. Backup the file(s) using |
270 | * tar and gzip --best. Report failure or success | 270 | * tar and gzip --best. Report failure or success |
271 | */ | 271 | */ |
272 | void BackupAndRestore::backup() | 272 | void BackupAndRestore::backup() |
273 | { | 273 | { |
274 | if ( cb_type_userdata->isChecked() ) | 274 | if ( cb_type_userdata->isChecked() ) |
275 | backupUserData(); | 275 | backupUserData(); |
276 | else | 276 | else |
277 | backupRootFs(); | 277 | backupRootFs(); |
278 | } | 278 | } |
279 | 279 | ||
280 | 280 | ||
281 | void BackupAndRestore::backupRootFs() | 281 | void BackupAndRestore::backupRootFs() |
282 | { | 282 | { |
283 | //#define MDEBUG | 283 | if ( ( ODevice::inst()->model() != Model_Zaurus_SL5000 ) && ( ODevice::inst()->model() != Model_Zaurus_SL5500 ) ) |
284 | #ifndef MDEBUG | 284 | { |
285 | QMessageBox::critical( this, "Opie-Backup", "<qt>This feature is not yet implemented.</qt>", "Bummer!" ); | 285 | QMessageBox::critical( this, "Not yet implemented!", "<qt>Sorry, support for this model is not yet done.</qt>", "Ok" ); |
286 | return; | 286 | return; |
287 | #endif | 287 | } |
288 | |||
289 | if ( !QFile::exists( "/usr/bin/mkfs.jffs2" ) && !QFile::exists( "/usr/sbin/mkfs.jffs2" ) ) | ||
290 | { | ||
291 | QMessageBox::critical( this, "Can't find utility!", "<qt>Can't find mkfs.jffs2 - Install mtd-utils.</qt>", "Ok" ); | ||
292 | return; | ||
293 | } | ||
294 | |||
288 | // call 'mount' and parse its output to gather the device on which the root partition is mounted | 295 | // call 'mount' and parse its output to gather the device on which the root partition is mounted |
289 | FILE* mountp = popen( "mount", "r" ); | 296 | FILE* mountp = popen( "mount", "r" ); |
290 | QString device; | 297 | QString device; |
291 | QString mountpoint; | 298 | QString mountpoint; |
292 | { | 299 | { |
293 | QTextStream mounto( mountp, IO_ReadOnly ); | 300 | QTextStream mounto( mountp, IO_ReadOnly ); |
294 | QString on; | 301 | QString on; |
295 | QString type; | 302 | QString type; |
296 | QString filesystem; | 303 | QString filesystem; |
297 | QString options; | 304 | QString options; |
298 | while ( !mounto.atEnd() ) | 305 | while ( !mounto.atEnd() ) |
299 | { | 306 | { |
300 | mounto >> device >> on >> mountpoint >> type >> filesystem >> options; | 307 | mounto >> device >> on >> mountpoint >> type >> filesystem >> options; |
301 | if ( mountpoint == "/" ) break; | 308 | if ( mountpoint == "/" ) break; |
302 | } | 309 | } |
303 | odebug << device << " is formatted w/ " << filesystem << " and mounted on " << mountpoint << oendl; | 310 | odebug << device << " is formatted w/ '" << filesystem << "' and mounted on '" << mountpoint << "'" << oendl; |
304 | 311 | ||
305 | if ( !mountpoint.startsWith( "/dev/mtdblock" ) ) | 312 | if ( !device.startsWith( "/dev/mtdblock" ) ) |
306 | { | 313 | { |
307 | QMessageBox::critical( this, "Can't backup!", QString( "<qt>unsupported rootfs %1 - needs to be /dev/mtdblockN</qt>").arg( device ), "Ok" ); | 314 | QMessageBox::critical( this, "Can't backup!", QString( "<qt>unsupported root device '%1' - needs to be /dev/mtdblockN</qt>").arg( device ), "Ok" ); |
308 | #ifndef MDEBUG | ||
309 | return; | 315 | return; |
310 | #endif | ||
311 | } | 316 | } |
312 | } // at this point, the QTextStream has been destroy and we can close the FILE* | 317 | } // at this point, the QTextStream has been destroy and we can close the FILE* |
313 | pclose( mountp ); | 318 | pclose( mountp ); |
314 | 319 | ||
315 | #ifndef MDEBUG | 320 | #if 1 |
316 | int rootmtd = device.right( 1 ).toInt(); | 321 | int rootmtd = device.right( 1 ).toInt(); |
317 | #else | 322 | #else |
318 | int rootmtd = 0; | 323 | int rootmtd = 0; |
319 | #endif | 324 | #endif |
320 | odebug << "root mtdblock seems to be '" << rootmtd << "'" << oendl; | 325 | odebug << "root mtdblock seems to be '" << rootmtd << "'" << oendl; |
321 | 326 | ||
322 | // scan /proc/mtd to gather the size and erasesize of the root mtdblock | 327 | // scan /proc/mtd to gather the size and erasesize of the root mtdblock |
323 | QFile procmtdf( "/proc/mtd" ); | 328 | QFile procmtdf( "/proc/mtd" ); |
324 | if ( !procmtdf.open( IO_ReadOnly ) ) | 329 | if ( !procmtdf.open( IO_ReadOnly ) ) |
325 | { | 330 | { |
326 | QMessageBox::critical( this, "Can't backup!", "<qt>Can't open /proc/mtd</qt>", "Ok" ); | 331 | QMessageBox::critical( this, "Can't backup!", "<qt>Can't open /proc/mtd</qt>", "Ok" ); |
332 | return; | ||
327 | } | 333 | } |
328 | 334 | ||
329 | QTextStream procmtd( &procmtdf ); | 335 | QTextStream procmtd( &procmtdf ); |
330 | for ( int i = 0; i <= rootmtd; ++i ) procmtd.readLine(); // skip uninteresting things | 336 | for ( int i = 0; i <= rootmtd; ++i ) procmtd.readLine(); // skip uninteresting things |
331 | QString dev; | 337 | QString dev; |
332 | QString size; | 338 | QString size; |
333 | QString erasesize; | 339 | QString erasesize; |
334 | QString devname; | 340 | QString devname; |
335 | procmtd >> dev >> size >> erasesize >> devname; | 341 | procmtd >> dev >> size >> erasesize >> devname; |
336 | 342 | ||
337 | odebug << "device " << dev << " size = " << size << ", erase size = " << erasesize << ", name = " << devname << "\"" << oendl; | 343 | odebug << "device " << dev << " size = " << size << ", erase size = " << erasesize << ", name = " << devname << "\"" << oendl; |
338 | 344 | ||
339 | // compute pad | 345 | // compute pad |
340 | QString pad = "--pad"; | 346 | QString pad = "--pad"; |
341 | switch ( ODevice::inst()->model() ) | 347 | switch ( ODevice::inst()->model() ) |
342 | { | 348 | { |
343 | case Model_Zaurus_SL5000: pad = "--pad=14680064"; break; | 349 | case Model_Zaurus_SL5000: pad = "--pad=14680064"; break; |
344 | case Model_Zaurus_SL5500: pad = "--pad=14680064"; break; | 350 | case Model_Zaurus_SL5500: pad = "--pad=14680064"; break; |
345 | // FIXME: Add Beagle and SIMpad | 351 | // FIXME: Add Beagle and SIMpad |
346 | } | 352 | } |
347 | 353 | ||
348 | // compute eraseblock | 354 | // compute eraseblock |
349 | QString eraseblock = "--eraseblock=0x" + erasesize; | 355 | QString eraseblock = "--eraseblock=0x" + erasesize; |
350 | 356 | ||
351 | // compute output | 357 | // compute output |
352 | QString outputFile = "--output=" + backupLocations[storeToLocation->currentText()]; | 358 | QString outputFile = "--output=" + backupLocations[storeToLocation->currentText()]; |
353 | QDateTime datetime = QDateTime::currentDateTime(); | 359 | QDateTime datetime = QDateTime::currentDateTime(); |
354 | QString dateString = QString::number( datetime.date().year() ) + QString::number( datetime.date().month() ).rightJustify(2, '0') + | 360 | QString dateString = QString::number( datetime.date().year() ) + QString::number( datetime.date().month() ).rightJustify(2, '0') + |
355 | QString::number( datetime.date().day() ).rightJustify(2, '0'); | 361 | QString::number( datetime.date().day() ).rightJustify(2, '0'); |
356 | outputFile += "/initrd.bin-" + dateString; | 362 | outputFile += "/initrd.bin-" + dateString; |
357 | 363 | ||
358 | // call mkfs.jffs2 to create the backup | 364 | // call mkfs.jffs2 to create the backup |
359 | QString cmdline = QString( "mkfs.jffs2 --root=/ %1 --little-endian %2 %3 -n" ).arg( outputFile ).arg( pad ).arg( eraseblock ); | 365 | QString cmdline = QString( "mkfs.jffs2 --faketime --root=/ %1 --little-endian %2 %3 -n" ).arg( outputFile ).arg( pad ).arg( eraseblock ); |
366 | cmdline.append( " --ignore=/tmp --ignore=/mnt --ignore=/var --ignore=/proc" ); | ||
360 | owarn << "Calling '" << cmdline << "'" << oendl; | 367 | owarn << "Calling '" << cmdline << "'" << oendl; |
361 | 368 | ||
362 | #ifndef MDEBUG | 369 | OWait *owait = new OWait(); |
363 | ::system( cmdline ); | 370 | Global::statusMessage( tr( "Backing up..." ) ); |
364 | #endif | 371 | owait->show(); |
372 | qApp->processEvents(); | ||
365 | 373 | ||
366 | // FIXME: Add image postprocessing for C7x0 and C8x0, for Beagle, for SIMpad | 374 | int r = ::system( cmdline ); |
375 | |||
376 | owait->hide(); | ||
377 | delete owait; | ||
378 | |||
379 | if ( r != 0 ) | ||
380 | { | ||
381 | perror("Error: "); | ||
382 | QString errorMsg = QString( tr( "<qt>%1</qt>" ).arg( strerror( errno ) ) ); | ||
383 | QMessageBox::critical(this, tr( "Backup Failed!" ), errorMsg, QString( tr( "Ok" ) ) ); | ||
384 | } | ||
367 | 385 | ||
386 | // FIXME: Add image postprocessing for C7x0 and C8x0, for Beagle, for SIMpad | ||
368 | } | 387 | } |
369 | 388 | ||
370 | void BackupAndRestore::backupUserData() | 389 | void BackupAndRestore::backupUserData() |
371 | { | 390 | { |
372 | QString backupFiles; | 391 | QString backupFiles; |
373 | if(getBackupFiles(backupFiles, NULL) == 0) | 392 | if(getBackupFiles(backupFiles, NULL) == 0) |
374 | { | 393 | { |
375 | QMessageBox::critical(this, "Message", | 394 | QMessageBox::critical(this, "Message", |
376 | "No items selected.",QString("Ok") ); | 395 | "No items selected.",QString("Ok") ); |
377 | return; | 396 | return; |
378 | } | 397 | } |
379 | 398 | ||
380 | OWait *owait = new OWait(); | 399 | OWait *owait = new OWait(); |
381 | Global::statusMessage( tr( "Backing up..." ) ); | 400 | Global::statusMessage( tr( "Backing up..." ) ); |
382 | owait->show(); | 401 | owait->show(); |
383 | qApp->processEvents(); | 402 | qApp->processEvents(); |
384 | 403 | ||
385 | QString outputFile = backupLocations[storeToLocation->currentText()]; | 404 | QString outputFile = backupLocations[storeToLocation->currentText()]; |
386 | 405 | ||
387 | QDateTime datetime = QDateTime::currentDateTime(); | 406 | QDateTime datetime = QDateTime::currentDateTime(); |
388 | QString dateString = QString::number( datetime.date().year() ) + QString::number( datetime.date().month() ).rightJustify(2, '0') + | 407 | QString dateString = QString::number( datetime.date().year() ) + QString::number( datetime.date().month() ).rightJustify(2, '0') + |
389 | QString::number( datetime.date().day() ).rightJustify(2, '0'); | 408 | QString::number( datetime.date().day() ).rightJustify(2, '0'); |
390 | 409 | ||
391 | outputFile += "/" + dateString; | 410 | outputFile += "/" + dateString; |
392 | 411 | ||
393 | QString t = outputFile; | 412 | QString t = outputFile; |
394 | int c = 1; | 413 | int c = 1; |
395 | while(QFile::exists(outputFile + EXTENSION)) | 414 | while(QFile::exists(outputFile + EXTENSION)) |
396 | { | 415 | { |
397 | outputFile = t + QString("%1").arg(c); | 416 | outputFile = t + QString("%1").arg(c); |
398 | c++; | 417 | c++; |
399 | } | 418 | } |
400 | 419 | ||
401 | // We execute tar and compressing its output with gzip.. | 420 | // We execute tar and compressing its output with gzip.. |
402 | // The error output will be written into a temp-file which could be provided | 421 | // The error output will be written into a temp-file which could be provided |
403 | // for debugging.. | 422 | // for debugging.. |
404 | odebug << "Storing file: " << outputFile.latin1() << "" << oendl; | 423 | odebug << "Storing file: " << outputFile.latin1() << "" << oendl; |
405 | outputFile += EXTENSION; | 424 | outputFile += EXTENSION; |
406 | 425 | ||
407 | QString commandLine = QString( "cd %1 && (tar -X %1 -cz %2 Applications/backup/exclude -f %3 ) 2> %4" ).arg( QDir::homeDirPath() ) | 426 | QString commandLine = QString( "cd %1 && (tar -X %1 -cz %2 Applications/backup/exclude -f %3 ) 2> %4" ).arg( QDir::homeDirPath() ) |
408 | .arg( getExcludeFile() ) | 427 | .arg( getExcludeFile() ) |
409 | .arg( backupFiles ) | 428 | .arg( backupFiles ) |
410 | .arg( outputFile.latin1() ) | 429 | .arg( outputFile.latin1() ) |
411 | .arg( tempFileName.latin1() ); | 430 | .arg( tempFileName.latin1() ); |
412 | 431 | ||
413 | odebug << commandLine << oendl; | 432 | odebug << commandLine << oendl; |
414 | 433 | ||
415 | int r = system( commandLine ); | 434 | int r = system( commandLine ); |
416 | 435 | ||
417 | owait->hide(); | 436 | owait->hide(); |
418 | delete owait; | 437 | delete owait; |
419 | 438 | ||
420 | //Error-Handling | 439 | //Error-Handling |
421 | if(r != 0) | 440 | if(r != 0) |
422 | { | 441 | { |
423 | perror("Error: "); | 442 | perror("Error: "); |
424 | QString errorMsg= tr( "Error from System:\n" ) + (QString)strerror( errno ); | 443 | QString errorMsg= tr( "Error from System:\n" ) + (QString)strerror( errno ); |
425 | 444 | ||
426 | switch( QMessageBox::critical(this, tr( "Message" ), tr( "Backup Failed!" ) + "\n" | 445 | switch( QMessageBox::critical(this, tr( "Message" ), tr( "Backup Failed!" ) + "\n" |
427 | + errorMsg, QString( tr( "Ok" ) ), QString( tr( "Details" ) ) ) ) | 446 | + errorMsg, QString( tr( "Ok" ) ), QString( tr( "Details" ) ) ) ) |
428 | { | 447 | { |
429 | 448 | ||
430 | case 1: | 449 | case 1: |
431 | owarn << "Details pressed !" << oendl; | 450 | owarn << "Details pressed !" << oendl; |
432 | ErrorDialog* pErrDialog = new ErrorDialog( this, NULL, true ); | 451 | ErrorDialog* pErrDialog = new ErrorDialog( this, NULL, true ); |
433 | QFile errorFile( tempFileName ); | 452 | QFile errorFile( tempFileName ); |
434 | if ( errorFile.open(IO_ReadOnly) ) | 453 | if ( errorFile.open(IO_ReadOnly) ) |
435 | { | 454 | { |
436 | QTextStream t( &errorFile ); | 455 | QTextStream t( &errorFile ); |
437 | QString s; | 456 | QString s; |
438 | while ( !t.eof() ) | 457 | while ( !t.eof() ) |
439 | { // until end of file... | 458 | { // until end of file... |
440 | s += t.readLine(); // line of text excluding '\n' | 459 | s += t.readLine(); // line of text excluding '\n' |
441 | } | 460 | } |
442 | errorFile.close(); | 461 | errorFile.close(); |
443 | 462 | ||
444 | pErrDialog->m_textarea->setText( s ); | 463 | pErrDialog->m_textarea->setText( s ); |
445 | } | 464 | } |
446 | else | 465 | else |
447 | { | 466 | { |
448 | pErrDialog->m_textarea->setText( "Unable to open File: /tmp/backup.er" ); | 467 | pErrDialog->m_textarea->setText( "Unable to open File: /tmp/backup.er" ); |
449 | } | 468 | } |
450 | QPEApplication::execDialog( pErrDialog ); | 469 | QPEApplication::execDialog( pErrDialog ); |
451 | delete pErrDialog; | 470 | delete pErrDialog; |
452 | break; | 471 | break; |
453 | } | 472 | } |
454 | setCaption(tr("Backup and Restore.. Failed !!")); | 473 | setCaption(tr("Backup and Restore.. Failed !!")); |
455 | return; | 474 | return; |
456 | } | 475 | } |
457 | else | 476 | else |
458 | { | 477 | { |
459 | QMessageBox::information(this, tr( "Message" ), tr( "Backup Successful." ), QString(tr( "Ok" ) ) ); | 478 | QMessageBox::information(this, tr( "Message" ), tr( "Backup Successful." ), QString(tr( "Ok" ) ) ); |
460 | } | 479 | } |
461 | 480 | ||
462 | //write store-location | 481 | //write store-location |
463 | Config config( "BackupAndRestore" ); | 482 | Config config( "BackupAndRestore" ); |
464 | config.setGroup( "LastLocation" ); | 483 | config.setGroup( "LastLocation" ); |
465 | config.writeEntry( "LastStoreLocation", storeToLocation->currentText() ); | 484 | config.writeEntry( "LastStoreLocation", storeToLocation->currentText() ); |
466 | 485 | ||
467 | setCaption(tr("Backup and Restore")); | 486 | setCaption(tr("Backup and Restore")); |
468 | } | 487 | } |
469 | 488 | ||
470 | /*** | 489 | /*** |
471 | * Get a list of all of the files to backup. | 490 | * Get a list of all of the files to backup. |
472 | */ | 491 | */ |
473 | int BackupAndRestore::getBackupFiles(QString &backupFiles, QListViewItem *parent) | 492 | int BackupAndRestore::getBackupFiles(QString &backupFiles, QListViewItem *parent) |
474 | { | 493 | { |
475 | QListViewItem * currentItem; | 494 | QListViewItem * currentItem; |
476 | QString currentHome; | 495 | QString currentHome; |
477 | if(!parent) | 496 | if(!parent) |
478 | currentItem = backupList->firstChild(); | 497 | currentItem = backupList->firstChild(); |
479 | else | 498 | else |
480 | { | 499 | { |
481 | currentItem = parent->firstChild(); | 500 | currentItem = parent->firstChild(); |
482 | currentHome = parent->text(BACKUP_LOCATION); | 501 | currentHome = parent->text(BACKUP_LOCATION); |
483 | } | 502 | } |
484 | 503 | ||
485 | uint count = 0; | 504 | uint count = 0; |
486 | while( currentItem != 0 ) | 505 | while( currentItem != 0 ) |
487 | { | 506 | { |
488 | if(currentItem->text(HEADER_BACKUP) == "B" ) | 507 | if(currentItem->text(HEADER_BACKUP) == "B" ) |
489 | { | 508 | { |
490 | if(currentItem->childCount() == 0 ) | 509 | if(currentItem->childCount() == 0 ) |
491 | { | 510 | { |
492 | if(parent == NULL) | 511 | if(parent == NULL) |
493 | backupFiles += currentItem->text(BACKUP_LOCATION); | 512 | backupFiles += currentItem->text(BACKUP_LOCATION); |
494 | else | 513 | else |
495 | backupFiles += currentHome + currentItem->text(HEADER_NAME); | 514 | backupFiles += currentHome + currentItem->text(HEADER_NAME); |
diff --git a/share/backup/device_table-minimal.txt b/share/backup/device_table-minimal.txt new file mode 100644 index 0000000..66cafae --- a/dev/null +++ b/share/backup/device_table-minimal.txt | |||
@@ -0,0 +1,20 @@ | |||
1 | /dev/initctl p 600 0 0 - - -- | ||
2 | /dev/apm_bios c 660 0 46 10 134 - -- | ||
3 | /dev/fb0 c 600 0 0 29 0 - -- | ||
4 | /dev/hda b 660 0 6 3 0 - -- | ||
5 | /dev/hda b 660 0 6 3 1 1 120 | ||
6 | /dev/kmem c 640 0 15 1 2 - -- | ||
7 | /dev/mem c 640 0 15 1 1 - -- | ||
8 | /dev/null c 666 0 0 1 3 - -- | ||
9 | /dev/ram b 640 0 0 1 0 0 14 | ||
10 | /dev/tty c 662 0 5 5 0 - -- | ||
11 | /dev/tty c 666 0 5 4 0 0 19 | ||
12 | /dev/ttyS c 640 0 5 4 64 0 11 | ||
13 | /dev/ttySA c 640 0 5 204 5 0 11 | ||
14 | /dev/zero c 644 0 0 1 5 -- | ||
15 | /dev/mtd c 660 0 6 90 0 0 28 | ||
16 | /dev/mtdblock b 640 0 0 31 0 0 18 | ||
17 | /dev/console c 662 0 5 5 1 -- | ||
18 | /bin/tinylogin f 4755 0 0 - - -- | ||
19 | /bin/mount f 4755 0 0 - - -- | ||
20 | /bin/umount f 4755 0 0 - - -- | ||