author | mickeyl <mickeyl> | 2002-11-25 20:43:21 (UTC) |
---|---|---|
committer | mickeyl <mickeyl> | 2002-11-25 20:43:21 (UTC) |
commit | 9307404cf3ef2edfea615a073bbc9db2d1eac8a5 (patch) (side-by-side diff) | |
tree | 16839e56c19aea7d2a80a398fcc081fce02aaa3f | |
parent | 1e1de522890ad2ea46c95543cace9a2a5ae14716 (diff) | |
download | opie-9307404cf3ef2edfea615a073bbc9db2d1eac8a5.zip opie-9307404cf3ef2edfea615a073bbc9db2d1eac8a5.tar.gz opie-9307404cf3ef2edfea615a073bbc9db2d1eac8a5.tar.bz2 |
gui opens socket and checks messages from daemon.
-rw-r--r-- | noncore/net/wellenreiter/gui/wellenreiter.cpp | 57 | ||||
-rw-r--r-- | noncore/net/wellenreiter/gui/wellenreiter.h | 9 | ||||
-rw-r--r-- | noncore/net/wellenreiter/libwellenreiter/source/Makefile | 2 | ||||
-rw-r--r-- | noncore/net/wellenreiter/wellenreiter.pro | 2 |
4 files changed, 66 insertions, 4 deletions
diff --git a/noncore/net/wellenreiter/gui/wellenreiter.cpp b/noncore/net/wellenreiter/gui/wellenreiter.cpp index 9364a75..96ab7bd 100644 --- a/noncore/net/wellenreiter/gui/wellenreiter.cpp +++ b/noncore/net/wellenreiter/gui/wellenreiter.cpp @@ -14,8 +14,20 @@ ***********************************************************************/ +// Qt + +#include <qpushbutton.h> + +// Standard + +#include <unistd.h> +#include <sys/types.h> + +// Local + #include "wellenreiter.h" #include "scanlistitem.h" -#include <qpushbutton.h> +#include "../libwellenreiter/source/sock.hh" // <--- ugly path, FIX THIS! +#include "../daemon/source/config.hh" // <--- ugly path, FIX THIS! Wellenreiter::Wellenreiter( QWidget* parent, const char* name, WFlags fl ) @@ -25,4 +37,14 @@ Wellenreiter::Wellenreiter( QWidget* parent, const char* name, WFlags fl ) connect( button, SIGNAL( clicked() ), this, SLOT( buttonClicked() ) ); + // + // setup socket for daemon communication and start poller + // + + daemon_fd = commsock( DAEMONADDR, DAEMONPORT ); + if ( daemon_fd == -1 ) + qDebug( "D'oh! Could not get file descriptor for daemon socket." ); + else + startTimer( 700 ); + } @@ -32,4 +54,37 @@ Wellenreiter::~Wellenreiter() } +void Wellenreiter::handleMessage() +{ + // FIXME: receive message and handle it + + qDebug( "received message from daemon." ); +} + + +bool Wellenreiter::hasMessage() +{ + fd_set rfds; + FD_ZERO( &rfds ); + FD_SET( daemon_fd, &rfds ); + struct timeval tv; + tv.tv_sec = 0; + tv.tv_usec = 0; + return select( 1, &rfds, NULL, NULL, &tv ); +} + +void Wellenreiter::timerEvent( QTimerEvent* e ) +{ + // qDebug( "checking for message..." ); + + if ( hasMessage() ) + { + handleMessage(); + } + else + { + // qDebug( "no message :(" ); + } +} + void Wellenreiter::buttonClicked() { diff --git a/noncore/net/wellenreiter/gui/wellenreiter.h b/noncore/net/wellenreiter/gui/wellenreiter.h index 7ba8b01..206f364 100644 --- a/noncore/net/wellenreiter/gui/wellenreiter.h +++ b/noncore/net/wellenreiter/gui/wellenreiter.h @@ -19,4 +19,6 @@ #include "wellenreiterbase.h" +class QTimerEvent; + class Wellenreiter : public WellenreiterBase { Q_OBJECT @@ -28,5 +30,5 @@ public: protected: - + virtual void timerEvent( QTimerEvent* ); public slots: @@ -34,4 +36,9 @@ public slots: private: + int daemon_fd; // socket filedescriptor for udp communication socket + + bool hasMessage(); + void handleMessage(); + //void readConfig(); //void writeConfig(); diff --git a/noncore/net/wellenreiter/libwellenreiter/source/Makefile b/noncore/net/wellenreiter/libwellenreiter/source/Makefile index ecae73c..05a5bd3 100644 --- a/noncore/net/wellenreiter/libwellenreiter/source/Makefile +++ b/noncore/net/wellenreiter/libwellenreiter/source/Makefile @@ -3,5 +3,5 @@ INCLUDES = LIBRARIES = -LIBOBJ = proto.o sock.o log.o +LIBOBJ = sock.o log.o CXX = g++ -Wall -pedantic -g $(INCLUDES) -DDEBUG diff --git a/noncore/net/wellenreiter/wellenreiter.pro b/noncore/net/wellenreiter/wellenreiter.pro index 6b6276b..6f07ac4 100644 --- a/noncore/net/wellenreiter/wellenreiter.pro +++ b/noncore/net/wellenreiter/wellenreiter.pro @@ -7,5 +7,5 @@ SOURCES = gui/main.cpp gui/wellenreiter.cpp gui/scanlistitem.cpp INCLUDEPATH += $(OPIEDIR)/include gui daemon DEPENDPATH += $(OPIEDIR)/include gui daemon -LIBS += -lqpe +LIBS += -lqpe -Llibwellenreiter/source -lwellenreiter INTERFACES = gui/wellenreiterbase.ui TARGET = wellenreiter |