summaryrefslogtreecommitdiff
authoreilers <eilers>2003-02-07 08:52:58 (UTC)
committer eilers <eilers>2003-02-07 08:52:58 (UTC)
commit1561b2314308255c1fb181f1c979b38962c51373 (patch) (side-by-side diff)
tree52c39a9d5f5727c53c0c723986b3e8ead88a8691
parent31c0c1ca13b5eb13f920dfe11d21239be5d4b5e6 (diff)
downloadopie-1561b2314308255c1fb181f1c979b38962c51373.zip
opie-1561b2314308255c1fb181f1c979b38962c51373.tar.gz
opie-1561b2314308255c1fb181f1c979b38962c51373.tar.bz2
Directories "." & ".." are removed from backup list ..
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/settings/backup/backuprestore.cpp6
1 files changed, 4 insertions, 2 deletions
diff --git a/noncore/settings/backup/backuprestore.cpp b/noncore/settings/backup/backuprestore.cpp
index 81d7ed3..358f663 100644
--- a/noncore/settings/backup/backuprestore.cpp
+++ b/noncore/settings/backup/backuprestore.cpp
@@ -112,98 +112,100 @@ BackupAndRestore::~BackupAndRestore(){
int count = 0;
for(uint i = 0; i < list.count(); i++){
if(list.at(i)->text(HEADER_BACKUP) == ""){
config.writeEntry(QString("%1").arg(count), list.at(i)->text(HEADER_NAME));
count++;
}
}
config.writeEntry("Total", count);
}
QList<QListViewItem> BackupAndRestore::getAllItems(QListViewItem *item, QList<QListViewItem> &list){
while(item){
if(item->childCount() > 0)
getAllItems(item->firstChild(), list);
list.append(item);
item = item->nextSibling();
}
return list;
}
/**
* Selects and unselects the item by setting the HEADER_BACKUP to B or !.
* and changing the icon to match
* @param currentItem the item to swich the selection choice.
*/
void BackupAndRestore::selectItem(QListViewItem *currentItem){
if(!currentItem)
return;
if(currentItem->text(HEADER_BACKUP) == "B"){
currentItem->setPixmap(HEADER_NAME, Resource::loadPixmap("backup/null"));
currentItem->setText(HEADER_BACKUP, "");
}
else{
currentItem->setPixmap(HEADER_NAME, Resource::loadPixmap("backup/check"));
currentItem->setText(HEADER_BACKUP, "B");
}
}
void BackupAndRestore::scanForApplicationSettings(){
QDir d(applicationSettings->text(BACKUP_LOCATION));
d.setFilter( QDir::Dirs | QDir::Files | QDir::NoSymLinks );
const QFileInfoList *list = d.entryInfoList();
QFileInfoListIterator it( *list );
QFileInfo *fi;
while ( (fi=it.current()) ) {
// qDebug((d.path()+fi->fileName()).latin1());
- QListViewItem *newItem = new QListViewItem(applicationSettings, fi->fileName());
- selectItem(newItem);
+ if ( ( fi->fileName() != "." ) && ( fi->fileName() != ".." ) ) {
+ QListViewItem *newItem = new QListViewItem(applicationSettings, fi->fileName());
+ selectItem(newItem);
+ }
++it;
}
}
/**
* The "Backup" button has been pressed. Get a list of all of the files that
* should be backed up. If there are no files, emit and error and exit.
* Determine the file name to store the backup in. Backup the file(s) using
* tar and gzip --best. Report failure or success
*/
void BackupAndRestore::backupPressed(){
QString backupFiles;
if(getBackupFiles(backupFiles, NULL) == 0){
QMessageBox::critical(this, "Message",
"No items selected.",QString("Ok") );
return;
}
setCaption(tr("Backup and Restore... working..."));
QString outputFile = backupLocations[storeToLocation->currentText()];
QDateTime time = QDateTime::currentDateTime();
QString dateString = time.date().toString().replace(QRegExp(" "), "");
outputFile += "/" + dateString;
QString t = outputFile;
int c = 1;
while(QFile::exists(outputFile + EXTENSION)){
outputFile = t + QString("%1").arg(c);
c++;
}
qDebug(QString("system(\"tar -c %1 | gzip > %2\")").arg(backupFiles).arg(outputFile).latin1());
outputFile += EXTENSION;
int r = system( QString("tar -c %1 | gzip > %2").arg(backupFiles).arg(outputFile).latin1() );
if(r != 0){
perror("Error: ");
QString errorMsg="Error\n"+(QString)strerror(errno);
QMessageBox::critical(this, "Message", "Backup Failed.\n"+errorMsg, QString("Ok") );
return;
}
else{
QMessageBox::information(this, "Message", "Backup Successfull.",QString("Ok") );