author | eilers <eilers> | 2003-02-07 08:52:58 (UTC) |
---|---|---|
committer | eilers <eilers> | 2003-02-07 08:52:58 (UTC) |
commit | 1561b2314308255c1fb181f1c979b38962c51373 (patch) (unidiff) | |
tree | 52c39a9d5f5727c53c0c723986b3e8ead88a8691 | |
parent | 31c0c1ca13b5eb13f920dfe11d21239be5d4b5e6 (diff) | |
download | opie-1561b2314308255c1fb181f1c979b38962c51373.zip opie-1561b2314308255c1fb181f1c979b38962c51373.tar.gz opie-1561b2314308255c1fb181f1c979b38962c51373.tar.bz2 |
Directories "." & ".." are removed from backup list ..
-rw-r--r-- | noncore/settings/backup/backuprestore.cpp | 6 |
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 | |||
@@ -64,194 +64,196 @@ BackupAndRestore::BackupAndRestore( QWidget* parent, const char* name) | |||
64 | //todo make less static here and use Storage class to get infos | 64 | //todo make less static here and use Storage class to get infos |
65 | if(totalLocations == 0){ | 65 | if(totalLocations == 0){ |
66 | backupLocations.insert("Documents", "/root/Documents"); | 66 | backupLocations.insert("Documents", "/root/Documents"); |
67 | backupLocations.insert("CF", "/mnt/cf"); | 67 | backupLocations.insert("CF", "/mnt/cf"); |
68 | backupLocations.insert("SD", "/mnt/card"); | 68 | backupLocations.insert("SD", "/mnt/card"); |
69 | } | 69 | } |
70 | else{ | 70 | else{ |
71 | for(int i = 0; i < totalLocations; i++){ | 71 | for(int i = 0; i < totalLocations; i++){ |
72 | backupLocations.insert(config.readEntry(QString("backupLocationName_%1").arg(i)), | 72 | backupLocations.insert(config.readEntry(QString("backupLocationName_%1").arg(i)), |
73 | config.readEntry(QString("backupLocation_%1").arg(i))); | 73 | config.readEntry(QString("backupLocation_%1").arg(i))); |
74 | } | 74 | } |
75 | } | 75 | } |
76 | QMap<QString, QString>::Iterator it; | 76 | QMap<QString, QString>::Iterator it; |
77 | for( it = backupLocations.begin(); it != backupLocations.end(); ++it ){ | 77 | for( it = backupLocations.begin(); it != backupLocations.end(); ++it ){ |
78 | storeToLocation->insertItem(it.key()); | 78 | storeToLocation->insertItem(it.key()); |
79 | restoreSource->insertItem(it.key()); | 79 | restoreSource->insertItem(it.key()); |
80 | } | 80 | } |
81 | 81 | ||
82 | // Read the list of items to ignore. | 82 | // Read the list of items to ignore. |
83 | QList<QString> dontBackupList; | 83 | QList<QString> dontBackupList; |
84 | dontBackupList.setAutoDelete(true); | 84 | dontBackupList.setAutoDelete(true); |
85 | config.setGroup("DontBackup"); | 85 | config.setGroup("DontBackup"); |
86 | int total = config.readNumEntry("Total", 0); | 86 | int total = config.readNumEntry("Total", 0); |
87 | for(int i = 0; i < total; i++){ | 87 | for(int i = 0; i < total; i++){ |
88 | dontBackupList.append(new QString(config.readEntry(QString("%1").arg(i), ""))); | 88 | dontBackupList.append(new QString(config.readEntry(QString("%1").arg(i), ""))); |
89 | } | 89 | } |
90 | 90 | ||
91 | QList<QListViewItem> list; | 91 | QList<QListViewItem> list; |
92 | getAllItems(backupList->firstChild(), list); | 92 | getAllItems(backupList->firstChild(), list); |
93 | 93 | ||
94 | for(uint i = 0; i < list.count(); i++){ | 94 | for(uint i = 0; i < list.count(); i++){ |
95 | QString text = list.at(i)->text(HEADER_NAME); | 95 | QString text = list.at(i)->text(HEADER_NAME); |
96 | for(uint i2 = 0; i2 < dontBackupList.count(); i2++){ | 96 | for(uint i2 = 0; i2 < dontBackupList.count(); i2++){ |
97 | if(*dontBackupList.at(i2) == text){ | 97 | if(*dontBackupList.at(i2) == text){ |
98 | selectItem(list.at(i)); | 98 | selectItem(list.at(i)); |
99 | break; | 99 | break; |
100 | } | 100 | } |
101 | } | 101 | } |
102 | } | 102 | } |
103 | } | 103 | } |
104 | 104 | ||
105 | BackupAndRestore::~BackupAndRestore(){ | 105 | BackupAndRestore::~BackupAndRestore(){ |
106 | QList<QListViewItem> list; | 106 | QList<QListViewItem> list; |
107 | getAllItems(backupList->firstChild(), list); | 107 | getAllItems(backupList->firstChild(), list); |
108 | 108 | ||
109 | Config config("BackupAndRestore"); | 109 | Config config("BackupAndRestore"); |
110 | config.setGroup("DontBackup"); | 110 | config.setGroup("DontBackup"); |
111 | config.clearGroup(); | 111 | config.clearGroup(); |
112 | 112 | ||
113 | int count = 0; | 113 | int count = 0; |
114 | for(uint i = 0; i < list.count(); i++){ | 114 | for(uint i = 0; i < list.count(); i++){ |
115 | if(list.at(i)->text(HEADER_BACKUP) == ""){ | 115 | if(list.at(i)->text(HEADER_BACKUP) == ""){ |
116 | config.writeEntry(QString("%1").arg(count), list.at(i)->text(HEADER_NAME)); | 116 | config.writeEntry(QString("%1").arg(count), list.at(i)->text(HEADER_NAME)); |
117 | count++; | 117 | count++; |
118 | } | 118 | } |
119 | } | 119 | } |
120 | config.writeEntry("Total", count); | 120 | config.writeEntry("Total", count); |
121 | } | 121 | } |
122 | 122 | ||
123 | QList<QListViewItem> BackupAndRestore::getAllItems(QListViewItem *item, QList<QListViewItem> &list){ | 123 | QList<QListViewItem> BackupAndRestore::getAllItems(QListViewItem *item, QList<QListViewItem> &list){ |
124 | while(item){ | 124 | while(item){ |
125 | if(item->childCount() > 0) | 125 | if(item->childCount() > 0) |
126 | getAllItems(item->firstChild(), list); | 126 | getAllItems(item->firstChild(), list); |
127 | list.append(item); | 127 | list.append(item); |
128 | item = item->nextSibling(); | 128 | item = item->nextSibling(); |
129 | } | 129 | } |
130 | return list; | 130 | return list; |
131 | } | 131 | } |
132 | 132 | ||
133 | /** | 133 | /** |
134 | * Selects and unselects the item by setting the HEADER_BACKUP to B or !. | 134 | * Selects and unselects the item by setting the HEADER_BACKUP to B or !. |
135 | * and changing the icon to match | 135 | * and changing the icon to match |
136 | * @param currentItem the item to swich the selection choice. | 136 | * @param currentItem the item to swich the selection choice. |
137 | */ | 137 | */ |
138 | void BackupAndRestore::selectItem(QListViewItem *currentItem){ | 138 | void BackupAndRestore::selectItem(QListViewItem *currentItem){ |
139 | if(!currentItem) | 139 | if(!currentItem) |
140 | return; | 140 | return; |
141 | 141 | ||
142 | if(currentItem->text(HEADER_BACKUP) == "B"){ | 142 | if(currentItem->text(HEADER_BACKUP) == "B"){ |
143 | currentItem->setPixmap(HEADER_NAME, Resource::loadPixmap("backup/null")); | 143 | currentItem->setPixmap(HEADER_NAME, Resource::loadPixmap("backup/null")); |
144 | currentItem->setText(HEADER_BACKUP, ""); | 144 | currentItem->setText(HEADER_BACKUP, ""); |
145 | } | 145 | } |
146 | else{ | 146 | else{ |
147 | currentItem->setPixmap(HEADER_NAME, Resource::loadPixmap("backup/check")); | 147 | currentItem->setPixmap(HEADER_NAME, Resource::loadPixmap("backup/check")); |
148 | currentItem->setText(HEADER_BACKUP, "B"); | 148 | currentItem->setText(HEADER_BACKUP, "B"); |
149 | } | 149 | } |
150 | } | 150 | } |
151 | 151 | ||
152 | void BackupAndRestore::scanForApplicationSettings(){ | 152 | void BackupAndRestore::scanForApplicationSettings(){ |
153 | QDir d(applicationSettings->text(BACKUP_LOCATION)); | 153 | QDir d(applicationSettings->text(BACKUP_LOCATION)); |
154 | d.setFilter( QDir::Dirs | QDir::Files | QDir::NoSymLinks ); | 154 | d.setFilter( QDir::Dirs | QDir::Files | QDir::NoSymLinks ); |
155 | const QFileInfoList *list = d.entryInfoList(); | 155 | const QFileInfoList *list = d.entryInfoList(); |
156 | QFileInfoListIterator it( *list ); | 156 | QFileInfoListIterator it( *list ); |
157 | QFileInfo *fi; | 157 | QFileInfo *fi; |
158 | while ( (fi=it.current()) ) { | 158 | while ( (fi=it.current()) ) { |
159 | // qDebug((d.path()+fi->fileName()).latin1()); | 159 | // qDebug((d.path()+fi->fileName()).latin1()); |
160 | QListViewItem *newItem = new QListViewItem(applicationSettings, fi->fileName()); | 160 | if ( ( fi->fileName() != "." ) && ( fi->fileName() != ".." ) ) { |
161 | selectItem(newItem); | 161 | QListViewItem *newItem = new QListViewItem(applicationSettings, fi->fileName()); |
162 | selectItem(newItem); | ||
163 | } | ||
162 | ++it; | 164 | ++it; |
163 | } | 165 | } |
164 | } | 166 | } |
165 | 167 | ||
166 | /** | 168 | /** |
167 | * The "Backup" button has been pressed. Get a list of all of the files that | 169 | * The "Backup" button has been pressed. Get a list of all of the files that |
168 | * should be backed up. If there are no files, emit and error and exit. | 170 | * should be backed up. If there are no files, emit and error and exit. |
169 | * Determine the file name to store the backup in. Backup the file(s) using | 171 | * Determine the file name to store the backup in. Backup the file(s) using |
170 | * tar and gzip --best. Report failure or success | 172 | * tar and gzip --best. Report failure or success |
171 | */ | 173 | */ |
172 | void BackupAndRestore::backupPressed(){ | 174 | void BackupAndRestore::backupPressed(){ |
173 | QString backupFiles; | 175 | QString backupFiles; |
174 | if(getBackupFiles(backupFiles, NULL) == 0){ | 176 | if(getBackupFiles(backupFiles, NULL) == 0){ |
175 | QMessageBox::critical(this, "Message", | 177 | QMessageBox::critical(this, "Message", |
176 | "No items selected.",QString("Ok") ); | 178 | "No items selected.",QString("Ok") ); |
177 | return; | 179 | return; |
178 | } | 180 | } |
179 | 181 | ||
180 | setCaption(tr("Backup and Restore... working...")); | 182 | setCaption(tr("Backup and Restore... working...")); |
181 | QString outputFile = backupLocations[storeToLocation->currentText()]; | 183 | QString outputFile = backupLocations[storeToLocation->currentText()]; |
182 | 184 | ||
183 | QDateTime time = QDateTime::currentDateTime(); | 185 | QDateTime time = QDateTime::currentDateTime(); |
184 | QString dateString = time.date().toString().replace(QRegExp(" "), ""); | 186 | QString dateString = time.date().toString().replace(QRegExp(" "), ""); |
185 | outputFile += "/" + dateString; | 187 | outputFile += "/" + dateString; |
186 | 188 | ||
187 | QString t = outputFile; | 189 | QString t = outputFile; |
188 | int c = 1; | 190 | int c = 1; |
189 | while(QFile::exists(outputFile + EXTENSION)){ | 191 | while(QFile::exists(outputFile + EXTENSION)){ |
190 | outputFile = t + QString("%1").arg(c); | 192 | outputFile = t + QString("%1").arg(c); |
191 | c++; | 193 | c++; |
192 | } | 194 | } |
193 | 195 | ||
194 | qDebug(QString("system(\"tar -c %1 | gzip > %2\")").arg(backupFiles).arg(outputFile).latin1()); | 196 | qDebug(QString("system(\"tar -c %1 | gzip > %2\")").arg(backupFiles).arg(outputFile).latin1()); |
195 | outputFile += EXTENSION; | 197 | outputFile += EXTENSION; |
196 | 198 | ||
197 | int r = system( QString("tar -c %1 | gzip > %2").arg(backupFiles).arg(outputFile).latin1() ); | 199 | int r = system( QString("tar -c %1 | gzip > %2").arg(backupFiles).arg(outputFile).latin1() ); |
198 | 200 | ||
199 | 201 | ||
200 | 202 | ||
201 | if(r != 0){ | 203 | if(r != 0){ |
202 | perror("Error: "); | 204 | perror("Error: "); |
203 | QString errorMsg="Error\n"+(QString)strerror(errno); | 205 | QString errorMsg="Error\n"+(QString)strerror(errno); |
204 | 206 | ||
205 | QMessageBox::critical(this, "Message", "Backup Failed.\n"+errorMsg, QString("Ok") ); | 207 | QMessageBox::critical(this, "Message", "Backup Failed.\n"+errorMsg, QString("Ok") ); |
206 | return; | 208 | return; |
207 | } | 209 | } |
208 | else{ | 210 | else{ |
209 | QMessageBox::information(this, "Message", "Backup Successfull.",QString("Ok") ); | 211 | QMessageBox::information(this, "Message", "Backup Successfull.",QString("Ok") ); |
210 | 212 | ||
211 | } | 213 | } |
212 | setCaption(tr("Backup and Restore")); | 214 | setCaption(tr("Backup and Restore")); |
213 | } | 215 | } |
214 | 216 | ||
215 | /*** | 217 | /*** |
216 | * Get a list of all of the files to backup. | 218 | * Get a list of all of the files to backup. |
217 | */ | 219 | */ |
218 | int BackupAndRestore::getBackupFiles(QString &backupFiles, QListViewItem *parent){ | 220 | int BackupAndRestore::getBackupFiles(QString &backupFiles, QListViewItem *parent){ |
219 | QListViewItem * currentItem; | 221 | QListViewItem * currentItem; |
220 | QString currentHome; | 222 | QString currentHome; |
221 | if(!parent) | 223 | if(!parent) |
222 | currentItem = backupList->firstChild(); | 224 | currentItem = backupList->firstChild(); |
223 | else{ | 225 | else{ |
224 | currentItem = parent->firstChild(); | 226 | currentItem = parent->firstChild(); |
225 | currentHome = parent->text(BACKUP_LOCATION); | 227 | currentHome = parent->text(BACKUP_LOCATION); |
226 | } | 228 | } |
227 | 229 | ||
228 | uint count = 0; | 230 | uint count = 0; |
229 | while( currentItem != 0 ){ | 231 | while( currentItem != 0 ){ |
230 | if(currentItem->text(HEADER_BACKUP) == "B" ){ | 232 | if(currentItem->text(HEADER_BACKUP) == "B" ){ |
231 | if(currentItem->childCount() == 0 ){ | 233 | if(currentItem->childCount() == 0 ){ |
232 | if(parent == NULL) | 234 | if(parent == NULL) |
233 | backupFiles += currentItem->text(BACKUP_LOCATION); | 235 | backupFiles += currentItem->text(BACKUP_LOCATION); |
234 | else | 236 | else |
235 | backupFiles += currentHome + currentItem->text(HEADER_NAME); | 237 | backupFiles += currentHome + currentItem->text(HEADER_NAME); |
236 | backupFiles += " "; | 238 | backupFiles += " "; |
237 | count++; | 239 | count++; |
238 | } | 240 | } |
239 | else{ | 241 | else{ |
240 | count += getBackupFiles(backupFiles, currentItem); | 242 | count += getBackupFiles(backupFiles, currentItem); |
241 | } | 243 | } |
242 | } | 244 | } |
243 | currentItem = currentItem->nextSibling(); | 245 | currentItem = currentItem->nextSibling(); |
244 | } | 246 | } |
245 | return count; | 247 | return count; |
246 | } | 248 | } |
247 | 249 | ||
248 | void BackupAndRestore::sourceDirChanged(int selection){ | 250 | void BackupAndRestore::sourceDirChanged(int selection){ |
249 | restoreList->clear(); | 251 | restoreList->clear(); |
250 | rescanFolder(backupLocations[restoreSource->text(selection)]); | 252 | rescanFolder(backupLocations[restoreSource->text(selection)]); |
251 | } | 253 | } |
252 | 254 | ||
253 | /** | 255 | /** |
254 | * Scans directory for any backup files. Will recursivly go down, | 256 | * Scans directory for any backup files. Will recursivly go down, |
255 | * but will not follow symlinks. | 257 | * but will not follow symlinks. |
256 | * @param directory - the directory to look in. | 258 | * @param directory - the directory to look in. |
257 | */ | 259 | */ |