author | korovkin <korovkin> | 2006-04-30 08:54:54 (UTC) |
---|---|---|
committer | korovkin <korovkin> | 2006-04-30 08:54:54 (UTC) |
commit | 2f32b6d589d389848c5c73ba2e5ad13117c1da9e (patch) (unidiff) | |
tree | ec8a086ad17e3fa9014baa9476ab9cc77c5c29dc | |
parent | b91d3399fbd3178085e9d0fc5faeefbe31c674b7 (diff) | |
download | opie-2f32b6d589d389848c5c73ba2e5ad13117c1da9e.zip opie-2f32b6d589d389848c5c73ba2e5ad13117c1da9e.tar.gz opie-2f32b6d589d389848c5c73ba2e5ad13117c1da9e.tar.bz2 |
Fixed bug with suspend reenabling.
Made some minor formatting.
-rw-r--r-- | noncore/net/opietooth/manager/bluebase.cpp | 39 | ||||
-rw-r--r-- | noncore/net/opietooth/manager/obexftpdialog.cpp | 2 |
2 files changed, 29 insertions, 12 deletions
diff --git a/noncore/net/opietooth/manager/bluebase.cpp b/noncore/net/opietooth/manager/bluebase.cpp index 58f97fa..85385d8 100644 --- a/noncore/net/opietooth/manager/bluebase.cpp +++ b/noncore/net/opietooth/manager/bluebase.cpp | |||
@@ -441,361 +441,378 @@ void BlueBase::addServicesToDevices() | |||
441 | 441 | ||
442 | /** | 442 | /** |
443 | * Search and display avail. services for a device (on expand from device listing) | 443 | * Search and display avail. services for a device (on expand from device listing) |
444 | * @param item the service item returned | 444 | * @param item the service item returned |
445 | */ | 445 | */ |
446 | void BlueBase::addServicesToDevice( BTDeviceItem * item ) | 446 | void BlueBase::addServicesToDevice( BTDeviceItem * item ) |
447 | { | 447 | { |
448 | odebug << "BlueBase::addServicesToDevice" << oendl; | 448 | odebug << "BlueBase::addServicesToDevice" << oendl; |
449 | // row of mac adress text(3) | 449 | // row of mac adress text(3) |
450 | RemoteDevice device = item->remoteDevice(); | 450 | RemoteDevice device = item->remoteDevice(); |
451 | m_deviceList.insert( item->mac() , item ); | 451 | m_deviceList.insert( item->mac() , item ); |
452 | // and some time later I get a signal foundServices( const QString& device, Services::ValueList ); back | 452 | // and some time later I get a signal foundServices( const QString& device, Services::ValueList ); back |
453 | m_localDevice->searchServices( device ); | 453 | m_localDevice->searchServices( device ); |
454 | } | 454 | } |
455 | 455 | ||
456 | 456 | ||
457 | /** | 457 | /** |
458 | * @param device the mac address of the remote device | 458 | * @param device the mac address of the remote device |
459 | * @param servicesList the list with the service the device has. | 459 | * @param servicesList the list with the service the device has. |
460 | */ | 460 | */ |
461 | void BlueBase::addServicesToDevice( const QString& device, Services::ValueList servicesList ) | 461 | void BlueBase::addServicesToDevice( const QString& device, Services::ValueList servicesList ) |
462 | { | 462 | { |
463 | odebug << "BlueBase::fill services list" << oendl; | 463 | odebug << "BlueBase::fill services list" << oendl; |
464 | 464 | ||
465 | QMap<QString,BTDeviceItem*>::Iterator it; | 465 | QMap<QString,BTDeviceItem*>::Iterator it; |
466 | BTDeviceItem* deviceItem = 0; | 466 | BTDeviceItem* deviceItem = 0; |
467 | 467 | ||
468 | // get the right devices which requested the search | 468 | // get the right devices which requested the search |
469 | it = m_deviceList.find( device ); | 469 | it = m_deviceList.find( device ); |
470 | if( it == m_deviceList.end() ) | 470 | if( it == m_deviceList.end() ) |
471 | return; | 471 | return; |
472 | deviceItem = it.data(); | 472 | deviceItem = it.data(); |
473 | 473 | ||
474 | // remove previous entries | 474 | // remove previous entries |
475 | QList<QListViewItem> tempList; | 475 | QList<QListViewItem> tempList; |
476 | tempList.setAutoDelete( true ); | 476 | tempList.setAutoDelete( true ); |
477 | QListViewItem * child = deviceItem->firstChild(); | 477 | QListViewItem * child = deviceItem->firstChild(); |
478 | while( child ) | 478 | while( child ) |
479 | { | 479 | { |
480 | tempList.append( child ); | 480 | tempList.append( child ); |
481 | child = child->nextSibling(); | 481 | child = child->nextSibling(); |
482 | } | 482 | } |
483 | tempList.clear(); | 483 | tempList.clear(); |
484 | 484 | ||
485 | QValueList<OpieTooth::Services>::Iterator it2; | 485 | QValueList<OpieTooth::Services>::Iterator it2; |
486 | BTServiceItem* serviceItem; | 486 | BTServiceItem* serviceItem; |
487 | 487 | ||
488 | 488 | ||
489 | if (!servicesList.isEmpty() ) | 489 | if (!servicesList.isEmpty() ) |
490 | { | 490 | { |
491 | // add services | 491 | // add services |
492 | QMap<int, QString> list; | 492 | QMap<int, QString> list; |
493 | QMap<int, QString>::Iterator classIt; | 493 | QMap<int, QString>::Iterator classIt; |
494 | for( it2 = servicesList.begin(); it2 != servicesList.end(); ++it2 ) | 494 | for( it2 = servicesList.begin(); it2 != servicesList.end(); ++it2 ) |
495 | { | 495 | { |
496 | serviceItem = new BTServiceItem( deviceItem, (*it2) ); | 496 | serviceItem = new BTServiceItem( deviceItem, (*it2) ); |
497 | list = (*it2).classIdList(); | 497 | list = (*it2).classIdList(); |
498 | classIt = list.begin(); | 498 | classIt = list.begin(); |
499 | int classId=0; | 499 | int classId=0; |
500 | if ( classIt != list.end() ) | 500 | if ( classIt != list.end() ) |
501 | { | 501 | { |
502 | classId = classIt.key(); | 502 | classId = classIt.key(); |
503 | } | 503 | } |
504 | 504 | ||
505 | serviceItem->setPixmap( 0, m_iconLoader->serviceIcon( classId ) ); | 505 | serviceItem->setPixmap( 0, m_iconLoader->serviceIcon( classId ) ); |
506 | } | 506 | } |
507 | } | 507 | } |
508 | else | 508 | else |
509 | { | 509 | { |
510 | Services s1; | 510 | Services s1; |
511 | s1.setServiceName( tr("no services found") ); | 511 | s1.setServiceName( tr("no services found") ); |
512 | serviceItem = new BTServiceItem( deviceItem, s1 ); | 512 | serviceItem = new BTServiceItem( deviceItem, s1 ); |
513 | } | 513 | } |
514 | // now remove them from the list | 514 | // now remove them from the list |
515 | m_deviceList.remove( it ); | 515 | m_deviceList.remove( it ); |
516 | } | 516 | } |
517 | 517 | ||
518 | void BlueBase::addSignalStrength() | 518 | void BlueBase::addSignalStrength() |
519 | { | 519 | { |
520 | 520 | ||
521 | QListViewItemIterator it( connectionsView ); | 521 | QListViewItemIterator it( connectionsView ); |
522 | for ( ; it.current(); ++it ) | 522 | for ( ; it.current(); ++it ) |
523 | { | 523 | { |
524 | m_localDevice->signalStrength( ((BTConnectionItem*)it.current() )->connection().mac() ); | 524 | m_localDevice->signalStrength( ((BTConnectionItem*)it.current() )->connection().mac() ); |
525 | } | 525 | } |
526 | 526 | ||
527 | QTimer::singleShot( 5000, this, SLOT( addSignalStrength() ) ); | 527 | QTimer::singleShot( 5000, this, SLOT( addSignalStrength() ) ); |
528 | } | 528 | } |
529 | 529 | ||
530 | void BlueBase::addSignalStrength( const QString& mac, const QString& strength ) | 530 | void BlueBase::addSignalStrength( const QString& mac, const QString& strength ) |
531 | { | 531 | { |
532 | 532 | ||
533 | QListViewItemIterator it( connectionsView ); | 533 | QListViewItemIterator it( connectionsView ); |
534 | for ( ; it.current(); ++it ) | 534 | for ( ; it.current(); ++it ) |
535 | { | 535 | { |
536 | if( ((BTConnectionItem*)it.current())->connection().mac() == mac ) | 536 | if( ((BTConnectionItem*)it.current())->connection().mac() == mac ) |
537 | { | 537 | { |
538 | ((BTConnectionItem*)it.current() )->setSignalStrength( strength ); | 538 | ((BTConnectionItem*)it.current() )->setSignalStrength( strength ); |
539 | } | 539 | } |
540 | } | 540 | } |
541 | } | 541 | } |
542 | 542 | ||
543 | /** | 543 | /** |
544 | * Add the existing connections (pairs) to the connections tab. | 544 | * Add the existing connections (pairs) to the connections tab. |
545 | * This one triggers the search | 545 | * This one triggers the search |
546 | */ | 546 | */ |
547 | void BlueBase::addConnectedDevices() | 547 | void BlueBase::addConnectedDevices() |
548 | { | 548 | { |
549 | m_localDevice->searchConnections(); | 549 | m_localDevice->searchConnections(); |
550 | QTimer::singleShot( 5000, this, SLOT( addSignalStrength() ) ); | 550 | QTimer::singleShot( 5000, this, SLOT( addSignalStrength() ) ); |
551 | } | 551 | } |
552 | 552 | ||
553 | /** | 553 | /** |
554 | * This adds the found connections to the connection tab. | 554 | * This adds the found connections to the connection tab. |
555 | * @param connectionList the ValueList with all current connections | 555 | * @param connectionList the ValueList with all current connections |
556 | */ | 556 | */ |
557 | void BlueBase::addConnectedDevices( ConnectionState::ValueList connectionList ) | 557 | void BlueBase::addConnectedDevices( ConnectionState::ValueList connectionList ) |
558 | { | 558 | { |
559 | 559 | ||
560 | QValueList<OpieTooth::ConnectionState>::Iterator it; | 560 | QValueList<OpieTooth::ConnectionState>::Iterator it; |
561 | BTConnectionItem * connectionItem; | 561 | BTConnectionItem * connectionItem; |
562 | 562 | ||
563 | if ( !connectionList.isEmpty() ) | 563 | if ( !connectionList.isEmpty() ) |
564 | { | 564 | { |
565 | 565 | ||
566 | for (it = connectionList.begin(); it != connectionList.end(); ++it) | 566 | for (it = connectionList.begin(); it != connectionList.end(); ++it) |
567 | { | 567 | { |
568 | 568 | ||
569 | QListViewItemIterator it2( connectionsView ); | 569 | QListViewItemIterator it2( connectionsView ); |
570 | bool found = false; | 570 | bool found = false; |
571 | for ( ; it2.current(); ++it2 ) | 571 | for ( ; it2.current(); ++it2 ) |
572 | { | 572 | { |
573 | if( ( (BTConnectionItem*)it2.current())->connection().mac() == (*it).mac() ) | 573 | if( ( (BTConnectionItem*)it2.current())->connection().mac() == (*it).mac() ) |
574 | { | 574 | { |
575 | found = true; | 575 | found = true; |
576 | } | 576 | } |
577 | } | 577 | } |
578 | 578 | ||
579 | if ( found == false ) | 579 | if ( found == false ) |
580 | { | 580 | { |
581 | connectionItem = new BTConnectionItem( connectionsView, (*it) ); | 581 | connectionItem = new BTConnectionItem( connectionsView, (*it) ); |
582 | 582 | ||
583 | if( m_deviceList.find((*it).mac()).data() ) | 583 | if( m_deviceList.find((*it).mac()).data() ) |
584 | { | 584 | { |
585 | connectionItem->setName( m_deviceList.find( (*it).mac()).data()->name() ); | 585 | connectionItem->setName( m_deviceList.find( (*it).mac()).data()->name() ); |
586 | } | 586 | } |
587 | } | 587 | } |
588 | 588 | ||
589 | } | 589 | } |
590 | 590 | ||
591 | QListViewItemIterator it2( connectionsView ); | 591 | QListViewItemIterator it2( connectionsView ); |
592 | for ( ; it2.current(); ++it2 ) | 592 | for ( ; it2.current(); ++it2 ) |
593 | { | 593 | { |
594 | bool found = false; | 594 | bool found = false; |
595 | for (it = connectionList.begin(); it != connectionList.end(); ++it) | 595 | for (it = connectionList.begin(); it != connectionList.end(); ++it) |
596 | { | 596 | { |
597 | if( ( ((BTConnectionItem*)it2.current())->connection().mac() ) == (*it).mac() ) | 597 | if( ( ((BTConnectionItem*)it2.current())->connection().mac() ) == (*it).mac() ) |
598 | { | 598 | { |
599 | found = true; | 599 | found = true; |
600 | } | 600 | } |
601 | } | 601 | } |
602 | 602 | ||
603 | if ( !found ) | 603 | if ( !found ) |
604 | { | 604 | { |
605 | delete it2.current(); | 605 | delete it2.current(); |
606 | } | 606 | } |
607 | 607 | ||
608 | } | 608 | } |
609 | 609 | ||
610 | 610 | ||
611 | } | 611 | } |
612 | else | 612 | else |
613 | { | 613 | { |
614 | connectionsView->clear(); | 614 | connectionsView->clear(); |
615 | ConnectionState con; | 615 | ConnectionState con; |
616 | con.setMac( tr("No connections found") ); | 616 | con.setMac( tr("No connections found") ); |
617 | connectionItem = new BTConnectionItem( connectionsView , con ); | 617 | connectionItem = new BTConnectionItem( connectionsView , con ); |
618 | } | 618 | } |
619 | 619 | ||
620 | // recall connection search after some time | 620 | // recall connection search after some time |
621 | QTimer::singleShot( 15000, this, SLOT( addConnectedDevices() ) ); | 621 | QTimer::singleShot( 15000, this, SLOT( addConnectedDevices() ) ); |
622 | } | 622 | } |
623 | 623 | ||
624 | 624 | ||
625 | /** | 625 | /** |
626 | * Find out if a device can currently be reached | 626 | * Find out if a device can currently be reached |
627 | * @param device | 627 | * @param device |
628 | */ | 628 | */ |
629 | void BlueBase::deviceActive( const RemoteDevice &device ) | 629 | void BlueBase::deviceActive( const RemoteDevice &device ) |
630 | { | 630 | { |
631 | // search by mac, async, gets a signal back | 631 | // search by mac, async, gets a signal back |
632 | // We should have a BTDeviceItem there or where does it get added to the map -zecke | 632 | // We should have a BTDeviceItem there or where does it get added to the map -zecke |
633 | m_localDevice->isAvailable( device.mac() ); | 633 | m_localDevice->isAvailable( device.mac() ); |
634 | } | 634 | } |
635 | 635 | ||
636 | 636 | ||
637 | /** | 637 | /** |
638 | * The signal catcher. Set the avail. status on device. | 638 | * The signal catcher. Set the avail. status on device. |
639 | * @param device - the mac address | 639 | * @param device - the mac address |
640 | * @param connected - if it is avail. or not | 640 | * @param connected - if it is avail. or not |
641 | */ | 641 | */ |
642 | void BlueBase::deviceActive( const QString& device, bool connected ) | 642 | void BlueBase::deviceActive( const QString& device, bool connected ) |
643 | { | 643 | { |
644 | odebug << "deviceActive slot" << oendl; | 644 | odebug << "deviceActive slot" << oendl; |
645 | 645 | ||
646 | QMap<QString,BTDeviceItem*>::Iterator it; | 646 | QMap<QString,BTDeviceItem*>::Iterator it; |
647 | 647 | ||
648 | it = m_deviceList.find( device ); | 648 | it = m_deviceList.find( device ); |
649 | if( it == m_deviceList.end() ) | 649 | if( it == m_deviceList.end() ) |
650 | return; | 650 | return; |
651 | 651 | ||
652 | BTDeviceItem* deviceItem = it.data(); | 652 | BTDeviceItem* deviceItem = it.data(); |
653 | 653 | ||
654 | if ( connected ) | 654 | if ( connected ) |
655 | { | 655 | { |
656 | deviceItem->setPixmap( 1, m_onPix ); | 656 | deviceItem->setPixmap( 1, m_onPix ); |
657 | } | 657 | } |
658 | else | 658 | else |
659 | { | 659 | { |
660 | deviceItem->setPixmap( 1, m_offPix ); | 660 | deviceItem->setPixmap( 1, m_offPix ); |
661 | } | 661 | } |
662 | m_deviceList.remove( it ); | 662 | m_deviceList.remove( it ); |
663 | } | 663 | } |
664 | 664 | ||
665 | 665 | ||
666 | /** | 666 | /** |
667 | * Open the "scan for devices" dialog | 667 | * Open the "scan for devices" dialog |
668 | */ | 668 | */ |
669 | void BlueBase::startScan() | 669 | void BlueBase::startScan() |
670 | { | 670 | { |
671 | ScanDialog *scan = new ScanDialog( this, "ScanDialog", | 671 | ScanDialog *scan = new ScanDialog( this, "ScanDialog", |
672 | true, WDestructiveClose ); | 672 | true, WDestructiveClose ); |
673 | QObject::connect( scan, SIGNAL( selectedDevices(const QValueList<RemoteDevice>&) ), | 673 | QObject::connect( scan, SIGNAL( selectedDevices(const QValueList<RemoteDevice>&) ), |
674 | this, SLOT( addSearchedDevices(const QValueList<RemoteDevice>&) ) ); | 674 | this, SLOT( addSearchedDevices(const QValueList<RemoteDevice>&) ) ); |
675 | 675 | ||
676 | QPEApplication::showDialog( scan ); | 676 | QPEApplication::showDialog( scan ); |
677 | } | 677 | } |
678 | 678 | ||
679 | 679 | ||
680 | /** | 680 | /** |
681 | * Set the informations about the local device in information Tab | 681 | * Set the informations about the local device in information Tab |
682 | */ | 682 | */ |
683 | void BlueBase::setInfo() | 683 | void BlueBase::setInfo() |
684 | { | 684 | { |
685 | StatusLabel->setText( status() ); | 685 | StatusLabel->setText( status() ); |
686 | } | 686 | } |
687 | 687 | ||
688 | 688 | ||
689 | /** | 689 | /** |
690 | * Decontructor | 690 | * Decontructor |
691 | */ | 691 | */ |
692 | BlueBase::~BlueBase() | 692 | BlueBase::~BlueBase() |
693 | { | 693 | { |
694 | writeSavedDevices(); | 694 | writeSavedDevices(); |
695 | if (forwarder) { | 695 | if (forwarder) { |
696 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) | 696 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) |
697 | QCopEnvelope("QPE/System", "setScreenSaverMode(int)" ) | 697 | { |
698 | << QPEApplication::Enable; | 698 | odebug << "SUSP: Enable suspend mode" << oendl; |
699 | QCopEnvelope e("QPE/System", "setScreenSaverMode(int)" ); | ||
700 | e << QPEApplication::Enable; | ||
701 | } | ||
699 | #endif | 702 | #endif |
700 | delete forwarder; | 703 | delete forwarder; |
701 | forwarder = NULL; | 704 | forwarder = NULL; |
702 | } | 705 | } |
703 | delete m_iconLoader; | 706 | delete m_iconLoader; |
704 | } | 707 | } |
705 | 708 | ||
706 | 709 | ||
707 | /** | 710 | /** |
708 | * find searches the ListView for a BTDeviceItem containig | 711 | * find searches the ListView for a BTDeviceItem containig |
709 | * the same Device if found return true else false | 712 | * the same Device if found return true else false |
710 | * @param dev RemoteDevice to find | 713 | * @param dev RemoteDevice to find |
711 | * @return returns true if found | 714 | * @return returns true if found |
712 | */ | 715 | */ |
713 | bool BlueBase::find( const RemoteDevice& rem ) | 716 | bool BlueBase::find( const RemoteDevice& rem ) |
714 | { | 717 | { |
715 | QListViewItemIterator it( devicesView ); | 718 | QListViewItemIterator it( devicesView ); |
716 | BTListItem* item; | 719 | BTListItem* item; |
717 | BTDeviceItem* device; | 720 | BTDeviceItem* device; |
718 | for (; it.current(); ++it ) | 721 | for (; it.current(); ++it ) |
719 | { | 722 | { |
720 | item = (BTListItem*) it.current(); | 723 | item = (BTListItem*) it.current(); |
721 | if ( item->typeId() != BTListItem::Device ) | 724 | if ( item->typeId() != BTListItem::Device ) |
722 | continue; | 725 | continue; |
723 | 726 | ||
724 | device = (BTDeviceItem*)item; | 727 | device = (BTDeviceItem*)item; |
725 | if ( rem.equals( device->remoteDevice() ) ) | 728 | if ( rem.equals( device->remoteDevice() ) ) |
726 | return true; | 729 | return true; |
727 | } | 730 | } |
728 | return false; // not found | 731 | return false; // not found |
729 | } | 732 | } |
730 | 733 | ||
731 | /** | 734 | /** |
732 | * Start process of the cell phone forwarding | 735 | * Start process of the cell phone forwarding |
733 | */ | 736 | */ |
734 | void BlueBase::doForward() | 737 | void BlueBase::doForward() |
735 | { | 738 | { |
736 | if (forwarder && forwarder->isRunning()) { | 739 | if (forwarder && forwarder->isRunning()) { |
737 | runButton->setText("start gateway"); | 740 | runButton->setText("start gateway"); |
738 | forwarder->stop(); | 741 | forwarder->stop(); |
739 | delete forwarder; | 742 | delete forwarder; |
740 | forwarder = NULL; | 743 | forwarder = NULL; |
744 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) | ||
745 | { | ||
746 | odebug << "SUSP: Enable suspend mode" << oendl; | ||
747 | QCopEnvelope e("QPE/System", "setScreenSaverMode(int)" ); | ||
748 | e << QPEApplication::Enable; | ||
749 | } | ||
750 | #endif | ||
741 | return; | 751 | return; |
742 | } | 752 | } |
743 | QString str = serDevName->text(); | 753 | QString str = serDevName->text(); |
744 | forwarder = new SerialForwarder(str, speeds[serSpeed->currentItem()].val); | 754 | forwarder = new SerialForwarder(str, speeds[serSpeed->currentItem()].val); |
745 | connect(forwarder, SIGNAL(processExited(Opie::Core::OProcess*)), | ||
746 | this, SLOT(forwardExited(Opie::Core::OProcess*))); | ||
747 | if (forwarder->start(OProcess::NotifyOnExit) < 0) { | 755 | if (forwarder->start(OProcess::NotifyOnExit) < 0) { |
748 | QMessageBox::critical(this, tr("Forwarder Error"), | 756 | QMessageBox::critical(this, tr("Forwarder Error"), |
749 | tr("Forwarder start error:") + tr(strerror(errno))); | 757 | tr("Forwarder start error:") + tr(strerror(errno))); |
750 | return; | 758 | return; |
751 | } | 759 | } |
760 | connect(forwarder, SIGNAL(processExited(Opie::Core::OProcess*)), | ||
761 | this, SLOT(forwardExited(Opie::Core::OProcess*))); | ||
752 | runButton->setText("stop gateway"); | 762 | runButton->setText("stop gateway"); |
753 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) | 763 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) |
754 | QCopEnvelope("QPE/System", "setScreenSaverMode(int)") | 764 | { |
755 | << QPEApplication::DisableSuspend; | 765 | odebug << "SUSP: Disable suspend mode" << oendl; |
766 | QCopEnvelope e("QPE/System", "setScreenSaverMode(int)"); | ||
767 | e << QPEApplication::DisableSuspend; | ||
768 | } | ||
756 | #endif | 769 | #endif |
757 | } | 770 | } |
758 | 771 | ||
759 | /** | 772 | /** |
760 | * React on the process end | 773 | * React on the process end |
761 | */ | 774 | */ |
762 | void BlueBase::forwardExit(Opie::Core::OProcess* proc) | 775 | void BlueBase::forwardExit(Opie::Core::OProcess* proc) |
763 | { | 776 | { |
777 | odebug << "Process exited" << oendl; | ||
764 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) | 778 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) |
765 | QCopEnvelope("QPE/System", "setScreenSaverMode(int)" ) | 779 | if (forwarder) { |
766 | << QPEApplication::Enable; | 780 | delete forwarder; |
781 | forwarder = NULL; | ||
782 | runButton->setText("start gateway"); | ||
783 | odebug << "SUSP: Enable suspend mode" << oendl; | ||
784 | QCopEnvelope e("QPE/System", "setScreenSaverMode(int)" ); | ||
785 | e << QPEApplication::Enable; | ||
786 | } | ||
767 | #endif | 787 | #endif |
768 | if (proc->exitStatus() != 0) | 788 | if (proc->exitStatus() != 0) |
769 | QMessageBox::critical(this, tr("Forwarder Error"), | 789 | QMessageBox::critical(this, tr("Forwarder Error"), |
770 | tr("Forwarder start error")); | 790 | tr("Forwarder start error")); |
771 | delete proc; | ||
772 | forwarder = NULL; | ||
773 | runButton->setText("start gateway"); | ||
774 | } | 791 | } |
775 | 792 | ||
776 | /** | 793 | /** |
777 | * Encrypt entered passkey | 794 | * Encrypt entered passkey |
778 | * doit - do encryption of the key | 795 | * doit - do encryption of the key |
779 | */ | 796 | */ |
780 | void BlueBase::doEncrypt(bool doit) | 797 | void BlueBase::doEncrypt(bool doit) |
781 | { | 798 | { |
782 | passkeyLine->setEchoMode((doit)? QLineEdit::Password: QLineEdit::Normal); | 799 | passkeyLine->setEchoMode((doit)? QLineEdit::Password: QLineEdit::Normal); |
783 | } | 800 | } |
784 | 801 | ||
785 | /** | 802 | /** |
786 | * Start services edit dialog | 803 | * Start services edit dialog |
787 | */ | 804 | */ |
788 | void BlueBase::editServices() | 805 | void BlueBase::editServices() |
789 | { | 806 | { |
790 | QString conf = "/etc/default/bluetooth"; | 807 | QString conf = "/etc/default/bluetooth"; |
791 | //// Use for debugging purposes | 808 | //// Use for debugging purposes |
792 | //// QString conf = "/mnt/net/opie/bin/bluetooth"; | 809 | //// QString conf = "/mnt/net/opie/bin/bluetooth"; |
793 | ServicesDialog svcEdit(conf, this, "ServicesDialog", true, | 810 | ServicesDialog svcEdit(conf, this, "ServicesDialog", true, |
794 | WStyle_ContextHelp); | 811 | WStyle_ContextHelp); |
795 | 812 | ||
796 | if (QPEApplication::execDialog(&svcEdit) == QDialog::Accepted) | 813 | if (QPEApplication::execDialog(&svcEdit) == QDialog::Accepted) |
797 | { | 814 | { |
798 | } | 815 | } |
799 | } | 816 | } |
800 | 817 | ||
801 | //eof | 818 | //eof |
diff --git a/noncore/net/opietooth/manager/obexftpdialog.cpp b/noncore/net/opietooth/manager/obexftpdialog.cpp index fd2015e..2f04ecf 100644 --- a/noncore/net/opietooth/manager/obexftpdialog.cpp +++ b/noncore/net/opietooth/manager/obexftpdialog.cpp | |||
@@ -25,513 +25,513 @@ | |||
25 | #include <qlistview.h> | 25 | #include <qlistview.h> |
26 | #include <qprogressbar.h> | 26 | #include <qprogressbar.h> |
27 | #include <qlabel.h> | 27 | #include <qlabel.h> |
28 | #include <qlayout.h> | 28 | #include <qlayout.h> |
29 | #include <errno.h> | 29 | #include <errno.h> |
30 | #include <qfile.h> | 30 | #include <qfile.h> |
31 | #include <qtextstream.h> | 31 | #include <qtextstream.h> |
32 | #include <qstringlist.h> | 32 | #include <qstringlist.h> |
33 | #include "obexftpdialog.h" | 33 | #include "obexftpdialog.h" |
34 | #include "filelistitem.h" | 34 | #include "filelistitem.h" |
35 | 35 | ||
36 | #include <qpe/qpeapplication.h> | 36 | #include <qpe/qpeapplication.h> |
37 | #include <qpe/resource.h> | 37 | #include <qpe/resource.h> |
38 | #include <qpe/config.h> | 38 | #include <qpe/config.h> |
39 | #include <opie2/odebug.h> | 39 | #include <opie2/odebug.h> |
40 | #include <opie2/ofileselector.h> | 40 | #include <opie2/ofileselector.h> |
41 | #include <opie2/ofiledialog.h> | 41 | #include <opie2/ofiledialog.h> |
42 | 42 | ||
43 | using namespace Opie::Core; | 43 | using namespace Opie::Core; |
44 | using namespace Opie::Ui; | 44 | using namespace Opie::Ui; |
45 | 45 | ||
46 | using namespace OpieTooth; | 46 | using namespace OpieTooth; |
47 | 47 | ||
48 | #define MAX_PROGRESS 14 //Maximal progress bar | 48 | #define MAX_PROGRESS 14 //Maximal progress bar |
49 | 49 | ||
50 | static void info_cb(int event, const char *msg, int len, void* data); | 50 | static void info_cb(int event, const char *msg, int len, void* data); |
51 | 51 | ||
52 | /* | 52 | /* |
53 | * Public constructor | 53 | * Public constructor |
54 | * device - bluetooth address of the device | 54 | * device - bluetooth address of the device |
55 | * port - port to connect to | 55 | * port - port to connect to |
56 | */ | 56 | */ |
57 | ObexFtpDialog::ObexFtpDialog(const QString& device, int port, | 57 | ObexFtpDialog::ObexFtpDialog(const QString& device, int port, |
58 | QWidget* parent, const char* name, bool modal, WFlags fl) | 58 | QWidget* parent, const char* name, bool modal, WFlags fl) |
59 | : ObexFtpDialogBase(parent, name, modal, fl), m_device(device), | 59 | : ObexFtpDialogBase(parent, name, modal, fl), m_device(device), |
60 | m_port(port), curdir("") | 60 | m_port(port), curdir("") |
61 | { | 61 | { |
62 | client = NULL; | 62 | client = NULL; |
63 | nRetries = 3; | 63 | nRetries = 3; |
64 | transport = OBEX_TRANS_BLUETOOTH; | 64 | transport = OBEX_TRANS_BLUETOOTH; |
65 | use_conn = TRUE; | 65 | use_conn = TRUE; |
66 | use_path = TRUE; | 66 | use_path = TRUE; |
67 | progressStatus = 0; | 67 | progressStatus = 0; |
68 | localCurdir = "/"; | 68 | localCurdir = "/"; |
69 | browseLog->setEdited(FALSE); | 69 | browseLog->setEdited(FALSE); |
70 | fileList->setSorting(1); | 70 | fileList->setSorting(1); |
71 | fileList->clear(); | 71 | fileList->clear(); |
72 | fileProgress->setTotalSteps(MAX_PROGRESS); | 72 | fileProgress->setTotalSteps(MAX_PROGRESS); |
73 | statusBar->clear(); | 73 | statusBar->clear(); |
74 | localLayout = new QVBoxLayout(localFs); | 74 | localLayout = new QVBoxLayout(localFs); |
75 | localLayout->setSpacing( 0 ); | 75 | localLayout->setSpacing( 0 ); |
76 | localLayout->setMargin( 0 ); | 76 | localLayout->setMargin( 0 ); |
77 | destFile = new OFileSelector(localFs, | 77 | destFile = new OFileSelector(localFs, |
78 | OFileSelector::FileSelector, | 78 | OFileSelector::FileSelector, |
79 | OFileSelector::ExtendedAll, localCurdir, ""); | 79 | OFileSelector::ExtendedAll, localCurdir, ""); |
80 | destFile->setCloseVisible(false); | 80 | destFile->setCloseVisible(false); |
81 | destFile->setNewVisible(false); | 81 | destFile->setNewVisible(false); |
82 | localLayout->addWidget(destFile); | 82 | localLayout->addWidget(destFile); |
83 | nReries->setValue(nRetries); | 83 | nReries->setValue(nRetries); |
84 | connect(browseOK, SIGNAL(clicked()), SLOT(slotBrowse())); | 84 | connect(browseOK, SIGNAL(clicked()), SLOT(slotBrowse())); |
85 | connect(fileList, SIGNAL(clicked(QListViewItem*)), | 85 | connect(fileList, SIGNAL(clicked(QListViewItem*)), |
86 | SLOT(slotCd(QListViewItem*))); | 86 | SLOT(slotCd(QListViewItem*))); |
87 | connect(getButton, | 87 | connect(getButton, |
88 | SIGNAL(clicked()), | 88 | SIGNAL(clicked()), |
89 | SLOT(getFile())); | 89 | SLOT(getFile())); |
90 | connect(putButton, | 90 | connect(putButton, |
91 | SIGNAL(clicked()), | 91 | SIGNAL(clicked()), |
92 | SLOT(putFile())); | 92 | SLOT(putFile())); |
93 | connect(delButton, | 93 | connect(delButton, |
94 | SIGNAL(clicked()), | 94 | SIGNAL(clicked()), |
95 | SLOT(delFile())); | 95 | SLOT(delFile())); |
96 | connect(destFile, | 96 | connect(destFile, |
97 | SIGNAL(dirSelected (const QString&)), | 97 | SIGNAL(dirSelected (const QString&)), |
98 | SLOT(updateDir(const QString&))); | 98 | SLOT(updateDir(const QString&))); |
99 | connect(saveButton, | 99 | connect(saveButton, |
100 | SIGNAL(clicked()), | 100 | SIGNAL(clicked()), |
101 | SLOT(slotSaveLog())); | 101 | SLOT(slotSaveLog())); |
102 | connect(browseButton, | 102 | connect(browseButton, |
103 | SIGNAL(clicked()), | 103 | SIGNAL(clicked()), |
104 | SLOT(slotBrowseLog())); | 104 | SLOT(slotBrowseLog())); |
105 | } | 105 | } |
106 | 106 | ||
107 | ObexFtpDialog::~ObexFtpDialog() | 107 | ObexFtpDialog::~ObexFtpDialog() |
108 | { | 108 | { |
109 | if (client != NULL) { | 109 | if (client != NULL) { |
110 | obexftp_disconnect(client); | 110 | obexftp_disconnect(client); |
111 | obexftp_close(client); | 111 | obexftp_close(client); |
112 | } | 112 | } |
113 | } | 113 | } |
114 | 114 | ||
115 | /* | 115 | /* |
116 | * Do device browsing | 116 | * Do device browsing |
117 | */ | 117 | */ |
118 | void ObexFtpDialog::slotBrowse() | 118 | void ObexFtpDialog::slotBrowse() |
119 | { | 119 | { |
120 | stat_entry_t* ent; //Directory entry | 120 | stat_entry_t* ent; //Directory entry |
121 | void *dir; //Directory to read | 121 | void *dir; //Directory to read |
122 | const uint8_t* use_uuid; //uuid | 122 | const uint8_t* use_uuid; //uuid |
123 | int len; //uuid length | 123 | int len; //uuid length |
124 | FileListItem* root; //root node | 124 | FileListItem* root; //root node |
125 | int fsize; //file size | 125 | int fsize; //file size |
126 | bool numOk; //true if the string is a number | 126 | bool numOk; //true if the string is a number |
127 | int tmp; //just a temp var | 127 | int tmp; //just a temp var |
128 | 128 | ||
129 | status(tr("Connecting to ") + m_device); | 129 | status(tr("Connecting to ") + m_device); |
130 | odebug << "Browse device " << m_device << oendl; | 130 | odebug << "Browse device " << m_device << oendl; |
131 | browseLog->clear(); | 131 | browseLog->clear(); |
132 | fileList->clear(); | 132 | fileList->clear(); |
133 | progressStatus = 0; | 133 | progressStatus = 0; |
134 | fileProgress->setTotalSteps(MAX_PROGRESS); | 134 | fileProgress->setTotalSteps(MAX_PROGRESS); |
135 | fileProgress->reset(); | 135 | fileProgress->reset(); |
136 | 136 | ||
137 | //Get parameters | 137 | //Get parameters |
138 | tmp = nReries->text().toInt(&numOk); | 138 | tmp = nReries->text().toInt(&numOk); |
139 | if (numOk) | 139 | if (numOk) |
140 | nRetries = tmp; | 140 | nRetries = tmp; |
141 | if (uuidType->currentText() == "FBS") { | 141 | if (uuidType->currentText() == "FBS") { |
142 | use_uuid = UUID_FBS; | 142 | use_uuid = UUID_FBS; |
143 | len = sizeof(UUID_FBS); | 143 | len = sizeof(UUID_FBS); |
144 | } else if (uuidType->currentText() == "S45") { | 144 | } else if (uuidType->currentText() == "S45") { |
145 | use_uuid = UUID_S45; | 145 | use_uuid = UUID_S45; |
146 | len = sizeof(UUID_S45); | 146 | len = sizeof(UUID_S45); |
147 | } else { | 147 | } else { |
148 | use_uuid = UUID_FBS; | 148 | use_uuid = UUID_FBS; |
149 | len = sizeof(UUID_FBS); | 149 | len = sizeof(UUID_FBS); |
150 | } | 150 | } |
151 | 151 | ||
152 | if (!cli_connect_uuid(use_uuid, len)) { | 152 | if (!cli_connect_uuid(use_uuid, len)) { |
153 | log(tr("Connection failed: ") + tr(strerror(errno))); | 153 | log(tr("Connection failed: ") + tr(strerror(errno))); |
154 | errBox("Connection failed"); | 154 | errBox("Connection failed"); |
155 | status("Connection failed"); | 155 | status("Connection failed"); |
156 | return; | 156 | return; |
157 | } | 157 | } |
158 | else { | 158 | else { |
159 | log(QString("Connected to ") + m_device); | 159 | log(QString("Connected to ") + m_device); |
160 | status(QString("Connected to ") + m_device); | 160 | status(QString("Connected to ") + m_device); |
161 | } | 161 | } |
162 | /* List folder */ | 162 | /* List folder */ |
163 | root = new FileListItem(fileList, NULL); | 163 | root = new FileListItem(fileList, NULL); |
164 | dir = obexftp_opendir(client, curdir); | 164 | dir = obexftp_opendir(client, curdir); |
165 | while ((ent = obexftp_readdir(dir)) != NULL) { | 165 | while ((ent = obexftp_readdir(dir)) != NULL) { |
166 | FileListItem* a; //List view item | 166 | FileListItem* a; //List view item |
167 | if (ent->mode != 16877) { | 167 | if (ent->mode != 16877) { |
168 | fsize = ent->size; | 168 | fsize = ent->size; |
169 | } | 169 | } |
170 | else | 170 | else |
171 | fsize = 0; | 171 | fsize = 0; |
172 | log(QString(ent->name) + QString(" ") + | 172 | log(QString(ent->name) + QString(" ") + |
173 | QString::number(ent->mode)); | 173 | QString::number(ent->mode)); |
174 | 174 | ||
175 | a = new FileListItem(fileList, ent, fsize); | 175 | a = new FileListItem(fileList, ent, fsize); |
176 | } | 176 | } |
177 | obexftp_closedir(dir); | 177 | obexftp_closedir(dir); |
178 | } | 178 | } |
179 | 179 | ||
180 | //Error message box | 180 | //Error message box |
181 | int ObexFtpDialog::errBox(QCString msg) | 181 | int ObexFtpDialog::errBox(QCString msg) |
182 | { | 182 | { |
183 | return QMessageBox::critical(this, tr("ObexFTP error"), msg); | 183 | return QMessageBox::critical(this, tr("ObexFTP error"), msg); |
184 | } | 184 | } |
185 | 185 | ||
186 | int ObexFtpDialog::errBox(QString msg) | 186 | int ObexFtpDialog::errBox(QString msg) |
187 | { | 187 | { |
188 | return QMessageBox::critical(this, tr("ObexFTP error"), msg); | 188 | return QMessageBox::critical(this, tr("ObexFTP error"), msg); |
189 | } | 189 | } |
190 | 190 | ||
191 | int ObexFtpDialog::errBox(const char* msg) | 191 | int ObexFtpDialog::errBox(const char* msg) |
192 | { | 192 | { |
193 | return QMessageBox::critical(this, tr("ObexFTP error"), tr(msg)); | 193 | return QMessageBox::critical(this, tr("ObexFTP error"), tr(msg)); |
194 | } | 194 | } |
195 | 195 | ||
196 | //Text in the status bar | 196 | //Text in the status bar |
197 | void ObexFtpDialog::status(QCString msg) | 197 | void ObexFtpDialog::status(QCString msg) |
198 | { | 198 | { |
199 | statusBar->setText(msg); | 199 | statusBar->setText(msg); |
200 | statusBar->repaint(); | 200 | statusBar->repaint(); |
201 | } | 201 | } |
202 | 202 | ||
203 | void ObexFtpDialog::status(QString msg) | 203 | void ObexFtpDialog::status(QString msg) |
204 | { | 204 | { |
205 | statusBar->setText(msg); | 205 | statusBar->setText(msg); |
206 | statusBar->repaint(); | 206 | statusBar->repaint(); |
207 | } | 207 | } |
208 | 208 | ||
209 | void ObexFtpDialog::status(const char* msg) | 209 | void ObexFtpDialog::status(const char* msg) |
210 | { | 210 | { |
211 | statusBar->setText(msg); | 211 | statusBar->setText(msg); |
212 | statusBar->repaint(); | 212 | statusBar->repaint(); |
213 | } | 213 | } |
214 | 214 | ||
215 | /* | 215 | /* |
216 | * Change directory with item under the cursor | 216 | * Change directory with item under the cursor |
217 | */ | 217 | */ |
218 | void ObexFtpDialog::slotCd(QListViewItem* item) | 218 | void ObexFtpDialog::slotCd(QListViewItem* item) |
219 | { | 219 | { |
220 | FileListItem* file = (FileListItem*)item; | 220 | FileListItem* file = (FileListItem*)item; |
221 | int idx; | 221 | int idx; |
222 | if (file == NULL) | 222 | if (file == NULL) |
223 | return; | 223 | return; |
224 | odebug << "Item " << file->text(0) << " clicked" << oendl; | 224 | odebug << "Item " << file->text(0) << " clicked" << oendl; |
225 | if (file->gettype() == IS_DIR) { | 225 | if (file->gettype() == IS_DIR) { |
226 | if (file->text(0) == "../") { | 226 | if (file->text(0) == "../") { |
227 | if (curdir.right(1) == "/") | 227 | if (curdir.right(1) == "/") |
228 | curdir.remove(curdir.length() - 1, 1); | 228 | curdir.remove(curdir.length() - 1, 1); |
229 | idx = curdir.findRev('/'); | 229 | idx = curdir.findRev('/'); |
230 | if (idx >= 0) | 230 | if (idx >= 0) |
231 | curdir.remove(idx, curdir.length() - idx); | 231 | curdir.remove(idx, curdir.length() - idx); |
232 | else | 232 | else |
233 | curdir = ""; | 233 | curdir = ""; |
234 | } | 234 | } |
235 | else { | 235 | else { |
236 | if (curdir != "" && curdir.right(1) != "/") | 236 | if (curdir != "" && curdir.right(1) != "/") |
237 | curdir += "/"; | 237 | curdir += "/"; |
238 | curdir += file->text(0); | 238 | curdir += file->text(0); |
239 | } | 239 | } |
240 | odebug << "Browse " << curdir << oendl; | 240 | odebug << "Browse " << curdir << oendl; |
241 | if (obexftp_setpath(client, curdir, 0) < 0) | 241 | if (obexftp_setpath(client, curdir, 0) < 0) |
242 | log(tr("CD failed: ") + tr(strerror(errno))); | 242 | log(tr("CD failed: ") + tr(strerror(errno))); |
243 | slotBrowse(); | 243 | slotBrowse(); |
244 | } | 244 | } |
245 | } | 245 | } |
246 | 246 | ||
247 | /* | 247 | /* |
248 | * Copy file from a remote device to the local device | 248 | * Copy file from a remote device to the local device |
249 | */ | 249 | */ |
250 | void ObexFtpDialog::getFile() | 250 | void ObexFtpDialog::getFile() |
251 | { | 251 | { |
252 | FileListItem* file = (FileListItem*)fileList->selectedItem(); | 252 | FileListItem* file = (FileListItem*)fileList->selectedItem(); |
253 | int result; | 253 | int result; |
254 | if (file == NULL) | 254 | if (file == NULL) |
255 | return; | 255 | return; |
256 | file2get = "/"; | 256 | file2get = "/"; |
257 | local = localCurdir; | 257 | local = localCurdir; |
258 | if (local == "") { | 258 | if (local == "") { |
259 | errBox("Select a destination first"); | 259 | errBox("Select a destination first"); |
260 | return; | 260 | return; |
261 | } | 261 | } |
262 | if (local.right(1) != "/") | 262 | if (local.right(1) != "/") |
263 | local += "/"; | 263 | local += "/"; |
264 | if (file->gettype() == IS_FILE) { | 264 | if (file->gettype() == IS_FILE) { |
265 | if (client == NULL) { | 265 | if (client == NULL) { |
266 | errBox("No connection established"); | 266 | errBox("No connection established"); |
267 | return; | 267 | return; |
268 | } | 268 | } |
269 | file2get += curdir; | 269 | file2get += curdir; |
270 | if (curdir != "" && curdir.right(1) != "/") | 270 | if (curdir != "" && curdir.right(1) != "/") |
271 | file2get += "/"; | 271 | file2get += "/"; |
272 | file2get += file->text(0); | 272 | file2get += file->text(0); |
273 | local += file->text(0); | 273 | local += file->text(0); |
274 | odebug << "Copy " << file2get << " to " << local << oendl; | 274 | odebug << "Copy " << file2get << " to " << local << oendl; |
275 | progressStatus = 0; | 275 | progressStatus = 0; |
276 | fileProgress->setTotalSteps(file->getsize() / 1024); | 276 | fileProgress->setTotalSteps(file->getsize() / 1024); |
277 | fileProgress->reset(); | 277 | fileProgress->reset(); |
278 | status(tr("Receiving file ") + file2get); | 278 | status(tr("Receiving file ") + file2get); |
279 | result = obexftp_get(client, local, file2get); | 279 | result = obexftp_get(client, local, file2get); |
280 | if (result < 0) { | 280 | if (result < 0) { |
281 | log(file2get + QString(" receive ERROR:\n") + tr(strerror(errno))); | 281 | log(file2get + QString(" receive ERROR:\n") + tr(strerror(errno))); |
282 | errBox(file2get + QString(" receive ERROR")); | 282 | errBox(file2get + QString(" receive ERROR")); |
283 | status(file2get + QString(" receive ERROR")); | 283 | status(file2get + QString(" receive ERROR")); |
284 | } | 284 | } |
285 | else { | 285 | else { |
286 | log(file2get + QString(" received")); | 286 | log(file2get + QString(" received")); |
287 | status(file2get + QString(" received")); | 287 | status(file2get + QString(" received")); |
288 | destFile->reread(); | 288 | destFile->reread(); |
289 | } | 289 | } |
290 | } | 290 | } |
291 | } | 291 | } |
292 | 292 | ||
293 | /* | 293 | /* |
294 | * Copy file from the local device to a remote device | 294 | * Copy file from the local device to a remote device |
295 | */ | 295 | */ |
296 | void ObexFtpDialog::putFile() | 296 | void ObexFtpDialog::putFile() |
297 | { | 297 | { |
298 | int result; //OPeration result | 298 | int result; //OPeration result |
299 | int idx; //Index of a symbol in the string | 299 | int idx; //Index of a symbol in the string |
300 | struct stat localFStat; //Local file information | 300 | struct stat localFStat; //Local file information |
301 | 301 | ||
302 | if (client == NULL) { | 302 | if (client == NULL) { |
303 | errBox("No connection established"); | 303 | errBox("No connection established"); |
304 | return; | 304 | return; |
305 | } | 305 | } |
306 | local = destFile->selectedName(); | 306 | local = destFile->selectedName(); |
307 | if (local == "") { | 307 | if (local == "") { |
308 | errBox("No file slected"); | 308 | errBox("No file slected"); |
309 | return; | 309 | return; |
310 | } | 310 | } |
311 | result = stat(local, &localFStat); | 311 | result = stat(local, &localFStat); |
312 | if (result < 0) { | 312 | if (result < 0) { |
313 | errBox(tr("Wrong file selected ") + local + tr(" ") + | 313 | errBox(tr("Wrong file selected ") + local + tr(" ") + |
314 | tr(strerror(errno))); | 314 | tr(strerror(errno))); |
315 | return; | 315 | return; |
316 | } | 316 | } |
317 | idx = local.findRev('/'); | 317 | idx = local.findRev('/'); |
318 | if (idx > 0) { | 318 | if (idx > 0) { |
319 | file2get = local.right(local.length() - idx - 1); | 319 | file2get = local.right(local.length() - idx - 1); |
320 | } | 320 | } |
321 | else | 321 | else |
322 | file2get = local; | 322 | file2get = local; |
323 | 323 | ||
324 | odebug << "Copy " << local << " to " << file2get << oendl; | 324 | odebug << "Copy " << local << " to " << file2get << oendl; |
325 | progressStatus = 0; | 325 | progressStatus = 0; |
326 | fileProgress->setTotalSteps(localFStat.st_size / 1024); | 326 | fileProgress->setTotalSteps(localFStat.st_size / 1024); |
327 | fileProgress->reset(); | 327 | fileProgress->reset(); |
328 | status(tr("Sending file ") + local); | 328 | status(tr("Sending file ") + local); |
329 | result = obexftp_put_file(client, local, file2get); | 329 | result = obexftp_put_file(client, local, file2get); |
330 | if (result < 0) { | 330 | if (result < 0) { |
331 | log(local + QString(" send ERROR:\n") + tr(strerror(errno))); | 331 | log(local + QString(" send ERROR:\n") + tr(strerror(errno))); |
332 | errBox(local + QString(" send ERROR")); | 332 | errBox(local + QString(" send ERROR")); |
333 | status(local + QString(" send ERROR")); | 333 | status(local + QString(" send ERROR")); |
334 | } | 334 | } |
335 | else { | 335 | else { |
336 | slotBrowse(); | 336 | slotBrowse(); |
337 | log(local + QString(" sent")); | 337 | log(local + QString(" sent")); |
338 | status(local + QString(" sent")); | 338 | status(local + QString(" sent")); |
339 | } | 339 | } |
340 | } | 340 | } |
341 | 341 | ||
342 | /* | 342 | /* |
343 | * Delete file on a remote device | 343 | * Delete file on a remote device |
344 | */ | 344 | */ |
345 | void ObexFtpDialog::delFile() | 345 | void ObexFtpDialog::delFile() |
346 | { | 346 | { |
347 | FileListItem* file = (FileListItem*)fileList->selectedItem(); | 347 | FileListItem* file = (FileListItem*)fileList->selectedItem(); |
348 | int result; | 348 | int result; |
349 | if (file == NULL) | 349 | if (file == NULL) |
350 | return; | 350 | return; |
351 | file2get = "/"; | 351 | file2get = "/"; |
352 | if (file->gettype() == IS_FILE) { | 352 | if (file->gettype() == IS_FILE) { |
353 | if (client == NULL) { | 353 | if (client == NULL) { |
354 | errBox("No connection established"); | 354 | errBox("No connection established"); |
355 | return; | 355 | return; |
356 | } | 356 | } |
357 | file2get += curdir; | 357 | file2get += curdir; |
358 | if (curdir != "" && curdir.right(1) != "/") | 358 | if (curdir != "" && curdir.right(1) != "/") |
359 | file2get += "/"; | 359 | file2get += "/"; |
360 | file2get += file->text(0); | 360 | file2get += file->text(0); |
361 | } | 361 | } |
362 | result = QMessageBox::warning(this, tr("Remove File"), | 362 | result = QMessageBox::warning(this, tr("Remove File"), |
363 | tr("Do you want to remove\n") + file2get, "Yes", "No"); | 363 | tr("Do you want to remove\n") + file2get, "Yes", "No"); |
364 | if (result != 0) | 364 | if (result != 0) |
365 | return; | 365 | return; |
366 | odebug << "Remove " << file2get << oendl; | 366 | odebug << "Remove " << file2get << oendl; |
367 | result = obexftp_del(client, file2get); | 367 | result = obexftp_del(client, file2get); |
368 | if (result < 0) { | 368 | if (result < 0) { |
369 | log(file2get + QString(" remove ERROR\n") + tr(strerror(errno))); | 369 | log(file2get + QString(" remove ERROR\n") + tr(strerror(errno))); |
370 | errBox(file2get + QString(" remove ERROR")); | 370 | errBox(file2get + QString(" remove ERROR")); |
371 | status(file2get + QString(" remove ERROR")); | 371 | status(file2get + QString(" remove ERROR")); |
372 | } | 372 | } |
373 | else { | 373 | else { |
374 | slotBrowse(); | 374 | slotBrowse(); |
375 | log(file2get + QString(" removed")); | 375 | log(file2get + QString(" removed")); |
376 | status(file2get + QString(" removed")); | 376 | status(file2get + QString(" removed")); |
377 | } | 377 | } |
378 | } | 378 | } |
379 | 379 | ||
380 | /* connect with given uuid. re-connect every time */ | 380 | /* connect with given uuid. re-connect every time */ |
381 | int ObexFtpDialog::cli_connect_uuid(const uint8_t *uuid, int uuid_len) | 381 | int ObexFtpDialog::cli_connect_uuid(const uint8_t *uuid, int uuid_len) |
382 | { | 382 | { |
383 | int retry; | 383 | int retry; |
384 | if (client != NULL) | 384 | if (client != NULL) |
385 | return TRUE; | 385 | return TRUE; |
386 | /* Open */ | 386 | /* Open */ |
387 | client = obexftp_open (transport, NULL, info_cb, this); | 387 | client = obexftp_open (transport, NULL, info_cb, this); |
388 | if(client == NULL) { | 388 | if(client == NULL) { |
389 | errBox("Error opening obexftp-client"); | 389 | errBox("Error opening obexftp-client"); |
390 | return FALSE; | 390 | return FALSE; |
391 | } | 391 | } |
392 | if (!use_conn) | 392 | if (!use_conn) |
393 | client->quirks &= ~OBEXFTP_CONN_HEADER; | 393 | client->quirks &= ~OBEXFTP_CONN_HEADER; |
394 | if (!use_path) | 394 | if (!use_path) |
395 | client->quirks &= ~OBEXFTP_SPLIT_SETPATH; | 395 | client->quirks &= ~OBEXFTP_SPLIT_SETPATH; |
396 | for (retry = 0; retry < nRetries; retry++) { | 396 | for (retry = 0; retry < nRetries; retry++) { |
397 | /* Connect */ | 397 | /* Connect */ |
398 | switch (transport) { | 398 | switch (transport) { |
399 | case OBEX_TRANS_IRDA: | 399 | case OBEX_TRANS_IRDA: |
400 | if (obexftp_connect_uuid(client, NULL, 0, uuid, uuid_len) >= 0) | 400 | if (obexftp_connect_uuid(client, NULL, 0, uuid, uuid_len) >= 0) |
401 | return TRUE; | 401 | return TRUE; |
402 | break; | 402 | break; |
403 | case OBEX_TRANS_BLUETOOTH: | 403 | case OBEX_TRANS_BLUETOOTH: |
404 | if (obexftp_connect_uuid(client, m_device, m_port, | 404 | if (obexftp_connect_uuid(client, m_device, m_port, |
405 | uuid, uuid_len) >= 0) | 405 | uuid, uuid_len) >= 0) |
406 | return TRUE; | 406 | return TRUE; |
407 | break; | 407 | break; |
408 | default: | 408 | default: |
409 | errBox("Transport type unknown"); | 409 | errBox("Transport type unknown"); |
410 | return FALSE; | 410 | return FALSE; |
411 | } | 411 | } |
412 | log(tr("Still trying to connect")); | 412 | log(tr("Still trying to connect")); |
413 | } | 413 | } |
414 | client = NULL; | 414 | client = NULL; |
415 | 415 | ||
416 | return FALSE; | 416 | return FALSE; |
417 | } | 417 | } |
418 | 418 | ||
419 | /* | 419 | /* |
420 | * Put a message to the log window | 420 | * Put a message to the log window |
421 | */ | 421 | */ |
422 | void ObexFtpDialog::log(QString str) | 422 | void ObexFtpDialog::log(QString str) |
423 | { | 423 | { |
424 | browseLog->append(str); | 424 | browseLog->append(str); |
425 | } | 425 | } |
426 | 426 | ||
427 | void ObexFtpDialog::log(QCString str) | 427 | void ObexFtpDialog::log(QCString str) |
428 | { | 428 | { |
429 | browseLog->append(str); | 429 | browseLog->append(str); |
430 | } | 430 | } |
431 | 431 | ||
432 | void ObexFtpDialog::log(QString& str) | 432 | void ObexFtpDialog::log(QString& str) |
433 | { | 433 | { |
434 | browseLog->append(str); | 434 | browseLog->append(str); |
435 | } | 435 | } |
436 | 436 | ||
437 | void ObexFtpDialog::log(const char* str) | 437 | void ObexFtpDialog::log(const char* str) |
438 | { | 438 | { |
439 | browseLog->append(str); | 439 | browseLog->append(str); |
440 | } | 440 | } |
441 | 441 | ||
442 | void ObexFtpDialog::incProgress() | 442 | void ObexFtpDialog::incProgress() |
443 | { | 443 | { |
444 | if (progressStatus < fileProgress->totalSteps()) | 444 | if (progressStatus < fileProgress->totalSteps()) |
445 | fileProgress->setProgress(progressStatus++); | 445 | fileProgress->setProgress(progressStatus++); |
446 | } | 446 | } |
447 | 447 | ||
448 | void ObexFtpDialog::doneProgress() | 448 | void ObexFtpDialog::doneProgress() |
449 | { | 449 | { |
450 | progressStatus = 0; | 450 | progressStatus = 0; |
451 | fileProgress->reset(); | 451 | fileProgress->reset(); |
452 | } | 452 | } |
453 | 453 | ||
454 | void ObexFtpDialog::updateDir(const QString& newdir) | 454 | void ObexFtpDialog::updateDir(const QString& newdir) |
455 | { | 455 | { |
456 | localCurdir = newdir; | 456 | localCurdir = newdir; |
457 | } | 457 | } |
458 | 458 | ||
459 | /** | 459 | /** |
460 | * Save Log to the specified file | 460 | * Save Log to the specified file |
461 | */ | 461 | */ |
462 | void ObexFtpDialog::slotSaveLog() | 462 | void ObexFtpDialog::slotSaveLog() |
463 | { | 463 | { |
464 | QFile logFile(saveLogEdit->text()); | 464 | QFile logFile(saveLogEdit->text()); |
465 | if (!logFile.open(IO_WriteOnly)) { | 465 | if (!logFile.open(IO_WriteOnly)) { |
466 | errBox(tr("Unable to open file ") + saveLogEdit->text() + tr(" ") + | 466 | errBox(tr("Unable to open file ") + saveLogEdit->text() + tr(" ") + |
467 | tr(strerror(errno))); | 467 | tr(strerror(errno))); |
468 | return; | 468 | return; |
469 | } | 469 | } |
470 | QTextStream stream(&logFile); | 470 | QTextStream stream(&logFile); |
471 | stream << browseLog->text() << endl; | 471 | stream << browseLog->text() << endl; |
472 | QMessageBox::information(this, tr("Saving"), | 472 | QMessageBox::information(this, tr("Saving"), |
473 | tr("Log file saved to ") + saveLogEdit->text()); | 473 | tr("Log file saved to ") + saveLogEdit->text()); |
474 | } | 474 | } |
475 | 475 | ||
476 | void ObexFtpDialog::slotBrowseLog() | 476 | void ObexFtpDialog::slotBrowseLog() |
477 | { | 477 | { |
478 | MimeTypes types; | 478 | MimeTypes types; |
479 | QStringList all; | 479 | QStringList all; |
480 | all << "*/*"; | 480 | all << "*/*"; |
481 | types.insert("All Files", all ); | 481 | types.insert("All Files", all ); |
482 | 482 | ||
483 | QString str = OFileDialog::getOpenFileName( 1,"/","", types, 0 ); | 483 | QString str = OFileDialog::getOpenFileName( 1,"/","", types, 0 ); |
484 | saveLogEdit->setText(str); | 484 | saveLogEdit->setText(str); |
485 | } | 485 | } |
486 | 486 | ||
487 | /* | 487 | /* |
488 | * Event callback function | 488 | * Event callback function |
489 | */ | 489 | */ |
490 | static void info_cb(int event, const char *msg, int len, void* data) | 490 | static void info_cb(int event, const char *msg, int len, void* data) |
491 | { | 491 | { |
492 | ObexFtpDialog* dlg = (ObexFtpDialog*)data; | 492 | ObexFtpDialog* dlg = (ObexFtpDialog*)data; |
493 | QCString cmsg(msg, len); //Message to display | 493 | QCString cmsg(msg, len); //Message to display |
494 | 494 | ||
495 | switch (event) { | 495 | switch (event) { |
496 | 496 | ||
497 | case OBEXFTP_EV_ERRMSG: | 497 | case OBEXFTP_EV_ERRMSG: |
498 | dlg->log(QCString("Error: ") + cmsg); | 498 | dlg->log(QCString("Error: ") + cmsg); |
499 | break; | 499 | break; |
500 | 500 | ||
501 | case OBEXFTP_EV_ERR: | 501 | case OBEXFTP_EV_ERR: |
502 | dlg->log(QCString("failed: ") + cmsg); | 502 | dlg->log(QCString("failed: ") + cmsg); |
503 | dlg->doneProgress(); | 503 | dlg->doneProgress(); |
504 | break; | 504 | break; |
505 | case OBEXFTP_EV_OK: | 505 | case OBEXFTP_EV_OK: |
506 | dlg->log(QCString("done")); | 506 | dlg->log(QCString("done")); |
507 | dlg->doneProgress(); | 507 | dlg->doneProgress(); |
508 | break; | 508 | break; |
509 | 509 | ||
510 | case OBEXFTP_EV_CONNECTING: | 510 | case OBEXFTP_EV_CONNECTING: |
511 | dlg->log(QCString("Connecting...")); | 511 | dlg->log(QCString("Connecting...")); |
512 | break; | 512 | break; |
513 | case OBEXFTP_EV_DISCONNECTING: | 513 | case OBEXFTP_EV_DISCONNECTING: |
514 | dlg->log(QCString("Disconnecting...")); | 514 | dlg->log(QCString("Disconnecting...")); |
515 | break; | 515 | break; |
516 | case OBEXFTP_EV_SENDING: | 516 | case OBEXFTP_EV_SENDING: |
517 | dlg->log(QCString("Sending ") + msg); | 517 | dlg->log(QCString("Sending ") + msg); |
518 | break; | 518 | break; |
519 | case OBEXFTP_EV_RECEIVING: | 519 | case OBEXFTP_EV_RECEIVING: |
520 | dlg->log(QCString("Receiving ") + msg); | 520 | dlg->log(QCString("Receiving ") + msg); |
521 | break; | 521 | break; |
522 | 522 | ||
523 | case OBEXFTP_EV_LISTENING: | 523 | case OBEXFTP_EV_LISTENING: |
524 | dlg->log(QCString("Waiting for incoming connection")); | 524 | dlg->log(QCString("Waiting for incoming connection")); |
525 | break; | 525 | break; |
526 | 526 | ||
527 | case OBEXFTP_EV_CONNECTIND: | 527 | case OBEXFTP_EV_CONNECTIND: |
528 | dlg->log(QCString("Incoming connection")); | 528 | dlg->log(QCString("Incoming connection")); |
529 | break; | 529 | break; |
530 | case OBEXFTP_EV_DISCONNECTIND: | 530 | case OBEXFTP_EV_DISCONNECTIND: |
531 | dlg->log(QCString("Disconnecting")); | 531 | dlg->log(QCString("Disconnecting")); |
532 | break; | 532 | break; |
533 | 533 | ||
534 | case OBEXFTP_EV_INFO: | 534 | case OBEXFTP_EV_INFO: |
535 | // 64 bit problems ? | 535 | // 64 bit problems ? |
536 | dlg->log(QString("Got info ") + QString::number((int)msg)); | 536 | dlg->log(QString("Got info ") + QString::number((int)msg)); |
537 | break; | 537 | break; |