-rw-r--r-- | library/lnkproperties.cpp | 19 |
1 files changed, 13 insertions, 6 deletions
diff --git a/library/lnkproperties.cpp b/library/lnkproperties.cpp index 50cf5af..8dca4ab 100644 --- a/library/lnkproperties.cpp +++ b/library/lnkproperties.cpp | |||
@@ -50,32 +50,37 @@ | |||
50 | #include <qsize.h> | 50 | #include <qsize.h> |
51 | #include <qcombobox.h> | 51 | #include <qcombobox.h> |
52 | #include <qregexp.h> | 52 | #include <qregexp.h> |
53 | #include <qbuttongroup.h> | 53 | #include <qbuttongroup.h> |
54 | 54 | ||
55 | #include <stdlib.h> | 55 | #include <stdlib.h> |
56 | 56 | ||
57 | LnkProperties::LnkProperties( AppLnk* l, QWidget* parent ) | 57 | LnkProperties::LnkProperties( AppLnk* l, QWidget* parent ) |
58 | : QDialog( parent, 0, TRUE ), lnk(l), fileSize( 0 ) | 58 | : QDialog( parent, 0, TRUE ), lnk(l), fileSize( 0 ) |
59 | { | 59 | { |
60 | setCaption( tr("Properties") ); | 60 | setCaption( tr("Properties") ); |
61 | 61 | ||
62 | QVBoxLayout *vbox = new QVBoxLayout( this ); | 62 | QVBoxLayout *vbox = new QVBoxLayout( this ); |
63 | d = new LnkPropertiesBase( this ); | 63 | d = new LnkPropertiesBase( this ); |
64 | vbox->add( d ); | 64 | vbox->add( d ); |
65 | 65 | ||
66 | // hide custom rotation feature for now, need a new implementation to fit quicklauch, | ||
67 | // is confusing for the user and doubtable useful since life rotation | ||
68 | d->rotate->hide(); | ||
69 | d->rotateButtons->hide(); | ||
70 | |||
66 | d->docname->setText(l->name()); | 71 | d->docname->setText(l->name()); |
67 | QString inf; | 72 | QString inf; |
68 | if ( l->type().isEmpty() ) { | 73 | if ( l->type().isEmpty() ) { |
69 | d->type->hide(); | 74 | d->type->hide(); |
70 | d->typeLabel->hide(); | 75 | d->typeLabel->hide(); |
71 | } else { | 76 | } else { |
72 | d->type->setText( l->type() ); | 77 | d->type->setText( l->type() ); |
73 | } | 78 | } |
74 | 79 | ||
75 | if ( l->comment().isEmpty() ) { | 80 | if ( l->comment().isEmpty() ) { |
76 | d->comment->hide(); | 81 | d->comment->hide(); |
77 | d->commentLabel->hide(); | 82 | d->commentLabel->hide(); |
78 | } else { | 83 | } else { |
79 | d->comment->setText( l->comment() ); | 84 | d->comment->setText( l->comment() ); |
80 | } | 85 | } |
81 | 86 | ||
@@ -102,33 +107,34 @@ LnkProperties::LnkProperties( AppLnk* l, QWidget* parent ) | |||
102 | d->duplicate->hide(); | 107 | d->duplicate->hide(); |
103 | d->beam->hide(); | 108 | d->beam->hide(); |
104 | d->hline->hide(); | 109 | d->hline->hide(); |
105 | d->locationLabel->hide(); | 110 | d->locationLabel->hide(); |
106 | d->locationCombo->hide(); | 111 | d->locationCombo->hide(); |
107 | 112 | ||
108 | // Can't edit categories, since the app .desktop files are global, | 113 | // Can't edit categories, since the app .desktop files are global, |
109 | // possibly read-only. | 114 | // possibly read-only. |
110 | d->categoryEdit->hide(); | 115 | d->categoryEdit->hide(); |
111 | 116 | ||
112 | d->docname->setReadOnly( TRUE ); | 117 | d->docname->setReadOnly( TRUE ); |
113 | 118 | ||
114 | if ( l->property("CanFastload") == "0" ) | 119 | if ( l->property("CanFastload") == "0" ) |
115 | d->preload->hide(); | 120 | d->preload->hide(); |
116 | if ( !l->property("Rotation"). isEmpty ()) { | 121 | if ( !l->property("Rotation"). isEmpty ()) { |
117 | d->rotate->setChecked ( true ); | 122 | d->rotate->setChecked ( true ); |
118 | d->rotateButtons->setButton((l->rotation().toInt()%360)/90); | 123 | //don't use rotate buttons for now (see comment above) |
124 | //d->rotateButtons->setButton((l->rotation().toInt()%360)/90); | ||
119 | } | 125 | } |
120 | else { | 126 | else { |
121 | d->rotateButtons->setEnabled(false); | 127 | d->rotateButtons->setEnabled(false); |
122 | } | 128 | } |
123 | 129 | ||
124 | Config cfg("Launcher"); | 130 | Config cfg("Launcher"); |
125 | cfg.setGroup("Preload"); | 131 | cfg.setGroup("Preload"); |
126 | QStringList apps = cfg.readListEntry("Apps",','); | 132 | QStringList apps = cfg.readListEntry("Apps",','); |
127 | d->preload->setChecked( apps.contains(l->exec()) ); | 133 | d->preload->setChecked( apps.contains(l->exec()) ); |
128 | if ( Global::isBuiltinCommand(lnk->exec()) ) | 134 | if ( Global::isBuiltinCommand(lnk->exec()) ) |
129 | d->preload->hide(); // builtins are always fast | 135 | d->preload->hide(); // builtins are always fast |
130 | 136 | ||
131 | currentLocation = 0; // apps not movable (yet) | 137 | currentLocation = 0; // apps not movable (yet) |
132 | } | 138 | } |
133 | } | 139 | } |
134 | 140 | ||
@@ -155,36 +161,37 @@ void LnkProperties::setupLocations() | |||
155 | StorageInfo storage; | 161 | StorageInfo storage; |
156 | const QList<FileSystem> &fs = storage.fileSystems(); | 162 | const QList<FileSystem> &fs = storage.fileSystems(); |
157 | QListIterator<FileSystem> it ( fs ); | 163 | QListIterator<FileSystem> it ( fs ); |
158 | QString s; | 164 | QString s; |
159 | QString homeDir = getenv("HOME"); | 165 | QString homeDir = getenv("HOME"); |
160 | QString hardDiskHome; | 166 | QString hardDiskHome; |
161 | QString hardDiskPath; | 167 | QString hardDiskPath; |
162 | int index = 0; | 168 | int index = 0; |
163 | currentLocation = -1; | 169 | currentLocation = -1; |
164 | for ( ; it.current(); ++it ) { | 170 | for ( ; it.current(); ++it ) { |
165 | // we add 10k to the file size so we are sure we can also save the desktop file | 171 | // we add 10k to the file size so we are sure we can also save the desktop file |
166 | if ( (ulong)(*it)->availBlocks() * (ulong)(*it)->blockSize() > (ulong)fileSize + 10000 ) { | 172 | if ( (ulong)(*it)->availBlocks() * (ulong)(*it)->blockSize() > (ulong)fileSize + 10000 ) { |
167 | if ( (*it)->isRemovable() || | 173 | if ( (*it)->isRemovable() || |
168 | (*it)->disk() == "/dev/mtdblock1" || | 174 | (*it)->disk() == "/dev/mtdblock1" || |
169 | (*it)->disk() == "/dev/mtdblock/1" || | 175 | (*it)->disk() == "/dev/mtdblock/1" || |
170 | (*it)->disk().left(13) == "/dev/mtdblock" || | 176 | (*it)->disk().left(13) == "/dev/mtdblock" || |
171 | (*it)->disk() == "/dev/mtdblock6" || | 177 | (*it)->disk() == "/dev/mtdblock6" || |
178 | (*it )->disk() == "/dev/root" || | ||
172 | (*it)->disk() == "tmpfs" ) { | 179 | (*it)->disk() == "tmpfs" ) { |
173 | d->locationCombo->insertItem( (*it)->name(), index ); | 180 | d->locationCombo->insertItem( (*it)->name(), index ); |
174 | locations.append( ( ((*it)->isRemovable() || | 181 | locations.append( ( ((*it)->isRemovable() || |
175 | (*it)->disk() == "/dev/mtdblock6" || | 182 | (*it)->disk() == "/dev/mtdblock6" || |
176 | (*it)->disk() == "tmpfs" ) | 183 | (*it)->disk() == "tmpfs" ) |
177 | ? (*it)->path() : homeDir) ); | 184 | ? (*it)->path() : homeDir) ); |
178 | if ( lnk->file().contains( (*it)->path() ) ) { | 185 | if ( lnk->file().contains( (*it)->path() ) ) { |
179 | d->locationCombo->setCurrentItem( index ); | 186 | d->locationCombo->setCurrentItem( index ); |
180 | currentLocation = index; | 187 | currentLocation = index; |
181 | } | 188 | } |
182 | index++; | 189 | index++; |
183 | } else if ( (*it)->name().contains( tr("Hard Disk") ) && | 190 | } else if ( (*it)->name().contains( tr("Hard Disk") ) && |
184 | homeDir.contains( (*it)->path() ) && | 191 | homeDir.contains( (*it)->path() ) && |
185 | (*it)->path().length() > hardDiskHome.length() ) { | 192 | (*it)->path().length() > hardDiskHome.length() ) { |
186 | hardDiskHome = (*it)->name(); | 193 | hardDiskHome = (*it)->name(); |
187 | hardDiskPath = (*it)->path(); | 194 | hardDiskPath = (*it)->path(); |
188 | } | 195 | } |
189 | } | 196 | } |
190 | } | 197 | } |
@@ -262,67 +269,67 @@ bool LnkProperties::copyFile( DocLnk &newdoc ) | |||
262 | } | 269 | } |
263 | newdoc.setFile( fn + fileExtn ); | 270 | newdoc.setFile( fn + fileExtn ); |
264 | newdoc.setLinkFile( fn + linkExtn ); | 271 | newdoc.setLinkFile( fn + linkExtn ); |
265 | 272 | ||
266 | // Copy file | 273 | // Copy file |
267 | FileManager fm; | 274 | FileManager fm; |
268 | if ( !fm.copyFile( *lnk, newdoc ) ) | 275 | if ( !fm.copyFile( *lnk, newdoc ) ) |
269 | return FALSE; | 276 | return FALSE; |
270 | return TRUE; | 277 | return TRUE; |
271 | } | 278 | } |
272 | 279 | ||
273 | void LnkProperties::done(int ok) | 280 | void LnkProperties::done(int ok) |
274 | { | 281 | { |
275 | if ( ok ) { | 282 | if ( ok ) { |
276 | bool changed=FALSE; | 283 | bool changed=FALSE; |
277 | bool reloadMime=FALSE; | 284 | bool reloadMime=FALSE; |
278 | 285 | ||
279 | if ( lnk->name() != d->docname->text() ) { | 286 | if ( lnk->name() != d->docname->text() ) { |
280 | lnk->setName(d->docname->text()); | 287 | lnk->setName(d->docname->text()); |
281 | changed=TRUE; | 288 | changed=TRUE; |
282 | } | 289 | } |
283 | if ( d->categoryEdit->isVisible() ) { | 290 | if ( d->categoryEdit->isVisible() ) { |
284 | QArray<int> tmp = d->categoryEdit->newCategories(); | 291 | QArray<int> tmp = d->categoryEdit->newCategories(); |
285 | if ( lnk->categories() != tmp ) { | 292 | if ( lnk->categories() != tmp ) { |
286 | lnk->setCategories( tmp ); | 293 | lnk->setCategories( tmp ); |
287 | changed = TRUE; | 294 | changed = TRUE; |
288 | } | 295 | } |
289 | } | 296 | } |
290 | if ( !d->rotate->isHidden()) { | 297 | if ( !d->rotate->isHidden()) { |
291 | QString newrot; | 298 | QString newrot; |
292 | 299 | ||
293 | if ( d->rotate->isChecked() ) { | 300 | if ( d->rotate->isChecked() ) { |
294 | int rot=0; | 301 | int rot=0; |
295 | for(; rot<4; rot++) { | 302 | for(; rot<4; rot++) { |
296 | if (d->rotateButtons->find(rot)->isOn()) | 303 | if (d->rotateButtons->find(rot)->isOn()) |
297 | break; | 304 | break; |
298 | } | 305 | } |
299 | newrot = QString::number((rot*90)%360); | 306 | newrot = QString::number((rot*90)%360); |
300 | } | 307 | } |
301 | if ( newrot != lnk->rotation() ) { | 308 | if ( newrot != lnk->rotation() ) { |
302 | lnk-> setRotation(newrot); | 309 | lnk-> setRotation(newrot); |
303 | changed = TRUE; | 310 | changed = TRUE; |
304 | reloadMime = TRUE; | 311 | reloadMime = TRUE; |
305 | } | 312 | } |
306 | } | 313 | } |
307 | if ( d->preload->isHidden() && d->locationCombo->currentItem() != currentLocation ) { | 314 | if ( d->preload->isHidden() && d->locationCombo->currentItem() != currentLocation ) { |
308 | moveLnk(); | 315 | moveLnk(); |
309 | } else if ( changed ) { | 316 | } else if ( changed ) { |
310 | lnk->writeLink(); | 317 | lnk->writeLink(); |
311 | } | 318 | } |
312 | 319 | ||
313 | if ( !d->preload->isHidden() ) { | 320 | if ( !d->preload->isHidden() ) { |
314 | Config cfg("Launcher"); | 321 | Config cfg("Launcher"); |
315 | cfg.setGroup("Preload"); | 322 | cfg.setGroup("Preload"); |
316 | QStringList apps = cfg.readListEntry("Apps",','); | 323 | QStringList apps = cfg.readListEntry("Apps",','); |
317 | QString exe = lnk->exec(); | 324 | QString exe = lnk->exec(); |
318 | if ( apps.contains(exe) != d->preload->isChecked() ) { | 325 | if ( apps.contains(exe) != d->preload->isChecked() ) { |
319 | if ( d->preload->isChecked() ) { | 326 | if ( d->preload->isChecked() ) { |
320 | apps.append(exe); | 327 | apps.append(exe); |
321 | #ifndef QT_NO_COP | 328 | #ifndef QT_NO_COP |
322 | QCopEnvelope e("QPE/Application/"+exe.local8Bit(), | 329 | QCopEnvelope e("QPE/Application/"+exe.local8Bit(), |
323 | "enablePreload()"); | 330 | "enablePreload()"); |
324 | #endif | 331 | #endif |
325 | } else { | 332 | } else { |
326 | apps.remove(exe); | 333 | apps.remove(exe); |
327 | #ifndef QT_NO_COP | 334 | #ifndef QT_NO_COP |
328 | QCopEnvelope e("QPE/Application/"+exe.local8Bit(), | 335 | QCopEnvelope e("QPE/Application/"+exe.local8Bit(), |