author | korovkin <korovkin> | 2006-05-09 12:38:24 (UTC) |
---|---|---|
committer | korovkin <korovkin> | 2006-05-09 12:38:24 (UTC) |
commit | 620d55ae3b94fa8d2fa696b6626893e4520c3a02 (patch) (side-by-side diff) | |
tree | ca1296808dfac6fa6c74086f4dda6af525d7b151 | |
parent | dc719be35432469c24dd8d10136c1ea25c6861d2 (diff) | |
download | opie-620d55ae3b94fa8d2fa696b6626893e4520c3a02.zip opie-620d55ae3b94fa8d2fa696b6626893e4520c3a02.tar.gz opie-620d55ae3b94fa8d2fa696b6626893e4520c3a02.tar.bz2 |
Instead of calling a process, do ::system on stop and use QCopEnvelope on start.
-rw-r--r-- | noncore/net/opietooth/applet/bluezapplet.cpp | 56 | ||||
-rw-r--r-- | noncore/net/opietooth/applet/bluezapplet.h | 2 |
2 files changed, 16 insertions, 42 deletions
diff --git a/noncore/net/opietooth/applet/bluezapplet.cpp b/noncore/net/opietooth/applet/bluezapplet.cpp index 9c6c71d..90b0c6d 100644 --- a/noncore/net/opietooth/applet/bluezapplet.cpp +++ b/noncore/net/opietooth/applet/bluezapplet.cpp @@ -54,9 +54,9 @@ using namespace Opie::Core; /* STD */ #include <device.h> -// #define OPIE120 // undefine it fo the latest OPIE +#define OPIE120 // undefine it fo the latest OPIE namespace OpieTooth { BluezApplet::BluezApplet( QWidget *parent, const char *name ) : QWidget( parent, name ) { setFixedHeight( AppLnk::smallIconSize() ); @@ -82,18 +82,9 @@ namespace OpieTooth { // TODO: determine whether this channel has to be closed at destruction time. QCopChannel* chan = new QCopChannel("QPE/Bluetooth", this ); connect(chan, SIGNAL(received(const QCString&,const QByteArray&) ), this, SLOT(slotMessage(const QCString&,const QByteArray&) ) ); - - OProcess* btstart = new OProcess(); - *btstart << "/etc/init.d/bluetooth" << "stop"; - btstart->setUseShell(true); - if (!btstart->start(OProcess::DontCare, OProcess::AllOutput)) - delete btstart; - else { - connect(btstart, SIGNAL(processExited(Opie::Core::OProcess*)), - this, SLOT(slotProcessExited(Opie::Core::OProcess*))); - } + ::system("/etc/init.d/bluetooth stop >/dev/null 2>/dev/null"); } BluezApplet::~BluezApplet() { if ( btDevice ) { @@ -103,29 +94,31 @@ namespace OpieTooth { delete btManager; } } -int BluezApplet::position() -{ + int BluezApplet::position() + { return 6; -} + } bool BluezApplet::checkBluezStatus() { if (btDevice) { if (btDevice->isLoaded() ) { + odebug << "btDevice isLoaded" << oendl; return true; } else { + odebug << "btDevice is NOT loaded" << oendl; return false; } } else { + odebug << "btDevice is ZERO" << oendl; return false; } } int BluezApplet::setBluezStatus(int c) { - OProcess* btstart = new OProcess(); if ( c == 1 ) { switch ( ODevice::inst()->model() ) { case Model_iPAQ_H39xx: btDevice = new Device( "/dev/tts/1", "bcsp", "921600" ); @@ -144,24 +137,15 @@ int BluezApplet::position() default: btDevice = new Device( "/dev/ttySB0", "bcsp", "230400" ); break; } - *btstart << "/etc/init.d/bluetooth" << "start"; - btstart->setUseShell(true); - if (!btstart->start(OProcess::DontCare, OProcess::AllOutput)) - delete btstart; - else { - connect(btstart, SIGNAL(processExited(Opie::Core::OProcess*)), - this, SLOT(slotProcessExited(Opie::Core::OProcess*))); - } + QCopEnvelope e("QPE/System", "execute(QString)"); + e << QString("/etc/init.d/bluetooth start"); } else { - *btstart << "/etc/init.d/bluetooth" << "stop"; - btstart->setUseShell(true); - if (!btstart->start(OProcess::DontCare, OProcess::AllOutput)) - delete btstart; - else { - connect(btstart, SIGNAL(processExited(Opie::Core::OProcess*)), - this, SLOT(slotProcessExited(Opie::Core::OProcess*))); + ::system("/etc/init.d/bluetooth stop >/dev/null 2>/dev/null"); + if ( btManager ) { + delete btManager; + btManager = 0; } if ( btDevice ) { delete btDevice; btDevice = 0; @@ -196,9 +180,9 @@ int BluezApplet::position() */ if (checkBluezStatus() && !m_wasOn) setBluezStatus(0); doListDevice = false; - } + } else if ( str == "listDevices()") { if (checkBluezStatus()) { doListDevice = false; timerEvent(0); @@ -261,8 +245,9 @@ int BluezApplet::position() QPoint p = mapToGlobal( QPoint(1, -menu->sizeHint().height()-1) ); ret = menu->exec(p, 0); + menu->hide(); switch(ret) { case 0: setBluezStatus(0); @@ -347,17 +332,8 @@ int BluezApplet::position() if (bluezDiscoveryActive) { p.drawPixmap( 0, 0, bluezDiscoveryOnPixmap ); } } - -/** - * Implementation of the process finish - * @param the finished process - */ - void BluezApplet::slotProcessExited(OProcess* proc) - { - delete proc; - } }; EXPORT_OPIE_APPLET_v1( OpieTooth::BluezApplet ) diff --git a/noncore/net/opietooth/applet/bluezapplet.h b/noncore/net/opietooth/applet/bluezapplet.h index 85022bb..90bee3b 100644 --- a/noncore/net/opietooth/applet/bluezapplet.h +++ b/noncore/net/opietooth/applet/bluezapplet.h @@ -72,10 +72,8 @@ public slots: bool m_wasOn; //If BT was started by menu? private slots: void slotMessage( const QCString& , const QByteArray& ); - void slotProcessExited(Opie::Core::OProcess* proc); - }; }; |