-rw-r--r-- | libopie/oclickablelabel.cpp | 2 | ||||
-rw-r--r-- | libopie/ofileselector.cc | 9 | ||||
-rw-r--r-- | libopie/ofileselector.h | 2 | ||||
-rw-r--r-- | libopie/ofileselector/odefaultfactories.cpp | 4 | ||||
-rw-r--r-- | libopie/ofileselector/odefaultfactories.h | 1 | ||||
-rw-r--r-- | libopie/ofileselector/ofileselector.cpp | 3 | ||||
-rw-r--r-- | libopie/pim/opimaccessbackend.h | 4 | ||||
-rw-r--r-- | libopie/pim/opimaccesstemplate.h | 10 | ||||
-rw-r--r-- | libopie/pim/orecordlist.h | 4 | ||||
-rw-r--r-- | libopie/pim/otodo.cpp | 2 | ||||
-rw-r--r-- | libopie2/opiepim/backend/opimaccessbackend.h | 4 | ||||
-rw-r--r-- | libopie2/opiepim/core/opimaccesstemplate.h | 10 | ||||
-rw-r--r-- | libopie2/opiepim/orecordlist.h | 4 | ||||
-rw-r--r-- | libopie2/opiepim/otodo.cpp | 2 |
14 files changed, 28 insertions, 33 deletions
diff --git a/libopie/oclickablelabel.cpp b/libopie/oclickablelabel.cpp index 43a0524..5768529 100644 --- a/libopie/oclickablelabel.cpp +++ b/libopie/oclickablelabel.cpp | |||
@@ -1,88 +1,88 @@ | |||
1 | #include "oclickablelabel.h" | 1 | #include "oclickablelabel.h" |
2 | #include <stdio.h> | 2 | #include <stdio.h> |
3 | 3 | ||
4 | OClickableLabel::OClickableLabel(QWidget* parent, | 4 | OClickableLabel::OClickableLabel(QWidget* parent, |
5 | const char* name, | 5 | const char* name, |
6 | WFlags fl) : | 6 | WFlags fl) : |
7 | QLabel(parent,name,fl) | 7 | QLabel(parent,name,fl) |
8 | { | 8 | { |
9 | textInverted=false; | 9 | textInverted=false; |
10 | isToggle=false; | 10 | isToggle=false; |
11 | isDown=false; | 11 | isDown=false; |
12 | showState(false); | 12 | showState(false); |
13 | setFrameShadow(Sunken); | 13 | setFrameShadow(Sunken); |
14 | } | 14 | } |
15 | 15 | ||
16 | void OClickableLabel::setToggleButton(bool t) { | 16 | void OClickableLabel::setToggleButton(bool t) { |
17 | isToggle=t; | 17 | isToggle=t; |
18 | } | 18 | } |
19 | 19 | ||
20 | void OClickableLabel::mousePressEvent( QMouseEvent *e ) { | 20 | void OClickableLabel::mousePressEvent( QMouseEvent * /*e*/ ) { |
21 | if (isToggle && isDown) { | 21 | if (isToggle && isDown) { |
22 | showState(false); | 22 | showState(false); |
23 | } else { | 23 | } else { |
24 | showState(true); | 24 | showState(true); |
25 | } | 25 | } |
26 | } | 26 | } |
27 | 27 | ||
28 | void OClickableLabel::mouseReleaseEvent( QMouseEvent *e ) { | 28 | void OClickableLabel::mouseReleaseEvent( QMouseEvent *e ) { |
29 | if (rect().contains(e->pos()) && isToggle) isDown=!isDown; | 29 | if (rect().contains(e->pos()) && isToggle) isDown=!isDown; |
30 | 30 | ||
31 | if (isToggle && isDown) { | 31 | if (isToggle && isDown) { |
32 | showState(true); | 32 | showState(true); |
33 | } else { | 33 | } else { |
34 | showState(false); | 34 | showState(false); |
35 | } | 35 | } |
36 | 36 | ||
37 | if (rect().contains(e->pos())) { | 37 | if (rect().contains(e->pos())) { |
38 | if (isToggle) { | 38 | if (isToggle) { |
39 | emit toggled(isDown); | 39 | emit toggled(isDown); |
40 | } | 40 | } |
41 | emit clicked(); | 41 | emit clicked(); |
42 | } | 42 | } |
43 | } | 43 | } |
44 | 44 | ||
45 | void OClickableLabel::mouseMoveEvent( QMouseEvent *e ) { | 45 | void OClickableLabel::mouseMoveEvent( QMouseEvent *e ) { |
46 | if (rect().contains(e->pos())) { | 46 | if (rect().contains(e->pos())) { |
47 | if (isToggle && isDown) { | 47 | if (isToggle && isDown) { |
48 | showState(false); | 48 | showState(false); |
49 | } else { | 49 | } else { |
50 | showState(true); | 50 | showState(true); |
51 | } | 51 | } |
52 | } else { | 52 | } else { |
53 | if (isToggle && isDown) { | 53 | if (isToggle && isDown) { |
54 | showState(true); | 54 | showState(true); |
55 | } else { | 55 | } else { |
56 | showState(false); | 56 | showState(false); |
57 | } | 57 | } |
58 | } | 58 | } |
59 | } | 59 | } |
60 | 60 | ||
61 | void OClickableLabel::showState(bool on) { | 61 | void OClickableLabel::showState(bool on) { |
62 | if (on) { | 62 | if (on) { |
63 | //setFrameShape(Panel); | 63 | //setFrameShape(Panel); |
64 | setInverted(true); | 64 | setInverted(true); |
65 | setBackgroundMode(PaletteHighlight); | 65 | setBackgroundMode(PaletteHighlight); |
66 | } else { | 66 | } else { |
67 | //setFrameShape(NoFrame); | 67 | //setFrameShape(NoFrame); |
68 | setInverted(false); | 68 | setInverted(false); |
69 | setBackgroundMode(PaletteBackground); | 69 | setBackgroundMode(PaletteBackground); |
70 | } | 70 | } |
71 | repaint(); | 71 | repaint(); |
72 | } | 72 | } |
73 | 73 | ||
74 | void OClickableLabel::setInverted(bool on) { | 74 | void OClickableLabel::setInverted(bool on) { |
75 | if ( (!textInverted && on) || (textInverted && !on) ) { | 75 | if ( (!textInverted && on) || (textInverted && !on) ) { |
76 | QPalette pal=palette(); | 76 | QPalette pal=palette(); |
77 | QColor col=pal.color(QPalette::Normal, QColorGroup::Foreground); | 77 | QColor col=pal.color(QPalette::Normal, QColorGroup::Foreground); |
78 | col.setRgb(255-col.red(),255-col.green(),255-col.blue()); | 78 | col.setRgb(255-col.red(),255-col.green(),255-col.blue()); |
79 | pal.setColor(QPalette::Normal, QColorGroup::Foreground, col); | 79 | pal.setColor(QPalette::Normal, QColorGroup::Foreground, col); |
80 | setPalette(pal); | 80 | setPalette(pal); |
81 | textInverted=!textInverted; | 81 | textInverted=!textInverted; |
82 | } | 82 | } |
83 | } | 83 | } |
84 | 84 | ||
85 | void OClickableLabel::setOn(bool on) { | 85 | void OClickableLabel::setOn(bool on) { |
86 | isDown=on; | 86 | isDown=on; |
87 | showState(isDown); | 87 | showState(isDown); |
88 | } | 88 | } |
diff --git a/libopie/ofileselector.cc b/libopie/ofileselector.cc index 9534667..6a6a300 100644 --- a/libopie/ofileselector.cc +++ b/libopie/ofileselector.cc | |||
@@ -186,1115 +186,1114 @@ void OFileSelector::reread() | |||
186 | const DocLnk *OFileSelector::selected() | 186 | const DocLnk *OFileSelector::selected() |
187 | { | 187 | { |
188 | DocLnk *lnk = new DocLnk(selectedDocument() ); | 188 | DocLnk *lnk = new DocLnk(selectedDocument() ); |
189 | return lnk; | 189 | return lnk; |
190 | } | 190 | } |
191 | 191 | ||
192 | void OFileSelector::setYesCancelVisible( bool show ) | 192 | void OFileSelector::setYesCancelVisible( bool show ) |
193 | { | 193 | { |
194 | initializeYes(); // FIXME if YesCancel is not shown we will initialize it to hide it :( | 194 | initializeYes(); // FIXME if YesCancel is not shown we will initialize it to hide it :( |
195 | m_shYesNo = show; | 195 | m_shYesNo = show; |
196 | if( m_shYesNo ) | 196 | if( m_shYesNo ) |
197 | m_boxOk->show(); | 197 | m_boxOk->show(); |
198 | else | 198 | else |
199 | m_boxOk->hide(); | 199 | m_boxOk->hide(); |
200 | 200 | ||
201 | } | 201 | } |
202 | void OFileSelector::setToolbarVisible( bool show ) | 202 | void OFileSelector::setToolbarVisible( bool show ) |
203 | { | 203 | { |
204 | m_shTool = show; | 204 | m_shTool = show; |
205 | initializeListView(); // FIXME see above waste of memory | 205 | initializeListView(); // FIXME see above waste of memory |
206 | if(!m_shTool ){ | 206 | if(!m_shTool ){ |
207 | m_location->hide(); | 207 | m_location->hide(); |
208 | m_up->hide(); | 208 | m_up->hide(); |
209 | m_homeButton->hide(); | 209 | m_homeButton->hide(); |
210 | m_docButton->hide(); | 210 | m_docButton->hide(); |
211 | }else{ | 211 | }else{ |
212 | m_location->show(); | 212 | m_location->show(); |
213 | m_up->show(); | 213 | m_up->show(); |
214 | m_homeButton->show(); | 214 | m_homeButton->show(); |
215 | m_docButton->show(); | 215 | m_docButton->show(); |
216 | } | 216 | } |
217 | } | 217 | } |
218 | void OFileSelector::setPermissionBarVisible( bool show ) | 218 | void OFileSelector::setPermissionBarVisible( bool show ) |
219 | { | 219 | { |
220 | m_shPerm = show; | 220 | m_shPerm = show; |
221 | initializePerm(); | 221 | initializePerm(); |
222 | if( m_shPerm ) | 222 | if( m_shPerm ) |
223 | m_checkPerm->show(); | 223 | m_checkPerm->show(); |
224 | else | 224 | else |
225 | m_checkPerm->hide(); | 225 | m_checkPerm->hide(); |
226 | } | 226 | } |
227 | void OFileSelector::setLineEditVisible( bool show ) | 227 | void OFileSelector::setLineEditVisible( bool show ) |
228 | { | 228 | { |
229 | if( show ){ | 229 | if( show ){ |
230 | initializeName(); | 230 | initializeName(); |
231 | m_boxName->show(); | 231 | m_boxName->show(); |
232 | }else{ | 232 | }else{ |
233 | if( m_shLne && m_boxName != 0 ){ // check if we showed before this is the way to go | 233 | if( m_shLne && m_boxName != 0 ){ // check if we showed before this is the way to go |
234 | m_boxName->hide(); | 234 | m_boxName->hide(); |
235 | } | 235 | } |
236 | } | 236 | } |
237 | m_shLne = show; | 237 | m_shLne = show; |
238 | } | 238 | } |
239 | 239 | ||
240 | void OFileSelector::setChooserVisible( bool show ) | 240 | void OFileSelector::setChooserVisible( bool show ) |
241 | { | 241 | { |
242 | m_shChooser = show; | 242 | m_shChooser = show; |
243 | initializeChooser(); | 243 | initializeChooser(); |
244 | if( m_shChooser ){ | 244 | if( m_shChooser ){ |
245 | m_boxView->hide(); | 245 | m_boxView->hide(); |
246 | }else{ | 246 | }else{ |
247 | m_boxView->show(); | 247 | m_boxView->show(); |
248 | } | 248 | } |
249 | } | 249 | } |
250 | 250 | ||
251 | QCheckBox* OFileSelector::permissionCheckbox() | 251 | QCheckBox* OFileSelector::permissionCheckbox() |
252 | { | 252 | { |
253 | if( m_selector == NORMAL ) | 253 | if( m_selector == NORMAL ) |
254 | return 0l; | 254 | return 0l; |
255 | else | 255 | else |
256 | return m_checkPerm; | 256 | return m_checkPerm; |
257 | } | 257 | } |
258 | bool OFileSelector::setPermission()const | 258 | bool OFileSelector::setPermission()const |
259 | { | 259 | { |
260 | return m_checkPerm == 0 ? false : m_checkPerm->isChecked(); | 260 | return m_checkPerm == 0 ? false : m_checkPerm->isChecked(); |
261 | } | 261 | } |
262 | void OFileSelector::setPermissionChecked( bool check ) | 262 | void OFileSelector::setPermissionChecked( bool check ) |
263 | { | 263 | { |
264 | if( m_checkPerm ) | 264 | if( m_checkPerm ) |
265 | m_checkPerm->setChecked( check ); | 265 | m_checkPerm->setChecked( check ); |
266 | } | 266 | } |
267 | 267 | ||
268 | void OFileSelector::setMode(int mode) // FIXME do direct raising | 268 | void OFileSelector::setMode(int mode) // FIXME do direct raising |
269 | { | 269 | { |
270 | m_mode = mode; | 270 | m_mode = mode; |
271 | if( m_selector == NORMAL ) | 271 | if( m_selector == NORMAL ) |
272 | return; | 272 | return; |
273 | } | 273 | } |
274 | void OFileSelector::setShowDirs(bool ) | 274 | void OFileSelector::setShowDirs(bool ) |
275 | { | 275 | { |
276 | m_dir = true; | 276 | m_dir = true; |
277 | reparse(); | 277 | reparse(); |
278 | } | 278 | } |
279 | void OFileSelector::setCaseSensetive(bool caSe ) | 279 | void OFileSelector::setCaseSensetive(bool caSe ) |
280 | { | 280 | { |
281 | m_case = caSe; | 281 | m_case = caSe; |
282 | reparse(); | 282 | reparse(); |
283 | } | 283 | } |
284 | void OFileSelector::setShowFiles(bool show ) | 284 | void OFileSelector::setShowFiles(bool show ) |
285 | { | 285 | { |
286 | m_files = show; | 286 | m_files = show; |
287 | reparse(); | 287 | reparse(); |
288 | } | 288 | } |
289 | /// | 289 | /// |
290 | bool OFileSelector::cd(const QString &path ) | 290 | bool OFileSelector::cd(const QString &path ) |
291 | { | 291 | { |
292 | m_currentDir = path; | 292 | m_currentDir = path; |
293 | reparse(); | 293 | reparse(); |
294 | return true; | 294 | return true; |
295 | } | 295 | } |
296 | void OFileSelector::setSelector(int mode ) | 296 | void OFileSelector::setSelector(int mode ) |
297 | { | 297 | { |
298 | QString text; | 298 | QString text; |
299 | switch( mode ){ | 299 | switch( mode ){ |
300 | case NORMAL: | 300 | case NORMAL: |
301 | text = tr("Documents"); | 301 | text = tr("Documents"); |
302 | break; | 302 | break; |
303 | case EXTENDED: | 303 | case EXTENDED: |
304 | text = tr("Files"); | 304 | text = tr("Files"); |
305 | break; | 305 | break; |
306 | case EXTENDED_ALL: | 306 | case EXTENDED_ALL: |
307 | text = tr("All Files"); | 307 | text = tr("All Files"); |
308 | break; | 308 | break; |
309 | } | 309 | } |
310 | slotViewCheck( text ); | 310 | slotViewCheck( text ); |
311 | } | 311 | } |
312 | 312 | ||
313 | void OFileSelector::setPopupMenu(QPopupMenu *popup ) | 313 | void OFileSelector::setPopupMenu(QPopupMenu *popup ) |
314 | { | 314 | { |
315 | m_custom = popup; | 315 | m_custom = popup; |
316 | m_showPopup = true; | 316 | m_showPopup = true; |
317 | } | 317 | } |
318 | 318 | ||
319 | //void OFileSelector::updateL | 319 | //void OFileSelector::updateL |
320 | 320 | ||
321 | QString OFileSelector::selectedName() const | 321 | QString OFileSelector::selectedName() const |
322 | { | 322 | { |
323 | QString name; | 323 | QString name; |
324 | if( m_selector == NORMAL ){ | 324 | if( m_selector == NORMAL ){ |
325 | DocLnk lnk = m_select->selectedDocument(); | 325 | DocLnk lnk = m_select->selectedDocument(); |
326 | name = lnk.file(); | 326 | name = lnk.file(); |
327 | }else if( m_selector == EXTENDED || m_selector == EXTENDED_ALL ){ | 327 | }else if( m_selector == EXTENDED || m_selector == EXTENDED_ALL ){ |
328 | if ( m_shLne ) { | 328 | if ( m_shLne ) { |
329 | name = m_currentDir + "/" +m_edit->text(); | 329 | name = m_currentDir + "/" +m_edit->text(); |
330 | }else{ | 330 | }else{ |
331 | QListViewItem *item = m_View->currentItem(); | 331 | QListViewItem *item = m_View->currentItem(); |
332 | if( item != 0 ) | 332 | if( item != 0 ) |
333 | name = m_currentDir + "/" + item->text( 1 ); | 333 | name = m_currentDir + "/" + item->text( 1 ); |
334 | } | 334 | } |
335 | }else { // installed view | 335 | }else { // installed view |
336 | ; | 336 | ; |
337 | } | 337 | } |
338 | return name; | 338 | return name; |
339 | } | 339 | } |
340 | QStringList OFileSelector::selectedNames()const | 340 | QStringList OFileSelector::selectedNames()const |
341 | { | 341 | { |
342 | QStringList list; | 342 | QStringList list; |
343 | if( m_selector == NORMAL ){ | 343 | if( m_selector == NORMAL ){ |
344 | list << selectedName(); | 344 | list << selectedName(); |
345 | }else if ( m_selector == EXTENDED || m_selector == EXTENDED_ALL ) { | 345 | }else if ( m_selector == EXTENDED || m_selector == EXTENDED_ALL ) { |
346 | list << selectedName(); // FIXME implement multiple Selections | 346 | list << selectedName(); // FIXME implement multiple Selections |
347 | } | 347 | } |
348 | return list; | 348 | return list; |
349 | } | 349 | } |
350 | /** If mode is set to the Dir selection this will return the selected path. | 350 | /** If mode is set to the Dir selection this will return the selected path. |
351 | * | 351 | * |
352 | * | 352 | * |
353 | */ | 353 | */ |
354 | QString OFileSelector::selectedPath()const | 354 | QString OFileSelector::selectedPath()const |
355 | { | 355 | { |
356 | QString path; | 356 | QString path; |
357 | if( m_selector == NORMAL ){ | 357 | if( m_selector == NORMAL ){ |
358 | path = QPEApplication::documentDir(); | 358 | path = QPEApplication::documentDir(); |
359 | }else if( m_selector == EXTENDED || m_selector == EXTENDED_ALL ){ | 359 | }else if( m_selector == EXTENDED || m_selector == EXTENDED_ALL ){ |
360 | ; | 360 | ; |
361 | } | 361 | } |
362 | return path; | 362 | return path; |
363 | } | 363 | } |
364 | QStringList OFileSelector::selectedPaths() const | 364 | QStringList OFileSelector::selectedPaths() const |
365 | { | 365 | { |
366 | QStringList list; | 366 | QStringList list; |
367 | list << selectedPath(); | 367 | list << selectedPath(); |
368 | return list; | 368 | return list; |
369 | } | 369 | } |
370 | QString OFileSelector::directory()const | 370 | QString OFileSelector::directory()const |
371 | { | 371 | { |
372 | if( m_selector == NORMAL ) | 372 | if( m_selector == NORMAL ) |
373 | return QPEApplication::documentDir(); | 373 | return QPEApplication::documentDir(); |
374 | 374 | ||
375 | return QDir(m_currentDir).absPath(); | 375 | return QDir(m_currentDir).absPath(); |
376 | } | 376 | } |
377 | 377 | ||
378 | int OFileSelector::fileCount() | 378 | int OFileSelector::fileCount() const |
379 | { | 379 | { |
380 | int count; | 380 | int count; |
381 | switch( m_selector ){ | 381 | switch( m_selector ){ |
382 | case NORMAL: | 382 | case NORMAL: |
383 | count = m_select->fileCount(); | 383 | count = m_select->fileCount(); |
384 | break; | 384 | break; |
385 | //case CUSTOM: | 385 | //case CUSTOM: |
386 | case EXTENDED: | 386 | case EXTENDED: |
387 | case EXTENDED_ALL: | 387 | case EXTENDED_ALL: |
388 | default: | 388 | default: |
389 | count = m_View->childCount(); | 389 | count = m_View->childCount(); |
390 | break; | 390 | break; |
391 | } | 391 | } |
392 | return count; | 392 | return count; |
393 | } | 393 | } |
394 | DocLnk OFileSelector::selectedDocument() const | 394 | DocLnk OFileSelector::selectedDocument() const |
395 | { | 395 | { |
396 | DocLnk lnk; | 396 | DocLnk lnk; |
397 | switch( m_selector ){ | 397 | switch( m_selector ){ |
398 | case NORMAL:{ | 398 | case NORMAL:{ |
399 | lnk = m_select->selectedDocument(); | 399 | lnk = m_select->selectedDocument(); |
400 | break; | 400 | break; |
401 | } | 401 | } |
402 | case EXTENDED: | 402 | case EXTENDED: |
403 | case EXTENDED_ALL: | 403 | case EXTENDED_ALL: |
404 | default: | 404 | default: |
405 | lnk = DocLnk( selectedName() ); // new DocLnk | 405 | lnk = DocLnk( selectedName() ); // new DocLnk |
406 | break; | 406 | break; |
407 | } | 407 | } |
408 | return lnk; | 408 | return lnk; |
409 | } | 409 | } |
410 | QValueList<DocLnk> OFileSelector::selectedDocuments() const | 410 | QValueList<DocLnk> OFileSelector::selectedDocuments() const |
411 | { | 411 | { |
412 | QValueList<DocLnk> docs; | 412 | QValueList<DocLnk> docs; |
413 | docs.append( selectedDocument() ); | 413 | docs.append( selectedDocument() ); |
414 | return docs; | 414 | return docs; |
415 | } | 415 | } |
416 | 416 | ||
417 | 417 | ||
418 | // slots internal | 418 | // slots internal |
419 | 419 | ||
420 | void OFileSelector::slotOk() | 420 | void OFileSelector::slotOk() |
421 | { | 421 | { |
422 | emit ok(); | 422 | emit ok(); |
423 | } | 423 | } |
424 | void OFileSelector::slotCancel() | 424 | void OFileSelector::slotCancel() |
425 | { | 425 | { |
426 | emit cancel(); | 426 | emit cancel(); |
427 | } | 427 | } |
428 | void OFileSelector::slotViewCheck(const QString &sel) | 428 | void OFileSelector::slotViewCheck(const QString &sel) |
429 | { | 429 | { |
430 | if( sel == tr("Documents" ) ){ | 430 | if( sel == tr("Documents" ) ){ |
431 | if( m_select == 0 ){ | 431 | if( m_select == 0 ){ |
432 | // autMime? fix cause now we use All and not the current | 432 | // autMime? fix cause now we use All and not the current |
433 | // yes currentMime fixes that for us | 433 | // yes currentMime fixes that for us |
434 | QString mime = currentMimeType(); | 434 | QString mime = currentMimeType(); |
435 | m_select = new FileSelector(mime, | 435 | m_select = new FileSelector(mime, |
436 | m_stack, "fileselector", | 436 | m_stack, "fileselector", |
437 | m_shNew, m_shClose); | 437 | m_shNew, m_shClose); |
438 | connect(m_select, SIGNAL(fileSelected( const DocLnk & ) ), | 438 | connect(m_select, SIGNAL(fileSelected( const DocLnk & ) ), |
439 | this, SLOT( slotFileBridgeSelected(const DocLnk & ) ) ); | 439 | this, SLOT( slotFileBridgeSelected(const DocLnk & ) ) ); |
440 | connect(m_select, SIGNAL(closeMe() ), | 440 | connect(m_select, SIGNAL(closeMe() ), |
441 | this, SIGNAL(closeMe() ) ); | 441 | this, SIGNAL(closeMe() ) ); |
442 | //connect to close me and other signals as well | 442 | //connect to close me and other signals as well |
443 | 443 | ||
444 | m_stack->addWidget( m_select, NORMAL ); | 444 | m_stack->addWidget( m_select, NORMAL ); |
445 | } | 445 | } |
446 | m_stack->raiseWidget( NORMAL ); | 446 | m_stack->raiseWidget( NORMAL ); |
447 | m_selector = NORMAL; | 447 | m_selector = NORMAL; |
448 | }else if( sel == tr("Files") ){ | 448 | }else if( sel == tr("Files") ){ |
449 | m_selector = EXTENDED; | 449 | m_selector = EXTENDED; |
450 | initializeListView(); | 450 | initializeListView(); |
451 | reparse(); | 451 | reparse(); |
452 | m_stack->raiseWidget( EXTENDED ); | 452 | m_stack->raiseWidget( EXTENDED ); |
453 | }else if( sel == tr("All Files") ){ | 453 | }else if( sel == tr("All Files") ){ |
454 | m_selector = EXTENDED_ALL; | 454 | m_selector = EXTENDED_ALL; |
455 | initializeListView(); | 455 | initializeListView(); |
456 | reparse(); | 456 | reparse(); |
457 | m_stack->raiseWidget( EXTENDED ); // same widget other QFileFilter | 457 | m_stack->raiseWidget( EXTENDED ); // same widget other QFileFilter |
458 | } | 458 | } |
459 | } | 459 | } |
460 | // not yet finished..... | 460 | // not yet finished..... |
461 | QString OFileSelector::currentMimeType() const{ | 461 | QString OFileSelector::currentMimeType() const{ |
462 | QString mime; | 462 | QString mime; |
463 | QString currentText; | 463 | QString currentText; |
464 | if (m_shChooser ) | 464 | if (m_shChooser ) |
465 | currentText = m_mimeCheck->currentText(); | 465 | currentText = m_mimeCheck->currentText(); |
466 | 466 | ||
467 | if (tr("All") == currentText ) return QString::null; | 467 | if (tr("All") == currentText ) return QString::null; |
468 | else if (currentText.isEmpty() ) { | 468 | else if (currentText.isEmpty() ) { |
469 | ; | 469 | ; |
470 | }else { | 470 | }else { |
471 | QMap<QString, QStringList>::ConstIterator it; | 471 | QMap<QString, QStringList>::ConstIterator it; |
472 | it = m_mimetypes.find( currentText ); | 472 | it = m_mimetypes.find( currentText ); |
473 | if ( it == m_mimetypes.end() ) { | 473 | if ( it == m_mimetypes.end() ) { |
474 | mime = it.data().join(";"); | 474 | mime = it.data().join(";"); |
475 | }else{ | 475 | }else{ |
476 | mime = currentText; | 476 | mime = currentText; |
477 | } | 477 | } |
478 | } | 478 | } |
479 | return mime; | 479 | return mime; |
480 | } | 480 | } |
481 | void OFileSelector::slotMimeCheck(const QString &mime) | 481 | void OFileSelector::slotMimeCheck(const QString &mime) |
482 | { | 482 | { |
483 | if( m_selector == NORMAL ){ | 483 | if( m_selector == NORMAL ){ |
484 | //if( m_autoMime ){ | 484 | //if( m_autoMime ){ |
485 | QString newMimeType; | 485 | QString newMimeType; |
486 | if (mime != tr("All") ) { | 486 | if (mime != tr("All") ) { |
487 | QMap<QString, QStringList>::Iterator it; | 487 | QMap<QString, QStringList>::Iterator it; |
488 | it = m_mimetypes.find(mime); | 488 | it = m_mimetypes.find(mime); |
489 | if ( it != m_mimetypes.end() ) { | 489 | if ( it != m_mimetypes.end() ) { |
490 | newMimeType = it.data().join(";"); | 490 | newMimeType = it.data().join(";"); |
491 | }else{ | 491 | }else{ |
492 | newMimeType = mime; | 492 | newMimeType = mime; |
493 | } | 493 | } |
494 | } | 494 | } |
495 | delete m_select; | 495 | delete m_select; |
496 | m_select = new FileSelector( newMimeType, | 496 | m_select = new FileSelector( newMimeType, |
497 | m_stack, "fileselector", | 497 | m_stack, "fileselector", |
498 | m_shNew, m_shClose); | 498 | m_shNew, m_shClose); |
499 | 499 | ||
500 | connect(m_select, SIGNAL(fileSelected( const DocLnk & ) ), | 500 | connect(m_select, SIGNAL(fileSelected( const DocLnk & ) ), |
501 | this, SLOT( slotFileBridgeSelected(const DocLnk & ) ) ); | 501 | this, SLOT( slotFileBridgeSelected(const DocLnk & ) ) ); |
502 | connect(m_select, SIGNAL(closeMe() ), | 502 | connect(m_select, SIGNAL(closeMe() ), |
503 | this, SIGNAL(closeMe() ) ); | 503 | this, SIGNAL(closeMe() ) ); |
504 | //connect to close me and other signals as well | 504 | //connect to close me and other signals as well |
505 | m_stack->addWidget( m_select, NORMAL ); | 505 | m_stack->addWidget( m_select, NORMAL ); |
506 | m_stack->raiseWidget( NORMAL ); | 506 | m_stack->raiseWidget( NORMAL ); |
507 | updateMimes(); | 507 | updateMimes(); |
508 | updateMimeCheck(); | 508 | updateMimeCheck(); |
509 | m_mimeCheck->setCurrentItem(indexByString( m_mimeCheck, mime) ); | 509 | m_mimeCheck->setCurrentItem(indexByString( m_mimeCheck, mime) ); |
510 | //} | 510 | //} |
511 | }else{ // others | 511 | }else{ // others |
512 | qWarning("Mime %s", mime.latin1() ); | 512 | qWarning("Mime %s", mime.latin1() ); |
513 | if(m_shChooser ){ | 513 | if(m_shChooser ){ |
514 | qWarning("Current Text %s", m_mimeCheck->currentText().latin1() ); | 514 | qWarning("Current Text %s", m_mimeCheck->currentText().latin1() ); |
515 | //m_mimeCheck->setCurrentItem(indexByString( m_mimeCheck, mime) ); | 515 | //m_mimeCheck->setCurrentItem(indexByString( m_mimeCheck, mime) ); |
516 | } | 516 | } |
517 | reparse(); | 517 | reparse(); |
518 | } | 518 | } |
519 | 519 | ||
520 | } | 520 | } |
521 | /* | 521 | /* |
522 | * Ok if a non dir gets inserted into this combobox | 522 | * Ok if a non dir gets inserted into this combobox |
523 | * we need to change it | 523 | * we need to change it |
524 | * QFileInfo and dirPath will give us the right Dir | 524 | * QFileInfo and dirPath will give us the right Dir |
525 | */ | 525 | */ |
526 | void OFileSelector::slotLocationActivated(const QString &file) | 526 | void OFileSelector::slotLocationActivated(const QString &file) |
527 | { | 527 | { |
528 | qWarning("slotLocationActivated"); | 528 | qWarning("slotLocationActivated"); |
529 | QString name = file.left( file.find("<-", 0, TRUE ) ); | 529 | QString name = file.left( file.find("<-", 0, TRUE ) ); |
530 | QFileInfo info( name ); | 530 | QFileInfo info( name ); |
531 | if ( info.isFile() ) | 531 | if ( info.isFile() ) |
532 | cd(info.dirPath( TRUE ) ); //absolute | 532 | cd(info.dirPath( TRUE ) ); //absolute |
533 | else | 533 | else |
534 | cd(name ); | 534 | cd(name ); |
535 | reparse(); | 535 | reparse(); |
536 | } | 536 | } |
537 | void OFileSelector::slotInsertLocationPath(const QString ¤tPath, int count) | 537 | void OFileSelector::slotInsertLocationPath(const QString ¤tPath, int count) |
538 | { | 538 | { |
539 | QStringList pathList; | 539 | QStringList pathList; |
540 | bool underDog = FALSE; | 540 | bool underDog = FALSE; |
541 | for(int i=0;i<count;i++) { | 541 | for(int i=0;i<count;i++) { |
542 | pathList << m_location->text(i); | 542 | pathList << m_location->text(i); |
543 | if( m_location->text(i) == currentPath) | 543 | if( m_location->text(i) == currentPath) |
544 | underDog = TRUE; | 544 | underDog = TRUE; |
545 | } | 545 | } |
546 | if( !underDog) { | 546 | if( !underDog) { |
547 | m_location->clear(); | 547 | m_location->clear(); |
548 | if( currentPath.left(2)=="//") | 548 | if( currentPath.left(2)=="//") |
549 | pathList.append( currentPath.right(currentPath.length()-1) ); | 549 | pathList.append( currentPath.right(currentPath.length()-1) ); |
550 | else | 550 | else |
551 | pathList.append( currentPath ); | 551 | pathList.append( currentPath ); |
552 | m_location->insertStringList( pathList,-1); | 552 | m_location->insertStringList( pathList,-1); |
553 | } | 553 | } |
554 | } | 554 | } |
555 | /* | 555 | /* |
556 | * Do not crash anymore | 556 | * Do not crash anymore |
557 | * don't try to change dir to a file | 557 | * don't try to change dir to a file |
558 | */ | 558 | */ |
559 | void OFileSelector::locationComboChanged() | 559 | void OFileSelector::locationComboChanged() |
560 | { | 560 | { |
561 | QFileInfo info( m_location->lineEdit()->text() ); | 561 | QFileInfo info( m_location->lineEdit()->text() ); |
562 | qWarning("info %s %s", info.dirPath(true).latin1(), m_location->lineEdit()->text().latin1() ); | 562 | qWarning("info %s %s", info.dirPath(true).latin1(), m_location->lineEdit()->text().latin1() ); |
563 | if (info.isFile() ) | 563 | if (info.isFile() ) |
564 | cd(info.dirPath(TRUE) ); //absolute path | 564 | cd(info.dirPath(TRUE) ); //absolute path |
565 | else | 565 | else |
566 | cd( m_location->lineEdit()->text() ); | 566 | cd( m_location->lineEdit()->text() ); |
567 | 567 | ||
568 | reparse(); | 568 | reparse(); |
569 | } | 569 | } |
570 | void OFileSelector::init() | 570 | void OFileSelector::init() |
571 | { | 571 | { |
572 | m_lay = new QVBoxLayout( this ); | 572 | m_lay = new QVBoxLayout( this ); |
573 | m_lay->setSpacing(0 ); | 573 | m_lay->setSpacing(0 ); |
574 | 574 | ||
575 | m_stack = new QWidgetStack( this ); | 575 | m_stack = new QWidgetStack( this ); |
576 | if( m_selector == NORMAL ){ | 576 | if( m_selector == NORMAL ){ |
577 | QString mime; | 577 | QString mime; |
578 | if (!m_autoMime) { | 578 | if (!m_autoMime) { |
579 | if (!m_mimetypes.isEmpty() ) { | 579 | if (!m_mimetypes.isEmpty() ) { |
580 | QMap<QString, QStringList>::Iterator it; | 580 | QMap<QString, QStringList>::Iterator it; |
581 | it = m_mimetypes.begin(); // cause we're in the init | 581 | it = m_mimetypes.begin(); // cause we're in the init |
582 | mime = it.data().join(";"); | 582 | mime = it.data().join(";"); |
583 | } | 583 | } |
584 | } | 584 | } |
585 | m_select = new FileSelector(mime, | 585 | m_select = new FileSelector(mime, |
586 | m_stack, "fileselector", | 586 | m_stack, "fileselector", |
587 | m_shNew, m_shClose); | 587 | m_shNew, m_shClose); |
588 | 588 | ||
589 | connect(m_select, SIGNAL(fileSelected( const DocLnk & ) ), | 589 | connect(m_select, SIGNAL(fileSelected( const DocLnk & ) ), |
590 | this, SLOT( slotFileBridgeSelected(const DocLnk & ) ) ); | 590 | this, SLOT( slotFileBridgeSelected(const DocLnk & ) ) ); |
591 | connect(m_select, SIGNAL(closeMe() ), | 591 | connect(m_select, SIGNAL(closeMe() ), |
592 | this, SIGNAL( closeMe() ) ); | 592 | this, SIGNAL( closeMe() ) ); |
593 | //connect to close me and other signals as well | 593 | //connect to close me and other signals as well |
594 | 594 | ||
595 | m_stack->addWidget( m_select, NORMAL ); | 595 | m_stack->addWidget( m_select, NORMAL ); |
596 | m_stack->raiseWidget( NORMAL ); | 596 | m_stack->raiseWidget( NORMAL ); |
597 | }else{ // we're in init so it will be EXTENDED or EXTENDED_ALL | 597 | }else{ // we're in init so it will be EXTENDED or EXTENDED_ALL |
598 | // and initializeListview will take care of those | 598 | // and initializeListview will take care of those |
599 | // toolbar get's generade in initializeListView | 599 | // toolbar get's generade in initializeListView |
600 | initializeListView( ); // will raise the widget as well | 600 | initializeListView( ); // will raise the widget as well |
601 | m_stack->raiseWidget( EXTENDED ); | 601 | m_stack->raiseWidget( EXTENDED ); |
602 | } | 602 | } |
603 | m_lay->addWidget( m_stack, 100 ); // add to the layout 10 = stretch | 603 | m_lay->addWidget( m_stack, 100 ); // add to the layout 10 = stretch |
604 | 604 | ||
605 | if( m_shLne ) // the LineEdit with the current FileName | 605 | if( m_shLne ) // the LineEdit with the current FileName |
606 | initializeName(); | 606 | initializeName(); |
607 | 607 | ||
608 | if( m_shPerm ) // the Permission QCheckBox | 608 | if( m_shPerm ) // the Permission QCheckBox |
609 | initializePerm(); | 609 | initializePerm(); |
610 | 610 | ||
611 | if( m_shChooser ) // the Chooser for the view and Mimetypes | 611 | if( m_shChooser ) // the Chooser for the view and Mimetypes |
612 | initializeChooser(); | 612 | initializeChooser(); |
613 | 613 | ||
614 | if( m_shYesNo ) // the Yes No button row | 614 | if( m_shYesNo ) // the Yes No button row |
615 | initializeYes( ); | 615 | initializeYes( ); |
616 | 616 | ||
617 | if (m_selector != NORMAL ) | 617 | if (m_selector != NORMAL ) |
618 | reparse(); | 618 | reparse(); |
619 | } | 619 | } |
620 | void OFileSelector::updateMimes() | 620 | void OFileSelector::updateMimes() |
621 | { | 621 | { |
622 | if( m_autoMime ){ | 622 | if( m_autoMime ){ |
623 | m_mimetypes.clear(); | 623 | m_mimetypes.clear(); |
624 | m_mimetypes.insert( tr("All"), QString::null ); | 624 | m_mimetypes.insert( tr("All"), QString::null ); |
625 | if( m_selector == NORMAL ){ | 625 | if( m_selector == NORMAL ){ |
626 | DocLnkSet set; | 626 | DocLnkSet set; |
627 | Global::findDocuments(&set, QString::null ); | 627 | Global::findDocuments(&set, QString::null ); |
628 | QListIterator<DocLnk> dit( set.children() ); | 628 | QListIterator<DocLnk> dit( set.children() ); |
629 | for( ; dit.current(); ++dit ){ | 629 | for( ; dit.current(); ++dit ){ |
630 | if( !m_mimetypes.contains( (*dit)->type() ) ) | 630 | if( !m_mimetypes.contains( (*dit)->type() ) ) |
631 | m_mimetypes.insert( (*dit)->type(), (*dit)->type() ); | 631 | m_mimetypes.insert( (*dit)->type(), (*dit)->type() ); |
632 | } | 632 | } |
633 | }// else done in reparse | 633 | }// else done in reparse |
634 | } | 634 | } |
635 | } | 635 | } |
636 | void OFileSelector::initVars() | 636 | void OFileSelector::initVars() |
637 | { | 637 | { |
638 | if( m_mimetypes.isEmpty() ) | 638 | if( m_mimetypes.isEmpty() ) |
639 | m_autoMime = true; | 639 | m_autoMime = true; |
640 | else | 640 | else |
641 | m_autoMime = false; | 641 | m_autoMime = false; |
642 | m_shClose = false; | 642 | m_shClose = false; |
643 | m_shNew = false; | 643 | m_shNew = false; |
644 | m_shTool = true; | 644 | m_shTool = true; |
645 | m_shPerm = false; | 645 | m_shPerm = false; |
646 | m_shLne = true; | 646 | m_shLne = true; |
647 | m_shChooser = true; | 647 | m_shChooser = true; |
648 | m_shYesNo = true; | 648 | m_shYesNo = true; |
649 | m_case = false; | 649 | m_case = false; |
650 | m_dir = true; | 650 | m_dir = true; |
651 | m_files = true; | 651 | m_files = true; |
652 | m_showPopup = false; | 652 | m_showPopup = false; |
653 | if(m_pixmaps == 0 ) // init the pixmaps | 653 | if(m_pixmaps == 0 ) // init the pixmaps |
654 | initPics(); | 654 | initPics(); |
655 | 655 | ||
656 | // pointers | 656 | // pointers |
657 | m_location = 0; | 657 | m_location = 0; |
658 | m_mimeCheck = 0; | 658 | m_mimeCheck = 0; |
659 | m_viewCheck = 0; | 659 | m_viewCheck = 0; |
660 | m_homeButton = 0; | 660 | m_homeButton = 0; |
661 | m_docButton = 0; | 661 | m_docButton = 0; |
662 | m_hideButton = 0; | 662 | m_hideButton = 0; |
663 | m_ok = 0; | 663 | m_ok = 0; |
664 | m_cancel = 0; | 664 | m_cancel = 0; |
665 | m_reread = 0; | 665 | m_reread = 0; |
666 | m_up = 0; | 666 | m_up = 0; |
667 | m_View = 0; | 667 | m_View = 0; |
668 | m_checkPerm = 0; | 668 | m_checkPerm = 0; |
669 | m_pseudo = 0; | 669 | m_pseudo = 0; |
670 | m_pseudoLayout = 0; | 670 | m_pseudoLayout = 0; |
671 | m_select = 0; | 671 | m_select = 0; |
672 | m_stack = 0; | 672 | m_stack = 0; |
673 | m_lay = 0; | 673 | m_lay = 0; |
674 | m_Oselector = 0; | 674 | m_Oselector = 0; |
675 | m_boxToolbar = 0; | 675 | m_boxToolbar = 0; |
676 | m_boxOk = 0; | 676 | m_boxOk = 0; |
677 | m_boxName = 0; | 677 | m_boxName = 0; |
678 | m_boxView = 0; | 678 | m_boxView = 0; |
679 | m_custom = 0; | 679 | m_custom = 0; |
680 | m_edit = 0; | 680 | m_edit = 0; |
681 | m_fnLabel = 0; | 681 | m_fnLabel = 0; |
682 | m_new = 0; | 682 | m_new = 0; |
683 | m_close = 0; | 683 | m_close = 0; |
684 | } | 684 | } |
685 | void OFileSelector::addFile(const QString &mime, QFileInfo *info, bool symlink) | 685 | void OFileSelector::addFile(const QString &/*mime*/, QFileInfo *info, bool symlink) |
686 | { | 686 | { |
687 | if(!m_files) | 687 | if(!m_files) |
688 | return; | 688 | return; |
689 | // if( !compliesMime(info->absFilePath(), mime ) ) | 689 | // if( !compliesMime(info->absFilePath(), mime ) ) |
690 | // return; | 690 | // return; |
691 | MimeType type( info->absFilePath() ); | 691 | MimeType type( info->absFilePath() ); |
692 | if (!compliesMime( type.id() ) ) | 692 | if (!compliesMime( type.id() ) ) |
693 | return; | 693 | return; |
694 | 694 | ||
695 | QPixmap pix = type.pixmap(); | 695 | QPixmap pix = type.pixmap(); |
696 | QString dir; | 696 | QString dir; |
697 | QString name; | 697 | QString name; |
698 | bool locked; | 698 | bool locked; |
699 | if( pix.isNull() ) | 699 | if( pix.isNull() ) |
700 | pix = Resource::loadPixmap( "UnknownDocument-14"); | 700 | pix = Resource::loadPixmap( "UnknownDocument-14"); |
701 | dir = info->dirPath( true ); | 701 | dir = info->dirPath( true ); |
702 | if( symlink ) | 702 | if( symlink ) |
703 | name = info->fileName() + " -> " +info->dirPath() + "/" + info->readLink(); | 703 | name = info->fileName() + " -> " +info->dirPath() + "/" + info->readLink(); |
704 | else { | 704 | else { |
705 | name = info->fileName(); | 705 | name = info->fileName(); |
706 | if( ( m_mode == OPEN && !info->isReadable() )|| | 706 | if( ( m_mode == OPEN && !info->isReadable() )|| |
707 | ( m_mode == SAVE && !info->isWritable() ) ){ | 707 | ( m_mode == SAVE && !info->isWritable() ) ){ |
708 | 708 | ||
709 | locked = true; pix = Resource::loadPixmap("locked"); | 709 | locked = true; pix = Resource::loadPixmap("locked"); |
710 | } | 710 | } |
711 | } | 711 | } |
712 | new OFileSelectorItem( m_View, pix, name, | 712 | new OFileSelectorItem( m_View, pix, name, |
713 | info->lastModified().toString(), | 713 | info->lastModified().toString(), |
714 | QString::number( info->size() ), | 714 | QString::number( info->size() ), |
715 | dir, locked ); | 715 | dir, locked ); |
716 | } | 716 | } |
717 | void OFileSelector::addDir(const QString &mime, QFileInfo *info, bool symlink ) | 717 | void OFileSelector::addDir(const QString &/*mime*/, QFileInfo *info, bool symlink ) |
718 | { | 718 | { |
719 | if(!m_dir) | 719 | if(!m_dir) |
720 | return; | 720 | return; |
721 | if( m_selector == EXTENDED_ALL || m_selector == EXTENDED ){ | 721 | if( m_selector == EXTENDED_ALL || m_selector == EXTENDED ){ |
722 | bool locked = false; | 722 | bool locked = false; |
723 | QString name; | 723 | QString name; |
724 | QPixmap pix; | 724 | QPixmap pix; |
725 | if( ( m_mode == OPEN && !info->isReadable() ) || ( m_mode == SAVE && !info->isWritable() ) ){ | 725 | if( ( m_mode == OPEN && !info->isReadable() ) || ( m_mode == SAVE && !info->isWritable() ) ){ |
726 | locked = true; | 726 | locked = true; |
727 | if( symlink ) | 727 | if( symlink ) |
728 | pix = (*m_pixmaps)["symlinkedlocked"]; | 728 | pix = (*m_pixmaps)["symlinkedlocked"]; |
729 | else | 729 | else |
730 | pix = Resource::loadPixmap("lockedfolder"); | 730 | pix = Resource::loadPixmap("lockedfolder"); |
731 | }else { // readable | 731 | }else { // readable |
732 | pix = symlink ? (*m_pixmaps)["dirsymlink"] : Resource::loadPixmap("folder") ; | 732 | pix = symlink ? (*m_pixmaps)["dirsymlink"] : Resource::loadPixmap("folder") ; |
733 | } | 733 | } |
734 | name = symlink ? info->fileName() + "->" + info->dirPath(true) + "/" +info->readLink() : info->fileName() ; | 734 | name = symlink ? info->fileName() + "->" + info->dirPath(true) + "/" +info->readLink() : info->fileName() ; |
735 | new OFileSelectorItem( m_View, pix, name, | 735 | new OFileSelectorItem( m_View, pix, name, |
736 | info->lastModified().toString(), | 736 | info->lastModified().toString(), |
737 | QString::number( info->size() ), | 737 | QString::number( info->size() ), |
738 | info->dirPath( true ), locked, | 738 | info->dirPath( true ), locked, |
739 | true ); | 739 | true ); |
740 | 740 | ||
741 | }// else CUSTOM View | 741 | }// else CUSTOM View |
742 | } | 742 | } |
743 | void OFileSelector::delItems() | 743 | void OFileSelector::delItems() |
744 | { | 744 | { |
745 | 745 | ||
746 | } | 746 | } |
747 | void OFileSelector::initializeName() | 747 | void OFileSelector::initializeName() |
748 | { | 748 | { |
749 | /** Name Layout Line | 749 | /** Name Layout Line |
750 | * This is the Layout line arranged in | 750 | * This is the Layout line arranged in |
751 | * horizontal way each components | 751 | * horizontal way each components |
752 | * are next to each other | 752 | * are next to each other |
753 | * but we will only do this if | 753 | * but we will only do this if |
754 | * we didn't initialize a while ago. | 754 | * we didn't initialize a while ago. |
755 | */ | 755 | */ |
756 | if( m_boxName == 0 ){ | 756 | if( m_boxName == 0 ){ |
757 | m_boxName = new QHBox( this ); // remove this this? or use a QHBox | 757 | m_boxName = new QHBox( this ); // remove this this? or use a QHBox |
758 | m_fnLabel = new QLabel( m_boxName ); | 758 | m_fnLabel = new QLabel( m_boxName ); |
759 | m_fnLabel->setText( tr("Name:") ); | 759 | m_fnLabel->setText( tr("Name:") ); |
760 | m_edit = new QLineEdit( m_boxName ); | 760 | m_edit = new QLineEdit( m_boxName ); |
761 | m_edit->setText( m_name ); | 761 | m_edit->setText( m_name ); |
762 | //m_boxName->addWidget( m_fnLabel ); | 762 | //m_boxName->addWidget( m_fnLabel ); |
763 | m_boxName->setMargin( 5 ); | 763 | m_boxName->setMargin( 5 ); |
764 | m_boxName->setSpacing( 8 ); | 764 | m_boxName->setSpacing( 8 ); |
765 | //m_boxName->setStretchFactor(m_edit, 100 ); // 100 is stretch factor | 765 | //m_boxName->setStretchFactor(m_edit, 100 ); // 100 is stretch factor |
766 | 766 | ||
767 | m_lay->addWidget( m_boxName, 0 ); // add it to the topLevel layout | 767 | m_lay->addWidget( m_boxName, 0 ); // add it to the topLevel layout |
768 | }// else we already initialized | 768 | }// else we already initialized |
769 | // maybe show the components? | 769 | // maybe show the components? |
770 | // | 770 | // |
771 | } | 771 | } |
772 | void OFileSelector::initializeYes() | 772 | void OFileSelector::initializeYes() |
773 | { | 773 | { |
774 | /** The Save Cancel bar | 774 | /** The Save Cancel bar |
775 | * | 775 | * |
776 | */ | 776 | */ |
777 | if( m_boxOk == 0 ){ | 777 | if( m_boxOk == 0 ){ |
778 | m_boxOk = new QHBox( this ); | 778 | m_boxOk = new QHBox( this ); |
779 | m_ok = new QPushButton( tr("&Save"),m_boxOk , "save" ); | 779 | m_ok = new QPushButton( tr("&Save"),m_boxOk , "save" ); |
780 | m_cancel = new QPushButton( tr("C&ancel"), m_boxOk, "cancel" ); | 780 | m_cancel = new QPushButton( tr("C&ancel"), m_boxOk, "cancel" ); |
781 | 781 | ||
782 | //m_boxOk->addWidget( m_ok ); | 782 | //m_boxOk->addWidget( m_ok ); |
783 | //m_boxOk->addWidget( m_cancel ); | 783 | //m_boxOk->addWidget( m_cancel ); |
784 | m_boxOk->setMargin( 5 ); | 784 | m_boxOk->setMargin( 5 ); |
785 | m_boxOk->setSpacing( 10 ); | 785 | m_boxOk->setSpacing( 10 ); |
786 | m_lay->addWidget( m_boxOk, 0 ); | 786 | m_lay->addWidget( m_boxOk, 0 ); |
787 | 787 | ||
788 | connect( m_ok, SIGNAL( clicked() ), | 788 | connect( m_ok, SIGNAL( clicked() ), |
789 | this, SLOT(slotOk() ) ); | 789 | this, SLOT(slotOk() ) ); |
790 | connect( m_cancel, SIGNAL( clicked() ), | 790 | connect( m_cancel, SIGNAL( clicked() ), |
791 | this, SLOT( slotCancel() ) ); | 791 | this, SLOT( slotCancel() ) ); |
792 | } | 792 | } |
793 | } | 793 | } |
794 | /* | 794 | /* |
795 | * OK m_mimeCheck is a QComboBox we now want to fill | 795 | * OK m_mimeCheck is a QComboBox we now want to fill |
796 | * out that combobox | 796 | * out that combobox |
797 | * if automime we need to update the mimetypes | 797 | * if automime we need to update the mimetypes |
798 | */ | 798 | */ |
799 | void OFileSelector::updateMimeCheck() { | 799 | void OFileSelector::updateMimeCheck() { |
800 | m_mimeCheck->clear(); | 800 | m_mimeCheck->clear(); |
801 | if (m_autoMime ) { | 801 | if (m_autoMime ) { |
802 | //m_mimeCheck->insertItem( tr("All") ); | 802 | //m_mimeCheck->insertItem( tr("All") ); |
803 | updateMimes(); | 803 | updateMimes(); |
804 | } | 804 | } |
805 | 805 | ||
806 | QMap<QString, QStringList>::Iterator it; | 806 | QMap<QString, QStringList>::Iterator it; |
807 | for (it = m_mimetypes.begin(); it != m_mimetypes.end(); ++it ) { | 807 | for (it = m_mimetypes.begin(); it != m_mimetypes.end(); ++it ) { |
808 | m_mimeCheck->insertItem( it.key() ); | 808 | m_mimeCheck->insertItem( it.key() ); |
809 | } | 809 | } |
810 | } | 810 | } |
811 | 811 | ||
812 | void OFileSelector::initializeChooser() | 812 | void OFileSelector::initializeChooser() |
813 | { | 813 | { |
814 | if( m_boxView == 0 ){ | 814 | if( m_boxView == 0 ){ |
815 | m_boxView = new QHBox( this ); | 815 | m_boxView = new QHBox( this ); |
816 | m_viewCheck = new QComboBox( m_boxView, "view check"); | 816 | m_viewCheck = new QComboBox( m_boxView, "view check"); |
817 | m_mimeCheck = new QComboBox( m_boxView, "mime check"); | 817 | m_mimeCheck = new QComboBox( m_boxView, "mime check"); |
818 | m_boxView->setSpacing( 8 ); | 818 | m_boxView->setSpacing( 8 ); |
819 | m_lay->addWidget(m_boxView, 0 ); | 819 | m_lay->addWidget(m_boxView, 0 ); |
820 | 820 | ||
821 | m_viewCheck->insertItem( tr("Documents") ); | 821 | m_viewCheck->insertItem( tr("Documents") ); |
822 | m_viewCheck->insertItem( tr("Files") ); | 822 | m_viewCheck->insertItem( tr("Files") ); |
823 | m_viewCheck->insertItem( tr("All Files") ); | 823 | m_viewCheck->insertItem( tr("All Files") ); |
824 | updateMimeCheck(); | 824 | updateMimeCheck(); |
825 | 825 | ||
826 | connect( m_viewCheck, SIGNAL( activated(const QString & ) ), | 826 | connect( m_viewCheck, SIGNAL( activated(const QString & ) ), |
827 | this, SLOT( slotViewCheck(const QString & ) ) ); | 827 | this, SLOT( slotViewCheck(const QString & ) ) ); |
828 | connect( m_mimeCheck, SIGNAL( activated(const QString & ) ), | 828 | connect( m_mimeCheck, SIGNAL( activated(const QString & ) ), |
829 | this, SLOT( slotMimeCheck( const QString & ) ) ); | 829 | this, SLOT( slotMimeCheck( const QString & ) ) ); |
830 | } | 830 | } |
831 | } | 831 | } |
832 | void OFileSelector::initializeListView() | 832 | void OFileSelector::initializeListView() |
833 | { | 833 | { |
834 | qWarning("initializeListView"); | 834 | qWarning("initializeListView"); |
835 | if( m_pseudo == 0 ){ | 835 | if( m_pseudo == 0 ){ |
836 | qWarning("init"); | 836 | qWarning("init"); |
837 | m_pseudo = new QWidget( m_stack, "Pseudo Widget"); | 837 | m_pseudo = new QWidget( m_stack, "Pseudo Widget"); |
838 | m_pseudoLayout = new QVBoxLayout( m_pseudo ); | 838 | m_pseudoLayout = new QVBoxLayout( m_pseudo ); |
839 | // toolbar | 839 | // toolbar |
840 | m_boxToolbar = new QHBox( m_pseudo ); | 840 | m_boxToolbar = new QHBox( m_pseudo ); |
841 | m_boxToolbar->setSpacing(0 ); // next to each other please | 841 | m_boxToolbar->setSpacing(0 ); // next to each other please |
842 | 842 | ||
843 | // toolbar members | 843 | // toolbar members |
844 | { | 844 | { |
845 | // location QComboBox | 845 | // location QComboBox |
846 | m_location = new QComboBox( m_boxToolbar ); | 846 | m_location = new QComboBox( m_boxToolbar ); |
847 | m_location->setEditable( TRUE ); | 847 | m_location->setEditable( TRUE ); |
848 | m_location->setDuplicatesEnabled( FALSE ); | 848 | m_location->setDuplicatesEnabled( FALSE ); |
849 | connect( m_location, SIGNAL(activated(const QString &) ), | 849 | connect( m_location, SIGNAL(activated(const QString &) ), |
850 | this, SLOT( slotLocationActivated(const QString &) ) ); | 850 | this, SLOT( slotLocationActivated(const QString &) ) ); |
851 | connect( m_location->lineEdit(), SIGNAL(returnPressed() ), | 851 | connect( m_location->lineEdit(), SIGNAL(returnPressed() ), |
852 | this, SLOT(locationComboChanged() ) ); | 852 | this, SLOT(locationComboChanged() ) ); |
853 | // UP Button | 853 | // UP Button |
854 | m_up = new QPushButton(Resource::loadIconSet("up"),"", | 854 | m_up = new QPushButton(Resource::loadIconSet("up"),"", |
855 | m_boxToolbar,"cdUpButton"); | 855 | m_boxToolbar,"cdUpButton"); |
856 | m_up->setFixedSize( QSize( 20, 20 ) ); | 856 | m_up->setFixedSize( QSize( 20, 20 ) ); |
857 | connect(m_up ,SIGNAL(clicked()),this,SLOT(cdUP() ) ); | 857 | connect(m_up ,SIGNAL(clicked()),this,SLOT(cdUP() ) ); |
858 | m_up->setFlat(TRUE); | 858 | m_up->setFlat(TRUE); |
859 | 859 | ||
860 | // Home Button | 860 | // Home Button |
861 | m_homeButton = new QPushButton(Resource::loadIconSet("home") , | 861 | m_homeButton = new QPushButton(Resource::loadIconSet("home") , |
862 | "", m_boxToolbar); | 862 | "", m_boxToolbar); |
863 | m_homeButton->setFixedSize( QSize( 20, 20 ) ); | 863 | m_homeButton->setFixedSize( QSize( 20, 20 ) ); |
864 | connect(m_homeButton,SIGNAL(clicked()),this,SLOT(slotHome() ) ); | 864 | connect(m_homeButton,SIGNAL(clicked()),this,SLOT(slotHome() ) ); |
865 | m_homeButton->setFlat(TRUE); | 865 | m_homeButton->setFlat(TRUE); |
866 | // Documents Button | 866 | // Documents Button |
867 | m_docButton = new QPushButton(Resource::loadIconSet("DocsIcon"),"", | 867 | m_docButton = new QPushButton(Resource::loadIconSet("DocsIcon"),"", |
868 | m_boxToolbar,"docsButton"); | 868 | m_boxToolbar,"docsButton"); |
869 | m_docButton->setFixedSize( QSize( 20, 20 ) ); | 869 | m_docButton->setFixedSize( QSize( 20, 20 ) ); |
870 | connect(m_homeButton,SIGNAL(clicked()),this,SLOT(slotDoc() ) ); | 870 | connect(m_homeButton,SIGNAL(clicked()),this,SLOT(slotDoc() ) ); |
871 | m_docButton->setFlat(TRUE); | 871 | m_docButton->setFlat(TRUE); |
872 | 872 | ||
873 | // Close button | 873 | // Close button |
874 | m_close = new QPushButton( Resource::loadIconSet( "close"), "", | 874 | m_close = new QPushButton( Resource::loadIconSet( "close"), "", |
875 | m_boxToolbar ); | 875 | m_boxToolbar ); |
876 | connect( m_close, SIGNAL(clicked() ), this, SIGNAL(closeMe() ) ); | 876 | connect( m_close, SIGNAL(clicked() ), this, SIGNAL(closeMe() ) ); |
877 | m_close->setFixedSize( 20, 20 ); | 877 | m_close->setFixedSize( 20, 20 ); |
878 | 878 | ||
879 | m_boxToolbar->setFixedHeight( 20 ); | 879 | m_boxToolbar->setFixedHeight( 20 ); |
880 | m_pseudoLayout->addWidget(m_boxToolbar ); | 880 | m_pseudoLayout->addWidget(m_boxToolbar ); |
881 | 881 | ||
882 | // let;s fill the Location ComboBox | 882 | // let;s fill the Location ComboBox |
883 | StorageInfo storage; | 883 | StorageInfo storage; |
884 | const QList<FileSystem> &fs = storage.fileSystems(); | 884 | const QList<FileSystem> &fs = storage.fileSystems(); |
885 | QListIterator<FileSystem> it ( fs ); | 885 | QListIterator<FileSystem> it ( fs ); |
886 | for( ; it.current(); ++it ){ | 886 | for( ; it.current(); ++it ){ |
887 | const QString disk = (*it)->name(); | 887 | const QString disk = (*it)->name(); |
888 | const QString path = (*it)->path(); | 888 | const QString path = (*it)->path(); |
889 | m_location->insertItem(path+ "<-"+disk ); | 889 | m_location->insertItem(path+ "<-"+disk ); |
890 | } | 890 | } |
891 | int count = m_location->count(); | 891 | int count = m_location->count(); |
892 | m_location->insertItem( m_currentDir ); | 892 | m_location->insertItem( m_currentDir ); |
893 | m_location->setCurrentItem( count ); | 893 | m_location->setCurrentItem( count ); |
894 | // due to the New and Close button we can not simply hide m_boxToolBar to not show it | 894 | // due to the New and Close button we can not simply hide m_boxToolBar to not show it |
895 | if( !m_shTool ){ | 895 | if( !m_shTool ){ |
896 | m_location->hide( ); | 896 | m_location->hide( ); |
897 | m_up->hide( ); | 897 | m_up->hide( ); |
898 | m_homeButton->hide( ); | 898 | m_homeButton->hide( ); |
899 | m_docButton->hide( ); | 899 | m_docButton->hide( ); |
900 | } | 900 | } |
901 | if(!m_shClose ) | 901 | if(!m_shClose ) |
902 | m_close->hide(); | 902 | m_close->hide(); |
903 | //if(!m_shNew) | 903 | //if(!m_shNew) |
904 | //m_close->hide(); | 904 | //m_close->hide(); |
905 | 905 | ||
906 | } // off toolbar | 906 | } // off toolbar |
907 | // the Main ListView | 907 | // the Main ListView |
908 | // make a QWidgetStack first so Views can share the Toolbar | 908 | // make a QWidgetStack first so Views can share the Toolbar |
909 | m_View = new QListView( m_pseudo, "Extended view"); | 909 | m_View = new QListView( m_pseudo, "Extended view"); |
910 | QPEApplication::setStylusOperation( m_View->viewport(), | 910 | QPEApplication::setStylusOperation( m_View->viewport(), |
911 | QPEApplication::RightOnHold); | 911 | QPEApplication::RightOnHold); |
912 | m_View->addColumn(" " ); | 912 | m_View->addColumn(" " ); |
913 | m_View->addColumn(tr("Name"), 135 ); | 913 | m_View->addColumn(tr("Name"), 135 ); |
914 | m_View->addColumn(tr("Size"), -1 ); | 914 | m_View->addColumn(tr("Size"), -1 ); |
915 | m_View->addColumn(tr("Date"), 60 ); | 915 | m_View->addColumn(tr("Date"), 60 ); |
916 | m_View->addColumn(tr("Mime Type"), -1 ); | 916 | m_View->addColumn(tr("Mime Type"), -1 ); |
917 | QHeader *header = m_View->header(); | 917 | QHeader *header = m_View->header(); |
918 | header->hide(); | 918 | header->hide(); |
919 | m_View->setSorting( 1 ); | 919 | m_View->setSorting( 1 ); |
920 | m_View->setAllColumnsShowFocus( TRUE ); | 920 | m_View->setAllColumnsShowFocus( TRUE ); |
921 | 921 | ||
922 | connect(m_View, SIGNAL(selectionChanged() ), | 922 | connect(m_View, SIGNAL(selectionChanged() ), |
923 | this, SLOT(slotSelectionChanged() ) ); | 923 | this, SLOT(slotSelectionChanged() ) ); |
924 | 924 | ||
925 | connect(m_View, SIGNAL(currentChanged(QListViewItem *) ), | 925 | connect(m_View, SIGNAL(currentChanged(QListViewItem *) ), |
926 | this, SLOT(slotCurrentChanged(QListViewItem * ) ) ); | 926 | this, SLOT(slotCurrentChanged(QListViewItem * ) ) ); |
927 | 927 | ||
928 | connect(m_View, SIGNAL(mouseButtonClicked(int, QListViewItem*, const QPoint &, int) ), | 928 | connect(m_View, SIGNAL(mouseButtonClicked(int, QListViewItem*, const QPoint &, int) ), |
929 | this, SLOT(slotClicked( int, QListViewItem *, const QPoint &, int) ) ); | 929 | this, SLOT(slotClicked( int, QListViewItem *, const QPoint &, int) ) ); |
930 | 930 | ||
931 | connect(m_View, SIGNAL(mouseButtonPressed(int, QListViewItem *, const QPoint &, int )), | 931 | connect(m_View, SIGNAL(mouseButtonPressed(int, QListViewItem *, const QPoint &, int )), |
932 | this, SLOT(slotRightButton(int, QListViewItem *, const QPoint &, int ) ) ); | 932 | this, SLOT(slotRightButton(int, QListViewItem *, const QPoint &, int ) ) ); |
933 | 933 | ||
934 | m_pseudoLayout->addWidget( m_View, 288 ); | 934 | m_pseudoLayout->addWidget( m_View, 288 ); |
935 | m_stack->addWidget( m_pseudo, EXTENDED ); | 935 | m_stack->addWidget( m_pseudo, EXTENDED ); |
936 | } | 936 | } |
937 | } | 937 | } |
938 | void OFileSelector::initializePerm() | 938 | void OFileSelector::initializePerm() |
939 | { | 939 | { |
940 | if( m_checkPerm == 0 ){ | 940 | if( m_checkPerm == 0 ){ |
941 | m_checkPerm = new QCheckBox(tr("Ser Permission"), this, "perm"); | 941 | m_checkPerm = new QCheckBox(tr("Ser Permission"), this, "perm"); |
942 | m_checkPerm->setChecked( false ); | 942 | m_checkPerm->setChecked( false ); |
943 | m_lay->addWidget( m_checkPerm ); | 943 | m_lay->addWidget( m_checkPerm ); |
944 | 944 | ||
945 | } | 945 | } |
946 | } | 946 | } |
947 | void OFileSelector::initPics() | 947 | void OFileSelector::initPics() |
948 | { | 948 | { |
949 | m_pixmaps = new QMap<QString,QPixmap>; | 949 | m_pixmaps = new QMap<QString,QPixmap>; |
950 | QPixmap pm = Resource::loadPixmap( "folder" ); | 950 | QPixmap pm = Resource::loadPixmap( "folder" ); |
951 | QPixmap lnk = Resource::loadPixmap( "opie/symlink" ); | 951 | QPixmap lnk = Resource::loadPixmap( "opie/symlink" ); |
952 | QPainter painter( &pm ); | 952 | QPainter painter( &pm ); |
953 | painter.drawPixmap( pm.width()-lnk.width(), pm.height()-lnk.height(), lnk ); | 953 | painter.drawPixmap( pm.width()-lnk.width(), pm.height()-lnk.height(), lnk ); |
954 | pm.setMask( pm.createHeuristicMask( FALSE ) ); | 954 | pm.setMask( pm.createHeuristicMask( FALSE ) ); |
955 | m_pixmaps->insert("dirsymlink", pm ); | 955 | m_pixmaps->insert("dirsymlink", pm ); |
956 | 956 | ||
957 | QPixmap pm2 = Resource::loadPixmap( "lockedfolder" ); | 957 | QPixmap pm2 = Resource::loadPixmap( "lockedfolder" ); |
958 | QPainter pen(&pm2 ); | 958 | QPainter pen(&pm2 ); |
959 | pen.drawPixmap(pm2.width()-lnk.width(), pm2.height()-lnk.height(), lnk ); | 959 | pen.drawPixmap(pm2.width()-lnk.width(), pm2.height()-lnk.height(), lnk ); |
960 | pm2.setMask( pm2.createHeuristicMask( FALSE ) ); | 960 | pm2.setMask( pm2.createHeuristicMask( FALSE ) ); |
961 | m_pixmaps->insert("symlinkedlocked", pm2 ); | 961 | m_pixmaps->insert("symlinkedlocked", pm2 ); |
962 | } | 962 | } |
963 | // if a mime complies with the m_mimeCheck->currentItem | 963 | // if a mime complies with the m_mimeCheck->currentItem |
964 | bool OFileSelector::compliesMime( const QString &path, const QString &mime ) | 964 | bool OFileSelector::compliesMime( const QString &path, const QString &mime ) |
965 | { | 965 | { |
966 | if( mime == "All" ) | 966 | if( mime == "All" ) |
967 | return true; | 967 | return true; |
968 | MimeType type( path ); | 968 | MimeType type( path ); |
969 | if( type.id() == mime ) | 969 | if( type.id() == mime ) |
970 | return true; | 970 | return true; |
971 | return false; | 971 | return false; |
972 | } | 972 | } |
973 | /* check if the mimetype in mime | 973 | /* check if the mimetype in mime |
974 | * complies with the one which is current | 974 | * complies with the one which is current |
975 | */ | 975 | */ |
976 | /* | 976 | /* |
977 | * We've the mimetype of the file | 977 | * We've the mimetype of the file |
978 | * We need to get the stringlist of the current mimetype | 978 | * We need to get the stringlist of the current mimetype |
979 | * | 979 | * |
980 | * mime = image/jpeg | 980 | * mime = image/jpeg |
981 | * QStringList = 'image/*' | 981 | * QStringList = 'image/*' |
982 | * or QStringList = image/jpeg;image/png;application/x-ogg | 982 | * or QStringList = image/jpeg;image/png;application/x-ogg |
983 | * or QStringList = application/x-ogg;image/*; | 983 | * or QStringList = application/x-ogg;image/*; |
984 | * with all these mime filters it should get acceptes | 984 | * with all these mime filters it should get acceptes |
985 | * to do so we need to look if mime is contained inside | 985 | * to do so we need to look if mime is contained inside |
986 | * the stringlist | 986 | * the stringlist |
987 | * if it's contained return true | 987 | * if it's contained return true |
988 | * if not ( I'm no RegExp expert at all ) we'll look if a '/*' | 988 | * if not ( I'm no RegExp expert at all ) we'll look if a '/*' |
989 | * is contained in the mimefilter and then we will | 989 | * is contained in the mimefilter and then we will |
990 | * look if both are equal until the '/' | 990 | * look if both are equal until the '/' |
991 | */ | 991 | */ |
992 | bool OFileSelector::compliesMime( const QString& mime ) { | 992 | bool OFileSelector::compliesMime( const QString& mime ) { |
993 | qWarning("mimetype is %s", mime.latin1() ); | 993 | qWarning("mimetype is %s", mime.latin1() ); |
994 | QString currentText; | 994 | QString currentText; |
995 | if (m_shChooser ) | 995 | if (m_shChooser ) |
996 | currentText = m_mimeCheck->currentText(); | 996 | currentText = m_mimeCheck->currentText(); |
997 | 997 | ||
998 | qWarning("current text is %s", currentText.latin1() ); | 998 | qWarning("current text is %s", currentText.latin1() ); |
999 | QMap<QString, QStringList>::Iterator it; | 999 | QMap<QString, QStringList>::Iterator it; |
1000 | QStringList list; | 1000 | QStringList list; |
1001 | if ( currentText == tr("All") ) return true; | 1001 | if ( currentText == tr("All") ) return true; |
1002 | else if ( currentText.isEmpty() && !m_mimetypes.isEmpty() ) { | 1002 | else if ( currentText.isEmpty() && !m_mimetypes.isEmpty() ) { |
1003 | it = m_mimetypes.begin(); | 1003 | it = m_mimetypes.begin(); |
1004 | list = it.data(); | 1004 | list = it.data(); |
1005 | }else if ( currentText.isEmpty() ) return true; | 1005 | }else if ( currentText.isEmpty() ) return true; |
1006 | else{ | 1006 | else{ |
1007 | it = m_mimetypes.find(currentText ); | 1007 | it = m_mimetypes.find(currentText ); |
1008 | if ( it == m_mimetypes.end() ) qWarning("not there"), list << currentText; | 1008 | if ( it == m_mimetypes.end() ) qWarning("not there"), list << currentText; |
1009 | else qWarning("found"), list = it.data(); | 1009 | else qWarning("found"), list = it.data(); |
1010 | } | 1010 | } |
1011 | // dump it now | 1011 | // dump it now |
1012 | //for ( QStringList::Iterator it = list.begin(); it != list.end(); ++it ) { | 1012 | //for ( QStringList::Iterator it = list.begin(); it != list.end(); ++it ) { |
1013 | // qWarning( "%s", (*it).latin1() ); | 1013 | // qWarning( "%s", (*it).latin1() ); |
1014 | //} | 1014 | //} |
1015 | 1015 | ||
1016 | 1016 | ||
1017 | if ( list.contains(mime) ) return true; | 1017 | if ( list.contains(mime) ) return true; |
1018 | qWarning("list doesn't contain it "); | 1018 | qWarning("list doesn't contain it "); |
1019 | QStringList::Iterator it2; | 1019 | QStringList::Iterator it2; |
1020 | int pos; | 1020 | int pos; |
1021 | int pos2; | ||
1022 | for ( it2 = list.begin(); it2 != list.end(); ++it2 ) { | 1021 | for ( it2 = list.begin(); it2 != list.end(); ++it2 ) { |
1023 | pos = (*it2).findRev("/*"); | 1022 | pos = (*it2).findRev("/*"); |
1024 | if ( pos >= 0 ) { | 1023 | if ( pos >= 0 ) { |
1025 | if ( mime.contains( (*it2).left(pos) ) ) return true; | 1024 | if ( mime.contains( (*it2).left(pos) ) ) return true; |
1026 | } | 1025 | } |
1027 | } | 1026 | } |
1028 | return false; | 1027 | return false; |
1029 | } | 1028 | } |
1030 | void OFileSelector::slotFileSelected( const QString &string ) | 1029 | void OFileSelector::slotFileSelected( const QString &string ) |
1031 | { | 1030 | { |
1032 | if( m_shLne ) | 1031 | if( m_shLne ) |
1033 | m_edit->setText( string ); | 1032 | m_edit->setText( string ); |
1034 | emit fileSelected( string ); | 1033 | emit fileSelected( string ); |
1035 | } | 1034 | } |
1036 | void OFileSelector::slotFileBridgeSelected( const DocLnk &lnk ) | 1035 | void OFileSelector::slotFileBridgeSelected( const DocLnk &lnk ) |
1037 | { | 1036 | { |
1038 | slotFileSelected( lnk.name() ); | 1037 | slotFileSelected( lnk.name() ); |
1039 | emit fileSelected( lnk ); | 1038 | emit fileSelected( lnk ); |
1040 | } | 1039 | } |
1041 | void OFileSelector::slotSelectionChanged() | 1040 | void OFileSelector::slotSelectionChanged() |
1042 | { | 1041 | { |
1043 | 1042 | ||
1044 | } | 1043 | } |
1045 | void OFileSelector::slotCurrentChanged(QListViewItem* item ) | 1044 | void OFileSelector::slotCurrentChanged(QListViewItem* item ) |
1046 | { | 1045 | { |
1047 | if( item == 0 ) | 1046 | if( item == 0 ) |
1048 | return; | 1047 | return; |
1049 | if( m_selector == EXTENDED || m_selector == EXTENDED_ALL ) { | 1048 | if( m_selector == EXTENDED || m_selector == EXTENDED_ALL ) { |
1050 | OFileSelectorItem *sel = (OFileSelectorItem*) item; // start to use the C++ casts ;) | 1049 | OFileSelectorItem *sel = (OFileSelectorItem*) item; // start to use the C++ casts ;) |
1051 | qWarning("current changed"); | 1050 | qWarning("current changed"); |
1052 | if(!sel->isDir() ){ | 1051 | if(!sel->isDir() ){ |
1053 | if( m_shLne ) | 1052 | if( m_shLne ) |
1054 | m_edit->setText( sel->text(1) ); | 1053 | m_edit->setText( sel->text(1) ); |
1055 | 1054 | ||
1056 | if (m_mode == FILESELECTOR ) { | 1055 | if (m_mode == FILESELECTOR ) { |
1057 | QStringList str = QStringList::split("->", sel->text(1) ); | 1056 | QStringList str = QStringList::split("->", sel->text(1) ); |
1058 | QString path =sel->directory() + "/" + str[0].stripWhiteSpace(); | 1057 | QString path =sel->directory() + "/" + str[0].stripWhiteSpace(); |
1059 | emit fileSelected(path ); | 1058 | emit fileSelected(path ); |
1060 | DocLnk lnk( path ); | 1059 | DocLnk lnk( path ); |
1061 | emit fileSelected(lnk ); | 1060 | emit fileSelected(lnk ); |
1062 | } | 1061 | } |
1063 | } | 1062 | } |
1064 | } | 1063 | } |
1065 | } | 1064 | } |
1066 | void OFileSelector::slotClicked( int button, QListViewItem *item, const QPoint &, int) | 1065 | void OFileSelector::slotClicked( int button, QListViewItem *item, const QPoint &, int) |
1067 | { | 1066 | { |
1068 | if ( item == 0 ) | 1067 | if ( item == 0 ) |
1069 | return; | 1068 | return; |
1070 | 1069 | ||
1071 | if( button != Qt::LeftButton ) | 1070 | if( button != Qt::LeftButton ) |
1072 | return; | 1071 | return; |
1073 | 1072 | ||
1074 | switch( m_selector ){ | 1073 | switch( m_selector ){ |
1075 | default: | 1074 | default: |
1076 | break; | 1075 | break; |
1077 | case EXTENDED: // fall through | 1076 | case EXTENDED: // fall through |
1078 | case EXTENDED_ALL:{ | 1077 | case EXTENDED_ALL:{ |
1079 | OFileSelectorItem *sel = (OFileSelectorItem*)item; | 1078 | OFileSelectorItem *sel = (OFileSelectorItem*)item; |
1080 | if(!sel->isLocked() ){ | 1079 | if(!sel->isLocked() ){ |
1081 | QStringList str = QStringList::split("->", sel->text(1) ); | 1080 | QStringList str = QStringList::split("->", sel->text(1) ); |
1082 | if( sel->isDir() ){ | 1081 | if( sel->isDir() ){ |
1083 | cd( sel->directory() + "/" + str[0].stripWhiteSpace() ); | 1082 | cd( sel->directory() + "/" + str[0].stripWhiteSpace() ); |
1084 | // if MODE Dir m_shLne set the Text | 1083 | // if MODE Dir m_shLne set the Text |
1085 | }else{ | 1084 | }else{ |
1086 | if( m_shLne ) | 1085 | if( m_shLne ) |
1087 | m_edit->setText( str[0].stripWhiteSpace() ); | 1086 | m_edit->setText( str[0].stripWhiteSpace() ); |
1088 | qWarning("selected here in slot clicked"); | 1087 | qWarning("selected here in slot clicked"); |
1089 | emit fileSelected( sel->directory() + "/" + str[0].stripWhiteSpace() ); | 1088 | emit fileSelected( sel->directory() + "/" + str[0].stripWhiteSpace() ); |
1090 | DocLnk lnk( sel->directory() + "/" + str[0].stripWhiteSpace() ); | 1089 | DocLnk lnk( sel->directory() + "/" + str[0].stripWhiteSpace() ); |
1091 | qWarning("file selected"); | 1090 | qWarning("file selected"); |
1092 | emit fileSelected( lnk ); | 1091 | emit fileSelected( lnk ); |
1093 | } | 1092 | } |
1094 | } | 1093 | } |
1095 | break; | 1094 | break; |
1096 | } | 1095 | } |
1097 | } | 1096 | } |
1098 | } | 1097 | } |
1099 | void OFileSelector::slotRightButton(int button, QListViewItem *item, const QPoint &, int ) | 1098 | void OFileSelector::slotRightButton(int button, QListViewItem *item, const QPoint &, int ) |
1100 | { | 1099 | { |
1101 | if( item == 0 ) | 1100 | if( item == 0 ) |
1102 | return; | 1101 | return; |
1103 | 1102 | ||
1104 | if( button != Qt::RightButton ) | 1103 | if( button != Qt::RightButton ) |
1105 | return; | 1104 | return; |
1106 | slotContextMenu( item ); | 1105 | slotContextMenu( item ); |
1107 | } | 1106 | } |
1108 | void OFileSelector::slotContextMenu( QListViewItem *item) | 1107 | void OFileSelector::slotContextMenu( QListViewItem * /*item*/) |
1109 | { | 1108 | { |
1110 | 1109 | ||
1111 | } | 1110 | } |
1112 | void OFileSelector::slotChangedDir() | 1111 | void OFileSelector::slotChangedDir() |
1113 | { | 1112 | { |
1114 | OFileSelectorItem *sel = (OFileSelectorItem*)m_View->currentItem(); | 1113 | OFileSelectorItem *sel = (OFileSelectorItem*)m_View->currentItem(); |
1115 | if(sel->isDir() ){ | 1114 | if(sel->isDir() ){ |
1116 | QStringList str = QStringList::split("->", sel->text(1) ); | 1115 | QStringList str = QStringList::split("->", sel->text(1) ); |
1117 | cd( sel->directory() + "/" + str[0].stripWhiteSpace() ); | 1116 | cd( sel->directory() + "/" + str[0].stripWhiteSpace() ); |
1118 | } | 1117 | } |
1119 | } | 1118 | } |
1120 | void OFileSelector::slotOpen() | 1119 | void OFileSelector::slotOpen() |
1121 | { | 1120 | { |
1122 | OFileSelectorItem *sel = (OFileSelectorItem*)m_View->currentItem(); | 1121 | OFileSelectorItem *sel = (OFileSelectorItem*)m_View->currentItem(); |
1123 | if(!sel->isDir() ){ | 1122 | if(!sel->isDir() ){ |
1124 | QStringList str = QStringList::split("->", sel->text(1) ); | 1123 | QStringList str = QStringList::split("->", sel->text(1) ); |
1125 | slotFileSelected( sel->directory() +"/" +str[0].stripWhiteSpace() ); | 1124 | slotFileSelected( sel->directory() +"/" +str[0].stripWhiteSpace() ); |
1126 | qWarning("slot open"); | 1125 | qWarning("slot open"); |
1127 | // DocLnk lnk( sel->directory() + "/" + str[0].stripWhiteSpace() ); | 1126 | // DocLnk lnk( sel->directory() + "/" + str[0].stripWhiteSpace() ); |
1128 | //emit fileSelected( lnk ); | 1127 | //emit fileSelected( lnk ); |
1129 | } | 1128 | } |
1130 | } | 1129 | } |
1131 | void OFileSelector::slotRescan() | 1130 | void OFileSelector::slotRescan() |
1132 | { | 1131 | { |
1133 | 1132 | ||
1134 | } | 1133 | } |
1135 | void OFileSelector::slotRename() | 1134 | void OFileSelector::slotRename() |
1136 | { | 1135 | { |
1137 | reparse(); | 1136 | reparse(); |
1138 | } | 1137 | } |
1139 | void OFileSelector::slotDelete() | 1138 | void OFileSelector::slotDelete() |
1140 | { | 1139 | { |
1141 | OFileSelectorItem *sel = (OFileSelectorItem*)m_View->currentItem(); | 1140 | OFileSelectorItem *sel = (OFileSelectorItem*)m_View->currentItem(); |
1142 | QStringList list = QStringList::split("->", sel->text(1) ); | 1141 | QStringList list = QStringList::split("->", sel->text(1) ); |
1143 | if( sel->isDir() ){ | 1142 | if( sel->isDir() ){ |
1144 | QString str = QString::fromLatin1("rm -rf ") + sel->directory() +"/" + list[0]; //better safe than sorry | 1143 | QString str = QString::fromLatin1("rm -rf ") + sel->directory() +"/" + list[0]; //better safe than sorry |
1145 | switch ( QMessageBox::warning(this,tr("Delete"),tr("Do you really want to delete\n")+list[0], | 1144 | switch ( QMessageBox::warning(this,tr("Delete"),tr("Do you really want to delete\n")+list[0], |
1146 | tr("Yes"),tr("No"),0,1,1) ) { | 1145 | tr("Yes"),tr("No"),0,1,1) ) { |
1147 | case 0: | 1146 | case 0: |
1148 | ::system(str.utf8().data() ); | 1147 | ::system(str.utf8().data() ); |
1149 | break; | 1148 | break; |
1150 | } | 1149 | } |
1151 | } else { | 1150 | } else { |
1152 | QFile::remove( list[0] ); | 1151 | QFile::remove( list[0] ); |
1153 | } | 1152 | } |
1154 | m_View->takeItem( sel ); | 1153 | m_View->takeItem( sel ); |
1155 | delete sel; | 1154 | delete sel; |
1156 | } | 1155 | } |
1157 | void OFileSelector::cdUP() | 1156 | void OFileSelector::cdUP() |
1158 | { | 1157 | { |
1159 | QDir dir( m_currentDir ); | 1158 | QDir dir( m_currentDir ); |
1160 | dir.cdUp(); | 1159 | dir.cdUp(); |
1161 | if(dir.exists() ){ | 1160 | if(dir.exists() ){ |
1162 | m_currentDir = dir.absPath(); | 1161 | m_currentDir = dir.absPath(); |
1163 | reparse(); | 1162 | reparse(); |
1164 | int count = m_location->count(); | 1163 | int count = m_location->count(); |
1165 | slotInsertLocationPath( m_currentDir, count); | 1164 | slotInsertLocationPath( m_currentDir, count); |
1166 | m_location->setCurrentItem( indexByString( m_location, m_currentDir)); | 1165 | m_location->setCurrentItem( indexByString( m_location, m_currentDir)); |
1167 | //this wont work in all instances | 1166 | //this wont work in all instances |
1168 | // FIXME | 1167 | // FIXME |
1169 | } | 1168 | } |
1170 | } | 1169 | } |
1171 | void OFileSelector::slotHome() | 1170 | void OFileSelector::slotHome() |
1172 | { | 1171 | { |
1173 | cd(QDir::homeDirPath() ); | 1172 | cd(QDir::homeDirPath() ); |
1174 | } | 1173 | } |
1175 | void OFileSelector::slotDoc() | 1174 | void OFileSelector::slotDoc() |
1176 | { | 1175 | { |
1177 | cd(QPEApplication::documentDir() ); | 1176 | cd(QPEApplication::documentDir() ); |
1178 | } | 1177 | } |
1179 | void OFileSelector::slotNavigate( ) | 1178 | void OFileSelector::slotNavigate( ) |
1180 | { | 1179 | { |
1181 | 1180 | ||
1182 | } | 1181 | } |
1183 | // fill the View with life | 1182 | // fill the View with life |
1184 | void OFileSelector::reparse() | 1183 | void OFileSelector::reparse() |
1185 | { | 1184 | { |
1186 | if( m_selector == NORMAL ) | 1185 | if( m_selector == NORMAL ) |
1187 | return; | 1186 | return; |
1188 | if( m_selector == EXTENDED || m_selector == EXTENDED_ALL ) | 1187 | if( m_selector == EXTENDED || m_selector == EXTENDED_ALL ) |
1189 | m_View->clear(); | 1188 | m_View->clear(); |
1190 | else // custom view | 1189 | else // custom view |
1191 | ; // currentView()->clear(); | 1190 | ; // currentView()->clear(); |
1192 | if( m_shChooser) | 1191 | if( m_shChooser) |
1193 | qWarning("reparse %s", m_mimeCheck->currentText().latin1() ); | 1192 | qWarning("reparse %s", m_mimeCheck->currentText().latin1() ); |
1194 | 1193 | ||
1195 | QString currentMimeType; | 1194 | QString currentMimeType; |
1196 | // let's update the mimetype | 1195 | // let's update the mimetype |
1197 | if( m_autoMime ){ | 1196 | if( m_autoMime ){ |
1198 | m_mimetypes.clear(); | 1197 | m_mimetypes.clear(); |
1199 | // ok we can change mimetype so we need to be able to give a selection | 1198 | // ok we can change mimetype so we need to be able to give a selection |
1200 | if( m_shChooser ) { | 1199 | if( m_shChooser ) { |
1201 | currentMimeType = m_mimeCheck->currentText(); | 1200 | currentMimeType = m_mimeCheck->currentText(); |
1202 | m_mimeCheck->clear(); | 1201 | m_mimeCheck->clear(); |
1203 | 1202 | ||
1204 | // let's find possible mimetypes | 1203 | // let's find possible mimetypes |
1205 | QDir dir( m_currentDir ); | 1204 | QDir dir( m_currentDir ); |
1206 | dir.setFilter( QDir::Files | QDir::Readable ); | 1205 | dir.setFilter( QDir::Files | QDir::Readable ); |
1207 | dir.setSorting( QDir::Size ); | 1206 | dir.setSorting( QDir::Size ); |
1208 | const QFileInfoList *list = dir.entryInfoList(); | 1207 | const QFileInfoList *list = dir.entryInfoList(); |
1209 | QFileInfoListIterator it( *list ); | 1208 | QFileInfoListIterator it( *list ); |
1210 | QFileInfo *fi; | 1209 | QFileInfo *fi; |
1211 | while( (fi=it.current() ) ) { | 1210 | while( (fi=it.current() ) ) { |
1212 | if( fi->extension() == QString::fromLatin1("desktop") ){ | 1211 | if( fi->extension() == QString::fromLatin1("desktop") ){ |
1213 | ++it; | 1212 | ++it; |
1214 | continue; | 1213 | continue; |
1215 | } | 1214 | } |
1216 | MimeType type( fi->absFilePath() ); | 1215 | MimeType type( fi->absFilePath() ); |
1217 | if( !m_mimetypes.contains( type.id() ) ){ | 1216 | if( !m_mimetypes.contains( type.id() ) ){ |
1218 | //qWarning("Type %s", type.id().latin1() ); | 1217 | //qWarning("Type %s", type.id().latin1() ); |
1219 | m_mimetypes.insert( type.id(), type.id() ); | 1218 | m_mimetypes.insert( type.id(), type.id() ); |
1220 | } | 1219 | } |
1221 | 1220 | ||
1222 | ++it; | 1221 | ++it; |
1223 | } | 1222 | } |
1224 | // add them to the chooser | 1223 | // add them to the chooser |
1225 | updateMimeCheck(); | 1224 | updateMimeCheck(); |
1226 | m_mimeCheck->setCurrentItem( indexByString( m_mimeCheck, currentMimeType ) ); | 1225 | m_mimeCheck->setCurrentItem( indexByString( m_mimeCheck, currentMimeType ) ); |
1227 | currentMimeType = m_mimeCheck->currentText(); | 1226 | currentMimeType = m_mimeCheck->currentText(); |
1228 | } | 1227 | } |
1229 | }else { // no autoMime | 1228 | }else { // no autoMime |
1230 | // let the mimetype be set from out side the m_mimeCheck FEATURE | 1229 | // let the mimetype be set from out side the m_mimeCheck FEATURE |
1231 | 1230 | ||
1232 | if( m_shChooser ){ | 1231 | if( m_shChooser ){ |
1233 | currentMimeType = m_mimeCheck->currentText(); | 1232 | currentMimeType = m_mimeCheck->currentText(); |
1234 | // updateMimeCheck(); | 1233 | // updateMimeCheck(); |
1235 | } | 1234 | } |
1236 | } | 1235 | } |
1237 | // now we got our mimetypes we can add the files | 1236 | // now we got our mimetypes we can add the files |
1238 | 1237 | ||
1239 | QDir dir( m_currentDir ); | 1238 | QDir dir( m_currentDir ); |
1240 | 1239 | ||
1241 | int sort; | 1240 | int sort; |
1242 | if ( m_case ) | 1241 | if ( m_case ) |
1243 | sort = (QDir::IgnoreCase | QDir::Name | QDir::DirsFirst | QDir::Reversed); | 1242 | sort = (QDir::IgnoreCase | QDir::Name | QDir::DirsFirst | QDir::Reversed); |
1244 | else | 1243 | else |
1245 | sort = (QDir::Name | QDir::DirsFirst | QDir::Reversed); | 1244 | sort = (QDir::Name | QDir::DirsFirst | QDir::Reversed); |
1246 | dir.setSorting( sort ); | 1245 | dir.setSorting( sort ); |
1247 | 1246 | ||
1248 | int filter; | 1247 | int filter; |
1249 | if( m_selector == EXTENDED_ALL /*|| m_selector ==CUSTOM_ALL */ ){ | 1248 | if( m_selector == EXTENDED_ALL /*|| m_selector ==CUSTOM_ALL */ ){ |
1250 | filter = QDir::Files | QDir::Dirs | QDir::Hidden | QDir::All; | 1249 | filter = QDir::Files | QDir::Dirs | QDir::Hidden | QDir::All; |
1251 | }else | 1250 | }else |
1252 | filter = QDir::Files | QDir::Dirs | QDir::All; | 1251 | filter = QDir::Files | QDir::Dirs | QDir::All; |
1253 | dir.setFilter( filter ); | 1252 | dir.setFilter( filter ); |
1254 | 1253 | ||
1255 | // now go through all files | 1254 | // now go through all files |
1256 | const QFileInfoList *list = dir.entryInfoList(); | 1255 | const QFileInfoList *list = dir.entryInfoList(); |
1257 | QFileInfoListIterator it( *list ); | 1256 | QFileInfoListIterator it( *list ); |
1258 | QFileInfo *fi; | 1257 | QFileInfo *fi; |
1259 | while( (fi=it.current() ) ){ | 1258 | while( (fi=it.current() ) ){ |
1260 | //qWarning("True and only" ); | 1259 | //qWarning("True and only" ); |
1261 | if( fi->fileName() == QString::fromLatin1("..") || fi->fileName() == QString::fromLatin1(".") ){ | 1260 | if( fi->fileName() == QString::fromLatin1("..") || fi->fileName() == QString::fromLatin1(".") ){ |
1262 | //qWarning(".. or ." ); | 1261 | //qWarning(".. or ." ); |
1263 | ++it; | 1262 | ++it; |
1264 | continue; | 1263 | continue; |
1265 | } | 1264 | } |
1266 | if( fi->isSymLink() ){ | 1265 | if( fi->isSymLink() ){ |
1267 | QString file = fi->dirPath( true ) + "/" + fi->readLink(); | 1266 | QString file = fi->dirPath( true ) + "/" + fi->readLink(); |
1268 | for( int i = 0; i<=4; i++) { // 5 tries to prevent dos | 1267 | for( int i = 0; i<=4; i++) { // 5 tries to prevent dos |
1269 | QFileInfo info( file ); | 1268 | QFileInfo info( file ); |
1270 | if( !info.exists() ){ | 1269 | if( !info.exists() ){ |
1271 | addSymlink( currentMimeType, fi, TRUE ); | 1270 | addSymlink( currentMimeType, fi, TRUE ); |
1272 | break; | 1271 | break; |
1273 | }else if( info.isDir() ){ | 1272 | }else if( info.isDir() ){ |
1274 | addDir( currentMimeType, fi, TRUE ); | 1273 | addDir( currentMimeType, fi, TRUE ); |
1275 | break; | 1274 | break; |
1276 | }else if( info.isFile() ){ | 1275 | }else if( info.isFile() ){ |
1277 | addFile( currentMimeType, fi, TRUE ); | 1276 | addFile( currentMimeType, fi, TRUE ); |
1278 | break; | 1277 | break; |
1279 | }else if( info.isSymLink() ){ | 1278 | }else if( info.isSymLink() ){ |
1280 | file = info.dirPath(true ) + "/" + info.readLink() ; | 1279 | file = info.dirPath(true ) + "/" + info.readLink() ; |
1281 | break; | 1280 | break; |
1282 | }else if( i == 4){ | 1281 | }else if( i == 4){ |
1283 | addSymlink( currentMimeType, fi ); | 1282 | addSymlink( currentMimeType, fi ); |
1284 | } | 1283 | } |
1285 | } // off for loop | 1284 | } // off for loop |
1286 | }else if( fi->isDir() ){ | 1285 | }else if( fi->isDir() ){ |
1287 | addDir( currentMimeType, fi ); | 1286 | addDir( currentMimeType, fi ); |
1288 | }else if( fi->isFile() ){ | 1287 | }else if( fi->isFile() ){ |
1289 | addFile( currentMimeType, fi ); | 1288 | addFile( currentMimeType, fi ); |
1290 | } | 1289 | } |
1291 | //qWarning( "%s", fi->fileName().latin1() ); | 1290 | //qWarning( "%s", fi->fileName().latin1() ); |
1292 | ++it; | 1291 | ++it; |
1293 | } // of while loop | 1292 | } // of while loop |
1294 | m_View->sort(); | 1293 | m_View->sort(); |
1295 | if( m_shTool ){ | 1294 | if( m_shTool ){ |
1296 | m_location->insertItem( m_currentDir ); | 1295 | m_location->insertItem( m_currentDir ); |
1297 | 1296 | ||
1298 | } | 1297 | } |
1299 | // reenable painting and updates | 1298 | // reenable painting and updates |
1300 | } | 1299 | } |
diff --git a/libopie/ofileselector.h b/libopie/ofileselector.h index f2d5f84..17c494e 100644 --- a/libopie/ofileselector.h +++ b/libopie/ofileselector.h | |||
@@ -1,309 +1,309 @@ | |||
1 | /* | 1 | /* |
2 | This is based on code and ideas of | 2 | This is based on code and ideas of |
3 | L. J. Potter ljp@llornkcor.com | 3 | L. J. Potter ljp@llornkcor.com |
4 | Thanks a lot | 4 | Thanks a lot |
5 | 5 | ||
6 | 6 | ||
7 | =. This file is part of the OPIE Project | 7 | =. This file is part of the OPIE Project |
8 | .=l. Copyright (c) 2002 Holger Freyther <zecke@handhelds.org> | 8 | .=l. Copyright (c) 2002 Holger Freyther <zecke@handhelds.org> |
9 | .>+-= | 9 | .>+-= |
10 | _;:, .> :=|. This library is free software; you can | 10 | _;:, .> :=|. This library is free software; you can |
11 | .> <`_, > . <= redistribute it and/or modify it under | 11 | .> <`_, > . <= redistribute it and/or modify it under |
12 | :`=1 )Y*s>-.-- : the terms of the GNU Library General Public | 12 | :`=1 )Y*s>-.-- : the terms of the GNU Library General Public |
13 | .="- .-=="i, .._ License as published by the Free Software | 13 | .="- .-=="i, .._ License as published by the Free Software |
14 | - . .-<_> .<> Foundation; either version 2 of the License, | 14 | - . .-<_> .<> Foundation; either version 2 of the License, |
15 | ._= =} : or (at your option) any later version. | 15 | ._= =} : or (at your option) any later version. |
16 | .%`+i> _;_. | 16 | .%`+i> _;_. |
17 | .i_,=:_. -<s. This library is distributed in the hope that | 17 | .i_,=:_. -<s. This library is distributed in the hope that |
18 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; | 18 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; |
19 | : .. .:, . . . without even the implied warranty of | 19 | : .. .:, . . . without even the implied warranty of |
20 | =_ + =;=|` MERCHANTABILITY or FITNESS FOR A | 20 | =_ + =;=|` MERCHANTABILITY or FITNESS FOR A |
21 | _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU | 21 | _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU |
22 | ..}^=.= = ; Library General Public License for more | 22 | ..}^=.= = ; Library General Public License for more |
23 | ++= -. .` .: details. | 23 | ++= -. .` .: details. |
24 | : = ...= . :.=- | 24 | : = ...= . :.=- |
25 | -. .:....=;==+<; You should have received a copy of the GNU | 25 | -. .:....=;==+<; You should have received a copy of the GNU |
26 | -_. . . )=. = Library General Public License along with | 26 | -_. . . )=. = Library General Public License along with |
27 | -- :-=` this library; see the file COPYING.LIB. | 27 | -- :-=` this library; see the file COPYING.LIB. |
28 | If not, write to the Free Software Foundation, | 28 | If not, write to the Free Software Foundation, |
29 | Inc., 59 Temple Place - Suite 330, | 29 | Inc., 59 Temple Place - Suite 330, |
30 | Boston, MA 02111-1307, USA. | 30 | Boston, MA 02111-1307, USA. |
31 | 31 | ||
32 | */ | 32 | */ |
33 | 33 | ||
34 | #ifndef opiefileselector_h | 34 | #ifndef opiefileselector_h |
35 | #define opiefileselector_h | 35 | #define opiefileselector_h |
36 | 36 | ||
37 | #include <qwidget.h> | 37 | #include <qwidget.h> |
38 | #include <qstring.h> | 38 | #include <qstring.h> |
39 | #include <qpixmap.h> | 39 | #include <qpixmap.h> |
40 | #include <qstringlist.h> | 40 | #include <qstringlist.h> |
41 | #include <qmap.h> | 41 | #include <qmap.h> |
42 | #include <qvaluelist.h> | 42 | #include <qvaluelist.h> |
43 | 43 | ||
44 | #include <qpe/applnk.h> | 44 | #include <qpe/applnk.h> |
45 | #include <qlistview.h> | 45 | #include <qlistview.h> |
46 | 46 | ||
47 | /** This is OPIEs FileDialog Widget. You can use it | 47 | /** This is OPIEs FileDialog Widget. You can use it |
48 | * as a dropin replacement of the fileselector and | 48 | * as a dropin replacement of the fileselector and |
49 | * or use any of the new features. | 49 | * or use any of the new features. |
50 | * This is also a complete FileSave and FileLoad widget | 50 | * This is also a complete FileSave and FileLoad widget |
51 | * If you look for a Dialog check OFileDialog | 51 | * If you look for a Dialog check OFileDialog |
52 | * | 52 | * |
53 | */ | 53 | */ |
54 | class DocLnk; | 54 | class DocLnk; |
55 | class QCheckBox; | 55 | class QCheckBox; |
56 | class QComboBox; | 56 | class QComboBox; |
57 | class QPushButton; | 57 | class QPushButton; |
58 | class FileSelector; | 58 | class FileSelector; |
59 | class QGridLayout; | 59 | class QGridLayout; |
60 | class QLineEdit; | 60 | class QLineEdit; |
61 | class QLabel; | 61 | class QLabel; |
62 | class QWidgetStack; | 62 | class QWidgetStack; |
63 | class QHBoxLayout; | 63 | class QHBoxLayout; |
64 | class QVBoxLayout; | 64 | class QVBoxLayout; |
65 | class QPopupMenu; | 65 | class QPopupMenu; |
66 | class QFileInfo; | 66 | class QFileInfo; |
67 | class QHBox; | 67 | class QHBox; |
68 | // | 68 | // |
69 | 69 | ||
70 | typedef QMap< QString, QStringList> MimeTypes; | 70 | typedef QMap< QString, QStringList> MimeTypes; |
71 | 71 | ||
72 | class OFileSelector : public QWidget { | 72 | class OFileSelector : public QWidget { |
73 | Q_OBJECT | 73 | Q_OBJECT |
74 | public: | 74 | public: |
75 | /** | 75 | /** |
76 | * The mode of the file selector | 76 | * The mode of the file selector |
77 | * Either open, save, fileselector or dir browsing mode | 77 | * Either open, save, fileselector or dir browsing mode |
78 | * | 78 | * |
79 | */ | 79 | */ |
80 | enum Mode {OPEN=1, SAVE=2, FILESELECTOR=4, DIR=8 }; | 80 | enum Mode {OPEN=1, SAVE=2, FILESELECTOR=4, DIR=8 }; |
81 | 81 | ||
82 | /** | 82 | /** |
83 | * Selector. Either NORMAL for the one shipped with | 83 | * Selector. Either NORMAL for the one shipped with |
84 | * libqpe or EXTENDED. for the EXTENDED | 84 | * libqpe or EXTENDED. for the EXTENDED |
85 | * EXTENDED_ALL also shows 'hidden' files | 85 | * EXTENDED_ALL also shows 'hidden' files |
86 | */ | 86 | */ |
87 | enum Selector{NORMAL=0, EXTENDED = 1, EXTENDED_ALL =2 }; | 87 | enum Selector{NORMAL=0, EXTENDED = 1, EXTENDED_ALL =2 }; |
88 | 88 | ||
89 | /** | 89 | /** |
90 | * This is reserved for futrue views | 90 | * This is reserved for futrue views |
91 | */ | 91 | */ |
92 | enum View { DIRS = 1, FILES = 2, TREE = 4, ICON = 8 }; | 92 | enum View { DIRS = 1, FILES = 2, TREE = 4, ICON = 8 }; |
93 | 93 | ||
94 | /** | 94 | /** |
95 | * A c'tor which should be used for advanced mode | 95 | * A c'tor which should be used for advanced mode |
96 | * @param wid the parent | 96 | * @param wid the parent |
97 | * @param mode the Mode of the Selector | 97 | * @param mode the Mode of the Selector |
98 | * @param selector the current View of the Selector | 98 | * @param selector the current View of the Selector |
99 | * @param dirName in which dir to start | 99 | * @param dirName in which dir to start |
100 | * @param fileName a proposed filename | 100 | * @param fileName a proposed filename |
101 | * @param mimetypes A list of mimetypes \ | 101 | * @param mimetypes A list of mimetypes \ |
102 | * QString is for a identifier name like "Text files" | 102 | * QString is for a identifier name like "Text files" |
103 | * the coresponding QStringList is used for the mimetypes | 103 | * the coresponding QStringList is used for the mimetypes |
104 | * if empty it'll fill the list of mimetypes depending | 104 | * if empty it'll fill the list of mimetypes depending |
105 | * on the content of the current directory | 105 | * on the content of the current directory |
106 | */ | 106 | */ |
107 | 107 | ||
108 | OFileSelector(QWidget *wid, int mode, int selector, | 108 | OFileSelector(QWidget *wid, int mode, int selector, |
109 | const QString &dirName, | 109 | const QString &dirName, |
110 | const QString &fileName = QString::null, | 110 | const QString &fileName = QString::null, |
111 | const MimeTypes &mimetypes = MimeTypes() ); | 111 | const MimeTypes &mimetypes = MimeTypes() ); |
112 | 112 | ||
113 | 113 | ||
114 | /** | 114 | /** |
115 | * This is a QPE compatible c'tor | 115 | * This is a QPE compatible c'tor |
116 | */ | 116 | */ |
117 | OFileSelector(const QString &mimeFilter, QWidget *parent, | 117 | OFileSelector(const QString &mimeFilter, QWidget *parent, |
118 | const char *name, bool newVisible = TRUE, | 118 | const char *name, bool newVisible = TRUE, |
119 | bool closeVisible = FALSE ); | 119 | bool closeVisible = FALSE ); |
120 | 120 | ||
121 | ~OFileSelector(); | 121 | ~OFileSelector(); |
122 | 122 | ||
123 | // currently only for the FILESELECTOR Mode | 123 | // currently only for the FILESELECTOR Mode |
124 | void setNewVisible( bool /*b*/ ); | 124 | void setNewVisible( bool /*b*/ ); |
125 | void setCloseVisible(bool /*b*/ ); | 125 | void setCloseVisible(bool /*b*/ ); |
126 | 126 | ||
127 | // end file selector mode | 127 | // end file selector mode |
128 | // deprecated | 128 | // deprecated |
129 | void reread(); | 129 | void reread(); |
130 | // make sure not to leak please | 130 | // make sure not to leak please |
131 | const DocLnk *selected(); | 131 | const DocLnk *selected(); |
132 | // end deprecated | 132 | // end deprecated |
133 | 133 | ||
134 | bool isToolbarVisible() const { return m_shTool; }; | 134 | bool isToolbarVisible() const { return m_shTool; }; |
135 | bool isPermissionBarVisible() const { return m_shPerm; }; | 135 | bool isPermissionBarVisible() const { return m_shPerm; }; |
136 | bool isLineEditVisible()const { return m_shLne; }; | 136 | bool isLineEditVisible()const { return m_shLne; }; |
137 | bool isChooserVisible( )const { return m_shChooser; }; | 137 | bool isChooserVisible( )const { return m_shChooser; }; |
138 | bool isYesCancelVisible()const { return m_shYesNo; }; | 138 | bool isYesCancelVisible()const { return m_shYesNo; }; |
139 | void setYesCancelVisible( bool show ); | 139 | void setYesCancelVisible( bool show ); |
140 | void setToolbarVisible( bool show ); | 140 | void setToolbarVisible( bool show ); |
141 | void setPermissionBarVisible( bool show ); | 141 | void setPermissionBarVisible( bool show ); |
142 | void setLineEditVisible(bool show) ; | 142 | void setLineEditVisible(bool show) ; |
143 | void setChooserVisible( bool chooser ); | 143 | void setChooserVisible( bool chooser ); |
144 | 144 | ||
145 | QCheckBox* permissionCheckbox(); | 145 | QCheckBox* permissionCheckbox(); |
146 | bool setPermission() const; | 146 | bool setPermission() const; |
147 | void setPermissionChecked( bool check ); | 147 | void setPermissionChecked( bool check ); |
148 | 148 | ||
149 | void setMode( int ); | 149 | void setMode( int ); |
150 | 150 | ||
151 | bool showDirs()const { return m_dir; } | 151 | bool showDirs()const { return m_dir; } |
152 | void setShowDirs(bool ); | 152 | void setShowDirs(bool ); |
153 | 153 | ||
154 | const QListView* listView() { return m_View; }; | 154 | const QListView* listView() { return m_View; }; |
155 | 155 | ||
156 | bool isCaseSensetive()const { return m_case; } | 156 | bool isCaseSensetive()const { return m_case; } |
157 | void setCaseSensetive(bool caSe ); | 157 | void setCaseSensetive(bool caSe ); |
158 | 158 | ||
159 | bool showFiles()const { return m_files; }; | 159 | bool showFiles()const { return m_files; }; |
160 | void setShowFiles(bool ); | 160 | void setShowFiles(bool ); |
161 | bool cd(const QString &path ); | 161 | bool cd(const QString &path ); |
162 | 162 | ||
163 | 163 | ||
164 | int mode()const { return m_mode; }; | 164 | int mode()const { return m_mode; }; |
165 | int selector()const { return m_selector; }; | 165 | int selector()const { return m_selector; }; |
166 | void setSelector( int ); | 166 | void setSelector( int ); |
167 | 167 | ||
168 | bool showPopup()const { return m_showPopup; }; | 168 | bool showPopup()const { return m_showPopup; }; |
169 | void setShowPopup( bool pop ) { m_showPopup = pop; }; | 169 | void setShowPopup( bool pop ) { m_showPopup = pop; }; |
170 | void setPopupMenu( QPopupMenu * ); | 170 | void setPopupMenu( QPopupMenu * ); |
171 | 171 | ||
172 | // void updateLay(); | 172 | // void updateLay(); |
173 | 173 | ||
174 | void reparse(); // re reads the dir | 174 | void reparse(); // re reads the dir |
175 | 175 | ||
176 | QString selectedName( )const; | 176 | QString selectedName( )const; |
177 | QStringList selectedNames()const; | 177 | QStringList selectedNames()const; |
178 | 178 | ||
179 | QString selectedPath() const; | 179 | QString selectedPath() const; |
180 | QStringList selectedPaths() const; | 180 | QStringList selectedPaths() const; |
181 | 181 | ||
182 | QString directory()const; | 182 | QString directory()const; |
183 | int fileCount(); | 183 | int fileCount() const; |
184 | 184 | ||
185 | /* the user needs to delete it */ | 185 | /* the user needs to delete it */ |
186 | DocLnk selectedDocument()const; | 186 | DocLnk selectedDocument()const; |
187 | /* the user needs to delete it */ | 187 | /* the user needs to delete it */ |
188 | QValueList<DocLnk> selectedDocuments()const; | 188 | QValueList<DocLnk> selectedDocuments()const; |
189 | 189 | ||
190 | signals: | 190 | signals: |
191 | void fileSelected( const DocLnk & ); | 191 | void fileSelected( const DocLnk & ); |
192 | void fileSelected( const QString & ); | 192 | void fileSelected( const QString & ); |
193 | void dirSelected(const QString &dir ); | 193 | void dirSelected(const QString &dir ); |
194 | void closeMe(); | 194 | void closeMe(); |
195 | void ok(); | 195 | void ok(); |
196 | void cancel(); | 196 | void cancel(); |
197 | void contextMenu(); | 197 | void contextMenu(); |
198 | 198 | ||
199 | private slots: | 199 | private slots: |
200 | void slotTest() { qWarning("slotTest" ); setLineEditVisible(false ); }; | 200 | void slotTest() { qWarning("slotTest" ); setLineEditVisible(false ); }; |
201 | void slotOk(); | 201 | void slotOk(); |
202 | void slotCancel(); | 202 | void slotCancel(); |
203 | void slotViewCheck(const QString & ); | 203 | void slotViewCheck(const QString & ); |
204 | void slotMimeCheck(const QString & ); | 204 | void slotMimeCheck(const QString & ); |
205 | void slotLocationActivated(const QString & ); | 205 | void slotLocationActivated(const QString & ); |
206 | void slotInsertLocationPath(const QString &, int); | 206 | void slotInsertLocationPath(const QString &, int); |
207 | void locationComboChanged(); | 207 | void locationComboChanged(); |
208 | 208 | ||
209 | private: | 209 | private: |
210 | void init(); | 210 | void init(); |
211 | void updateMimes(); | 211 | void updateMimes(); |
212 | 212 | ||
213 | protected: | 213 | protected: |
214 | 214 | ||
215 | private: | 215 | private: |
216 | int m_mode, m_selector; | 216 | int m_mode, m_selector; |
217 | QComboBox *m_location, *m_mimeCheck, *m_viewCheck; | 217 | QComboBox *m_location, *m_mimeCheck, *m_viewCheck; |
218 | QPushButton *m_homeButton, *m_docButton, *m_hideButton, *m_ok, *m_cancel; | 218 | QPushButton *m_homeButton, *m_docButton, *m_hideButton, *m_ok, *m_cancel; |
219 | QPushButton *m_reread, *m_up, *m_new, *m_close; | 219 | QPushButton *m_reread, *m_up, *m_new, *m_close; |
220 | QListView *m_View; | 220 | QListView *m_View; |
221 | QCheckBox *m_checkPerm; | 221 | QCheckBox *m_checkPerm; |
222 | QWidget *m_pseudo; | 222 | QWidget *m_pseudo; |
223 | QVBoxLayout *m_pseudoLayout; | 223 | QVBoxLayout *m_pseudoLayout; |
224 | 224 | ||
225 | QString m_currentDir; | 225 | QString m_currentDir; |
226 | QString m_name; | 226 | QString m_name; |
227 | // QStringList m_mimetypes; | 227 | // QStringList m_mimetypes; |
228 | QMap<QString, QStringList> m_mimetypes; | 228 | QMap<QString, QStringList> m_mimetypes; |
229 | 229 | ||
230 | FileSelector *m_select; | 230 | FileSelector *m_select; |
231 | QWidgetStack *m_stack; | 231 | QWidgetStack *m_stack; |
232 | QVBoxLayout *m_lay; | 232 | QVBoxLayout *m_lay; |
233 | QGridLayout *m_Oselector; | 233 | QGridLayout *m_Oselector; |
234 | 234 | ||
235 | QHBox *m_boxToolbar; | 235 | QHBox *m_boxToolbar; |
236 | QHBox *m_boxOk; // (no layout anymore) wait | 236 | QHBox *m_boxOk; // (no layout anymore) wait |
237 | QHBox *m_boxName; // (no Layout anymore) wait | 237 | QHBox *m_boxName; // (no Layout anymore) wait |
238 | QHBox *m_boxView; | 238 | QHBox *m_boxView; |
239 | 239 | ||
240 | QPopupMenu *m_custom; | 240 | QPopupMenu *m_custom; |
241 | 241 | ||
242 | QLineEdit *m_edit; | 242 | QLineEdit *m_edit; |
243 | QLabel *m_fnLabel; | 243 | QLabel *m_fnLabel; |
244 | 244 | ||
245 | bool m_shClose : 1; | 245 | bool m_shClose : 1; |
246 | bool m_shNew : 1; | 246 | bool m_shNew : 1; |
247 | bool m_shTool : 1; | 247 | bool m_shTool : 1; |
248 | bool m_shPerm : 1; | 248 | bool m_shPerm : 1; |
249 | bool m_shLne : 1; | 249 | bool m_shLne : 1; |
250 | bool m_shChooser : 1; | 250 | bool m_shChooser : 1; |
251 | bool m_shYesNo : 1; | 251 | bool m_shYesNo : 1; |
252 | bool m_boCheckPerm : 1; | 252 | bool m_boCheckPerm : 1; |
253 | bool m_autoMime : 1; | 253 | bool m_autoMime : 1; |
254 | bool m_case : 1; | 254 | bool m_case : 1; |
255 | bool m_dir : 1; | 255 | bool m_dir : 1; |
256 | bool m_files : 1; | 256 | bool m_files : 1; |
257 | bool m_showPopup : 1; | 257 | bool m_showPopup : 1; |
258 | 258 | ||
259 | void initVars(); | 259 | void initVars(); |
260 | virtual void addFile(const QString &mime, QFileInfo *info, bool symlink = FALSE ); | 260 | virtual void addFile(const QString &mime, QFileInfo *info, bool symlink = FALSE ); |
261 | virtual void addDir( const QString &mime, QFileInfo *info , bool symlink = FALSE ); | 261 | virtual void addDir( const QString &mime, QFileInfo *info , bool symlink = FALSE ); |
262 | virtual void addSymlink(const QString &, QFileInfo *, bool = FALSE ){}; | 262 | virtual void addSymlink(const QString &, QFileInfo *, bool = FALSE ){}; |
263 | void delItems(); | 263 | void delItems(); |
264 | void initializeName(); | 264 | void initializeName(); |
265 | void initializeYes(); | 265 | void initializeYes(); |
266 | void initializeChooser(); | 266 | void initializeChooser(); |
267 | void initializeListView(); | 267 | void initializeListView(); |
268 | void initializePerm(); | 268 | void initializePerm(); |
269 | void initPics(); | 269 | void initPics(); |
270 | bool compliesMime(const QString &path, | 270 | bool compliesMime(const QString &path, |
271 | const QString &mime); | 271 | const QString &mime); |
272 | bool compliesMime(const QString& mime ); | 272 | bool compliesMime(const QString& mime ); |
273 | /** | 273 | /** |
274 | * Updates the QComboBox with the current mimetypes | 274 | * Updates the QComboBox with the current mimetypes |
275 | */ | 275 | */ |
276 | void updateMimeCheck(); | 276 | void updateMimeCheck(); |
277 | 277 | ||
278 | /** | 278 | /** |
279 | * Returns the current mimetype | 279 | * Returns the current mimetype |
280 | */ | 280 | */ |
281 | QString currentMimeType()const; | 281 | QString currentMimeType()const; |
282 | class OFileSelectorPrivate; | 282 | class OFileSelectorPrivate; |
283 | OFileSelectorPrivate *d; | 283 | OFileSelectorPrivate *d; |
284 | static QMap<QString,QPixmap> *m_pixmaps; | 284 | static QMap<QString,QPixmap> *m_pixmaps; |
285 | 285 | ||
286 | private slots: | 286 | private slots: |
287 | void slotFileSelected(const QString & ); // not really meant to be a slot | 287 | void slotFileSelected(const QString & ); // not really meant to be a slot |
288 | void slotFileBridgeSelected( const DocLnk & ); | 288 | void slotFileBridgeSelected( const DocLnk & ); |
289 | virtual void slotSelectionChanged(); | 289 | virtual void slotSelectionChanged(); |
290 | virtual void slotCurrentChanged(QListViewItem* ); | 290 | virtual void slotCurrentChanged(QListViewItem* ); |
291 | virtual void slotClicked( int, QListViewItem *item, const QPoint &, int); | 291 | virtual void slotClicked( int, QListViewItem *item, const QPoint &, int); |
292 | virtual void slotRightButton(int, QListViewItem *, const QPoint &, int ); | 292 | virtual void slotRightButton(int, QListViewItem *, const QPoint &, int ); |
293 | virtual void slotContextMenu( QListViewItem *item); | 293 | virtual void slotContextMenu( QListViewItem *item); |
294 | // listview above | 294 | // listview above |
295 | // popup below | 295 | // popup below |
296 | virtual void slotChangedDir(); | 296 | virtual void slotChangedDir(); |
297 | virtual void slotOpen(); | 297 | virtual void slotOpen(); |
298 | virtual void slotRescan(); | 298 | virtual void slotRescan(); |
299 | virtual void slotRename(); | 299 | virtual void slotRename(); |
300 | virtual void slotDelete(); | 300 | virtual void slotDelete(); |
301 | virtual void cdUP(); | 301 | virtual void cdUP(); |
302 | virtual void slotHome(); | 302 | virtual void slotHome(); |
303 | virtual void slotDoc(); | 303 | virtual void slotDoc(); |
304 | virtual void slotNavigate( ); | 304 | virtual void slotNavigate( ); |
305 | }; | 305 | }; |
306 | 306 | ||
307 | 307 | ||
308 | #endif | 308 | #endif |
309 | 309 | ||
diff --git a/libopie/ofileselector/odefaultfactories.cpp b/libopie/ofileselector/odefaultfactories.cpp index c8efffb..2f8ef9b 100644 --- a/libopie/ofileselector/odefaultfactories.cpp +++ b/libopie/ofileselector/odefaultfactories.cpp | |||
@@ -1,23 +1,19 @@ | |||
1 | #include "ofilelistview.h" | 1 | #include "ofilelistview.h" |
2 | #include "ofileiconview.h" | ||
3 | #include "olocallister.h" | 2 | #include "olocallister.h" |
4 | 3 | ||
5 | 4 | ||
6 | #include "odefaultfactories.h" | 5 | #include "odefaultfactories.h" |
7 | 6 | ||
8 | extern "C" { | 7 | extern "C" { |
9 | 8 | ||
10 | 9 | ||
11 | OFileView* newFileIconView( OFileSelector* sel, QWidget* parent ) { | ||
12 | return new OFileIconView( parent, sel ); | ||
13 | } | ||
14 | 10 | ||
15 | OFileView* newFileListView( OFileSelector* sel, QWidget* par ) { | 11 | OFileView* newFileListView( OFileSelector* sel, QWidget* par ) { |
16 | return new OFileListView(par, sel ); | 12 | return new OFileListView(par, sel ); |
17 | } | 13 | } |
18 | 14 | ||
19 | OLister* newLocalLister( OFileSelector* sel) { | 15 | OLister* newLocalLister( OFileSelector* sel) { |
20 | return new OLocalLister( sel ); | 16 | return new OLocalLister( sel ); |
21 | } | 17 | } |
22 | 18 | ||
23 | }; | 19 | }; |
diff --git a/libopie/ofileselector/odefaultfactories.h b/libopie/ofileselector/odefaultfactories.h index b4c35af..0cc90e5 100644 --- a/libopie/ofileselector/odefaultfactories.h +++ b/libopie/ofileselector/odefaultfactories.h | |||
@@ -1,17 +1,16 @@ | |||
1 | #ifndef OPIE_DEFAULT_FACTORIES_H | 1 | #ifndef OPIE_DEFAULT_FACTORIES_H |
2 | #define OPIE_DEFAULT_FACTORIES_H | 2 | #define OPIE_DEFAULT_FACTORIES_H |
3 | 3 | ||
4 | #include "ofilefactory.h" | 4 | #include "ofilefactory.h" |
5 | 5 | ||
6 | extern "C" { | 6 | extern "C" { |
7 | 7 | ||
8 | OFileView* newFileIconView( OFileSelector*, QWidget* parent ); | ||
9 | OFileView* newFileListView( OFileSelector*, QWidget* parent ); | 8 | OFileView* newFileListView( OFileSelector*, QWidget* parent ); |
10 | 9 | ||
11 | OLister* newLocalLister(OFileSelector* ); | 10 | OLister* newLocalLister(OFileSelector* ); |
12 | 11 | ||
13 | 12 | ||
14 | }; | 13 | }; |
15 | 14 | ||
16 | 15 | ||
17 | #endif | 16 | #endif |
diff --git a/libopie/ofileselector/ofileselector.cpp b/libopie/ofileselector/ofileselector.cpp index c6e923f..abc2889 100644 --- a/libopie/ofileselector/ofileselector.cpp +++ b/libopie/ofileselector/ofileselector.cpp | |||
@@ -787,308 +787,309 @@ bool OFileSelector::compliesMime( const QString& mime ) { | |||
787 | 787 | ||
788 | qWarning("current text is %s", currentText.latin1() ); | 788 | qWarning("current text is %s", currentText.latin1() ); |
789 | QMap<QString, QStringList>::Iterator it; | 789 | QMap<QString, QStringList>::Iterator it; |
790 | QStringList list; | 790 | QStringList list; |
791 | if ( currentText == tr("All") ) return true; | 791 | if ( currentText == tr("All") ) return true; |
792 | else if ( currentText.isEmpty() && !m_mimetypes.isEmpty() ) { | 792 | else if ( currentText.isEmpty() && !m_mimetypes.isEmpty() ) { |
793 | it = m_mimetypes.begin(); | 793 | it = m_mimetypes.begin(); |
794 | list = it.data(); | 794 | list = it.data(); |
795 | }else if ( currentText.isEmpty() ) return true; | 795 | }else if ( currentText.isEmpty() ) return true; |
796 | else{ | 796 | else{ |
797 | it = m_mimetypes.find(currentText ); | 797 | it = m_mimetypes.find(currentText ); |
798 | if ( it == m_mimetypes.end() ) qWarning("not there"), list << currentText; | 798 | if ( it == m_mimetypes.end() ) qWarning("not there"), list << currentText; |
799 | else qWarning("found"), list = it.data(); | 799 | else qWarning("found"), list = it.data(); |
800 | } | 800 | } |
801 | 801 | ||
802 | 802 | ||
803 | if ( list.contains(mime) ) return true; | 803 | if ( list.contains(mime) ) return true; |
804 | qWarning("list doesn't contain it "); | 804 | qWarning("list doesn't contain it "); |
805 | QStringList::Iterator it2; | 805 | QStringList::Iterator it2; |
806 | int pos; | 806 | int pos; |
807 | for ( it2 = list.begin(); it2 != list.end(); ++it2 ) { | 807 | for ( it2 = list.begin(); it2 != list.end(); ++it2 ) { |
808 | pos = (*it2).findRev("/*"); | 808 | pos = (*it2).findRev("/*"); |
809 | if ( pos >= 0 ) { | 809 | if ( pos >= 0 ) { |
810 | if ( mime.contains( (*it2).left(pos) ) ) return true; | 810 | if ( mime.contains( (*it2).left(pos) ) ) return true; |
811 | } | 811 | } |
812 | } | 812 | } |
813 | return false; | 813 | return false; |
814 | } | 814 | } |
815 | void OFileSelector::slotFileSelected( const QString &string ) | 815 | void OFileSelector::slotFileSelected( const QString &string ) |
816 | { | 816 | { |
817 | if( m_shLne ) | 817 | if( m_shLne ) |
818 | m_edit->setText( string ); | 818 | m_edit->setText( string ); |
819 | emit fileSelected( string ); | 819 | emit fileSelected( string ); |
820 | } | 820 | } |
821 | void OFileSelector::slotFileBridgeSelected( const DocLnk &lnk ) | 821 | void OFileSelector::slotFileBridgeSelected( const DocLnk &lnk ) |
822 | { | 822 | { |
823 | slotFileSelected( lnk.name() ); | 823 | slotFileSelected( lnk.name() ); |
824 | // emit fileSelected( lnk ); | 824 | // emit fileSelected( lnk ); |
825 | } | 825 | } |
826 | 826 | ||
827 | 827 | ||
828 | void OFileSelector::slotDelete() | 828 | void OFileSelector::slotDelete() |
829 | { | 829 | { |
830 | /* | 830 | /* |
831 | OFileSelectorItem *sel = (OFileSelectorItem*)m_View->currentItem(); | 831 | OFileSelectorItem *sel = (OFileSelectorItem*)m_View->currentItem(); |
832 | QStringList list = QStringList::split("->", sel->text(1) ); | 832 | QStringList list = QStringList::split("->", sel->text(1) ); |
833 | if( sel->isDir() ){ | 833 | if( sel->isDir() ){ |
834 | QString str = QString::fromLatin1("rm -rf ") + sel->directory() +"/" + list[0]; //better safe than sorry | 834 | QString str = QString::fromLatin1("rm -rf ") + sel->directory() +"/" + list[0]; //better safe than sorry |
835 | switch ( QMessageBox::warning(this,tr("Delete"),tr("Do you really want to delete\n")+list[0], | 835 | switch ( QMessageBox::warning(this,tr("Delete"),tr("Do you really want to delete\n")+list[0], |
836 | tr("Yes"),tr("No"),0,1,1) ) { | 836 | tr("Yes"),tr("No"),0,1,1) ) { |
837 | case 0: | 837 | case 0: |
838 | ::system(str.utf8().data() ); | 838 | ::system(str.utf8().data() ); |
839 | break; | 839 | break; |
840 | } | 840 | } |
841 | } else { | 841 | } else { |
842 | QFile::remove( list[0] ); | 842 | QFile::remove( list[0] ); |
843 | } | 843 | } |
844 | m_View->takeItem( sel ); | 844 | m_View->takeItem( sel ); |
845 | delete sel; | 845 | delete sel; |
846 | */ | 846 | */ |
847 | } | 847 | } |
848 | void OFileSelector::cdUP() | 848 | void OFileSelector::cdUP() |
849 | { | 849 | { |
850 | // FIXME won't work on non filesystem based systems | 850 | // FIXME won't work on non filesystem based systems |
851 | // better call the Olister | 851 | // better call the Olister |
852 | QDir dir( m_currentDir ); | 852 | QDir dir( m_currentDir ); |
853 | dir.cdUp(); | 853 | dir.cdUp(); |
854 | if(dir.exists() ){ | 854 | if(dir.exists() ){ |
855 | m_currentDir = dir.absPath(); | 855 | m_currentDir = dir.absPath(); |
856 | reparse(); | 856 | reparse(); |
857 | int count = m_location->count(); | 857 | int count = m_location->count(); |
858 | slotInsertLocationPath( m_currentDir, count); | 858 | slotInsertLocationPath( m_currentDir, count); |
859 | m_location->setCurrentItem( indexByString( m_location, m_currentDir)); | 859 | m_location->setCurrentItem( indexByString( m_location, m_currentDir)); |
860 | } | 860 | } |
861 | } | 861 | } |
862 | void OFileSelector::slotHome() | 862 | void OFileSelector::slotHome() |
863 | { | 863 | { |
864 | cd(QDir::homeDirPath() ); | 864 | cd(QDir::homeDirPath() ); |
865 | } | 865 | } |
866 | void OFileSelector::slotDoc() | 866 | void OFileSelector::slotDoc() |
867 | { | 867 | { |
868 | cd(QPEApplication::documentDir() ); | 868 | cd(QPEApplication::documentDir() ); |
869 | } | 869 | } |
870 | void OFileSelector::slotNavigate( ) | 870 | void OFileSelector::slotNavigate( ) |
871 | { | 871 | { |
872 | 872 | ||
873 | } | 873 | } |
874 | // fill the View with life | 874 | // fill the View with life |
875 | void OFileSelector::reparse() | 875 | void OFileSelector::reparse() |
876 | { | 876 | { |
877 | if( m_selector == Normal ) | 877 | if( m_selector == Normal ) |
878 | return; | 878 | return; |
879 | 879 | ||
880 | currentView()->clear(); | 880 | currentView()->clear(); |
881 | 881 | ||
882 | if( m_shChooser) | 882 | if( m_shChooser) |
883 | qWarning("reparse %s", m_mimeCheck->currentText().latin1() ); | 883 | qWarning("reparse %s", m_mimeCheck->currentText().latin1() ); |
884 | 884 | ||
885 | QString currentMimeType; | 885 | QString currentMimeType; |
886 | 886 | ||
887 | // let's update the mimetype | 887 | // let's update the mimetype |
888 | if( m_autoMime ){ | 888 | if( m_autoMime ){ |
889 | m_mimetypes.clear(); | 889 | m_mimetypes.clear(); |
890 | // ok we can change mimetype so we need to be able to give a selection | 890 | // ok we can change mimetype so we need to be able to give a selection |
891 | if( m_shChooser ) { | 891 | if( m_shChooser ) { |
892 | currentMimeType = m_mimeCheck->currentText(); | 892 | currentMimeType = m_mimeCheck->currentText(); |
893 | m_mimeCheck->clear(); | 893 | m_mimeCheck->clear(); |
894 | 894 | ||
895 | // let's find possible mimetypes | 895 | // let's find possible mimetypes |
896 | m_mimetypes = currentLister()->mimeTypes( m_currentDir ); | 896 | m_mimetypes = currentLister()->mimeTypes( m_currentDir ); |
897 | 897 | ||
898 | // add them to the chooser | 898 | // add them to the chooser |
899 | updateMimeCheck(); | 899 | updateMimeCheck(); |
900 | m_mimeCheck->setCurrentItem( indexByString( m_mimeCheck, currentMimeType ) ); | 900 | m_mimeCheck->setCurrentItem( indexByString( m_mimeCheck, currentMimeType ) ); |
901 | currentMimeType = m_mimeCheck->currentText(); | 901 | currentMimeType = m_mimeCheck->currentText(); |
902 | } | 902 | } |
903 | }else { // no autoMime | 903 | }else { // no autoMime |
904 | // let the mimetype be set from out side the m_mimeCheck FEATURE | 904 | // let the mimetype be set from out side the m_mimeCheck FEATURE |
905 | 905 | ||
906 | if( m_shChooser ) | 906 | if( m_shChooser ) |
907 | currentMimeType = m_mimeCheck->currentText(); | 907 | currentMimeType = m_mimeCheck->currentText(); |
908 | 908 | ||
909 | } | 909 | } |
910 | // now we got our mimetypes we can add the files | 910 | // now we got our mimetypes we can add the files |
911 | 911 | ||
912 | currentLister()->reparse( m_currentDir ); | 912 | currentLister()->reparse( m_currentDir ); |
913 | /* we're done with adding let's sort */ | 913 | /* we're done with adding let's sort */ |
914 | currentView()->sort(); | 914 | currentView()->sort(); |
915 | 915 | ||
916 | 916 | ||
917 | if( m_shTool ){ | 917 | if( m_shTool ){ |
918 | m_location->insertItem( m_currentDir ); | 918 | m_location->insertItem( m_currentDir ); |
919 | 919 | ||
920 | } | 920 | } |
921 | // reenable painting and updates | 921 | // reenable painting and updates |
922 | } | 922 | } |
923 | /* switch lister to @param lister */ | 923 | /* switch lister to @param lister */ |
924 | void OFileSelector::setLister(const QString& lister) { | 924 | void OFileSelector::setLister(const QString& lister) { |
925 | QStringList listerList = factory()->lister(); | 925 | QStringList listerList = factory()->lister(); |
926 | 926 | ||
927 | if (listerList.contains(lister) ) { | 927 | if (listerList.contains(lister) ) { |
928 | delete (OLister*) m_lister; | 928 | delete (OLister*) m_lister; |
929 | m_lister = factory()->lister( lister, this ); | 929 | m_lister = factory()->lister( lister, this ); |
930 | }else if (!m_lister ) { | 930 | }else if (!m_lister ) { |
931 | /* | 931 | /* |
932 | * if we do not have a lister | 932 | * if we do not have a lister |
933 | * we need to take the default one | 933 | * we need to take the default one |
934 | */ | 934 | */ |
935 | m_lister = new OLocalLister(this); | 935 | m_lister = new OLocalLister(this); |
936 | } | 936 | } |
937 | m_listerName = lister; | 937 | m_listerName = lister; |
938 | } | 938 | } |
939 | void OFileSelector::setView( const QString& lis ) { | 939 | void OFileSelector::setView( const QString& lis ) { |
940 | qWarning("setView "); | 940 | qWarning("setView "); |
941 | fillList(); | 941 | fillList(); |
942 | if ( lis == tr("Documents") ) { | 942 | if ( lis == tr("Documents") ) { |
943 | m_selector = Normal; | 943 | m_selector = Normal; |
944 | delete m_lister; | 944 | delete m_lister; |
945 | delete m_fileView; | 945 | delete m_fileView; |
946 | m_lister = 0l; | 946 | m_lister = 0l; |
947 | m_fileView = 0l; | 947 | m_fileView = 0l; |
948 | initializeOldSelector(); | 948 | initializeOldSelector(); |
949 | }else { | 949 | }else { |
950 | qWarning("lis %s", lis.latin1() ); | 950 | qWarning("lis %s", lis.latin1() ); |
951 | QString list; | 951 | QString list; |
952 | 952 | ||
953 | delete m_lister; | 953 | delete m_lister; |
954 | delete m_fileView; | 954 | delete m_fileView; |
955 | delete m_select; | 955 | delete m_select; |
956 | m_lister =0l; | 956 | m_lister =0l; |
957 | m_fileView = 0l; | 957 | m_fileView = 0l; |
958 | m_select = 0l; | 958 | m_select = 0l; |
959 | if ( lis.startsWith("All") ) { | 959 | if ( lis.startsWith("All") ) { |
960 | m_selector = ExtendedAll; | 960 | m_selector = ExtendedAll; |
961 | list = lis.mid(4 ).stripWhiteSpace(); | 961 | list = lis.mid(4 ).stripWhiteSpace(); |
962 | } else{ | 962 | } else{ |
963 | list = lis; | 963 | list = lis; |
964 | m_selector = Extended; | 964 | m_selector = Extended; |
965 | } | 965 | } |
966 | setLister(m_listerName); | 966 | setLister(m_listerName); |
967 | m_fileView = factory()->view( list, this, m_mainView ); | 967 | m_fileView = factory()->view( list, this, m_mainView ); |
968 | m_mainView->setWidget( m_fileView->widget() ); | 968 | m_mainView->setWidget( m_fileView->widget() ); |
969 | reparse(); | 969 | reparse(); |
970 | } | 970 | } |
971 | } | 971 | } |
972 | /* | 972 | /* |
973 | * the factory | 973 | * the factory |
974 | */ | 974 | */ |
975 | void OFileSelector::initFactory() { | 975 | void OFileSelector::initFactory() { |
976 | m_fileFactory = new OFileFactory(); | 976 | m_fileFactory = new OFileFactory(); |
977 | m_fileFactory->addLister(tr("Files"), newLocalLister ); | 977 | m_fileFactory->addLister(tr("Files"), newLocalLister ); |
978 | m_fileFactory->addView(tr("List View"), newFileListView ); | 978 | m_fileFactory->addView(tr("List View"), newFileListView ); |
979 | m_fileFactory->addView(tr("Documents"), newFileIconView ); | 979 | /* dummy entry */ |
980 | m_fileFactory->addView(tr("Documents"), newFileListView ); | ||
980 | } | 981 | } |
981 | 982 | ||
982 | void OFileSelector::fillList() { | 983 | void OFileSelector::fillList() { |
983 | qWarning("fill list"); | 984 | qWarning("fill list"); |
984 | if (!m_viewCheck ) | 985 | if (!m_viewCheck ) |
985 | return; | 986 | return; |
986 | 987 | ||
987 | m_viewCheck->clear(); | 988 | m_viewCheck->clear(); |
988 | QStringList list = factory()->views(); | 989 | QStringList list = factory()->views(); |
989 | qWarning("views: " + list.join(";") ); | 990 | qWarning("views: " + list.join(";") ); |
990 | for (QStringList::Iterator it = list.begin(); it != list.end(); ++it ) { | 991 | for (QStringList::Iterator it = list.begin(); it != list.end(); ++it ) { |
991 | qWarning( (*it) ); | 992 | qWarning( (*it) ); |
992 | if ( (*it) == tr("Documents") ) { | 993 | if ( (*it) == tr("Documents") ) { |
993 | m_viewCheck->insertItem( (*it) ); | 994 | m_viewCheck->insertItem( (*it) ); |
994 | }else{ | 995 | }else{ |
995 | m_viewCheck->insertItem( (*it) ); | 996 | m_viewCheck->insertItem( (*it) ); |
996 | m_viewCheck->insertItem( tr("All ") + (*it) ); | 997 | m_viewCheck->insertItem( tr("All ") + (*it) ); |
997 | } | 998 | } |
998 | } | 999 | } |
999 | } | 1000 | } |
1000 | OFileFactory* OFileSelector::factory() { | 1001 | OFileFactory* OFileSelector::factory() { |
1001 | return m_fileFactory; | 1002 | return m_fileFactory; |
1002 | } | 1003 | } |
1003 | 1004 | ||
1004 | 1005 | ||
1005 | OFileView* OFileSelector::currentView() { | 1006 | OFileView* OFileSelector::currentView() { |
1006 | return m_fileView; | 1007 | return m_fileView; |
1007 | } | 1008 | } |
1008 | OFileView* OFileSelector::currentView() const{ | 1009 | OFileView* OFileSelector::currentView() const{ |
1009 | return m_fileView; | 1010 | return m_fileView; |
1010 | } | 1011 | } |
1011 | int OFileSelector::filter() { | 1012 | int OFileSelector::filter() { |
1012 | int filter; | 1013 | int filter; |
1013 | if ( m_selector == ExtendedAll ) | 1014 | if ( m_selector == ExtendedAll ) |
1014 | filter = QDir::Files | QDir::Dirs | QDir::Hidden | QDir::All; | 1015 | filter = QDir::Files | QDir::Dirs | QDir::Hidden | QDir::All; |
1015 | else | 1016 | else |
1016 | filter = QDir::Files | QDir::Dirs | QDir::All ; | 1017 | filter = QDir::Files | QDir::Dirs | QDir::All ; |
1017 | 1018 | ||
1018 | return filter; | 1019 | return filter; |
1019 | } | 1020 | } |
1020 | int OFileSelector::sorting() { | 1021 | int OFileSelector::sorting() { |
1021 | int sort; | 1022 | int sort; |
1022 | 1023 | ||
1023 | if (m_case ) | 1024 | if (m_case ) |
1024 | sort = ( QDir::IgnoreCase | QDir::Name | QDir::DirsFirst | QDir::Reversed ); | 1025 | sort = ( QDir::IgnoreCase | QDir::Name | QDir::DirsFirst | QDir::Reversed ); |
1025 | else | 1026 | else |
1026 | sort = ( QDir::Name | QDir::DirsFirst | QDir::Reversed ); | 1027 | sort = ( QDir::Name | QDir::DirsFirst | QDir::Reversed ); |
1027 | 1028 | ||
1028 | return sort; | 1029 | return sort; |
1029 | } | 1030 | } |
1030 | void OFileSelector::internFileSelected( const QString& s) { | 1031 | void OFileSelector::internFileSelected( const QString& s) { |
1031 | emit fileSelected( s ); | 1032 | emit fileSelected( s ); |
1032 | DocLnk lnk( s ); | 1033 | DocLnk lnk( s ); |
1033 | internFileSelected( lnk ); | 1034 | internFileSelected( lnk ); |
1034 | } | 1035 | } |
1035 | void OFileSelector::internFileSelected( const DocLnk& d ) { | 1036 | void OFileSelector::internFileSelected( const DocLnk& d ) { |
1036 | emit fileSelected( d ); | 1037 | emit fileSelected( d ); |
1037 | } | 1038 | } |
1038 | void OFileSelector::internContextMenu() { | 1039 | void OFileSelector::internContextMenu() { |
1039 | emit contextMenu(); | 1040 | emit contextMenu(); |
1040 | } | 1041 | } |
1041 | void OFileSelector::internChangedDir( const QString& s) { | 1042 | void OFileSelector::internChangedDir( const QString& s) { |
1042 | emit dirSelected( s ); | 1043 | emit dirSelected( s ); |
1043 | cd(s ); | 1044 | cd(s ); |
1044 | } | 1045 | } |
1045 | void OFileSelector::internChangedDir( const QDir& s) { | 1046 | void OFileSelector::internChangedDir( const QDir& s) { |
1046 | emit dirSelected( s ); | 1047 | emit dirSelected( s ); |
1047 | } | 1048 | } |
1048 | QPixmap OFileSelector::pixmap( const QString& s ) { | 1049 | QPixmap OFileSelector::pixmap( const QString& s ) { |
1049 | 1050 | ||
1050 | return (*m_pixmaps)[s]; | 1051 | return (*m_pixmaps)[s]; |
1051 | } | 1052 | } |
1052 | OLister* OFileSelector::currentLister()const { | 1053 | OLister* OFileSelector::currentLister()const { |
1053 | return m_lister; | 1054 | return m_lister; |
1054 | } | 1055 | } |
1055 | void OFileSelector::initializeOldSelector() { | 1056 | void OFileSelector::initializeOldSelector() { |
1056 | qWarning("initializeOldSelector"); | 1057 | qWarning("initializeOldSelector"); |
1057 | 1058 | ||
1058 | delete m_select; | 1059 | delete m_select; |
1059 | 1060 | ||
1060 | // we need to initialize but keep the selected mimetype | 1061 | // we need to initialize but keep the selected mimetype |
1061 | /* we default not to show close and new buttons */ | 1062 | /* we default not to show close and new buttons */ |
1062 | QString mime = currentMimeType(); | 1063 | QString mime = currentMimeType(); |
1063 | qWarning("MimeType " + mime ); | 1064 | qWarning("MimeType " + mime ); |
1064 | m_select = new FileSelector( mime , | 1065 | m_select = new FileSelector( mime , |
1065 | m_mainView, "fileselector", | 1066 | m_mainView, "fileselector", |
1066 | FALSE, FALSE); | 1067 | FALSE, FALSE); |
1067 | m_select->setCategorySelectVisible( FALSE ); | 1068 | m_select->setCategorySelectVisible( FALSE ); |
1068 | m_select->setTypeComboVisible( FALSE ); | 1069 | m_select->setTypeComboVisible( FALSE ); |
1069 | 1070 | ||
1070 | connect(m_select, SIGNAL(fileSelected( const DocLnk & ) ), | 1071 | connect(m_select, SIGNAL(fileSelected( const DocLnk & ) ), |
1071 | this, SLOT( slotFileBridgeSelected(const DocLnk & ) ) ); | 1072 | this, SLOT( slotFileBridgeSelected(const DocLnk & ) ) ); |
1072 | connect(m_select, SIGNAL(closeMe() ), | 1073 | connect(m_select, SIGNAL(closeMe() ), |
1073 | this, SIGNAL(closeMe() ) ); | 1074 | this, SIGNAL(closeMe() ) ); |
1074 | //connect to close me and other signals as well | 1075 | //connect to close me and other signals as well |
1075 | m_mainView->setWidget( m_select ); | 1076 | m_mainView->setWidget( m_select ); |
1076 | } | 1077 | } |
1077 | /* | 1078 | /* |
1078 | * initialize the listview | 1079 | * initialize the listview |
1079 | * we will call fillList | 1080 | * we will call fillList |
1080 | * setLister | 1081 | * setLister |
1081 | * with QString::null to get the default | 1082 | * with QString::null to get the default |
1082 | * setView with either Files or All Files | 1083 | * setView with either Files or All Files |
1083 | * depending on Extended | 1084 | * depending on Extended |
1084 | */ | 1085 | */ |
1085 | void OFileSelector::initializeView() { | 1086 | void OFileSelector::initializeView() { |
1086 | setLister(QString::null); | 1087 | setLister(QString::null); |
1087 | fillList(); | 1088 | fillList(); |
1088 | if (m_selector == Extended ) { | 1089 | if (m_selector == Extended ) { |
1089 | setView( tr("List View") ); | 1090 | setView( tr("List View") ); |
1090 | }else{ | 1091 | }else{ |
1091 | setView( tr("All List View") ); | 1092 | setView( tr("All List View") ); |
1092 | } | 1093 | } |
1093 | } | 1094 | } |
1094 | 1095 | ||
diff --git a/libopie/pim/opimaccessbackend.h b/libopie/pim/opimaccessbackend.h index 0bd2723..4f00bc9 100644 --- a/libopie/pim/opimaccessbackend.h +++ b/libopie/pim/opimaccessbackend.h | |||
@@ -1,141 +1,141 @@ | |||
1 | #ifndef OPIE_PIM_ACCESS_BACKEND | 1 | #ifndef OPIE_PIM_ACCESS_BACKEND |
2 | #define OPIE_PIM_ACCESS_BACKEND | 2 | #define OPIE_PIM_ACCESS_BACKEND |
3 | 3 | ||
4 | #include <qarray.h> | 4 | #include <qarray.h> |
5 | 5 | ||
6 | #include <opie/otemplatebase.h> | 6 | #include <opie/otemplatebase.h> |
7 | #include <opie/opimrecord.h> | 7 | #include <opie/opimrecord.h> |
8 | 8 | ||
9 | 9 | ||
10 | /** | 10 | /** |
11 | * OPimAccessBackend is the base class | 11 | * OPimAccessBackend is the base class |
12 | * for all private backends | 12 | * for all private backends |
13 | * it operates on OPimRecord as the base class | 13 | * it operates on OPimRecord as the base class |
14 | * and it's responsible for fast manipulating | 14 | * and it's responsible for fast manipulating |
15 | * the resource the implementation takes care | 15 | * the resource the implementation takes care |
16 | * of | 16 | * of |
17 | */ | 17 | */ |
18 | template <class T = OPimRecord> | 18 | template <class T = OPimRecord> |
19 | class OPimAccessBackend { | 19 | class OPimAccessBackend { |
20 | public: | 20 | public: |
21 | typedef OTemplateBase<T> Frontend; | 21 | typedef OTemplateBase<T> Frontend; |
22 | OPimAccessBackend(); | 22 | OPimAccessBackend(); |
23 | virtual ~OPimAccessBackend(); | 23 | virtual ~OPimAccessBackend(); |
24 | 24 | ||
25 | /** | 25 | /** |
26 | * load the resource | 26 | * load the resource |
27 | */ | 27 | */ |
28 | virtual bool load() = 0; | 28 | virtual bool load() = 0; |
29 | 29 | ||
30 | /** | 30 | /** |
31 | * reload the resource | 31 | * reload the resource |
32 | */ | 32 | */ |
33 | virtual bool reload() = 0; | 33 | virtual bool reload() = 0; |
34 | 34 | ||
35 | /** | 35 | /** |
36 | * save the resource and | 36 | * save the resource and |
37 | * all it's changes | 37 | * all it's changes |
38 | */ | 38 | */ |
39 | virtual bool save() = 0; | 39 | virtual bool save() = 0; |
40 | 40 | ||
41 | /** | 41 | /** |
42 | * return an array of | 42 | * return an array of |
43 | * all available uids | 43 | * all available uids |
44 | */ | 44 | */ |
45 | virtual QArray<int> allRecords()const = 0; | 45 | virtual QArray<int> allRecords()const = 0; |
46 | 46 | ||
47 | /** | 47 | /** |
48 | * queryByExample for T with the SortOrder | 48 | * queryByExample for T with the SortOrder |
49 | * sort | 49 | * sort |
50 | */ | 50 | */ |
51 | virtual QArray<int> queryByExample( const T& t, int sort ) = 0; | 51 | virtual QArray<int> queryByExample( const T& t, int sort ) = 0; |
52 | 52 | ||
53 | /** | 53 | /** |
54 | * find the OPimRecord with uid @param uid | 54 | * find the OPimRecord with uid @param uid |
55 | * returns T and T.isEmpty() if nothing was found | 55 | * returns T and T.isEmpty() if nothing was found |
56 | */ | 56 | */ |
57 | virtual T find(int uid )const = 0; | 57 | virtual T find(int uid )const = 0; |
58 | 58 | ||
59 | virtual T find(int uid, const QArray<int>& items, | 59 | virtual T find(int uid, const QArray<int>& items, |
60 | uint current, Frontend::CacheDirection )const ; | 60 | uint current, typename Frontend::CacheDirection )const ; |
61 | /** | 61 | /** |
62 | * clear the back end | 62 | * clear the back end |
63 | */ | 63 | */ |
64 | virtual void clear() = 0; | 64 | virtual void clear() = 0; |
65 | 65 | ||
66 | /** | 66 | /** |
67 | * add T | 67 | * add T |
68 | */ | 68 | */ |
69 | virtual bool add( const T& t ) = 0; | 69 | virtual bool add( const T& t ) = 0; |
70 | 70 | ||
71 | /** | 71 | /** |
72 | * remove | 72 | * remove |
73 | */ | 73 | */ |
74 | virtual bool remove( int uid ) = 0; | 74 | virtual bool remove( int uid ) = 0; |
75 | 75 | ||
76 | /** | 76 | /** |
77 | * replace a record with T.uid() | 77 | * replace a record with T.uid() |
78 | */ | 78 | */ |
79 | virtual bool replace( const T& t ) = 0; | 79 | virtual bool replace( const T& t ) = 0; |
80 | 80 | ||
81 | /* | 81 | /* |
82 | * setTheFrontEnd!!! | 82 | * setTheFrontEnd!!! |
83 | */ | 83 | */ |
84 | void setFrontend( Frontend* front ); | 84 | void setFrontend( Frontend* front ); |
85 | 85 | ||
86 | /** | 86 | /** |
87 | * set the read ahead count | 87 | * set the read ahead count |
88 | */ | 88 | */ |
89 | void setReadAhead( uint count ); | 89 | void setReadAhead( uint count ); |
90 | protected: | 90 | protected: |
91 | void cache( const T& t )const; | 91 | void cache( const T& t )const; |
92 | 92 | ||
93 | /** | 93 | /** |
94 | * use a prime number here! | 94 | * use a prime number here! |
95 | */ | 95 | */ |
96 | void setSaneCacheSize( int ); | 96 | void setSaneCacheSize( int ); |
97 | 97 | ||
98 | uint readAhead()const; | 98 | uint readAhead()const; |
99 | 99 | ||
100 | private: | 100 | private: |
101 | Frontend* m_front; | 101 | Frontend* m_front; |
102 | uint m_read; | 102 | uint m_read; |
103 | 103 | ||
104 | }; | 104 | }; |
105 | 105 | ||
106 | template <class T> | 106 | template <class T> |
107 | OPimAccessBackend<T>::OPimAccessBackend() { | 107 | OPimAccessBackend<T>::OPimAccessBackend() { |
108 | m_front = 0l; | 108 | m_front = 0l; |
109 | } | 109 | } |
110 | template <class T> | 110 | template <class T> |
111 | OPimAccessBackend<T>::~OPimAccessBackend() { | 111 | OPimAccessBackend<T>::~OPimAccessBackend() { |
112 | 112 | ||
113 | } | 113 | } |
114 | template <class T> | 114 | template <class T> |
115 | void OPimAccessBackend<T>::setFrontend( Frontend* fr ) { | 115 | void OPimAccessBackend<T>::setFrontend( Frontend* fr ) { |
116 | m_front = fr; | 116 | m_front = fr; |
117 | } | 117 | } |
118 | template <class T> | 118 | template <class T> |
119 | void OPimAccessBackend<T>::cache( const T& t )const { | 119 | void OPimAccessBackend<T>::cache( const T& t )const { |
120 | if (m_front ) | 120 | if (m_front ) |
121 | m_front->cache( t ); | 121 | m_front->cache( t ); |
122 | } | 122 | } |
123 | template <class T> | 123 | template <class T> |
124 | void OPimAccessBackend<T>::setSaneCacheSize( int size) { | 124 | void OPimAccessBackend<T>::setSaneCacheSize( int size) { |
125 | if (m_front ) | 125 | if (m_front ) |
126 | m_front->setSaneCacheSize( size ); | 126 | m_front->setSaneCacheSize( size ); |
127 | } | 127 | } |
128 | template <class T> | 128 | template <class T> |
129 | T OPimAccessBackend<T>::find( int uid, const QArray<int>&, | 129 | T OPimAccessBackend<T>::find( int uid, const QArray<int>&, |
130 | uint, Frontend::CacheDirection )const { | 130 | uint, typename Frontend::CacheDirection )const { |
131 | return find( uid ); | 131 | return find( uid ); |
132 | } | 132 | } |
133 | template <class T> | 133 | template <class T> |
134 | void OPimAccessBackend<T>::setReadAhead( uint count ) { | 134 | void OPimAccessBackend<T>::setReadAhead( uint count ) { |
135 | m_read = count; | 135 | m_read = count; |
136 | } | 136 | } |
137 | template <class T> | 137 | template <class T> |
138 | uint OPimAccessBackend<T>::readAhead()const { | 138 | uint OPimAccessBackend<T>::readAhead()const { |
139 | return m_read; | 139 | return m_read; |
140 | } | 140 | } |
141 | #endif | 141 | #endif |
diff --git a/libopie/pim/opimaccesstemplate.h b/libopie/pim/opimaccesstemplate.h index c5523a8..6de68b1 100644 --- a/libopie/pim/opimaccesstemplate.h +++ b/libopie/pim/opimaccesstemplate.h | |||
@@ -1,259 +1,259 @@ | |||
1 | #ifndef OPIE_PIM_ACCESS_TEMPLATE_H | 1 | #ifndef OPIE_PIM_ACCESS_TEMPLATE_H |
2 | #define OPIE_PIM_ACCESS_TEMPLATE_H | 2 | #define OPIE_PIM_ACCESS_TEMPLATE_H |
3 | 3 | ||
4 | #include <qarray.h> | 4 | #include <qarray.h> |
5 | 5 | ||
6 | #include <opie/opimrecord.h> | 6 | #include <opie/opimrecord.h> |
7 | #include <opie/opimaccessbackend.h> | 7 | #include <opie/opimaccessbackend.h> |
8 | #include <opie/orecordlist.h> | 8 | #include <opie/orecordlist.h> |
9 | 9 | ||
10 | #include "opimcache.h" | 10 | #include "opimcache.h" |
11 | #include "otemplatebase.h" | 11 | #include "otemplatebase.h" |
12 | 12 | ||
13 | /** | 13 | /** |
14 | * Thats the frontend to our OPIE PIM | 14 | * Thats the frontend to our OPIE PIM |
15 | * Library. Either you want to use it's | 15 | * Library. Either you want to use it's |
16 | * interface or you want to implement | 16 | * interface or you want to implement |
17 | * your own Access lib | 17 | * your own Access lib |
18 | * Just create a OPimRecord and inherit from | 18 | * Just create a OPimRecord and inherit from |
19 | * the plugins | 19 | * the plugins |
20 | */ | 20 | */ |
21 | 21 | ||
22 | template <class T = OPimRecord > | 22 | template <class T = OPimRecord > |
23 | class OPimAccessTemplate : public OTemplateBase<T> { | 23 | class OPimAccessTemplate : public OTemplateBase<T> { |
24 | public: | 24 | public: |
25 | typedef ORecordList<T> List; | 25 | typedef ORecordList<T> List; |
26 | typedef OPimAccessBackend<T> BackEnd; | 26 | typedef OPimAccessBackend<T> BackEnd; |
27 | typedef OPimCache<T> Cache; | 27 | typedef OPimCache<T> Cache; |
28 | 28 | ||
29 | /** | 29 | /** |
30 | * c'tor BackEnd | 30 | * c'tor BackEnd |
31 | */ | 31 | */ |
32 | OPimAccessTemplate( BackEnd* end); | 32 | OPimAccessTemplate( BackEnd* end); |
33 | virtual ~OPimAccessTemplate(); | 33 | virtual ~OPimAccessTemplate(); |
34 | 34 | ||
35 | /** | 35 | /** |
36 | * load from the backend | 36 | * load from the backend |
37 | */ | 37 | */ |
38 | virtual bool load(); | 38 | virtual bool load(); |
39 | 39 | ||
40 | /** Reload database. | 40 | /** Reload database. |
41 | * You should execute this function if the external database | 41 | * You should execute this function if the external database |
42 | * was changed. | 42 | * was changed. |
43 | * This function will load the external database and afterwards | 43 | * This function will load the external database and afterwards |
44 | * rejoin the local changes. Therefore the local database will be set consistent. | 44 | * rejoin the local changes. Therefore the local database will be set consistent. |
45 | */ | 45 | */ |
46 | virtual bool reload(); | 46 | virtual bool reload(); |
47 | 47 | ||
48 | /** Save contacts database. | 48 | /** Save contacts database. |
49 | * Save is more a "commit". After calling this function, all changes are public available. | 49 | * Save is more a "commit". After calling this function, all changes are public available. |
50 | * @return true if successful | 50 | * @return true if successful |
51 | */ | 51 | */ |
52 | virtual bool save(); | 52 | virtual bool save(); |
53 | 53 | ||
54 | /** | 54 | /** |
55 | * if the resource was changed externally | 55 | * if the resource was changed externally |
56 | * You should use the signal handling instead of polling possible changes ! | 56 | * You should use the signal handling instead of polling possible changes ! |
57 | * zecke: Do you implement a signal for otodoaccess ? | 57 | * zecke: Do you implement a signal for otodoaccess ? |
58 | */ | 58 | */ |
59 | bool wasChangedExternally()const; | 59 | bool wasChangedExternally()const; |
60 | 60 | ||
61 | /** | 61 | /** |
62 | * return a List of records | 62 | * return a List of records |
63 | * you can iterate over them | 63 | * you can iterate over them |
64 | */ | 64 | */ |
65 | virtual List allRecords()const; | 65 | virtual List allRecords()const; |
66 | 66 | ||
67 | /** | 67 | /** |
68 | * queryByExample. | 68 | * queryByExample. |
69 | * @see otodoaccess, ocontactaccess | 69 | * @see otodoaccess, ocontactaccess |
70 | */ | 70 | */ |
71 | virtual List queryByExample( const T& t, int querySettings ); | 71 | virtual List queryByExample( const T& t, int querySettings ); |
72 | 72 | ||
73 | /** | 73 | /** |
74 | * find the OPimRecord uid | 74 | * find the OPimRecord uid |
75 | */ | 75 | */ |
76 | virtual T find( int uid )const; | 76 | virtual T find( int uid )const; |
77 | 77 | ||
78 | /** | 78 | /** |
79 | * read ahead cache find method ;) | 79 | * read ahead cache find method ;) |
80 | */ | 80 | */ |
81 | virtual T find( int uid, const QArray<int>&, | 81 | virtual T find( int uid, const QArray<int>&, |
82 | uint current, CacheDirection dir = Forward )const; | 82 | uint current, typename OTemplateBase<T>::CacheDirection dir = OTemplateBase<T>::Forward )const; |
83 | 83 | ||
84 | /* invalidate cache here */ | 84 | /* invalidate cache here */ |
85 | /** | 85 | /** |
86 | * clears the backend and invalidates the backend | 86 | * clears the backend and invalidates the backend |
87 | */ | 87 | */ |
88 | virtual void clear() ; | 88 | virtual void clear() ; |
89 | 89 | ||
90 | /** | 90 | /** |
91 | * add T to the backend | 91 | * add T to the backend |
92 | * @param t The item to add. | 92 | * @param t The item to add. |
93 | * @return <i>true</i> if added successfully. | 93 | * @return <i>true</i> if added successfully. |
94 | */ | 94 | */ |
95 | virtual bool add( const T& t ) ; | 95 | virtual bool add( const T& t ) ; |
96 | 96 | ||
97 | /* only the uid matters */ | 97 | /* only the uid matters */ |
98 | /** | 98 | /** |
99 | * remove T from the backend | 99 | * remove T from the backend |
100 | * @param t The item to remove | 100 | * @param t The item to remove |
101 | * @return <i>true</i> if successful. | 101 | * @return <i>true</i> if successful. |
102 | */ | 102 | */ |
103 | virtual bool remove( const T& t ); | 103 | virtual bool remove( const T& t ); |
104 | 104 | ||
105 | /** | 105 | /** |
106 | * remove the OPimRecord with uid | 106 | * remove the OPimRecord with uid |
107 | * @param uid The ID of the item to remove | 107 | * @param uid The ID of the item to remove |
108 | * @return <i>true</i> if successful. | 108 | * @return <i>true</i> if successful. |
109 | */ | 109 | */ |
110 | virtual bool remove( int uid ); | 110 | virtual bool remove( int uid ); |
111 | 111 | ||
112 | /** | 112 | /** |
113 | * replace T from backend | 113 | * replace T from backend |
114 | * @param t The item to replace | 114 | * @param t The item to replace |
115 | * @return <i>true</i> if successful. | 115 | * @return <i>true</i> if successful. |
116 | */ | 116 | */ |
117 | virtual bool replace( const T& t) ; | 117 | virtual bool replace( const T& t) ; |
118 | 118 | ||
119 | void setReadAhead( uint count ); | 119 | void setReadAhead( uint count ); |
120 | /** | 120 | /** |
121 | * @internal | 121 | * @internal |
122 | */ | 122 | */ |
123 | void cache( const T& )const; | 123 | void cache( const T& )const; |
124 | void setSaneCacheSize( int ); | 124 | void setSaneCacheSize( int ); |
125 | protected: | 125 | protected: |
126 | /** | 126 | /** |
127 | * invalidate the cache | 127 | * invalidate the cache |
128 | */ | 128 | */ |
129 | void invalidateCache(); | 129 | void invalidateCache(); |
130 | 130 | ||
131 | void setBackEnd( BackEnd* end ); | 131 | void setBackEnd( BackEnd* end ); |
132 | /** | 132 | /** |
133 | * returns the backend | 133 | * returns the backend |
134 | */ | 134 | */ |
135 | BackEnd* backEnd(); | 135 | BackEnd* backEnd(); |
136 | BackEnd* m_backEnd; | 136 | BackEnd* m_backEnd; |
137 | Cache m_cache; | 137 | Cache m_cache; |
138 | 138 | ||
139 | }; | 139 | }; |
140 | 140 | ||
141 | template <class T> | 141 | template <class T> |
142 | OPimAccessTemplate<T>::OPimAccessTemplate( BackEnd* end ) | 142 | OPimAccessTemplate<T>::OPimAccessTemplate( BackEnd* end ) |
143 | : OTemplateBase<T>(), m_backEnd( end ) | 143 | : OTemplateBase<T>(), m_backEnd( end ) |
144 | { | 144 | { |
145 | if (end ) | 145 | if (end ) |
146 | end->setFrontend( this ); | 146 | end->setFrontend( this ); |
147 | } | 147 | } |
148 | template <class T> | 148 | template <class T> |
149 | OPimAccessTemplate<T>::~OPimAccessTemplate() { | 149 | OPimAccessTemplate<T>::~OPimAccessTemplate() { |
150 | qWarning("~OPimAccessTemplate<T>"); | 150 | qWarning("~OPimAccessTemplate<T>"); |
151 | delete m_backEnd; | 151 | delete m_backEnd; |
152 | } | 152 | } |
153 | template <class T> | 153 | template <class T> |
154 | bool OPimAccessTemplate<T>::load() { | 154 | bool OPimAccessTemplate<T>::load() { |
155 | invalidateCache(); | 155 | invalidateCache(); |
156 | return m_backEnd->load(); | 156 | return m_backEnd->load(); |
157 | } | 157 | } |
158 | template <class T> | 158 | template <class T> |
159 | bool OPimAccessTemplate<T>::reload() { | 159 | bool OPimAccessTemplate<T>::reload() { |
160 | invalidateCache(); // zecke: I think this should be added (se) | 160 | invalidateCache(); // zecke: I think this should be added (se) |
161 | return m_backEnd->reload(); | 161 | return m_backEnd->reload(); |
162 | } | 162 | } |
163 | template <class T> | 163 | template <class T> |
164 | bool OPimAccessTemplate<T>::save() { | 164 | bool OPimAccessTemplate<T>::save() { |
165 | return m_backEnd->save(); | 165 | return m_backEnd->save(); |
166 | } | 166 | } |
167 | template <class T> | 167 | template <class T> |
168 | OPimAccessTemplate<T>::List OPimAccessTemplate<T>::allRecords()const { | 168 | typename OPimAccessTemplate<T>::List OPimAccessTemplate<T>::allRecords()const { |
169 | QArray<int> ints = m_backEnd->allRecords(); | 169 | QArray<int> ints = m_backEnd->allRecords(); |
170 | List lis(ints, this ); | 170 | List lis(ints, this ); |
171 | return lis; | 171 | return lis; |
172 | } | 172 | } |
173 | template <class T> | 173 | template <class T> |
174 | OPimAccessTemplate<T>::List | 174 | typename OPimAccessTemplate<T>::List |
175 | OPimAccessTemplate<T>::queryByExample( const T& t, int sortOrder ) { | 175 | OPimAccessTemplate<T>::queryByExample( const T& t, int sortOrder ) { |
176 | QArray<int> ints = m_backEnd->queryByExample( t, sortOrder ); | 176 | QArray<int> ints = m_backEnd->queryByExample( t, sortOrder ); |
177 | 177 | ||
178 | List lis(ints, this ); | 178 | List lis(ints, this ); |
179 | return lis; | 179 | return lis; |
180 | } | 180 | } |
181 | template <class T> | 181 | template <class T> |
182 | T OPimAccessTemplate<T>::find( int uid ) const{ | 182 | T OPimAccessTemplate<T>::find( int uid ) const{ |
183 | T t = m_backEnd->find( uid ); | 183 | T t = m_backEnd->find( uid ); |
184 | cache( t ); | 184 | cache( t ); |
185 | return t; | 185 | return t; |
186 | } | 186 | } |
187 | template <class T> | 187 | template <class T> |
188 | T OPimAccessTemplate<T>::find( int uid, const QArray<int>& ar, | 188 | T OPimAccessTemplate<T>::find( int uid, const QArray<int>& ar, |
189 | uint current, CacheDirection dir )const { | 189 | uint current, typename OTemplateBase<T>::CacheDirection dir )const { |
190 | /* | 190 | /* |
191 | * better do T.isEmpty() | 191 | * better do T.isEmpty() |
192 | * after a find this way we would | 192 | * after a find this way we would |
193 | * avoid two finds in QCache... | 193 | * avoid two finds in QCache... |
194 | */ | 194 | */ |
195 | // qWarning("find it now %d", uid ); | 195 | // qWarning("find it now %d", uid ); |
196 | if (m_cache.contains( uid ) ) { | 196 | if (m_cache.contains( uid ) ) { |
197 | return m_cache.find( uid ); | 197 | return m_cache.find( uid ); |
198 | } | 198 | } |
199 | 199 | ||
200 | T t = m_backEnd->find( uid, ar, current, dir ); | 200 | T t = m_backEnd->find( uid, ar, current, dir ); |
201 | cache( t ); | 201 | cache( t ); |
202 | return t; | 202 | return t; |
203 | } | 203 | } |
204 | template <class T> | 204 | template <class T> |
205 | void OPimAccessTemplate<T>::clear() { | 205 | void OPimAccessTemplate<T>::clear() { |
206 | invalidateCache(); | 206 | invalidateCache(); |
207 | m_backEnd->clear(); | 207 | m_backEnd->clear(); |
208 | } | 208 | } |
209 | template <class T> | 209 | template <class T> |
210 | bool OPimAccessTemplate<T>::add( const T& t ) { | 210 | bool OPimAccessTemplate<T>::add( const T& t ) { |
211 | cache( t ); | 211 | cache( t ); |
212 | return m_backEnd->add( t ); | 212 | return m_backEnd->add( t ); |
213 | } | 213 | } |
214 | template <class T> | 214 | template <class T> |
215 | bool OPimAccessTemplate<T>::remove( const T& t ) { | 215 | bool OPimAccessTemplate<T>::remove( const T& t ) { |
216 | return remove( t.uid() ); | 216 | return remove( t.uid() ); |
217 | } | 217 | } |
218 | template <class T> | 218 | template <class T> |
219 | bool OPimAccessTemplate<T>::remove( int uid ) { | 219 | bool OPimAccessTemplate<T>::remove( int uid ) { |
220 | m_cache.remove( uid ); | 220 | m_cache.remove( uid ); |
221 | return m_backEnd->remove( uid ); | 221 | return m_backEnd->remove( uid ); |
222 | } | 222 | } |
223 | template <class T> | 223 | template <class T> |
224 | bool OPimAccessTemplate<T>::replace( const T& t ) { | 224 | bool OPimAccessTemplate<T>::replace( const T& t ) { |
225 | m_cache.replace( t ); | 225 | m_cache.replace( t ); |
226 | return m_backEnd->replace( t ); | 226 | return m_backEnd->replace( t ); |
227 | } | 227 | } |
228 | template <class T> | 228 | template <class T> |
229 | void OPimAccessTemplate<T>::invalidateCache() { | 229 | void OPimAccessTemplate<T>::invalidateCache() { |
230 | m_cache.invalidate(); | 230 | m_cache.invalidate(); |
231 | } | 231 | } |
232 | template <class T> | 232 | template <class T> |
233 | OPimAccessTemplate<T>::BackEnd* OPimAccessTemplate<T>::backEnd() { | 233 | typename OPimAccessTemplate<T>::BackEnd* OPimAccessTemplate<T>::backEnd() { |
234 | return m_backEnd; | 234 | return m_backEnd; |
235 | } | 235 | } |
236 | template <class T> | 236 | template <class T> |
237 | bool OPimAccessTemplate<T>::wasChangedExternally()const { | 237 | bool OPimAccessTemplate<T>::wasChangedExternally()const { |
238 | return false; | 238 | return false; |
239 | } | 239 | } |
240 | template <class T> | 240 | template <class T> |
241 | void OPimAccessTemplate<T>::setBackEnd( BackEnd* end ) { | 241 | void OPimAccessTemplate<T>::setBackEnd( BackEnd* end ) { |
242 | m_backEnd = end; | 242 | m_backEnd = end; |
243 | if (m_backEnd ) | 243 | if (m_backEnd ) |
244 | m_backEnd->setFrontend( this ); | 244 | m_backEnd->setFrontend( this ); |
245 | } | 245 | } |
246 | template <class T> | 246 | template <class T> |
247 | void OPimAccessTemplate<T>::cache( const T& t ) const{ | 247 | void OPimAccessTemplate<T>::cache( const T& t ) const{ |
248 | /* hacky we need to work around the const*/ | 248 | /* hacky we need to work around the const*/ |
249 | ((OPimAccessTemplate<T>*)this)->m_cache.add( t ); | 249 | ((OPimAccessTemplate<T>*)this)->m_cache.add( t ); |
250 | } | 250 | } |
251 | template <class T> | 251 | template <class T> |
252 | void OPimAccessTemplate<T>::setSaneCacheSize( int size ) { | 252 | void OPimAccessTemplate<T>::setSaneCacheSize( int size ) { |
253 | m_cache.setSize( size ); | 253 | m_cache.setSize( size ); |
254 | } | 254 | } |
255 | template <class T> | 255 | template <class T> |
256 | void OPimAccessTemplate<T>::setReadAhead( uint count ) { | 256 | void OPimAccessTemplate<T>::setReadAhead( uint count ) { |
257 | m_backEnd->setReadAhead( count ); | 257 | m_backEnd->setReadAhead( count ); |
258 | } | 258 | } |
259 | #endif | 259 | #endif |
diff --git a/libopie/pim/orecordlist.h b/libopie/pim/orecordlist.h index 8ed41e2..b77a4ab 100644 --- a/libopie/pim/orecordlist.h +++ b/libopie/pim/orecordlist.h | |||
@@ -58,243 +58,243 @@ public: | |||
58 | uint count()const; | 58 | uint count()const; |
59 | 59 | ||
60 | /** | 60 | /** |
61 | * sets the current item | 61 | * sets the current item |
62 | */ | 62 | */ |
63 | void setCurrent( uint cur ); | 63 | void setCurrent( uint cur ); |
64 | 64 | ||
65 | private: | 65 | private: |
66 | QArray<int> m_uids; | 66 | QArray<int> m_uids; |
67 | uint m_current; | 67 | uint m_current; |
68 | const Base* m_temp; | 68 | const Base* m_temp; |
69 | bool m_end : 1; | 69 | bool m_end : 1; |
70 | T m_record; | 70 | T m_record; |
71 | bool m_direction :1; | 71 | bool m_direction :1; |
72 | 72 | ||
73 | /* d pointer for future versions */ | 73 | /* d pointer for future versions */ |
74 | class IteratorPrivate; | 74 | class IteratorPrivate; |
75 | IteratorPrivate *d; | 75 | IteratorPrivate *d; |
76 | }; | 76 | }; |
77 | /** | 77 | /** |
78 | * The recordlist used as a return type | 78 | * The recordlist used as a return type |
79 | * from OPimAccessTemplate | 79 | * from OPimAccessTemplate |
80 | */ | 80 | */ |
81 | template <class T = OPimRecord > | 81 | template <class T = OPimRecord > |
82 | class ORecordList { | 82 | class ORecordList { |
83 | public: | 83 | public: |
84 | typedef OTemplateBase<T> Base; | 84 | typedef OTemplateBase<T> Base; |
85 | typedef ORecordListIterator<T> Iterator; | 85 | typedef ORecordListIterator<T> Iterator; |
86 | 86 | ||
87 | /** | 87 | /** |
88 | * c'tor | 88 | * c'tor |
89 | */ | 89 | */ |
90 | ORecordList () { | 90 | ORecordList () { |
91 | } | 91 | } |
92 | ORecordList( const QArray<int>& ids, | 92 | ORecordList( const QArray<int>& ids, |
93 | const Base* ); | 93 | const Base* ); |
94 | ~ORecordList(); | 94 | ~ORecordList(); |
95 | 95 | ||
96 | /** | 96 | /** |
97 | * the first iterator | 97 | * the first iterator |
98 | */ | 98 | */ |
99 | Iterator begin(); | 99 | Iterator begin(); |
100 | 100 | ||
101 | /** | 101 | /** |
102 | * the end | 102 | * the end |
103 | */ | 103 | */ |
104 | Iterator end(); | 104 | Iterator end(); |
105 | 105 | ||
106 | /** | 106 | /** |
107 | * the number of items in the list | 107 | * the number of items in the list |
108 | */ | 108 | */ |
109 | uint count()const; | 109 | uint count()const; |
110 | 110 | ||
111 | T operator[]( uint i ); | 111 | T operator[]( uint i ); |
112 | int uidAt(uint i ); | 112 | int uidAt(uint i ); |
113 | 113 | ||
114 | /** | 114 | /** |
115 | * Remove the contact with given uid | 115 | * Remove the contact with given uid |
116 | */ | 116 | */ |
117 | bool remove( int uid ); | 117 | bool remove( int uid ); |
118 | 118 | ||
119 | /* | 119 | /* |
120 | ConstIterator begin()const; | 120 | ConstIterator begin()const; |
121 | ConstIterator end()const; | 121 | ConstIterator end()const; |
122 | */ | 122 | */ |
123 | private: | 123 | private: |
124 | QArray<int> m_ids; | 124 | QArray<int> m_ids; |
125 | const Base* m_acc; | 125 | const Base* m_acc; |
126 | }; | 126 | }; |
127 | 127 | ||
128 | /* ok now implement it */ | 128 | /* ok now implement it */ |
129 | template <class T> | 129 | template <class T> |
130 | ORecordListIterator<T>::ORecordListIterator() { | 130 | ORecordListIterator<T>::ORecordListIterator() { |
131 | m_current = 0; | 131 | m_current = 0; |
132 | m_temp = 0l; | 132 | m_temp = 0l; |
133 | m_end = true; | 133 | m_end = true; |
134 | m_record = T(); | 134 | m_record = T(); |
135 | /* forward */ | 135 | /* forward */ |
136 | m_direction = TRUE; | 136 | m_direction = TRUE; |
137 | } | 137 | } |
138 | template <class T> | 138 | template <class T> |
139 | ORecordListIterator<T>::~ORecordListIterator() { | 139 | ORecordListIterator<T>::~ORecordListIterator() { |
140 | /* nothing to delete */ | 140 | /* nothing to delete */ |
141 | } | 141 | } |
142 | 142 | ||
143 | template <class T> | 143 | template <class T> |
144 | ORecordListIterator<T>::ORecordListIterator( const ORecordListIterator<T>& it) { | 144 | ORecordListIterator<T>::ORecordListIterator( const ORecordListIterator<T>& it) { |
145 | // qWarning("ORecordListIterator copy c'tor"); | 145 | // qWarning("ORecordListIterator copy c'tor"); |
146 | m_uids = it.m_uids; | 146 | m_uids = it.m_uids; |
147 | m_current = it.m_current; | 147 | m_current = it.m_current; |
148 | m_temp = it.m_temp; | 148 | m_temp = it.m_temp; |
149 | m_end = it.m_end; | 149 | m_end = it.m_end; |
150 | m_record = it.m_record; | 150 | m_record = it.m_record; |
151 | m_direction = it.m_direction; | 151 | m_direction = it.m_direction; |
152 | } | 152 | } |
153 | 153 | ||
154 | template <class T> | 154 | template <class T> |
155 | ORecordListIterator<T> &ORecordListIterator<T>::operator=( const ORecordListIterator<T>& it) { | 155 | ORecordListIterator<T> &ORecordListIterator<T>::operator=( const ORecordListIterator<T>& it) { |
156 | m_uids = it.m_uids; | 156 | m_uids = it.m_uids; |
157 | m_current = it.m_current; | 157 | m_current = it.m_current; |
158 | m_temp = it.m_temp; | 158 | m_temp = it.m_temp; |
159 | m_end = it.m_end; | 159 | m_end = it.m_end; |
160 | m_record = it.m_record; | 160 | m_record = it.m_record; |
161 | 161 | ||
162 | return *this; | 162 | return *this; |
163 | } | 163 | } |
164 | 164 | ||
165 | template <class T> | 165 | template <class T> |
166 | T ORecordListIterator<T>::operator*() { | 166 | T ORecordListIterator<T>::operator*() { |
167 | //qWarning("operator* %d %d", m_current, m_uids[m_current] ); | 167 | //qWarning("operator* %d %d", m_current, m_uids[m_current] ); |
168 | if (!m_end ) | 168 | if (!m_end ) |
169 | m_record = m_temp->find( m_uids[m_current], m_uids, m_current, | 169 | m_record = m_temp->find( m_uids[m_current], m_uids, m_current, |
170 | m_direction ? Base::Forward : | 170 | m_direction ? Base::Forward : |
171 | Base::Reverse ); | 171 | Base::Reverse ); |
172 | else | 172 | else |
173 | m_record = T(); | 173 | m_record = T(); |
174 | 174 | ||
175 | return m_record; | 175 | return m_record; |
176 | } | 176 | } |
177 | 177 | ||
178 | template <class T> | 178 | template <class T> |
179 | ORecordListIterator<T> &ORecordListIterator<T>::operator++() { | 179 | ORecordListIterator<T> &ORecordListIterator<T>::operator++() { |
180 | m_direction = true; | 180 | m_direction = true; |
181 | if (m_current < m_uids.count() ) { | 181 | if (m_current < m_uids.count() ) { |
182 | m_end = false; | 182 | m_end = false; |
183 | ++m_current; | 183 | ++m_current; |
184 | }else | 184 | }else |
185 | m_end = true; | 185 | m_end = true; |
186 | 186 | ||
187 | return *this; | 187 | return *this; |
188 | } | 188 | } |
189 | template <class T> | 189 | template <class T> |
190 | ORecordListIterator<T> &ORecordListIterator<T>::operator--() { | 190 | ORecordListIterator<T> &ORecordListIterator<T>::operator--() { |
191 | m_direction = false; | 191 | m_direction = false; |
192 | if ( m_current > 0 ) { | 192 | if ( m_current > 0 ) { |
193 | --m_current; | 193 | --m_current; |
194 | m_end = false; | 194 | m_end = false; |
195 | } else | 195 | } else |
196 | m_end = true; | 196 | m_end = true; |
197 | 197 | ||
198 | return *this; | 198 | return *this; |
199 | } | 199 | } |
200 | 200 | ||
201 | template <class T> | 201 | template <class T> |
202 | bool ORecordListIterator<T>::operator==( const ORecordListIterator<T>& it ) { | 202 | bool ORecordListIterator<T>::operator==( const ORecordListIterator<T>& it ) { |
203 | 203 | ||
204 | /* if both are at we're the same.... */ | 204 | /* if both are at we're the same.... */ |
205 | if ( m_end == it.m_end ) return true; | 205 | if ( m_end == it.m_end ) return true; |
206 | 206 | ||
207 | if ( m_uids != it.m_uids ) return false; | 207 | if ( m_uids != it.m_uids ) return false; |
208 | if ( m_current != it.m_current ) return false; | 208 | if ( m_current != it.m_current ) return false; |
209 | if ( m_temp != it.m_temp ) return false; | 209 | if ( m_temp != it.m_temp ) return false; |
210 | 210 | ||
211 | return true; | 211 | return true; |
212 | } | 212 | } |
213 | template <class T> | 213 | template <class T> |
214 | bool ORecordListIterator<T>::operator!=( const ORecordListIterator<T>& it ) { | 214 | bool ORecordListIterator<T>::operator!=( const ORecordListIterator<T>& it ) { |
215 | return !(*this == it ); | 215 | return !(*this == it ); |
216 | } | 216 | } |
217 | template <class T> | 217 | template <class T> |
218 | ORecordListIterator<T>::ORecordListIterator( const QArray<int> uids, | 218 | ORecordListIterator<T>::ORecordListIterator( const QArray<int> uids, |
219 | const Base* t ) | 219 | const Base* t ) |
220 | : m_uids( uids ), m_current( 0 ), m_temp( t ), m_end( false ), | 220 | : m_uids( uids ), m_current( 0 ), m_temp( t ), m_end( false ), |
221 | m_direction( false ) | 221 | m_direction( false ) |
222 | { | 222 | { |
223 | } | 223 | } |
224 | template <class T> | 224 | template <class T> |
225 | uint ORecordListIterator<T>::current()const { | 225 | uint ORecordListIterator<T>::current()const { |
226 | return m_current; | 226 | return m_current; |
227 | } | 227 | } |
228 | template <class T> | 228 | template <class T> |
229 | void ORecordListIterator<T>::setCurrent( uint cur ) { | 229 | void ORecordListIterator<T>::setCurrent( uint cur ) { |
230 | if( cur < m_uids.count() ) { | 230 | if( cur < m_uids.count() ) { |
231 | m_end = false; | 231 | m_end = false; |
232 | m_current= cur; | 232 | m_current= cur; |
233 | } | 233 | } |
234 | } | 234 | } |
235 | template <class T> | 235 | template <class T> |
236 | uint ORecordListIterator<T>::count()const { | 236 | uint ORecordListIterator<T>::count()const { |
237 | return m_uids.count(); | 237 | return m_uids.count(); |
238 | } | 238 | } |
239 | template <class T> | 239 | template <class T> |
240 | ORecordList<T>::ORecordList( const QArray<int>& ids, | 240 | ORecordList<T>::ORecordList( const QArray<int>& ids, |
241 | const Base* acc ) | 241 | const Base* acc ) |
242 | : m_ids( ids ), m_acc( acc ) | 242 | : m_ids( ids ), m_acc( acc ) |
243 | { | 243 | { |
244 | } | 244 | } |
245 | template <class T> | 245 | template <class T> |
246 | ORecordList<T>::~ORecordList() { | 246 | ORecordList<T>::~ORecordList() { |
247 | /* nothing to do here */ | 247 | /* nothing to do here */ |
248 | } | 248 | } |
249 | template <class T> | 249 | template <class T> |
250 | ORecordList<T>::Iterator ORecordList<T>::begin() { | 250 | typename ORecordList<T>::Iterator ORecordList<T>::begin() { |
251 | Iterator it( m_ids, m_acc ); | 251 | Iterator it( m_ids, m_acc ); |
252 | return it; | 252 | return it; |
253 | } | 253 | } |
254 | template <class T> | 254 | template <class T> |
255 | ORecordList<T>::Iterator ORecordList<T>::end() { | 255 | typename ORecordList<T>::Iterator ORecordList<T>::end() { |
256 | Iterator it( m_ids, m_acc ); | 256 | Iterator it( m_ids, m_acc ); |
257 | it.m_end = true; | 257 | it.m_end = true; |
258 | it.m_current = m_ids.count(); | 258 | it.m_current = m_ids.count(); |
259 | 259 | ||
260 | return it; | 260 | return it; |
261 | } | 261 | } |
262 | template <class T> | 262 | template <class T> |
263 | uint ORecordList<T>::count()const { | 263 | uint ORecordList<T>::count()const { |
264 | return m_ids.count(); | 264 | return m_ids.count(); |
265 | } | 265 | } |
266 | template <class T> | 266 | template <class T> |
267 | T ORecordList<T>::operator[]( uint i ) { | 267 | T ORecordList<T>::operator[]( uint i ) { |
268 | if ( i < 0 || (i+1) > m_ids.count() ) | 268 | if ( i < 0 || (i+1) > m_ids.count() ) |
269 | return T(); | 269 | return T(); |
270 | /* forward */ | 270 | /* forward */ |
271 | return m_acc->find( m_ids[i], m_ids, i ); | 271 | return m_acc->find( m_ids[i], m_ids, i ); |
272 | } | 272 | } |
273 | template <class T> | 273 | template <class T> |
274 | int ORecordList<T>::uidAt( uint i ) { | 274 | int ORecordList<T>::uidAt( uint i ) { |
275 | return m_ids[i]; | 275 | return m_ids[i]; |
276 | } | 276 | } |
277 | 277 | ||
278 | template <class T> | 278 | template <class T> |
279 | bool ORecordList<T>::remove( int uid ) { | 279 | bool ORecordList<T>::remove( int uid ) { |
280 | QArray<int> copy( m_ids.count() ); | 280 | QArray<int> copy( m_ids.count() ); |
281 | int counter = 0; | 281 | int counter = 0; |
282 | bool ret_val = false; | 282 | bool ret_val = false; |
283 | 283 | ||
284 | for (uint i = 0; i < m_ids.count(); i++){ | 284 | for (uint i = 0; i < m_ids.count(); i++){ |
285 | if ( m_ids[i] != uid ){ | 285 | if ( m_ids[i] != uid ){ |
286 | copy[counter++] = m_ids[i]; | 286 | copy[counter++] = m_ids[i]; |
287 | 287 | ||
288 | }else | 288 | }else |
289 | ret_val = true; | 289 | ret_val = true; |
290 | } | 290 | } |
291 | 291 | ||
292 | copy.resize( counter ); | 292 | copy.resize( counter ); |
293 | m_ids = copy; | 293 | m_ids = copy; |
294 | 294 | ||
295 | 295 | ||
296 | return ret_val; | 296 | return ret_val; |
297 | } | 297 | } |
298 | 298 | ||
299 | 299 | ||
300 | #endif | 300 | #endif |
diff --git a/libopie/pim/otodo.cpp b/libopie/pim/otodo.cpp index 0d5b1d3..4d5cb79 100644 --- a/libopie/pim/otodo.cpp +++ b/libopie/pim/otodo.cpp | |||
@@ -210,196 +210,196 @@ bool OTodo::isOverdue( ) | |||
210 | } | 210 | } |
211 | void OTodo::setProgress(ushort progress ) | 211 | void OTodo::setProgress(ushort progress ) |
212 | { | 212 | { |
213 | changeOrModify(); | 213 | changeOrModify(); |
214 | data->prog = progress; | 214 | data->prog = progress; |
215 | } | 215 | } |
216 | QString OTodo::toShortText() const { | 216 | QString OTodo::toShortText() const { |
217 | return summary(); | 217 | return summary(); |
218 | } | 218 | } |
219 | /*! | 219 | /*! |
220 | Returns a richt text string | 220 | Returns a richt text string |
221 | */ | 221 | */ |
222 | QString OTodo::toRichText() const | 222 | QString OTodo::toRichText() const |
223 | { | 223 | { |
224 | QString text; | 224 | QString text; |
225 | QStringList catlist; | 225 | QStringList catlist; |
226 | 226 | ||
227 | // Description of the todo | 227 | // Description of the todo |
228 | if ( !summary().isEmpty() ) { | 228 | if ( !summary().isEmpty() ) { |
229 | text += "<b>" + QObject::tr( "Summary:") + "</b><br>"; | 229 | text += "<b>" + QObject::tr( "Summary:") + "</b><br>"; |
230 | text += Qtopia::escapeString(summary() ).replace(QRegExp( "[\n]"), "<br>" ) + "<br>"; | 230 | text += Qtopia::escapeString(summary() ).replace(QRegExp( "[\n]"), "<br>" ) + "<br>"; |
231 | } | 231 | } |
232 | if( !description().isEmpty() ){ | 232 | if( !description().isEmpty() ){ |
233 | text += "<b>" + QObject::tr( "Description:" ) + "</b><br>"; | 233 | text += "<b>" + QObject::tr( "Description:" ) + "</b><br>"; |
234 | text += Qtopia::escapeString(description() ).replace(QRegExp( "[\n]"), "<br>" ) ; | 234 | text += Qtopia::escapeString(description() ).replace(QRegExp( "[\n]"), "<br>" ) ; |
235 | } | 235 | } |
236 | text += "<br><br><br>"; | 236 | text += "<br><br><br>"; |
237 | 237 | ||
238 | text += "<b>" + QObject::tr( "Priority:") +" </b>" | 238 | text += "<b>" + QObject::tr( "Priority:") +" </b>" |
239 | + QString::number( priority() ) + " <br>"; | 239 | + QString::number( priority() ) + " <br>"; |
240 | text += "<b>" + QObject::tr( "Progress:") + " </b>" | 240 | text += "<b>" + QObject::tr( "Progress:") + " </b>" |
241 | + QString::number( progress() ) + " %<br>"; | 241 | + QString::number( progress() ) + " %<br>"; |
242 | if (hasDueDate() ){ | 242 | if (hasDueDate() ){ |
243 | text += "<b>" + QObject::tr( "Deadline:") + " </b>"; | 243 | text += "<b>" + QObject::tr( "Deadline:") + " </b>"; |
244 | text += dueDate().toString(); | 244 | text += dueDate().toString(); |
245 | text += "<br>"; | 245 | text += "<br>"; |
246 | } | 246 | } |
247 | if (hasAlarmDateTime() ){ | 247 | if (hasAlarmDateTime() ){ |
248 | text += "<b>" + QObject::tr( "Alarmed Notification:") + " </b>"; | 248 | text += "<b>" + QObject::tr( "Alarmed Notification:") + " </b>"; |
249 | text += alarmDateTime().toString(); | 249 | text += alarmDateTime().toString(); |
250 | text += "<br>"; | 250 | text += "<br>"; |
251 | } | 251 | } |
252 | 252 | ||
253 | text += "<b>" + QObject::tr( "Category:") + "</b> "; | 253 | text += "<b>" + QObject::tr( "Category:") + "</b> "; |
254 | text += categoryNames().join(", "); | 254 | text += categoryNames().join(", "); |
255 | text += "<br>"; | 255 | text += "<br>"; |
256 | 256 | ||
257 | return text; | 257 | return text; |
258 | } | 258 | } |
259 | 259 | ||
260 | bool OTodo::operator<( const OTodo &toDoEvent )const{ | 260 | bool OTodo::operator<( const OTodo &toDoEvent )const{ |
261 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true; | 261 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true; |
262 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return false; | 262 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return false; |
263 | if( hasDueDate() && toDoEvent.hasDueDate() ){ | 263 | if( hasDueDate() && toDoEvent.hasDueDate() ){ |
264 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide | 264 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide |
265 | return priority() < toDoEvent.priority(); | 265 | return priority() < toDoEvent.priority(); |
266 | }else{ | 266 | }else{ |
267 | return dueDate() < toDoEvent.dueDate(); | 267 | return dueDate() < toDoEvent.dueDate(); |
268 | } | 268 | } |
269 | } | 269 | } |
270 | return false; | 270 | return false; |
271 | } | 271 | } |
272 | bool OTodo::operator<=(const OTodo &toDoEvent )const | 272 | bool OTodo::operator<=(const OTodo &toDoEvent )const |
273 | { | 273 | { |
274 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true; | 274 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true; |
275 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return true; | 275 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return true; |
276 | if( hasDueDate() && toDoEvent.hasDueDate() ){ | 276 | if( hasDueDate() && toDoEvent.hasDueDate() ){ |
277 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide | 277 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide |
278 | return priority() <= toDoEvent.priority(); | 278 | return priority() <= toDoEvent.priority(); |
279 | }else{ | 279 | }else{ |
280 | return dueDate() <= toDoEvent.dueDate(); | 280 | return dueDate() <= toDoEvent.dueDate(); |
281 | } | 281 | } |
282 | } | 282 | } |
283 | return true; | 283 | return true; |
284 | } | 284 | } |
285 | bool OTodo::operator>(const OTodo &toDoEvent )const | 285 | bool OTodo::operator>(const OTodo &toDoEvent )const |
286 | { | 286 | { |
287 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return false; | 287 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return false; |
288 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return false; | 288 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return false; |
289 | if( hasDueDate() && toDoEvent.hasDueDate() ){ | 289 | if( hasDueDate() && toDoEvent.hasDueDate() ){ |
290 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide | 290 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide |
291 | return priority() > toDoEvent.priority(); | 291 | return priority() > toDoEvent.priority(); |
292 | }else{ | 292 | }else{ |
293 | return dueDate() > toDoEvent.dueDate(); | 293 | return dueDate() > toDoEvent.dueDate(); |
294 | } | 294 | } |
295 | } | 295 | } |
296 | return false; | 296 | return false; |
297 | } | 297 | } |
298 | bool OTodo::operator>=(const OTodo &toDoEvent )const | 298 | bool OTodo::operator>=(const OTodo &toDoEvent )const |
299 | { | 299 | { |
300 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true; | 300 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true; |
301 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return false; | 301 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return false; |
302 | if( hasDueDate() && toDoEvent.hasDueDate() ){ | 302 | if( hasDueDate() && toDoEvent.hasDueDate() ){ |
303 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide | 303 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide |
304 | return priority() > toDoEvent.priority(); | 304 | return priority() > toDoEvent.priority(); |
305 | }else{ | 305 | }else{ |
306 | return dueDate() > toDoEvent.dueDate(); | 306 | return dueDate() > toDoEvent.dueDate(); |
307 | } | 307 | } |
308 | } | 308 | } |
309 | return true; | 309 | return true; |
310 | } | 310 | } |
311 | bool OTodo::operator==(const OTodo &toDoEvent )const | 311 | bool OTodo::operator==(const OTodo &toDoEvent )const |
312 | { | 312 | { |
313 | if ( data->priority != toDoEvent.data->priority ) return false; | 313 | if ( data->priority != toDoEvent.data->priority ) return false; |
314 | if ( data->priority != toDoEvent.data->prog ) return false; | 314 | if ( data->priority != toDoEvent.data->prog ) return false; |
315 | if ( data->isCompleted != toDoEvent.data->isCompleted ) return false; | 315 | if ( data->isCompleted != toDoEvent.data->isCompleted ) return false; |
316 | if ( data->hasDate != toDoEvent.data->hasDate ) return false; | 316 | if ( data->hasDate != toDoEvent.data->hasDate ) return false; |
317 | if ( data->date != toDoEvent.data->date ) return false; | 317 | if ( data->date != toDoEvent.data->date ) return false; |
318 | if ( data->sum != toDoEvent.data->sum ) return false; | 318 | if ( data->sum != toDoEvent.data->sum ) return false; |
319 | if ( data->desc != toDoEvent.data->desc ) return false; | 319 | if ( data->desc != toDoEvent.data->desc ) return false; |
320 | if ( data->hasAlarmDateTime != toDoEvent.data->hasAlarmDateTime ) | 320 | if ( data->hasAlarmDateTime != toDoEvent.data->hasAlarmDateTime ) |
321 | return false; | 321 | return false; |
322 | if ( data->alarmDateTime != toDoEvent.data->alarmDateTime ) | 322 | if ( data->alarmDateTime != toDoEvent.data->alarmDateTime ) |
323 | return false; | 323 | return false; |
324 | 324 | ||
325 | return OPimRecord::operator==( toDoEvent ); | 325 | return OPimRecord::operator==( toDoEvent ); |
326 | } | 326 | } |
327 | void OTodo::deref() { | 327 | void OTodo::deref() { |
328 | 328 | ||
329 | // qWarning("deref in ToDoEvent"); | 329 | // qWarning("deref in ToDoEvent"); |
330 | if ( data->deref() ) { | 330 | if ( data->deref() ) { |
331 | // qWarning("deleting"); | 331 | // qWarning("deleting"); |
332 | delete data; | 332 | delete data; |
333 | data= 0; | 333 | data= 0; |
334 | } | 334 | } |
335 | } | 335 | } |
336 | OTodo &OTodo::operator=(const OTodo &item ) | 336 | OTodo &OTodo::operator=(const OTodo &item ) |
337 | { | 337 | { |
338 | OPimRecord::operator=( item ); | 338 | OPimRecord::operator=( item ); |
339 | //qWarning("operator= ref "); | 339 | //qWarning("operator= ref "); |
340 | item.data->ref(); | 340 | item.data->ref(); |
341 | deref(); | 341 | deref(); |
342 | data = item.data; | 342 | data = item.data; |
343 | 343 | ||
344 | return *this; | 344 | return *this; |
345 | } | 345 | } |
346 | 346 | ||
347 | QMap<int, QString> OTodo::toMap() const { | 347 | QMap<int, QString> OTodo::toMap() const { |
348 | QMap<int, QString> map; | 348 | QMap<int, QString> map; |
349 | 349 | ||
350 | map.insert( Uid, QString::number( uid() ) ); | 350 | map.insert( Uid, QString::number( uid() ) ); |
351 | map.insert( Category, idsToString( categories() ) ); | 351 | map.insert( Category, idsToString( categories() ) ); |
352 | map.insert( HasDate, QString::number( data->hasDate ) ); | 352 | map.insert( HasDate, QString::number( data->hasDate ) ); |
353 | map.insert( Completed, QString::number( data->isCompleted ) ); | 353 | map.insert( Completed, QString::number( data->isCompleted ) ); |
354 | map.insert( Description, data->desc ); | 354 | map.insert( Description, data->desc ); |
355 | map.insert( Summary, data->sum ); | 355 | map.insert( Summary, data->sum ); |
356 | map.insert( Priority, QString::number( data->priority ) ); | 356 | map.insert( Priority, QString::number( data->priority ) ); |
357 | map.insert( DateDay, QString::number( data->date.day() ) ); | 357 | map.insert( DateDay, QString::number( data->date.day() ) ); |
358 | map.insert( DateMonth, QString::number( data->date.month() ) ); | 358 | map.insert( DateMonth, QString::number( data->date.month() ) ); |
359 | map.insert( DateYear, QString::number( data->date.year() ) ); | 359 | map.insert( DateYear, QString::number( data->date.year() ) ); |
360 | map.insert( Progress, QString::number( data->prog ) ); | 360 | map.insert( Progress, QString::number( data->prog ) ); |
361 | map.insert( CrossReference, crossToString() ); | 361 | map.insert( CrossReference, crossToString() ); |
362 | map.insert( HasAlarmDateTime, QString::number( data->hasAlarmDateTime ) ); | 362 | map.insert( HasAlarmDateTime, QString::number( data->hasAlarmDateTime ) ); |
363 | map.insert( AlarmDateTime, data->alarmDateTime.toString() ); | 363 | map.insert( AlarmDateTime, data->alarmDateTime.toString() ); |
364 | 364 | ||
365 | return map; | 365 | return map; |
366 | } | 366 | } |
367 | 367 | ||
368 | QMap<QString, QString> OTodo::toExtraMap()const { | 368 | QMap<QString, QString> OTodo::toExtraMap()const { |
369 | return data->extra; | 369 | return data->extra; |
370 | } | 370 | } |
371 | /** | 371 | /** |
372 | * change or modify looks at the ref count and either | 372 | * change or modify looks at the ref count and either |
373 | * creates a new QShared Object or it can modify it | 373 | * creates a new QShared Object or it can modify it |
374 | * right in place | 374 | * right in place |
375 | */ | 375 | */ |
376 | void OTodo::changeOrModify() { | 376 | void OTodo::changeOrModify() { |
377 | if ( data->count != 1 ) { | 377 | if ( data->count != 1 ) { |
378 | qWarning("changeOrModify"); | 378 | qWarning("changeOrModify"); |
379 | data->deref(); | 379 | data->deref(); |
380 | OTodoData* d2 = new OTodoData(); | 380 | OTodoData* d2 = new OTodoData(); |
381 | copy(data, d2 ); | 381 | copy(data, d2 ); |
382 | data = d2; | 382 | data = d2; |
383 | } | 383 | } |
384 | } | 384 | } |
385 | void OTodo::copy( OTodoData* src, OTodoData* dest ) { | 385 | void OTodo::copy( OTodoData* src, OTodoData* dest ) { |
386 | dest->date = src->date; | 386 | dest->date = src->date; |
387 | dest->isCompleted = src->isCompleted; | 387 | dest->isCompleted = src->isCompleted; |
388 | dest->hasDate = src->hasDate; | 388 | dest->hasDate = src->hasDate; |
389 | dest->priority = src->priority; | 389 | dest->priority = src->priority; |
390 | dest->desc = src->desc; | 390 | dest->desc = src->desc; |
391 | dest->sum = src->sum; | 391 | dest->sum = src->sum; |
392 | dest->extra = src->extra; | 392 | dest->extra = src->extra; |
393 | dest->prog = src->prog; | 393 | dest->prog = src->prog; |
394 | dest->hasAlarmDateTime = src->hasAlarmDateTime; | 394 | dest->hasAlarmDateTime = src->hasAlarmDateTime; |
395 | dest->alarmDateTime = src->alarmDateTime; | 395 | dest->alarmDateTime = src->alarmDateTime; |
396 | dest->state = src->state; | 396 | dest->state = src->state; |
397 | dest->recur = src->recur; | 397 | dest->recur = src->recur; |
398 | } | 398 | } |
399 | QString OTodo::type() const { | 399 | QString OTodo::type() const { |
400 | return QString::fromLatin1("OTodo"); | 400 | return QString::fromLatin1("OTodo"); |
401 | } | 401 | } |
402 | QString OTodo::recordField(int id )const { | 402 | QString OTodo::recordField(int /*id*/ )const { |
403 | return QString::null; | 403 | return QString::null; |
404 | } | 404 | } |
405 | 405 | ||
diff --git a/libopie2/opiepim/backend/opimaccessbackend.h b/libopie2/opiepim/backend/opimaccessbackend.h index 0bd2723..4f00bc9 100644 --- a/libopie2/opiepim/backend/opimaccessbackend.h +++ b/libopie2/opiepim/backend/opimaccessbackend.h | |||
@@ -1,141 +1,141 @@ | |||
1 | #ifndef OPIE_PIM_ACCESS_BACKEND | 1 | #ifndef OPIE_PIM_ACCESS_BACKEND |
2 | #define OPIE_PIM_ACCESS_BACKEND | 2 | #define OPIE_PIM_ACCESS_BACKEND |
3 | 3 | ||
4 | #include <qarray.h> | 4 | #include <qarray.h> |
5 | 5 | ||
6 | #include <opie/otemplatebase.h> | 6 | #include <opie/otemplatebase.h> |
7 | #include <opie/opimrecord.h> | 7 | #include <opie/opimrecord.h> |
8 | 8 | ||
9 | 9 | ||
10 | /** | 10 | /** |
11 | * OPimAccessBackend is the base class | 11 | * OPimAccessBackend is the base class |
12 | * for all private backends | 12 | * for all private backends |
13 | * it operates on OPimRecord as the base class | 13 | * it operates on OPimRecord as the base class |
14 | * and it's responsible for fast manipulating | 14 | * and it's responsible for fast manipulating |
15 | * the resource the implementation takes care | 15 | * the resource the implementation takes care |
16 | * of | 16 | * of |
17 | */ | 17 | */ |
18 | template <class T = OPimRecord> | 18 | template <class T = OPimRecord> |
19 | class OPimAccessBackend { | 19 | class OPimAccessBackend { |
20 | public: | 20 | public: |
21 | typedef OTemplateBase<T> Frontend; | 21 | typedef OTemplateBase<T> Frontend; |
22 | OPimAccessBackend(); | 22 | OPimAccessBackend(); |
23 | virtual ~OPimAccessBackend(); | 23 | virtual ~OPimAccessBackend(); |
24 | 24 | ||
25 | /** | 25 | /** |
26 | * load the resource | 26 | * load the resource |
27 | */ | 27 | */ |
28 | virtual bool load() = 0; | 28 | virtual bool load() = 0; |
29 | 29 | ||
30 | /** | 30 | /** |
31 | * reload the resource | 31 | * reload the resource |
32 | */ | 32 | */ |
33 | virtual bool reload() = 0; | 33 | virtual bool reload() = 0; |
34 | 34 | ||
35 | /** | 35 | /** |
36 | * save the resource and | 36 | * save the resource and |
37 | * all it's changes | 37 | * all it's changes |
38 | */ | 38 | */ |
39 | virtual bool save() = 0; | 39 | virtual bool save() = 0; |
40 | 40 | ||
41 | /** | 41 | /** |
42 | * return an array of | 42 | * return an array of |
43 | * all available uids | 43 | * all available uids |
44 | */ | 44 | */ |
45 | virtual QArray<int> allRecords()const = 0; | 45 | virtual QArray<int> allRecords()const = 0; |
46 | 46 | ||
47 | /** | 47 | /** |
48 | * queryByExample for T with the SortOrder | 48 | * queryByExample for T with the SortOrder |
49 | * sort | 49 | * sort |
50 | */ | 50 | */ |
51 | virtual QArray<int> queryByExample( const T& t, int sort ) = 0; | 51 | virtual QArray<int> queryByExample( const T& t, int sort ) = 0; |
52 | 52 | ||
53 | /** | 53 | /** |
54 | * find the OPimRecord with uid @param uid | 54 | * find the OPimRecord with uid @param uid |
55 | * returns T and T.isEmpty() if nothing was found | 55 | * returns T and T.isEmpty() if nothing was found |
56 | */ | 56 | */ |
57 | virtual T find(int uid )const = 0; | 57 | virtual T find(int uid )const = 0; |
58 | 58 | ||
59 | virtual T find(int uid, const QArray<int>& items, | 59 | virtual T find(int uid, const QArray<int>& items, |
60 | uint current, Frontend::CacheDirection )const ; | 60 | uint current, typename Frontend::CacheDirection )const ; |
61 | /** | 61 | /** |
62 | * clear the back end | 62 | * clear the back end |
63 | */ | 63 | */ |
64 | virtual void clear() = 0; | 64 | virtual void clear() = 0; |
65 | 65 | ||
66 | /** | 66 | /** |
67 | * add T | 67 | * add T |
68 | */ | 68 | */ |
69 | virtual bool add( const T& t ) = 0; | 69 | virtual bool add( const T& t ) = 0; |
70 | 70 | ||
71 | /** | 71 | /** |
72 | * remove | 72 | * remove |
73 | */ | 73 | */ |
74 | virtual bool remove( int uid ) = 0; | 74 | virtual bool remove( int uid ) = 0; |
75 | 75 | ||
76 | /** | 76 | /** |
77 | * replace a record with T.uid() | 77 | * replace a record with T.uid() |
78 | */ | 78 | */ |
79 | virtual bool replace( const T& t ) = 0; | 79 | virtual bool replace( const T& t ) = 0; |
80 | 80 | ||
81 | /* | 81 | /* |
82 | * setTheFrontEnd!!! | 82 | * setTheFrontEnd!!! |
83 | */ | 83 | */ |
84 | void setFrontend( Frontend* front ); | 84 | void setFrontend( Frontend* front ); |
85 | 85 | ||
86 | /** | 86 | /** |
87 | * set the read ahead count | 87 | * set the read ahead count |
88 | */ | 88 | */ |
89 | void setReadAhead( uint count ); | 89 | void setReadAhead( uint count ); |
90 | protected: | 90 | protected: |
91 | void cache( const T& t )const; | 91 | void cache( const T& t )const; |
92 | 92 | ||
93 | /** | 93 | /** |
94 | * use a prime number here! | 94 | * use a prime number here! |
95 | */ | 95 | */ |
96 | void setSaneCacheSize( int ); | 96 | void setSaneCacheSize( int ); |
97 | 97 | ||
98 | uint readAhead()const; | 98 | uint readAhead()const; |
99 | 99 | ||
100 | private: | 100 | private: |
101 | Frontend* m_front; | 101 | Frontend* m_front; |
102 | uint m_read; | 102 | uint m_read; |
103 | 103 | ||
104 | }; | 104 | }; |
105 | 105 | ||
106 | template <class T> | 106 | template <class T> |
107 | OPimAccessBackend<T>::OPimAccessBackend() { | 107 | OPimAccessBackend<T>::OPimAccessBackend() { |
108 | m_front = 0l; | 108 | m_front = 0l; |
109 | } | 109 | } |
110 | template <class T> | 110 | template <class T> |
111 | OPimAccessBackend<T>::~OPimAccessBackend() { | 111 | OPimAccessBackend<T>::~OPimAccessBackend() { |
112 | 112 | ||
113 | } | 113 | } |
114 | template <class T> | 114 | template <class T> |
115 | void OPimAccessBackend<T>::setFrontend( Frontend* fr ) { | 115 | void OPimAccessBackend<T>::setFrontend( Frontend* fr ) { |
116 | m_front = fr; | 116 | m_front = fr; |
117 | } | 117 | } |
118 | template <class T> | 118 | template <class T> |
119 | void OPimAccessBackend<T>::cache( const T& t )const { | 119 | void OPimAccessBackend<T>::cache( const T& t )const { |
120 | if (m_front ) | 120 | if (m_front ) |
121 | m_front->cache( t ); | 121 | m_front->cache( t ); |
122 | } | 122 | } |
123 | template <class T> | 123 | template <class T> |
124 | void OPimAccessBackend<T>::setSaneCacheSize( int size) { | 124 | void OPimAccessBackend<T>::setSaneCacheSize( int size) { |
125 | if (m_front ) | 125 | if (m_front ) |
126 | m_front->setSaneCacheSize( size ); | 126 | m_front->setSaneCacheSize( size ); |
127 | } | 127 | } |
128 | template <class T> | 128 | template <class T> |
129 | T OPimAccessBackend<T>::find( int uid, const QArray<int>&, | 129 | T OPimAccessBackend<T>::find( int uid, const QArray<int>&, |
130 | uint, Frontend::CacheDirection )const { | 130 | uint, typename Frontend::CacheDirection )const { |
131 | return find( uid ); | 131 | return find( uid ); |
132 | } | 132 | } |
133 | template <class T> | 133 | template <class T> |
134 | void OPimAccessBackend<T>::setReadAhead( uint count ) { | 134 | void OPimAccessBackend<T>::setReadAhead( uint count ) { |
135 | m_read = count; | 135 | m_read = count; |
136 | } | 136 | } |
137 | template <class T> | 137 | template <class T> |
138 | uint OPimAccessBackend<T>::readAhead()const { | 138 | uint OPimAccessBackend<T>::readAhead()const { |
139 | return m_read; | 139 | return m_read; |
140 | } | 140 | } |
141 | #endif | 141 | #endif |
diff --git a/libopie2/opiepim/core/opimaccesstemplate.h b/libopie2/opiepim/core/opimaccesstemplate.h index c5523a8..6de68b1 100644 --- a/libopie2/opiepim/core/opimaccesstemplate.h +++ b/libopie2/opiepim/core/opimaccesstemplate.h | |||
@@ -1,259 +1,259 @@ | |||
1 | #ifndef OPIE_PIM_ACCESS_TEMPLATE_H | 1 | #ifndef OPIE_PIM_ACCESS_TEMPLATE_H |
2 | #define OPIE_PIM_ACCESS_TEMPLATE_H | 2 | #define OPIE_PIM_ACCESS_TEMPLATE_H |
3 | 3 | ||
4 | #include <qarray.h> | 4 | #include <qarray.h> |
5 | 5 | ||
6 | #include <opie/opimrecord.h> | 6 | #include <opie/opimrecord.h> |
7 | #include <opie/opimaccessbackend.h> | 7 | #include <opie/opimaccessbackend.h> |
8 | #include <opie/orecordlist.h> | 8 | #include <opie/orecordlist.h> |
9 | 9 | ||
10 | #include "opimcache.h" | 10 | #include "opimcache.h" |
11 | #include "otemplatebase.h" | 11 | #include "otemplatebase.h" |
12 | 12 | ||
13 | /** | 13 | /** |
14 | * Thats the frontend to our OPIE PIM | 14 | * Thats the frontend to our OPIE PIM |
15 | * Library. Either you want to use it's | 15 | * Library. Either you want to use it's |
16 | * interface or you want to implement | 16 | * interface or you want to implement |
17 | * your own Access lib | 17 | * your own Access lib |
18 | * Just create a OPimRecord and inherit from | 18 | * Just create a OPimRecord and inherit from |
19 | * the plugins | 19 | * the plugins |
20 | */ | 20 | */ |
21 | 21 | ||
22 | template <class T = OPimRecord > | 22 | template <class T = OPimRecord > |
23 | class OPimAccessTemplate : public OTemplateBase<T> { | 23 | class OPimAccessTemplate : public OTemplateBase<T> { |
24 | public: | 24 | public: |
25 | typedef ORecordList<T> List; | 25 | typedef ORecordList<T> List; |
26 | typedef OPimAccessBackend<T> BackEnd; | 26 | typedef OPimAccessBackend<T> BackEnd; |
27 | typedef OPimCache<T> Cache; | 27 | typedef OPimCache<T> Cache; |
28 | 28 | ||
29 | /** | 29 | /** |
30 | * c'tor BackEnd | 30 | * c'tor BackEnd |
31 | */ | 31 | */ |
32 | OPimAccessTemplate( BackEnd* end); | 32 | OPimAccessTemplate( BackEnd* end); |
33 | virtual ~OPimAccessTemplate(); | 33 | virtual ~OPimAccessTemplate(); |
34 | 34 | ||
35 | /** | 35 | /** |
36 | * load from the backend | 36 | * load from the backend |
37 | */ | 37 | */ |
38 | virtual bool load(); | 38 | virtual bool load(); |
39 | 39 | ||
40 | /** Reload database. | 40 | /** Reload database. |
41 | * You should execute this function if the external database | 41 | * You should execute this function if the external database |
42 | * was changed. | 42 | * was changed. |
43 | * This function will load the external database and afterwards | 43 | * This function will load the external database and afterwards |
44 | * rejoin the local changes. Therefore the local database will be set consistent. | 44 | * rejoin the local changes. Therefore the local database will be set consistent. |
45 | */ | 45 | */ |
46 | virtual bool reload(); | 46 | virtual bool reload(); |
47 | 47 | ||
48 | /** Save contacts database. | 48 | /** Save contacts database. |
49 | * Save is more a "commit". After calling this function, all changes are public available. | 49 | * Save is more a "commit". After calling this function, all changes are public available. |
50 | * @return true if successful | 50 | * @return true if successful |
51 | */ | 51 | */ |
52 | virtual bool save(); | 52 | virtual bool save(); |
53 | 53 | ||
54 | /** | 54 | /** |
55 | * if the resource was changed externally | 55 | * if the resource was changed externally |
56 | * You should use the signal handling instead of polling possible changes ! | 56 | * You should use the signal handling instead of polling possible changes ! |
57 | * zecke: Do you implement a signal for otodoaccess ? | 57 | * zecke: Do you implement a signal for otodoaccess ? |
58 | */ | 58 | */ |
59 | bool wasChangedExternally()const; | 59 | bool wasChangedExternally()const; |
60 | 60 | ||
61 | /** | 61 | /** |
62 | * return a List of records | 62 | * return a List of records |
63 | * you can iterate over them | 63 | * you can iterate over them |
64 | */ | 64 | */ |
65 | virtual List allRecords()const; | 65 | virtual List allRecords()const; |
66 | 66 | ||
67 | /** | 67 | /** |
68 | * queryByExample. | 68 | * queryByExample. |
69 | * @see otodoaccess, ocontactaccess | 69 | * @see otodoaccess, ocontactaccess |
70 | */ | 70 | */ |
71 | virtual List queryByExample( const T& t, int querySettings ); | 71 | virtual List queryByExample( const T& t, int querySettings ); |
72 | 72 | ||
73 | /** | 73 | /** |
74 | * find the OPimRecord uid | 74 | * find the OPimRecord uid |
75 | */ | 75 | */ |
76 | virtual T find( int uid )const; | 76 | virtual T find( int uid )const; |
77 | 77 | ||
78 | /** | 78 | /** |
79 | * read ahead cache find method ;) | 79 | * read ahead cache find method ;) |
80 | */ | 80 | */ |
81 | virtual T find( int uid, const QArray<int>&, | 81 | virtual T find( int uid, const QArray<int>&, |
82 | uint current, CacheDirection dir = Forward )const; | 82 | uint current, typename OTemplateBase<T>::CacheDirection dir = OTemplateBase<T>::Forward )const; |
83 | 83 | ||
84 | /* invalidate cache here */ | 84 | /* invalidate cache here */ |
85 | /** | 85 | /** |
86 | * clears the backend and invalidates the backend | 86 | * clears the backend and invalidates the backend |
87 | */ | 87 | */ |
88 | virtual void clear() ; | 88 | virtual void clear() ; |
89 | 89 | ||
90 | /** | 90 | /** |
91 | * add T to the backend | 91 | * add T to the backend |
92 | * @param t The item to add. | 92 | * @param t The item to add. |
93 | * @return <i>true</i> if added successfully. | 93 | * @return <i>true</i> if added successfully. |
94 | */ | 94 | */ |
95 | virtual bool add( const T& t ) ; | 95 | virtual bool add( const T& t ) ; |
96 | 96 | ||
97 | /* only the uid matters */ | 97 | /* only the uid matters */ |
98 | /** | 98 | /** |
99 | * remove T from the backend | 99 | * remove T from the backend |
100 | * @param t The item to remove | 100 | * @param t The item to remove |
101 | * @return <i>true</i> if successful. | 101 | * @return <i>true</i> if successful. |
102 | */ | 102 | */ |
103 | virtual bool remove( const T& t ); | 103 | virtual bool remove( const T& t ); |
104 | 104 | ||
105 | /** | 105 | /** |
106 | * remove the OPimRecord with uid | 106 | * remove the OPimRecord with uid |
107 | * @param uid The ID of the item to remove | 107 | * @param uid The ID of the item to remove |
108 | * @return <i>true</i> if successful. | 108 | * @return <i>true</i> if successful. |
109 | */ | 109 | */ |
110 | virtual bool remove( int uid ); | 110 | virtual bool remove( int uid ); |
111 | 111 | ||
112 | /** | 112 | /** |
113 | * replace T from backend | 113 | * replace T from backend |
114 | * @param t The item to replace | 114 | * @param t The item to replace |
115 | * @return <i>true</i> if successful. | 115 | * @return <i>true</i> if successful. |
116 | */ | 116 | */ |
117 | virtual bool replace( const T& t) ; | 117 | virtual bool replace( const T& t) ; |
118 | 118 | ||
119 | void setReadAhead( uint count ); | 119 | void setReadAhead( uint count ); |
120 | /** | 120 | /** |
121 | * @internal | 121 | * @internal |
122 | */ | 122 | */ |
123 | void cache( const T& )const; | 123 | void cache( const T& )const; |
124 | void setSaneCacheSize( int ); | 124 | void setSaneCacheSize( int ); |
125 | protected: | 125 | protected: |
126 | /** | 126 | /** |
127 | * invalidate the cache | 127 | * invalidate the cache |
128 | */ | 128 | */ |
129 | void invalidateCache(); | 129 | void invalidateCache(); |
130 | 130 | ||
131 | void setBackEnd( BackEnd* end ); | 131 | void setBackEnd( BackEnd* end ); |
132 | /** | 132 | /** |
133 | * returns the backend | 133 | * returns the backend |
134 | */ | 134 | */ |
135 | BackEnd* backEnd(); | 135 | BackEnd* backEnd(); |
136 | BackEnd* m_backEnd; | 136 | BackEnd* m_backEnd; |
137 | Cache m_cache; | 137 | Cache m_cache; |
138 | 138 | ||
139 | }; | 139 | }; |
140 | 140 | ||
141 | template <class T> | 141 | template <class T> |
142 | OPimAccessTemplate<T>::OPimAccessTemplate( BackEnd* end ) | 142 | OPimAccessTemplate<T>::OPimAccessTemplate( BackEnd* end ) |
143 | : OTemplateBase<T>(), m_backEnd( end ) | 143 | : OTemplateBase<T>(), m_backEnd( end ) |
144 | { | 144 | { |
145 | if (end ) | 145 | if (end ) |
146 | end->setFrontend( this ); | 146 | end->setFrontend( this ); |
147 | } | 147 | } |
148 | template <class T> | 148 | template <class T> |
149 | OPimAccessTemplate<T>::~OPimAccessTemplate() { | 149 | OPimAccessTemplate<T>::~OPimAccessTemplate() { |
150 | qWarning("~OPimAccessTemplate<T>"); | 150 | qWarning("~OPimAccessTemplate<T>"); |
151 | delete m_backEnd; | 151 | delete m_backEnd; |
152 | } | 152 | } |
153 | template <class T> | 153 | template <class T> |
154 | bool OPimAccessTemplate<T>::load() { | 154 | bool OPimAccessTemplate<T>::load() { |
155 | invalidateCache(); | 155 | invalidateCache(); |
156 | return m_backEnd->load(); | 156 | return m_backEnd->load(); |
157 | } | 157 | } |
158 | template <class T> | 158 | template <class T> |
159 | bool OPimAccessTemplate<T>::reload() { | 159 | bool OPimAccessTemplate<T>::reload() { |
160 | invalidateCache(); // zecke: I think this should be added (se) | 160 | invalidateCache(); // zecke: I think this should be added (se) |
161 | return m_backEnd->reload(); | 161 | return m_backEnd->reload(); |
162 | } | 162 | } |
163 | template <class T> | 163 | template <class T> |
164 | bool OPimAccessTemplate<T>::save() { | 164 | bool OPimAccessTemplate<T>::save() { |
165 | return m_backEnd->save(); | 165 | return m_backEnd->save(); |
166 | } | 166 | } |
167 | template <class T> | 167 | template <class T> |
168 | OPimAccessTemplate<T>::List OPimAccessTemplate<T>::allRecords()const { | 168 | typename OPimAccessTemplate<T>::List OPimAccessTemplate<T>::allRecords()const { |
169 | QArray<int> ints = m_backEnd->allRecords(); | 169 | QArray<int> ints = m_backEnd->allRecords(); |
170 | List lis(ints, this ); | 170 | List lis(ints, this ); |
171 | return lis; | 171 | return lis; |
172 | } | 172 | } |
173 | template <class T> | 173 | template <class T> |
174 | OPimAccessTemplate<T>::List | 174 | typename OPimAccessTemplate<T>::List |
175 | OPimAccessTemplate<T>::queryByExample( const T& t, int sortOrder ) { | 175 | OPimAccessTemplate<T>::queryByExample( const T& t, int sortOrder ) { |
176 | QArray<int> ints = m_backEnd->queryByExample( t, sortOrder ); | 176 | QArray<int> ints = m_backEnd->queryByExample( t, sortOrder ); |
177 | 177 | ||
178 | List lis(ints, this ); | 178 | List lis(ints, this ); |
179 | return lis; | 179 | return lis; |
180 | } | 180 | } |
181 | template <class T> | 181 | template <class T> |
182 | T OPimAccessTemplate<T>::find( int uid ) const{ | 182 | T OPimAccessTemplate<T>::find( int uid ) const{ |
183 | T t = m_backEnd->find( uid ); | 183 | T t = m_backEnd->find( uid ); |
184 | cache( t ); | 184 | cache( t ); |
185 | return t; | 185 | return t; |
186 | } | 186 | } |
187 | template <class T> | 187 | template <class T> |
188 | T OPimAccessTemplate<T>::find( int uid, const QArray<int>& ar, | 188 | T OPimAccessTemplate<T>::find( int uid, const QArray<int>& ar, |
189 | uint current, CacheDirection dir )const { | 189 | uint current, typename OTemplateBase<T>::CacheDirection dir )const { |
190 | /* | 190 | /* |
191 | * better do T.isEmpty() | 191 | * better do T.isEmpty() |
192 | * after a find this way we would | 192 | * after a find this way we would |
193 | * avoid two finds in QCache... | 193 | * avoid two finds in QCache... |
194 | */ | 194 | */ |
195 | // qWarning("find it now %d", uid ); | 195 | // qWarning("find it now %d", uid ); |
196 | if (m_cache.contains( uid ) ) { | 196 | if (m_cache.contains( uid ) ) { |
197 | return m_cache.find( uid ); | 197 | return m_cache.find( uid ); |
198 | } | 198 | } |
199 | 199 | ||
200 | T t = m_backEnd->find( uid, ar, current, dir ); | 200 | T t = m_backEnd->find( uid, ar, current, dir ); |
201 | cache( t ); | 201 | cache( t ); |
202 | return t; | 202 | return t; |
203 | } | 203 | } |
204 | template <class T> | 204 | template <class T> |
205 | void OPimAccessTemplate<T>::clear() { | 205 | void OPimAccessTemplate<T>::clear() { |
206 | invalidateCache(); | 206 | invalidateCache(); |
207 | m_backEnd->clear(); | 207 | m_backEnd->clear(); |
208 | } | 208 | } |
209 | template <class T> | 209 | template <class T> |
210 | bool OPimAccessTemplate<T>::add( const T& t ) { | 210 | bool OPimAccessTemplate<T>::add( const T& t ) { |
211 | cache( t ); | 211 | cache( t ); |
212 | return m_backEnd->add( t ); | 212 | return m_backEnd->add( t ); |
213 | } | 213 | } |
214 | template <class T> | 214 | template <class T> |
215 | bool OPimAccessTemplate<T>::remove( const T& t ) { | 215 | bool OPimAccessTemplate<T>::remove( const T& t ) { |
216 | return remove( t.uid() ); | 216 | return remove( t.uid() ); |
217 | } | 217 | } |
218 | template <class T> | 218 | template <class T> |
219 | bool OPimAccessTemplate<T>::remove( int uid ) { | 219 | bool OPimAccessTemplate<T>::remove( int uid ) { |
220 | m_cache.remove( uid ); | 220 | m_cache.remove( uid ); |
221 | return m_backEnd->remove( uid ); | 221 | return m_backEnd->remove( uid ); |
222 | } | 222 | } |
223 | template <class T> | 223 | template <class T> |
224 | bool OPimAccessTemplate<T>::replace( const T& t ) { | 224 | bool OPimAccessTemplate<T>::replace( const T& t ) { |
225 | m_cache.replace( t ); | 225 | m_cache.replace( t ); |
226 | return m_backEnd->replace( t ); | 226 | return m_backEnd->replace( t ); |
227 | } | 227 | } |
228 | template <class T> | 228 | template <class T> |
229 | void OPimAccessTemplate<T>::invalidateCache() { | 229 | void OPimAccessTemplate<T>::invalidateCache() { |
230 | m_cache.invalidate(); | 230 | m_cache.invalidate(); |
231 | } | 231 | } |
232 | template <class T> | 232 | template <class T> |
233 | OPimAccessTemplate<T>::BackEnd* OPimAccessTemplate<T>::backEnd() { | 233 | typename OPimAccessTemplate<T>::BackEnd* OPimAccessTemplate<T>::backEnd() { |
234 | return m_backEnd; | 234 | return m_backEnd; |
235 | } | 235 | } |
236 | template <class T> | 236 | template <class T> |
237 | bool OPimAccessTemplate<T>::wasChangedExternally()const { | 237 | bool OPimAccessTemplate<T>::wasChangedExternally()const { |
238 | return false; | 238 | return false; |
239 | } | 239 | } |
240 | template <class T> | 240 | template <class T> |
241 | void OPimAccessTemplate<T>::setBackEnd( BackEnd* end ) { | 241 | void OPimAccessTemplate<T>::setBackEnd( BackEnd* end ) { |
242 | m_backEnd = end; | 242 | m_backEnd = end; |
243 | if (m_backEnd ) | 243 | if (m_backEnd ) |
244 | m_backEnd->setFrontend( this ); | 244 | m_backEnd->setFrontend( this ); |
245 | } | 245 | } |
246 | template <class T> | 246 | template <class T> |
247 | void OPimAccessTemplate<T>::cache( const T& t ) const{ | 247 | void OPimAccessTemplate<T>::cache( const T& t ) const{ |
248 | /* hacky we need to work around the const*/ | 248 | /* hacky we need to work around the const*/ |
249 | ((OPimAccessTemplate<T>*)this)->m_cache.add( t ); | 249 | ((OPimAccessTemplate<T>*)this)->m_cache.add( t ); |
250 | } | 250 | } |
251 | template <class T> | 251 | template <class T> |
252 | void OPimAccessTemplate<T>::setSaneCacheSize( int size ) { | 252 | void OPimAccessTemplate<T>::setSaneCacheSize( int size ) { |
253 | m_cache.setSize( size ); | 253 | m_cache.setSize( size ); |
254 | } | 254 | } |
255 | template <class T> | 255 | template <class T> |
256 | void OPimAccessTemplate<T>::setReadAhead( uint count ) { | 256 | void OPimAccessTemplate<T>::setReadAhead( uint count ) { |
257 | m_backEnd->setReadAhead( count ); | 257 | m_backEnd->setReadAhead( count ); |
258 | } | 258 | } |
259 | #endif | 259 | #endif |
diff --git a/libopie2/opiepim/orecordlist.h b/libopie2/opiepim/orecordlist.h index 8ed41e2..b77a4ab 100644 --- a/libopie2/opiepim/orecordlist.h +++ b/libopie2/opiepim/orecordlist.h | |||
@@ -58,243 +58,243 @@ public: | |||
58 | uint count()const; | 58 | uint count()const; |
59 | 59 | ||
60 | /** | 60 | /** |
61 | * sets the current item | 61 | * sets the current item |
62 | */ | 62 | */ |
63 | void setCurrent( uint cur ); | 63 | void setCurrent( uint cur ); |
64 | 64 | ||
65 | private: | 65 | private: |
66 | QArray<int> m_uids; | 66 | QArray<int> m_uids; |
67 | uint m_current; | 67 | uint m_current; |
68 | const Base* m_temp; | 68 | const Base* m_temp; |
69 | bool m_end : 1; | 69 | bool m_end : 1; |
70 | T m_record; | 70 | T m_record; |
71 | bool m_direction :1; | 71 | bool m_direction :1; |
72 | 72 | ||
73 | /* d pointer for future versions */ | 73 | /* d pointer for future versions */ |
74 | class IteratorPrivate; | 74 | class IteratorPrivate; |
75 | IteratorPrivate *d; | 75 | IteratorPrivate *d; |
76 | }; | 76 | }; |
77 | /** | 77 | /** |
78 | * The recordlist used as a return type | 78 | * The recordlist used as a return type |
79 | * from OPimAccessTemplate | 79 | * from OPimAccessTemplate |
80 | */ | 80 | */ |
81 | template <class T = OPimRecord > | 81 | template <class T = OPimRecord > |
82 | class ORecordList { | 82 | class ORecordList { |
83 | public: | 83 | public: |
84 | typedef OTemplateBase<T> Base; | 84 | typedef OTemplateBase<T> Base; |
85 | typedef ORecordListIterator<T> Iterator; | 85 | typedef ORecordListIterator<T> Iterator; |
86 | 86 | ||
87 | /** | 87 | /** |
88 | * c'tor | 88 | * c'tor |
89 | */ | 89 | */ |
90 | ORecordList () { | 90 | ORecordList () { |
91 | } | 91 | } |
92 | ORecordList( const QArray<int>& ids, | 92 | ORecordList( const QArray<int>& ids, |
93 | const Base* ); | 93 | const Base* ); |
94 | ~ORecordList(); | 94 | ~ORecordList(); |
95 | 95 | ||
96 | /** | 96 | /** |
97 | * the first iterator | 97 | * the first iterator |
98 | */ | 98 | */ |
99 | Iterator begin(); | 99 | Iterator begin(); |
100 | 100 | ||
101 | /** | 101 | /** |
102 | * the end | 102 | * the end |
103 | */ | 103 | */ |
104 | Iterator end(); | 104 | Iterator end(); |
105 | 105 | ||
106 | /** | 106 | /** |
107 | * the number of items in the list | 107 | * the number of items in the list |
108 | */ | 108 | */ |
109 | uint count()const; | 109 | uint count()const; |
110 | 110 | ||
111 | T operator[]( uint i ); | 111 | T operator[]( uint i ); |
112 | int uidAt(uint i ); | 112 | int uidAt(uint i ); |
113 | 113 | ||
114 | /** | 114 | /** |
115 | * Remove the contact with given uid | 115 | * Remove the contact with given uid |
116 | */ | 116 | */ |
117 | bool remove( int uid ); | 117 | bool remove( int uid ); |
118 | 118 | ||
119 | /* | 119 | /* |
120 | ConstIterator begin()const; | 120 | ConstIterator begin()const; |
121 | ConstIterator end()const; | 121 | ConstIterator end()const; |
122 | */ | 122 | */ |
123 | private: | 123 | private: |
124 | QArray<int> m_ids; | 124 | QArray<int> m_ids; |
125 | const Base* m_acc; | 125 | const Base* m_acc; |
126 | }; | 126 | }; |
127 | 127 | ||
128 | /* ok now implement it */ | 128 | /* ok now implement it */ |
129 | template <class T> | 129 | template <class T> |
130 | ORecordListIterator<T>::ORecordListIterator() { | 130 | ORecordListIterator<T>::ORecordListIterator() { |
131 | m_current = 0; | 131 | m_current = 0; |
132 | m_temp = 0l; | 132 | m_temp = 0l; |
133 | m_end = true; | 133 | m_end = true; |
134 | m_record = T(); | 134 | m_record = T(); |
135 | /* forward */ | 135 | /* forward */ |
136 | m_direction = TRUE; | 136 | m_direction = TRUE; |
137 | } | 137 | } |
138 | template <class T> | 138 | template <class T> |
139 | ORecordListIterator<T>::~ORecordListIterator() { | 139 | ORecordListIterator<T>::~ORecordListIterator() { |
140 | /* nothing to delete */ | 140 | /* nothing to delete */ |
141 | } | 141 | } |
142 | 142 | ||
143 | template <class T> | 143 | template <class T> |
144 | ORecordListIterator<T>::ORecordListIterator( const ORecordListIterator<T>& it) { | 144 | ORecordListIterator<T>::ORecordListIterator( const ORecordListIterator<T>& it) { |
145 | // qWarning("ORecordListIterator copy c'tor"); | 145 | // qWarning("ORecordListIterator copy c'tor"); |
146 | m_uids = it.m_uids; | 146 | m_uids = it.m_uids; |
147 | m_current = it.m_current; | 147 | m_current = it.m_current; |
148 | m_temp = it.m_temp; | 148 | m_temp = it.m_temp; |
149 | m_end = it.m_end; | 149 | m_end = it.m_end; |
150 | m_record = it.m_record; | 150 | m_record = it.m_record; |
151 | m_direction = it.m_direction; | 151 | m_direction = it.m_direction; |
152 | } | 152 | } |
153 | 153 | ||
154 | template <class T> | 154 | template <class T> |
155 | ORecordListIterator<T> &ORecordListIterator<T>::operator=( const ORecordListIterator<T>& it) { | 155 | ORecordListIterator<T> &ORecordListIterator<T>::operator=( const ORecordListIterator<T>& it) { |
156 | m_uids = it.m_uids; | 156 | m_uids = it.m_uids; |
157 | m_current = it.m_current; | 157 | m_current = it.m_current; |
158 | m_temp = it.m_temp; | 158 | m_temp = it.m_temp; |
159 | m_end = it.m_end; | 159 | m_end = it.m_end; |
160 | m_record = it.m_record; | 160 | m_record = it.m_record; |
161 | 161 | ||
162 | return *this; | 162 | return *this; |
163 | } | 163 | } |
164 | 164 | ||
165 | template <class T> | 165 | template <class T> |
166 | T ORecordListIterator<T>::operator*() { | 166 | T ORecordListIterator<T>::operator*() { |
167 | //qWarning("operator* %d %d", m_current, m_uids[m_current] ); | 167 | //qWarning("operator* %d %d", m_current, m_uids[m_current] ); |
168 | if (!m_end ) | 168 | if (!m_end ) |
169 | m_record = m_temp->find( m_uids[m_current], m_uids, m_current, | 169 | m_record = m_temp->find( m_uids[m_current], m_uids, m_current, |
170 | m_direction ? Base::Forward : | 170 | m_direction ? Base::Forward : |
171 | Base::Reverse ); | 171 | Base::Reverse ); |
172 | else | 172 | else |
173 | m_record = T(); | 173 | m_record = T(); |
174 | 174 | ||
175 | return m_record; | 175 | return m_record; |
176 | } | 176 | } |
177 | 177 | ||
178 | template <class T> | 178 | template <class T> |
179 | ORecordListIterator<T> &ORecordListIterator<T>::operator++() { | 179 | ORecordListIterator<T> &ORecordListIterator<T>::operator++() { |
180 | m_direction = true; | 180 | m_direction = true; |
181 | if (m_current < m_uids.count() ) { | 181 | if (m_current < m_uids.count() ) { |
182 | m_end = false; | 182 | m_end = false; |
183 | ++m_current; | 183 | ++m_current; |
184 | }else | 184 | }else |
185 | m_end = true; | 185 | m_end = true; |
186 | 186 | ||
187 | return *this; | 187 | return *this; |
188 | } | 188 | } |
189 | template <class T> | 189 | template <class T> |
190 | ORecordListIterator<T> &ORecordListIterator<T>::operator--() { | 190 | ORecordListIterator<T> &ORecordListIterator<T>::operator--() { |
191 | m_direction = false; | 191 | m_direction = false; |
192 | if ( m_current > 0 ) { | 192 | if ( m_current > 0 ) { |
193 | --m_current; | 193 | --m_current; |
194 | m_end = false; | 194 | m_end = false; |
195 | } else | 195 | } else |
196 | m_end = true; | 196 | m_end = true; |
197 | 197 | ||
198 | return *this; | 198 | return *this; |
199 | } | 199 | } |
200 | 200 | ||
201 | template <class T> | 201 | template <class T> |
202 | bool ORecordListIterator<T>::operator==( const ORecordListIterator<T>& it ) { | 202 | bool ORecordListIterator<T>::operator==( const ORecordListIterator<T>& it ) { |
203 | 203 | ||
204 | /* if both are at we're the same.... */ | 204 | /* if both are at we're the same.... */ |
205 | if ( m_end == it.m_end ) return true; | 205 | if ( m_end == it.m_end ) return true; |
206 | 206 | ||
207 | if ( m_uids != it.m_uids ) return false; | 207 | if ( m_uids != it.m_uids ) return false; |
208 | if ( m_current != it.m_current ) return false; | 208 | if ( m_current != it.m_current ) return false; |
209 | if ( m_temp != it.m_temp ) return false; | 209 | if ( m_temp != it.m_temp ) return false; |
210 | 210 | ||
211 | return true; | 211 | return true; |
212 | } | 212 | } |
213 | template <class T> | 213 | template <class T> |
214 | bool ORecordListIterator<T>::operator!=( const ORecordListIterator<T>& it ) { | 214 | bool ORecordListIterator<T>::operator!=( const ORecordListIterator<T>& it ) { |
215 | return !(*this == it ); | 215 | return !(*this == it ); |
216 | } | 216 | } |
217 | template <class T> | 217 | template <class T> |
218 | ORecordListIterator<T>::ORecordListIterator( const QArray<int> uids, | 218 | ORecordListIterator<T>::ORecordListIterator( const QArray<int> uids, |
219 | const Base* t ) | 219 | const Base* t ) |
220 | : m_uids( uids ), m_current( 0 ), m_temp( t ), m_end( false ), | 220 | : m_uids( uids ), m_current( 0 ), m_temp( t ), m_end( false ), |
221 | m_direction( false ) | 221 | m_direction( false ) |
222 | { | 222 | { |
223 | } | 223 | } |
224 | template <class T> | 224 | template <class T> |
225 | uint ORecordListIterator<T>::current()const { | 225 | uint ORecordListIterator<T>::current()const { |
226 | return m_current; | 226 | return m_current; |
227 | } | 227 | } |
228 | template <class T> | 228 | template <class T> |
229 | void ORecordListIterator<T>::setCurrent( uint cur ) { | 229 | void ORecordListIterator<T>::setCurrent( uint cur ) { |
230 | if( cur < m_uids.count() ) { | 230 | if( cur < m_uids.count() ) { |
231 | m_end = false; | 231 | m_end = false; |
232 | m_current= cur; | 232 | m_current= cur; |
233 | } | 233 | } |
234 | } | 234 | } |
235 | template <class T> | 235 | template <class T> |
236 | uint ORecordListIterator<T>::count()const { | 236 | uint ORecordListIterator<T>::count()const { |
237 | return m_uids.count(); | 237 | return m_uids.count(); |
238 | } | 238 | } |
239 | template <class T> | 239 | template <class T> |
240 | ORecordList<T>::ORecordList( const QArray<int>& ids, | 240 | ORecordList<T>::ORecordList( const QArray<int>& ids, |
241 | const Base* acc ) | 241 | const Base* acc ) |
242 | : m_ids( ids ), m_acc( acc ) | 242 | : m_ids( ids ), m_acc( acc ) |
243 | { | 243 | { |
244 | } | 244 | } |
245 | template <class T> | 245 | template <class T> |
246 | ORecordList<T>::~ORecordList() { | 246 | ORecordList<T>::~ORecordList() { |
247 | /* nothing to do here */ | 247 | /* nothing to do here */ |
248 | } | 248 | } |
249 | template <class T> | 249 | template <class T> |
250 | ORecordList<T>::Iterator ORecordList<T>::begin() { | 250 | typename ORecordList<T>::Iterator ORecordList<T>::begin() { |
251 | Iterator it( m_ids, m_acc ); | 251 | Iterator it( m_ids, m_acc ); |
252 | return it; | 252 | return it; |
253 | } | 253 | } |
254 | template <class T> | 254 | template <class T> |
255 | ORecordList<T>::Iterator ORecordList<T>::end() { | 255 | typename ORecordList<T>::Iterator ORecordList<T>::end() { |
256 | Iterator it( m_ids, m_acc ); | 256 | Iterator it( m_ids, m_acc ); |
257 | it.m_end = true; | 257 | it.m_end = true; |
258 | it.m_current = m_ids.count(); | 258 | it.m_current = m_ids.count(); |
259 | 259 | ||
260 | return it; | 260 | return it; |
261 | } | 261 | } |
262 | template <class T> | 262 | template <class T> |
263 | uint ORecordList<T>::count()const { | 263 | uint ORecordList<T>::count()const { |
264 | return m_ids.count(); | 264 | return m_ids.count(); |
265 | } | 265 | } |
266 | template <class T> | 266 | template <class T> |
267 | T ORecordList<T>::operator[]( uint i ) { | 267 | T ORecordList<T>::operator[]( uint i ) { |
268 | if ( i < 0 || (i+1) > m_ids.count() ) | 268 | if ( i < 0 || (i+1) > m_ids.count() ) |
269 | return T(); | 269 | return T(); |
270 | /* forward */ | 270 | /* forward */ |
271 | return m_acc->find( m_ids[i], m_ids, i ); | 271 | return m_acc->find( m_ids[i], m_ids, i ); |
272 | } | 272 | } |
273 | template <class T> | 273 | template <class T> |
274 | int ORecordList<T>::uidAt( uint i ) { | 274 | int ORecordList<T>::uidAt( uint i ) { |
275 | return m_ids[i]; | 275 | return m_ids[i]; |
276 | } | 276 | } |
277 | 277 | ||
278 | template <class T> | 278 | template <class T> |
279 | bool ORecordList<T>::remove( int uid ) { | 279 | bool ORecordList<T>::remove( int uid ) { |
280 | QArray<int> copy( m_ids.count() ); | 280 | QArray<int> copy( m_ids.count() ); |
281 | int counter = 0; | 281 | int counter = 0; |
282 | bool ret_val = false; | 282 | bool ret_val = false; |
283 | 283 | ||
284 | for (uint i = 0; i < m_ids.count(); i++){ | 284 | for (uint i = 0; i < m_ids.count(); i++){ |
285 | if ( m_ids[i] != uid ){ | 285 | if ( m_ids[i] != uid ){ |
286 | copy[counter++] = m_ids[i]; | 286 | copy[counter++] = m_ids[i]; |
287 | 287 | ||
288 | }else | 288 | }else |
289 | ret_val = true; | 289 | ret_val = true; |
290 | } | 290 | } |
291 | 291 | ||
292 | copy.resize( counter ); | 292 | copy.resize( counter ); |
293 | m_ids = copy; | 293 | m_ids = copy; |
294 | 294 | ||
295 | 295 | ||
296 | return ret_val; | 296 | return ret_val; |
297 | } | 297 | } |
298 | 298 | ||
299 | 299 | ||
300 | #endif | 300 | #endif |
diff --git a/libopie2/opiepim/otodo.cpp b/libopie2/opiepim/otodo.cpp index 0d5b1d3..4d5cb79 100644 --- a/libopie2/opiepim/otodo.cpp +++ b/libopie2/opiepim/otodo.cpp | |||
@@ -210,196 +210,196 @@ bool OTodo::isOverdue( ) | |||
210 | } | 210 | } |
211 | void OTodo::setProgress(ushort progress ) | 211 | void OTodo::setProgress(ushort progress ) |
212 | { | 212 | { |
213 | changeOrModify(); | 213 | changeOrModify(); |
214 | data->prog = progress; | 214 | data->prog = progress; |
215 | } | 215 | } |
216 | QString OTodo::toShortText() const { | 216 | QString OTodo::toShortText() const { |
217 | return summary(); | 217 | return summary(); |
218 | } | 218 | } |
219 | /*! | 219 | /*! |
220 | Returns a richt text string | 220 | Returns a richt text string |
221 | */ | 221 | */ |
222 | QString OTodo::toRichText() const | 222 | QString OTodo::toRichText() const |
223 | { | 223 | { |
224 | QString text; | 224 | QString text; |
225 | QStringList catlist; | 225 | QStringList catlist; |
226 | 226 | ||
227 | // Description of the todo | 227 | // Description of the todo |
228 | if ( !summary().isEmpty() ) { | 228 | if ( !summary().isEmpty() ) { |
229 | text += "<b>" + QObject::tr( "Summary:") + "</b><br>"; | 229 | text += "<b>" + QObject::tr( "Summary:") + "</b><br>"; |
230 | text += Qtopia::escapeString(summary() ).replace(QRegExp( "[\n]"), "<br>" ) + "<br>"; | 230 | text += Qtopia::escapeString(summary() ).replace(QRegExp( "[\n]"), "<br>" ) + "<br>"; |
231 | } | 231 | } |
232 | if( !description().isEmpty() ){ | 232 | if( !description().isEmpty() ){ |
233 | text += "<b>" + QObject::tr( "Description:" ) + "</b><br>"; | 233 | text += "<b>" + QObject::tr( "Description:" ) + "</b><br>"; |
234 | text += Qtopia::escapeString(description() ).replace(QRegExp( "[\n]"), "<br>" ) ; | 234 | text += Qtopia::escapeString(description() ).replace(QRegExp( "[\n]"), "<br>" ) ; |
235 | } | 235 | } |
236 | text += "<br><br><br>"; | 236 | text += "<br><br><br>"; |
237 | 237 | ||
238 | text += "<b>" + QObject::tr( "Priority:") +" </b>" | 238 | text += "<b>" + QObject::tr( "Priority:") +" </b>" |
239 | + QString::number( priority() ) + " <br>"; | 239 | + QString::number( priority() ) + " <br>"; |
240 | text += "<b>" + QObject::tr( "Progress:") + " </b>" | 240 | text += "<b>" + QObject::tr( "Progress:") + " </b>" |
241 | + QString::number( progress() ) + " %<br>"; | 241 | + QString::number( progress() ) + " %<br>"; |
242 | if (hasDueDate() ){ | 242 | if (hasDueDate() ){ |
243 | text += "<b>" + QObject::tr( "Deadline:") + " </b>"; | 243 | text += "<b>" + QObject::tr( "Deadline:") + " </b>"; |
244 | text += dueDate().toString(); | 244 | text += dueDate().toString(); |
245 | text += "<br>"; | 245 | text += "<br>"; |
246 | } | 246 | } |
247 | if (hasAlarmDateTime() ){ | 247 | if (hasAlarmDateTime() ){ |
248 | text += "<b>" + QObject::tr( "Alarmed Notification:") + " </b>"; | 248 | text += "<b>" + QObject::tr( "Alarmed Notification:") + " </b>"; |
249 | text += alarmDateTime().toString(); | 249 | text += alarmDateTime().toString(); |
250 | text += "<br>"; | 250 | text += "<br>"; |
251 | } | 251 | } |
252 | 252 | ||
253 | text += "<b>" + QObject::tr( "Category:") + "</b> "; | 253 | text += "<b>" + QObject::tr( "Category:") + "</b> "; |
254 | text += categoryNames().join(", "); | 254 | text += categoryNames().join(", "); |
255 | text += "<br>"; | 255 | text += "<br>"; |
256 | 256 | ||
257 | return text; | 257 | return text; |
258 | } | 258 | } |
259 | 259 | ||
260 | bool OTodo::operator<( const OTodo &toDoEvent )const{ | 260 | bool OTodo::operator<( const OTodo &toDoEvent )const{ |
261 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true; | 261 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true; |
262 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return false; | 262 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return false; |
263 | if( hasDueDate() && toDoEvent.hasDueDate() ){ | 263 | if( hasDueDate() && toDoEvent.hasDueDate() ){ |
264 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide | 264 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide |
265 | return priority() < toDoEvent.priority(); | 265 | return priority() < toDoEvent.priority(); |
266 | }else{ | 266 | }else{ |
267 | return dueDate() < toDoEvent.dueDate(); | 267 | return dueDate() < toDoEvent.dueDate(); |
268 | } | 268 | } |
269 | } | 269 | } |
270 | return false; | 270 | return false; |
271 | } | 271 | } |
272 | bool OTodo::operator<=(const OTodo &toDoEvent )const | 272 | bool OTodo::operator<=(const OTodo &toDoEvent )const |
273 | { | 273 | { |
274 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true; | 274 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true; |
275 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return true; | 275 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return true; |
276 | if( hasDueDate() && toDoEvent.hasDueDate() ){ | 276 | if( hasDueDate() && toDoEvent.hasDueDate() ){ |
277 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide | 277 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide |
278 | return priority() <= toDoEvent.priority(); | 278 | return priority() <= toDoEvent.priority(); |
279 | }else{ | 279 | }else{ |
280 | return dueDate() <= toDoEvent.dueDate(); | 280 | return dueDate() <= toDoEvent.dueDate(); |
281 | } | 281 | } |
282 | } | 282 | } |
283 | return true; | 283 | return true; |
284 | } | 284 | } |
285 | bool OTodo::operator>(const OTodo &toDoEvent )const | 285 | bool OTodo::operator>(const OTodo &toDoEvent )const |
286 | { | 286 | { |
287 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return false; | 287 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return false; |
288 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return false; | 288 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return false; |
289 | if( hasDueDate() && toDoEvent.hasDueDate() ){ | 289 | if( hasDueDate() && toDoEvent.hasDueDate() ){ |
290 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide | 290 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide |
291 | return priority() > toDoEvent.priority(); | 291 | return priority() > toDoEvent.priority(); |
292 | }else{ | 292 | }else{ |
293 | return dueDate() > toDoEvent.dueDate(); | 293 | return dueDate() > toDoEvent.dueDate(); |
294 | } | 294 | } |
295 | } | 295 | } |
296 | return false; | 296 | return false; |
297 | } | 297 | } |
298 | bool OTodo::operator>=(const OTodo &toDoEvent )const | 298 | bool OTodo::operator>=(const OTodo &toDoEvent )const |
299 | { | 299 | { |
300 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true; | 300 | if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true; |
301 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return false; | 301 | if( !hasDueDate() && toDoEvent.hasDueDate() ) return false; |
302 | if( hasDueDate() && toDoEvent.hasDueDate() ){ | 302 | if( hasDueDate() && toDoEvent.hasDueDate() ){ |
303 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide | 303 | if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide |
304 | return priority() > toDoEvent.priority(); | 304 | return priority() > toDoEvent.priority(); |
305 | }else{ | 305 | }else{ |
306 | return dueDate() > toDoEvent.dueDate(); | 306 | return dueDate() > toDoEvent.dueDate(); |
307 | } | 307 | } |
308 | } | 308 | } |
309 | return true; | 309 | return true; |
310 | } | 310 | } |
311 | bool OTodo::operator==(const OTodo &toDoEvent )const | 311 | bool OTodo::operator==(const OTodo &toDoEvent )const |
312 | { | 312 | { |
313 | if ( data->priority != toDoEvent.data->priority ) return false; | 313 | if ( data->priority != toDoEvent.data->priority ) return false; |
314 | if ( data->priority != toDoEvent.data->prog ) return false; | 314 | if ( data->priority != toDoEvent.data->prog ) return false; |
315 | if ( data->isCompleted != toDoEvent.data->isCompleted ) return false; | 315 | if ( data->isCompleted != toDoEvent.data->isCompleted ) return false; |
316 | if ( data->hasDate != toDoEvent.data->hasDate ) return false; | 316 | if ( data->hasDate != toDoEvent.data->hasDate ) return false; |
317 | if ( data->date != toDoEvent.data->date ) return false; | 317 | if ( data->date != toDoEvent.data->date ) return false; |
318 | if ( data->sum != toDoEvent.data->sum ) return false; | 318 | if ( data->sum != toDoEvent.data->sum ) return false; |
319 | if ( data->desc != toDoEvent.data->desc ) return false; | 319 | if ( data->desc != toDoEvent.data->desc ) return false; |
320 | if ( data->hasAlarmDateTime != toDoEvent.data->hasAlarmDateTime ) | 320 | if ( data->hasAlarmDateTime != toDoEvent.data->hasAlarmDateTime ) |
321 | return false; | 321 | return false; |
322 | if ( data->alarmDateTime != toDoEvent.data->alarmDateTime ) | 322 | if ( data->alarmDateTime != toDoEvent.data->alarmDateTime ) |
323 | return false; | 323 | return false; |
324 | 324 | ||
325 | return OPimRecord::operator==( toDoEvent ); | 325 | return OPimRecord::operator==( toDoEvent ); |
326 | } | 326 | } |
327 | void OTodo::deref() { | 327 | void OTodo::deref() { |
328 | 328 | ||
329 | // qWarning("deref in ToDoEvent"); | 329 | // qWarning("deref in ToDoEvent"); |
330 | if ( data->deref() ) { | 330 | if ( data->deref() ) { |
331 | // qWarning("deleting"); | 331 | // qWarning("deleting"); |
332 | delete data; | 332 | delete data; |
333 | data= 0; | 333 | data= 0; |
334 | } | 334 | } |
335 | } | 335 | } |
336 | OTodo &OTodo::operator=(const OTodo &item ) | 336 | OTodo &OTodo::operator=(const OTodo &item ) |
337 | { | 337 | { |
338 | OPimRecord::operator=( item ); | 338 | OPimRecord::operator=( item ); |
339 | //qWarning("operator= ref "); | 339 | //qWarning("operator= ref "); |
340 | item.data->ref(); | 340 | item.data->ref(); |
341 | deref(); | 341 | deref(); |
342 | data = item.data; | 342 | data = item.data; |
343 | 343 | ||
344 | return *this; | 344 | return *this; |
345 | } | 345 | } |
346 | 346 | ||
347 | QMap<int, QString> OTodo::toMap() const { | 347 | QMap<int, QString> OTodo::toMap() const { |
348 | QMap<int, QString> map; | 348 | QMap<int, QString> map; |
349 | 349 | ||
350 | map.insert( Uid, QString::number( uid() ) ); | 350 | map.insert( Uid, QString::number( uid() ) ); |
351 | map.insert( Category, idsToString( categories() ) ); | 351 | map.insert( Category, idsToString( categories() ) ); |
352 | map.insert( HasDate, QString::number( data->hasDate ) ); | 352 | map.insert( HasDate, QString::number( data->hasDate ) ); |
353 | map.insert( Completed, QString::number( data->isCompleted ) ); | 353 | map.insert( Completed, QString::number( data->isCompleted ) ); |
354 | map.insert( Description, data->desc ); | 354 | map.insert( Description, data->desc ); |
355 | map.insert( Summary, data->sum ); | 355 | map.insert( Summary, data->sum ); |
356 | map.insert( Priority, QString::number( data->priority ) ); | 356 | map.insert( Priority, QString::number( data->priority ) ); |
357 | map.insert( DateDay, QString::number( data->date.day() ) ); | 357 | map.insert( DateDay, QString::number( data->date.day() ) ); |
358 | map.insert( DateMonth, QString::number( data->date.month() ) ); | 358 | map.insert( DateMonth, QString::number( data->date.month() ) ); |
359 | map.insert( DateYear, QString::number( data->date.year() ) ); | 359 | map.insert( DateYear, QString::number( data->date.year() ) ); |
360 | map.insert( Progress, QString::number( data->prog ) ); | 360 | map.insert( Progress, QString::number( data->prog ) ); |
361 | map.insert( CrossReference, crossToString() ); | 361 | map.insert( CrossReference, crossToString() ); |
362 | map.insert( HasAlarmDateTime, QString::number( data->hasAlarmDateTime ) ); | 362 | map.insert( HasAlarmDateTime, QString::number( data->hasAlarmDateTime ) ); |
363 | map.insert( AlarmDateTime, data->alarmDateTime.toString() ); | 363 | map.insert( AlarmDateTime, data->alarmDateTime.toString() ); |
364 | 364 | ||
365 | return map; | 365 | return map; |
366 | } | 366 | } |
367 | 367 | ||
368 | QMap<QString, QString> OTodo::toExtraMap()const { | 368 | QMap<QString, QString> OTodo::toExtraMap()const { |
369 | return data->extra; | 369 | return data->extra; |
370 | } | 370 | } |
371 | /** | 371 | /** |
372 | * change or modify looks at the ref count and either | 372 | * change or modify looks at the ref count and either |
373 | * creates a new QShared Object or it can modify it | 373 | * creates a new QShared Object or it can modify it |
374 | * right in place | 374 | * right in place |
375 | */ | 375 | */ |
376 | void OTodo::changeOrModify() { | 376 | void OTodo::changeOrModify() { |
377 | if ( data->count != 1 ) { | 377 | if ( data->count != 1 ) { |
378 | qWarning("changeOrModify"); | 378 | qWarning("changeOrModify"); |
379 | data->deref(); | 379 | data->deref(); |
380 | OTodoData* d2 = new OTodoData(); | 380 | OTodoData* d2 = new OTodoData(); |
381 | copy(data, d2 ); | 381 | copy(data, d2 ); |
382 | data = d2; | 382 | data = d2; |
383 | } | 383 | } |
384 | } | 384 | } |
385 | void OTodo::copy( OTodoData* src, OTodoData* dest ) { | 385 | void OTodo::copy( OTodoData* src, OTodoData* dest ) { |
386 | dest->date = src->date; | 386 | dest->date = src->date; |
387 | dest->isCompleted = src->isCompleted; | 387 | dest->isCompleted = src->isCompleted; |
388 | dest->hasDate = src->hasDate; | 388 | dest->hasDate = src->hasDate; |
389 | dest->priority = src->priority; | 389 | dest->priority = src->priority; |
390 | dest->desc = src->desc; | 390 | dest->desc = src->desc; |
391 | dest->sum = src->sum; | 391 | dest->sum = src->sum; |
392 | dest->extra = src->extra; | 392 | dest->extra = src->extra; |
393 | dest->prog = src->prog; | 393 | dest->prog = src->prog; |
394 | dest->hasAlarmDateTime = src->hasAlarmDateTime; | 394 | dest->hasAlarmDateTime = src->hasAlarmDateTime; |
395 | dest->alarmDateTime = src->alarmDateTime; | 395 | dest->alarmDateTime = src->alarmDateTime; |
396 | dest->state = src->state; | 396 | dest->state = src->state; |
397 | dest->recur = src->recur; | 397 | dest->recur = src->recur; |
398 | } | 398 | } |
399 | QString OTodo::type() const { | 399 | QString OTodo::type() const { |
400 | return QString::fromLatin1("OTodo"); | 400 | return QString::fromLatin1("OTodo"); |
401 | } | 401 | } |
402 | QString OTodo::recordField(int id )const { | 402 | QString OTodo::recordField(int /*id*/ )const { |
403 | return QString::null; | 403 | return QString::null; |
404 | } | 404 | } |
405 | 405 | ||