-rw-r--r-- | library/lnkproperties.cpp | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/library/lnkproperties.cpp b/library/lnkproperties.cpp index bd43e21..e8baca6 100644 --- a/library/lnkproperties.cpp +++ b/library/lnkproperties.cpp | |||
@@ -68,128 +68,130 @@ LnkProperties::LnkProperties( AppLnk* l, QWidget* parent ) | |||
68 | } | 68 | } |
69 | 69 | ||
70 | if ( l->comment().isEmpty() ) { | 70 | if ( l->comment().isEmpty() ) { |
71 | d->comment->hide(); | 71 | d->comment->hide(); |
72 | d->commentLabel->hide(); | 72 | d->commentLabel->hide(); |
73 | } else { | 73 | } else { |
74 | d->comment->setText( l->comment() ); | 74 | d->comment->setText( l->comment() ); |
75 | } | 75 | } |
76 | 76 | ||
77 | connect(d->beam,SIGNAL(clicked()),this,SLOT(beamLnk())); | 77 | connect(d->beam,SIGNAL(clicked()),this,SLOT(beamLnk())); |
78 | if ( lnk->type().contains('/') ) { // A document? (#### better predicate needed) | 78 | if ( lnk->type().contains('/') ) { // A document? (#### better predicate needed) |
79 | connect(d->unlink,SIGNAL(clicked()),this,SLOT(unlinkLnk())); | 79 | connect(d->unlink,SIGNAL(clicked()),this,SLOT(unlinkLnk())); |
80 | connect(d->duplicate,SIGNAL(clicked()),this,SLOT(duplicateLnk())); | 80 | connect(d->duplicate,SIGNAL(clicked()),this,SLOT(duplicateLnk())); |
81 | connect(d->delicon,SIGNAL(clicked()),this,SLOT(unlinkIcon())); | 81 | connect(d->delicon,SIGNAL(clicked()),this,SLOT(unlinkIcon())); |
82 | 82 | ||
83 | d->docname->setReadOnly( FALSE ); | 83 | d->docname->setReadOnly( FALSE ); |
84 | d->preload->hide(); | 84 | d->preload->hide(); |
85 | d->spacer->hide(); | 85 | d->spacer->hide(); |
86 | 86 | ||
87 | // ### THIS MUST GO, FIX WIERD BUG in QLAYOUT | 87 | // ### THIS MUST GO, FIX WIERD BUG in QLAYOUT |
88 | d->categoryEdit->kludge(); | 88 | d->categoryEdit->kludge(); |
89 | 89 | ||
90 | d->categoryEdit->setCategories( lnk->categories(), | 90 | d->categoryEdit->setCategories( lnk->categories(), |
91 | "Document View", | 91 | "Document View", |
92 | tr("Document View") ); | 92 | tr("Document View") ); |
93 | setupLocations(); | 93 | setupLocations(); |
94 | } else { | 94 | } else { |
95 | d->unlink->hide(); | 95 | d->unlink->hide(); |
96 | d->duplicate->hide(); | 96 | d->duplicate->hide(); |
97 | d->beam->hide(); | 97 | d->beam->hide(); |
98 | d->hline->hide(); | 98 | d->hline->hide(); |
99 | d->locationLabel->hide(); | 99 | d->locationLabel->hide(); |
100 | d->locationCombo->hide(); | 100 | d->locationCombo->hide(); |
101 | 101 | ||
102 | // Can't edit categories, since the app .desktop files are global, | 102 | // Can't edit categories, since the app .desktop files are global, |
103 | // possibly read-only. | 103 | // possibly read-only. |
104 | d->categoryEdit->hide(); | 104 | d->categoryEdit->hide(); |
105 | 105 | ||
106 | d->docname->setReadOnly( TRUE ); | 106 | d->docname->setReadOnly( TRUE ); |
107 | 107 | ||
108 | if ( l->property("CanFastload") == "0" ) | 108 | if ( l->property("CanFastload") == "0" ) |
109 | d->preload->hide(); | 109 | d->preload->hide(); |
110 | 110 | ||
111 | Config cfg("Launcher"); | 111 | Config cfg("Launcher"); |
112 | cfg.setGroup("Preload"); | 112 | cfg.setGroup("Preload"); |
113 | QStringList apps = cfg.readListEntry("Apps",','); | 113 | QStringList apps = cfg.readListEntry("Apps",','); |
114 | d->preload->setChecked( apps.contains(l->exec()) ); | 114 | d->preload->setChecked( apps.contains(l->exec()) ); |
115 | if ( Global::isBuiltinCommand(lnk->exec()) ) | 115 | if ( Global::isBuiltinCommand(lnk->exec()) ) |
116 | d->preload->hide(); // builtins are always fast | 116 | d->preload->hide(); // builtins are always fast |
117 | 117 | ||
118 | currentLocation = 0; // apps not movable (yet) | 118 | currentLocation = 0; // apps not movable (yet) |
119 | } | 119 | } |
120 | setCaption( l->file()); | 120 | setCaption( l->file()); |
121 | } | 121 | } |
122 | 122 | ||
123 | LnkProperties::~LnkProperties() | 123 | LnkProperties::~LnkProperties() |
124 | { | 124 | { |
125 | } | 125 | } |
126 | 126 | ||
127 | void LnkProperties::unlinkLnk() | 127 | void LnkProperties::unlinkLnk() |
128 | { | 128 | { |
129 | if ( QPEMessageBox::confirmDelete( this, tr("Delete"), lnk->name() ) ) { | 129 | if ( QPEMessageBox::confirmDelete( this, tr("Delete"), lnk->name() ) ) { |
130 | if ( QFile::exists(lnk->file()) ) | 130 | if ( QFile::exists(lnk->file()) ) |
131 | lnk->removeFiles(); | 131 | lnk->removeFiles(); |
132 | else | ||
133 | QMessageBox::warning( this, tr("Delete"), tr("File does not exist.") ); | ||
132 | if ( QFile::exists(lnk->file()) ) { | 134 | if ( QFile::exists(lnk->file()) ) { |
133 | QMessageBox::warning( this, tr("Delete"), tr("File deletion failed.") ); | 135 | QMessageBox::warning( this, tr("Delete"), tr("File deletion failed.") ); |
134 | } else { | 136 | } else { |
135 | reject(); | 137 | reject(); |
136 | } | 138 | } |
137 | } | 139 | } |
138 | } | 140 | } |
139 | 141 | ||
140 | 142 | ||
141 | /* | 143 | /* |
142 | * remove only the link from documents, not also the file | 144 | * remove only the link from documents, not also the file |
143 | */ | 145 | */ |
144 | void LnkProperties::unlinkIcon() | 146 | void LnkProperties::unlinkIcon() |
145 | { | 147 | { |
146 | if ( QPEMessageBox::confirmDelete( this, tr("Delete Icon and leave file"), lnk->name() ) ) { | 148 | if ( QPEMessageBox::confirmDelete( this, tr("Delete Icon and leave file"), lnk->name() ) ) { |
147 | lnk->removeLinkFile(); | 149 | lnk->removeLinkFile(); |
148 | if ( QFile::exists(lnk->linkFile()) ) { | 150 | if ( QFile::exists(lnk->linkFile()) ) { |
149 | QMessageBox::warning( this, tr("Delete"), tr("Icon deletion failed.") ); | 151 | QMessageBox::warning( this, tr("Delete"), tr("Icon deletion failed.") ); |
150 | } else { | 152 | } else { |
151 | reject(); | 153 | reject(); |
152 | } | 154 | } |
153 | } | 155 | } |
154 | } | 156 | } |
155 | 157 | ||
156 | void LnkProperties::setupLocations() | 158 | void LnkProperties::setupLocations() |
157 | { | 159 | { |
158 | QFileInfo fi( lnk->file() ); | 160 | QFileInfo fi( lnk->file() ); |
159 | fileSize = fi.size(); | 161 | fileSize = fi.size(); |
160 | StorageInfo storage; | 162 | StorageInfo storage; |
161 | const QList<FileSystem> &fs = storage.fileSystems(); | 163 | const QList<FileSystem> &fs = storage.fileSystems(); |
162 | QListIterator<FileSystem> it ( fs ); | 164 | QListIterator<FileSystem> it ( fs ); |
163 | QString s; | 165 | QString s; |
164 | QString homeDir = getenv("HOME"); | 166 | QString homeDir = getenv("HOME"); |
165 | QString hardDiskHome; | 167 | QString hardDiskHome; |
166 | QString hardDiskPath; | 168 | QString hardDiskPath; |
167 | int index = 0; | 169 | int index = 0; |
168 | currentLocation = -1; | 170 | currentLocation = -1; |
169 | for ( ; it.current(); ++it ) { | 171 | for ( ; it.current(); ++it ) { |
170 | // we add 10k to the file size so we are sure we can also save the desktop file | 172 | // we add 10k to the file size so we are sure we can also save the desktop file |
171 | if ( (*it)->availBlocks() * (*it)->blockSize() > fileSize + 10000 ) { | 173 | if ( (*it)->availBlocks() * (*it)->blockSize() > fileSize + 10000 ) { |
172 | if ( (*it)->isRemovable() || | 174 | if ( (*it)->isRemovable() || |
173 | (*it)->disk() == "/dev/mtdblock1" || | 175 | (*it)->disk() == "/dev/mtdblock1" || |
174 | (*it)->disk() == "/dev/mtdblock/1" || (*it)->disk().left(13) == "/dev/mtdblock" ) { | 176 | (*it)->disk() == "/dev/mtdblock/1" || (*it)->disk().left(13) == "/dev/mtdblock" ) { |
175 | d->locationCombo->insertItem( (*it)->name(), index ); | 177 | d->locationCombo->insertItem( (*it)->name(), index ); |
176 | locations.append( ((*it)->isRemovable() ? (*it)->path() : homeDir) ); | 178 | locations.append( ((*it)->isRemovable() ? (*it)->path() : homeDir) ); |
177 | if ( lnk->file().contains( (*it)->path() ) ) { | 179 | if ( lnk->file().contains( (*it)->path() ) ) { |
178 | d->locationCombo->setCurrentItem( index ); | 180 | d->locationCombo->setCurrentItem( index ); |
179 | currentLocation = index; | 181 | currentLocation = index; |
180 | } | 182 | } |
181 | index++; | 183 | index++; |
182 | } else if ( (*it)->name().contains( "Hard Disk") && | 184 | } else if ( (*it)->name().contains( "Hard Disk") && |
183 | homeDir.contains( (*it)->path() ) && | 185 | homeDir.contains( (*it)->path() ) && |
184 | (*it)->path().length() > hardDiskHome.length() ) { | 186 | (*it)->path().length() > hardDiskHome.length() ) { |
185 | hardDiskHome = (*it)->name(); | 187 | hardDiskHome = (*it)->name(); |
186 | hardDiskPath = (*it)->path(); | 188 | hardDiskPath = (*it)->path(); |
187 | } | 189 | } |
188 | } | 190 | } |
189 | } | 191 | } |
190 | if ( !hardDiskHome.isEmpty() ) { | 192 | if ( !hardDiskHome.isEmpty() ) { |
191 | d->locationCombo->insertItem( hardDiskHome ); | 193 | d->locationCombo->insertItem( hardDiskHome ); |
192 | locations.append( hardDiskPath ); | 194 | locations.append( hardDiskPath ); |
193 | if ( currentLocation == -1 ) { // assume it's the hard disk | 195 | if ( currentLocation == -1 ) { // assume it's the hard disk |
194 | d->locationCombo->setCurrentItem( index ); | 196 | d->locationCombo->setCurrentItem( index ); |
195 | currentLocation = index; | 197 | currentLocation = index; |