summaryrefslogtreecommitdiff
Side-by-side diff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/net/wellenreiter/gui/wellenreiter.cpp57
-rw-r--r--noncore/net/wellenreiter/gui/wellenreiter.h9
-rw-r--r--noncore/net/wellenreiter/libwellenreiter/source/Makefile2
-rw-r--r--noncore/net/wellenreiter/wellenreiter.pro2
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
@@ -1,46 +1,101 @@
/**********************************************************************
** Copyright (C) 2002 Michael 'Mickey' Lauer. All rights reserved.
**
** This file is part of Opie Environment.
**
** This file may be distributed and/or modified under the terms of the
** GNU General Public License version 2 as published by the Free Software
** Foundation and appearing in the file LICENSE.GPL included in the
** packaging of this file.
**
** 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" );
// add some icons, so that we can see if this works
new MScanListItem( netview, "managed", "MyNet", "04:00:20:EF:A6:43", true, 6, 80 );
new MScanListItem( netview, "adhoc", "YourNet", "40:03:A3:E7:56:22", false, 11, 30 );
}
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
@@ -5,36 +5,43 @@
**
** This file may be distributed and/or modified under the terms of the
** GNU General Public License version 2 as published by the Free Software
** Foundation and appearing in the file LICENSE.GPL included in the
** packaging of this file.
**
** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
**
**********************************************************************/
#ifndef WELLENREITER_H
#define WELLENREITER_H
#include "wellenreiterbase.h"
+class QTimerEvent;
+
class Wellenreiter : public WellenreiterBase {
Q_OBJECT
public:
Wellenreiter( QWidget* parent = 0, const char* name = 0, WFlags fl = 0 );
~Wellenreiter();
protected:
-
+ virtual void timerEvent( QTimerEvent* );
public slots:
void buttonClicked();
private:
+ int daemon_fd; // socket filedescriptor for udp communication socket
+
+ bool hasMessage();
+ void handleMessage();
+
//void readConfig();
//void writeConfig();
};
#endif
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
@@ -1,17 +1,17 @@
# $Id$
INCLUDES =
LIBRARIES =
-LIBOBJ = proto.o sock.o log.o
+LIBOBJ = sock.o log.o
CXX = g++ -Wall -pedantic -g $(INCLUDES) -DDEBUG
static: libwellenreiter.a
libwellenreiter.a: $(LIBOBJ)
ar -cr libwellenreiter.a $(LIBOBJ)
shared: libwellenreiter.so
libwellenreiter.so: $(LIBOBJ)
$(CXX) -shared -o libwellenreiter.so $(LIBOBJ)
clean:
rm -f *.o *.a *.so *~
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
@@ -1,11 +1,11 @@
DESTDIR = $(OPIEDIR)/bin
TEMPLATE = app
CONFIG = qt warn_on debug
#CONFIG = qt warn_on release
HEADERS = gui/mainwindowbase.h gui/wellenreiter.h gui/scanlistitem.h
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