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 /noncore/net/wellenreiter/gui/wellenreiter.cpp | |
parent | 1e1de522890ad2ea46c95543cace9a2a5ae14716 (diff) | |
download | opie-9307404cf3ef2edfea615a073bbc9db2d1eac8a5.zip opie-9307404cf3ef2edfea615a073bbc9db2d1eac8a5.tar.gz opie-9307404cf3ef2edfea615a073bbc9db2d1eac8a5.tar.bz2 |
gui opens socket and checks messages from daemon.
Diffstat (limited to 'noncore/net/wellenreiter/gui/wellenreiter.cpp') (more/less context) (show whitespace changes)
-rw-r--r-- | noncore/net/wellenreiter/gui/wellenreiter.cpp | 57 |
1 files changed, 56 insertions, 1 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 @@ -10,30 +10,85 @@ ** ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. ** ***********************************************************************/ +// 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 ) : WellenreiterBase( parent, name, 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 ); + } Wellenreiter::~Wellenreiter() { // no need to delete child widgets, Qt does it all for us } +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() { // FIXME: communicate with daemon and set button text according to state button->setText( "Stop Scanning" ); |