summaryrefslogtreecommitdiff
authorandyq <andyq>2002-11-02 09:09:41 (UTC)
committer andyq <andyq>2002-11-02 09:09:41 (UTC)
commitf8538844857840a2cdefe8e3b0dfa90a30163ae1 (patch) (unidiff)
tree57ea5c6cbd9195a3808180f8b999d6cda991df5c
parentbf9388acdebf6e55345dff3bd1cd652b45a2202a (diff)
downloadopie-f8538844857840a2cdefe8e3b0dfa90a30163ae1.zip
opie-f8538844857840a2cdefe8e3b0dfa90a30163ae1.tar.gz
opie-f8538844857840a2cdefe8e3b0dfa90a30163ae1.tar.bz2
Fixed bug where package should be removed but gets reinstalled
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/settings/aqpkg/networkpkgmgr.cpp3
1 files changed, 2 insertions, 1 deletions
diff --git a/noncore/settings/aqpkg/networkpkgmgr.cpp b/noncore/settings/aqpkg/networkpkgmgr.cpp
index b5d7352..3d06aef 100644
--- a/noncore/settings/aqpkg/networkpkgmgr.cpp
+++ b/noncore/settings/aqpkg/networkpkgmgr.cpp
@@ -426,226 +426,227 @@ void NetworkPackageManager :: downloadPackage()
426 { 426 {
427 if ( item->isOn() ) 427 if ( item->isOn() )
428 { 428 {
429 QString name = item->text(); 429 QString name = item->text();
430 int pos = name.find( "*" ); 430 int pos = name.find( "*" );
431 name.truncate( pos ); 431 name.truncate( pos );
432 432
433 // if (there is a (installed), remove it 433 // if (there is a (installed), remove it
434 pos = name.find( "(installed)" ); 434 pos = name.find( "(installed)" );
435 if ( pos > 0 ) 435 if ( pos > 0 )
436 name.truncate( pos - 1 ); 436 name.truncate( pos - 1 );
437 437
438 Package *p = dataMgr->getServer( serversList->currentText() )->getPackage( name ); 438 Package *p = dataMgr->getServer( serversList->currentText() )->getPackage( name );
439 QFile f( p->getFilename() ); 439 QFile f( p->getFilename() );
440 f.remove(); 440 f.remove();
441 } 441 }
442 } 442 }
443 } 443 }
444 444
445 dataMgr->reloadServerData(); 445 dataMgr->reloadServerData();
446 serverSelected( -1 ); 446 serverSelected( -1 );
447} 447}
448 448
449 449
450void NetworkPackageManager :: applyChanges() 450void NetworkPackageManager :: applyChanges()
451{ 451{
452 stickyOption = ""; 452 stickyOption = "";
453 453
454 // First, write out ipkg_conf file so that ipkg can use it 454 // First, write out ipkg_conf file so that ipkg can use it
455 dataMgr->writeOutIpkgConf(); 455 dataMgr->writeOutIpkgConf();
456 456
457 // Now for each selected item 457 // Now for each selected item
458 // deal with it 458 // deal with it
459 459
460 vector<InstallData> workingPackages; 460 vector<InstallData> workingPackages;
461 for ( QCheckListItem *item = (QCheckListItem *)packagesList->firstChild(); 461 for ( QCheckListItem *item = (QCheckListItem *)packagesList->firstChild();
462 item != 0 ; 462 item != 0 ;
463 item = (QCheckListItem *)item->nextSibling() ) 463 item = (QCheckListItem *)item->nextSibling() )
464 { 464 {
465 if ( item->isOn() ) 465 if ( item->isOn() )
466 { 466 {
467 InstallData data = dealWithItem( item ); 467 InstallData data = dealWithItem( item );
468 workingPackages.push_back( data ); 468 workingPackages.push_back( data );
469 } 469 }
470 } 470 }
471 471
472 if ( workingPackages.size() == 0 ) 472 if ( workingPackages.size() == 0 )
473 { 473 {
474 // Nothing to do 474 // Nothing to do
475 QMessageBox::information( this, "Nothing to do", 475 QMessageBox::information( this, "Nothing to do",
476 "No packages selected", "OK" ); 476 "No packages selected", "OK" );
477 477
478 return; 478 return;
479 } 479 }
480 480
481 // do the stuff 481 // do the stuff
482 InstallDlgImpl dlg( workingPackages, dataMgr, this, "Install", true ); 482 InstallDlgImpl dlg( workingPackages, dataMgr, this, "Install", true );
483 dlg.showDlg(); 483 dlg.showDlg();
484 484
485 // Reload data 485 // Reload data
486 dataMgr->reloadServerData(); 486 dataMgr->reloadServerData();
487 serverSelected(-1); 487 serverSelected(-1);
488 488
489#ifdef QWS 489#ifdef QWS
490 // Finally let the main system update itself 490 // Finally let the main system update itself
491 QCopEnvelope e("QPE/System", "linkChanged(QString)"); 491 QCopEnvelope e("QPE/System", "linkChanged(QString)");
492 QString lf = QString::null; 492 QString lf = QString::null;
493 e << lf; 493 e << lf;
494#endif 494#endif
495} 495}
496 496
497// decide what to do - either remove, upgrade or install 497// decide what to do - either remove, upgrade or install
498// Current rules: 498// Current rules:
499// If not installed - install 499// If not installed - install
500// If installed and different version available - upgrade 500// If installed and different version available - upgrade
501// If installed and version up to date - remove 501// If installed and version up to date - remove
502InstallData NetworkPackageManager :: dealWithItem( QCheckListItem *item ) 502InstallData NetworkPackageManager :: dealWithItem( QCheckListItem *item )
503{ 503{
504 QString name = item->text(); 504 QString name = item->text();
505 int pos = name.find( "*" ); 505 int pos = name.find( "*" );
506 name.truncate( pos ); 506 name.truncate( pos );
507 507
508 // if (there is a (installed), remove it 508 // if (there is a (installed), remove it
509 pos = name.find( "(installed)" ); 509 pos = name.find( "(installed)" );
510 if ( pos > 0 ) 510 if ( pos > 0 )
511 name.truncate( pos - 1 ); 511 name.truncate( pos - 1 );
512 512
513 // Get package 513 // Get package
514 Server *s = dataMgr->getServer( serversList->currentText() ); 514 Server *s = dataMgr->getServer( serversList->currentText() );
515 Package *p = s->getPackage( name ); 515 Package *p = s->getPackage( name );
516 516
517 // If the package has a filename then it is a local file 517 // If the package has a filename then it is a local file
518 if ( p->isPackageStoredLocally() ) 518 if ( p->isPackageStoredLocally() )
519 name = p->getFilename(); 519 name = p->getFilename();
520 QString option; 520 QString option;
521 QString dest = "root"; 521 QString dest = "root";
522 if ( !p->isInstalled() ) 522 if ( !p->isInstalled() )
523 { 523 {
524 InstallData item; 524 InstallData item;
525 item.option = "I"; 525 item.option = "I";
526 item.packageName = name; 526 item.packageName = name;
527 return item; 527 return item;
528 } 528 }
529 else 529 else
530 { 530 {
531 InstallData item; 531 InstallData item;
532 item.option = "D"; 532 item.option = "D";
533 item.packageName = p->getInstalledPackageName(); 533 item.packageName = p->getInstalledPackageName();
534 if ( p->getInstalledTo() ) 534 if ( p->getInstalledTo() )
535 { 535 {
536 item.destination = p->getInstalledTo(); 536 item.destination = p->getInstalledTo();
537 cout << "dest - " << p->getInstalledTo()->getDestinationName() << endl; 537 cout << "dest - " << p->getInstalledTo()->getDestinationName() << endl;
538 cout << "dest - " << p->getInstalledTo()->getDestinationPath() << endl; 538 cout << "dest - " << p->getInstalledTo()->getDestinationPath() << endl;
539 } 539 }
540 else 540 else
541 { 541 {
542 item.destination = p->getLocalPackage()->getInstalledTo(); 542 item.destination = p->getLocalPackage()->getInstalledTo();
543 } 543 }
544 544
545 // Now see if version is newer or not 545 // Now see if version is newer or not
546 int val = compareVersions( p->getInstalledVersion(), p->getVersion() ); 546 int val = compareVersions( p->getInstalledVersion(), p->getVersion() );
547 if ( val == -2 ) 547 if ( val == -2 )
548 { 548 {
549 // Error - should handle 549 // Error - should handle
550 } 550 }
551 else if ( val == -1 ) 551 else if ( val == -1 )
552 { 552 {
553 // Version available is older - remove only 553 // Version available is older - remove only
554 item.option = "R"; 554 item.option = "D";
555 } 555 }
556 else 556 else
557 { 557 {
558 QString caption; 558 QString caption;
559 QString text; 559 QString text;
560 QString secondButton; 560 QString secondButton;
561 QString secondOption; 561 QString secondOption;
562 if ( val == 0 ) 562 if ( val == 0 )
563 { 563 {
564 // Version available is the same - option to remove or reinstall 564 // Version available is the same - option to remove or reinstall
565 caption = "Do you wish to remove or reinstall\n%s?"; 565 caption = "Do you wish to remove or reinstall\n%s?";
566 text = "Remove or ReInstall"; 566 text = "Remove or ReInstall";
567 secondButton = "ReInstall"; 567 secondButton = "ReInstall";
568 secondOption = "R"; 568 secondOption = "R";
569 } 569 }
570 else if ( val == 1 ) 570 else if ( val == 1 )
571 { 571 {
572 // Version available is newer - option to remove or upgrade 572 // Version available is newer - option to remove or upgrade
573 caption = "Do you wish to remove or upgrade\n%s?"; 573 caption = "Do you wish to remove or upgrade\n%s?";
574 text = "Remove or Upgrade"; 574 text = "Remove or Upgrade";
575 secondButton = "Upgrade"; 575 secondButton = "Upgrade";
576 secondOption = "U"; 576 secondOption = "U";
577 } 577 }
578 578
579 // Sticky option not implemented yet, but will eventually allow 579 // Sticky option not implemented yet, but will eventually allow
580 // the user to say something like 'remove all' 580 // the user to say something like 'remove all'
581 if ( stickyOption == "" ) 581 if ( stickyOption == "" )
582 { 582 {
583 QString msgtext; 583 QString msgtext;
584 msgtext.sprintf( caption, (const char *)name ); 584 msgtext.sprintf( caption, (const char *)name );
585 switch( QMessageBox::information( this, text, 585 switch( QMessageBox::information( this, text,
586 msgtext, "Remove", secondButton ) ) 586 msgtext, "Remove", secondButton ) )
587 { 587 {
588 case 0: // Try again or Enter 588 case 0: // Try again or Enter
589 // option 0 = Remove
589 item.option = "D"; 590 item.option = "D";
590 break; 591 break;
591 case 1: // Quit or Escape 592 case 1: // Quit or Escape
592 item.option = secondOption; 593 item.option = secondOption;
593 break; 594 break;
594 } 595 }
595 } 596 }
596 else 597 else
597 { 598 {
598// item.option = stickyOption; 599// item.option = stickyOption;
599 } 600 }
600 } 601 }
601 602
602 603
603 // Check if we are reinstalling the same version 604 // Check if we are reinstalling the same version
604 if ( item.option != "R" ) 605 if ( item.option != "R" )
605 item.recreateLinks = true; 606 item.recreateLinks = true;
606 else 607 else
607 item.recreateLinks = false; 608 item.recreateLinks = false;
608 609
609 // User hit cancel (on dlg - assume remove) 610 // User hit cancel (on dlg - assume remove)
610 return item; 611 return item;
611 } 612 }
612} 613}
613 614
614void NetworkPackageManager :: displayText( const QString &t ) 615void NetworkPackageManager :: displayText( const QString &t )
615{ 616{
616 cout << t << endl; 617 cout << t << endl;
617} 618}
618 619
619 620
620void NetworkPackageManager :: letterPushed( QString t ) 621void NetworkPackageManager :: letterPushed( QString t )
621{ 622{
622 QCheckListItem *top = (QCheckListItem *)packagesList->firstChild(); 623 QCheckListItem *top = (QCheckListItem *)packagesList->firstChild();
623 QCheckListItem *start = (QCheckListItem *)packagesList->currentItem(); 624 QCheckListItem *start = (QCheckListItem *)packagesList->currentItem();
624 if ( packagesList->firstChild() == 0 ) 625 if ( packagesList->firstChild() == 0 )
625 return; 626 return;
626 627
627 QCheckListItem *item; 628 QCheckListItem *item;
628 if ( start == 0 ) 629 if ( start == 0 )
629 { 630 {
630 item = (QCheckListItem *)packagesList->firstChild(); 631 item = (QCheckListItem *)packagesList->firstChild();
631 start = top; 632 start = top;
632 } 633 }
633 else 634 else
634 item = (QCheckListItem *)start->nextSibling(); 635 item = (QCheckListItem *)start->nextSibling();
635 636
636 if ( item == 0 ) 637 if ( item == 0 )
637 item = (QCheckListItem *)packagesList->firstChild(); 638 item = (QCheckListItem *)packagesList->firstChild();
638 do 639 do
639 { 640 {
640 if ( item->text().lower().startsWith( t.lower() ) ) 641 if ( item->text().lower().startsWith( t.lower() ) )
641 { 642 {
642 packagesList->setSelected( item, true ); 643 packagesList->setSelected( item, true );
643 packagesList->ensureItemVisible( item ); 644 packagesList->ensureItemVisible( item );
644 break; 645 break;
645 } 646 }
646 647
647 item = (QCheckListItem *)item->nextSibling(); 648 item = (QCheckListItem *)item->nextSibling();
648 if ( !item ) 649 if ( !item )
649 item = (QCheckListItem *)packagesList->firstChild(); 650 item = (QCheckListItem *)packagesList->firstChild();
650 } while ( item != start); 651 } while ( item != start);
651} 652}