summaryrefslogtreecommitdiff
path: root/library
Unidiff
Diffstat (limited to 'library') (more/less context) (ignore whitespace changes)
-rw-r--r--library/lnkproperties.cpp19
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
57LnkProperties::LnkProperties( AppLnk* l, QWidget* parent ) 57LnkProperties::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
273void LnkProperties::done(int ok) 280void 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(),