author | harlekin <harlekin> | 2002-06-14 10:17:34 (UTC) |
---|---|---|
committer | harlekin <harlekin> | 2002-06-14 10:17:34 (UTC) |
commit | cf54bc85d0e9846d64ca2a2af55fffc3d4e2f4ad (patch) (side-by-side diff) | |
tree | 42616657f00051e0a13e06f6d9fa07c5ba838bea | |
parent | 1e09f5f7c691bff0d546dead1807a92c1a0b0303 (diff) | |
download | opie-cf54bc85d0e9846d64ca2a2af55fffc3d4e2f4ad.zip opie-cf54bc85d0e9846d64ca2a2af55fffc3d4e2f4ad.tar.gz opie-cf54bc85d0e9846d64ca2a2af55fffc3d4e2f4ad.tar.bz2 |
show discovered device
-rw-r--r-- | core/applets/irdaapplet/irda.cpp | 44 | ||||
-rw-r--r-- | core/applets/irdaapplet/irda.h | 2 |
2 files changed, 42 insertions, 4 deletions
diff --git a/core/applets/irdaapplet/irda.cpp b/core/applets/irdaapplet/irda.cpp index 28a79d1..e21f191 100644 --- a/core/applets/irdaapplet/irda.cpp +++ b/core/applets/irdaapplet/irda.cpp @@ -21,48 +21,49 @@ #include <qpe/resource.h> #include <qpe/qpeapplication.h> #include <qpe/timestring.h> #include <qpe/resource.h> #include <qpe/config.h> #include <qpe/applnk.h> #include <qpe/config.h> #include <qpe/ir.h> #include <qpe/qcopenvelope_qws.h> #include <qdir.h> #include <qfileinfo.h> #include <qpoint.h> #include <qpushbutton.h> #include <qpainter.h> #include <qcombobox.h> #include <qspinbox.h> #include <qslider.h> #include <qlayout.h> #include <qframe.h> #include <qpixmap.h> #include <qstring.h> #include <qfile.h> #include <qtimer.h> +#include <qtextstream.h> #include <qpopupmenu.h> #include <net/if.h> #include <netinet/in.h> #include <sys/types.h> #include <sys/socket.h> #include <sys/ioctl.h> //=========================================================================== IrdaApplet::IrdaApplet( QWidget *parent, const char *name ) : QWidget( parent, name ) { setFixedHeight( 18 ); setFixedWidth( 14 ); sockfd = socket(PF_INET, SOCK_DGRAM, IPPROTO_IP); irdaOnPixmap = Resource::loadPixmap( "irdaapplet/irdaon" ); irdaOffPixmap = Resource::loadPixmap( "irdaapplet/irdaoff" ); irdaDiscoveryOnPixmap = Resource::loadPixmap( "irdaapplet/magglass" ); receiveActivePixmap = Resource::loadPixmap("irdaapplet/receive"); receiveActive = false; startTimer(5000); timerEvent(NULL); } @@ -107,66 +108,101 @@ int IrdaApplet::checkIrdaDiscoveryStatus() { discovery.open( IO_ReadOnly|IO_Raw ); discovery.readBlock (&status, 1); discovery.close(); return atoi(&status); } int IrdaApplet::setIrdaDiscoveryStatus(int d) { QFile discovery("/proc/sys/net/irda/discovery"); discovery.open( IO_WriteOnly|IO_Raw ); if (d) discovery.putch('1'); else discovery.putch('0'); discovery.close(); return 0; } +void IrdaApplet::showDiscovered() { + QFile discovery("/proc/net/irda/discovery"); + + if (discovery.open(IO_ReadOnly) ) { + QStringList list; + // since it is /proc we _must_ use QTextStream + QTextStream stream ( &discovery); + QString streamIn; + streamIn = stream.read(); + list = QStringList::split("\n", streamIn); + + for(QStringList::Iterator line=list.begin(); line!=list.end(); line++) { + if( (*line).startsWith("nickname:") ){ + discoveredDevice = (*line).mid(((*line).find(':'))+1,(*line).find(',')-(*line).find(':')-1); + qDebug(discoveredDevice); + } + } + } + +} + void IrdaApplet::mousePressEvent( QMouseEvent *) { QPopupMenu *menu = new QPopupMenu(); QString cmd; int ret=0; + showDiscovered(); /* Refresh active state */ timerEvent(NULL); // menu->insertItem( tr("More..."), 4 ); - if (irdaactive) + + menu->insertItem( tr("Discovered Device:"), 9); + + if ( !discoveredDevice.isEmpty() ) { + menu->insertItem( discoveredDevice ,7 ); + } else { + menu->insertItem( tr("None"), 8); + } + + menu->insertSeparator(); + + if (irdaactive) { menu->insertItem( tr("Disable IrDA"), 0 ); - else + } else { menu->insertItem( tr("Enable IrDA"), 1 ); + } - if (irdaDiscoveryActive) + if (irdaDiscoveryActive) { menu->insertItem( tr("Disable Discovery"), 2 ); - else + } else { menu->insertItem( tr("Enable Discovery"), 3 ); + } if( receiveActive ){ menu->insertItem( tr("Disable Receive"), 5 ); } else { menu->insertItem( tr("Enable Receive"), 4 ); } QPoint p = mapToGlobal( QPoint(1, menu->sizeHint().height()-1) ); ret = menu->exec(p, 2); qDebug("ret was %d\n", ret); switch(ret) { case 0: setIrdaStatus(0); timerEvent(NULL); break; case 1: setIrdaStatus(1); timerEvent(NULL); break; case 2: setIrdaDiscoveryStatus(0); timerEvent(NULL); diff --git a/core/applets/irdaapplet/irda.h b/core/applets/irdaapplet/irda.h index 002d295..5822afe 100644 --- a/core/applets/irdaapplet/irda.h +++ b/core/applets/irdaapplet/irda.h @@ -21,43 +21,45 @@ #include <qframe.h> #include <qpixmap.h> #include <qguardedptr.h> #include <qtimer.h> #include <qfile.h> class IrdaApplet : public QWidget { Q_OBJECT public: IrdaApplet( QWidget *parent = 0, const char *name=0 ); ~IrdaApplet(); protected: void timerEvent(QTimerEvent *te ); private: void mousePressEvent( QMouseEvent * ); void paintEvent( QPaintEvent* ); int checkIrdaStatus(); int setIrdaStatus(int); int checkIrdaDiscoveryStatus(); int setIrdaDiscoveryStatus(int); + void showDiscovered(); int sockfd; private: QPixmap irdaOnPixmap; QPixmap irdaOffPixmap; QPixmap irdaDiscoveryOnPixmap; QPixmap receiveActivePixmap; + QString discoveredDevice; int irdaactive; // bool and bitfields later bool irdaactive :1 ; int irdaDiscoveryActive; bool receiveActive : 1; bool receiveStateChanged; private slots: }; #endif // __SCREENSHOT_APPLET_H__ |