summaryrefslogtreecommitdiff
Side-by-side diff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/net/wellenreiter/gui/cardconfig.cpp29
-rw-r--r--noncore/net/wellenreiter/gui/cardconfig.h58
-rw-r--r--noncore/net/wellenreiter/gui/configbase.ui10
-rw-r--r--noncore/net/wellenreiter/gui/gui-x11.pro6
-rw-r--r--noncore/net/wellenreiter/gui/gui.pro6
-rw-r--r--noncore/net/wellenreiter/gui/scanlist.cpp100
-rw-r--r--noncore/net/wellenreiter/gui/scanlist.h11
-rw-r--r--noncore/net/wellenreiter/gui/scanlistitem.cpp1
-rw-r--r--noncore/net/wellenreiter/gui/wellenreiter.cpp213
-rw-r--r--noncore/net/wellenreiter/gui/wellenreiter.h18
-rw-r--r--noncore/net/wellenreiter/gui/wellenreiterbase.cpp8
-rw-r--r--noncore/net/wellenreiter/gui/wellenreiterbase.h13
-rw-r--r--noncore/net/wellenreiter/gui/wlan.cpp57
-rw-r--r--noncore/net/wellenreiter/gui/wlan.h38
14 files changed, 403 insertions, 165 deletions
diff --git a/noncore/net/wellenreiter/gui/cardconfig.cpp b/noncore/net/wellenreiter/gui/cardconfig.cpp
new file mode 100644
index 0000000..1ca1d27
--- a/dev/null
+++ b/noncore/net/wellenreiter/gui/cardconfig.cpp
@@ -0,0 +1,29 @@
+/**********************************************************************
+** 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.
+**
+**********************************************************************/
+
+#include "cardconfig.h"
+
+#include <qstring.h>
+
+CardConfig::CardConfig( const QString& interface, Type type, int hopinterval )
+ :_interface( interface ), _type( type ), _hopinterval( hopinterval )
+{
+
+}
+
+CardConfig::~CardConfig()
+{
+}
+
diff --git a/noncore/net/wellenreiter/gui/cardconfig.h b/noncore/net/wellenreiter/gui/cardconfig.h
new file mode 100644
index 0000000..f54ebac
--- a/dev/null
+++ b/noncore/net/wellenreiter/gui/cardconfig.h
@@ -0,0 +1,58 @@
+/**********************************************************************
+** 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.
+**
+**********************************************************************/
+
+#ifndef CARDCONFIG_H
+#define CARDCONFIG_H
+
+#include <qstring.h>
+
+#ifdef QWS
+#include <opie/odevice.h>
+using namespace Opie;
+#endif
+
+class CardConfig
+{
+ public:
+
+ typedef enum { Prism, Orinoco, HostAP, Manual } Type;
+
+ public:
+
+ CardConfig( const QString& interface, Type type = Manual, int hopinterval = 100 );
+ virtual ~CardConfig();
+
+ const QString& interface() { return _interface; };
+ int hopinterval() { return _hopinterval; };
+ Type type() { return _type; };
+
+ #ifdef QWS
+ OSystem system() { return _system; };
+ #endif
+
+ private:
+
+ QString _interface;
+ Type _type;
+ int _hopinterval;
+
+ #ifdef QWS
+ OSystem _system;
+ #endif
+
+};
+
+#endif
+
diff --git a/noncore/net/wellenreiter/gui/configbase.ui b/noncore/net/wellenreiter/gui/configbase.ui
index e2f734a..8dcf513 100644
--- a/noncore/net/wellenreiter/gui/configbase.ui
+++ b/noncore/net/wellenreiter/gui/configbase.ui
@@ -13,3 +13,3 @@
<y>0</y>
- <width>232</width>
+ <width>228</width>
<height>267</height>
@@ -34,3 +34,3 @@
<name>spacing</name>
- <number>0</number>
+ <number>1</number>
</property>
@@ -182,8 +182,2 @@
<name>text</name>
- <string>cisco</string>
- </property>
- </item>
- <item>
- <property>
- <name>text</name>
<string>orinoco</string>
diff --git a/noncore/net/wellenreiter/gui/gui-x11.pro b/noncore/net/wellenreiter/gui/gui-x11.pro
index 6b4a7bf..523bf15 100644
--- a/noncore/net/wellenreiter/gui/gui-x11.pro
+++ b/noncore/net/wellenreiter/gui/gui-x11.pro
@@ -4,7 +4,7 @@ CONFIG = qt warn_on debug
#CONFIG = qt warn_on release
-HEADERS = wellenreiterbase.h wellenreiter.h scanlistitem.h scanlist.h logwindow.h hexwindow.h configwindow.h resource.h
-SOURCES = main.cpp wellenreiterbase.cpp wellenreiter.cpp scanlistitem.cpp scanlist.cpp logwindow.cpp hexwindow.cpp configwindow.cpp resource.cpp
+HEADERS = wellenreiterbase.h wellenreiter.h scanlistitem.h scanlist.h logwindow.h hexwindow.h configwindow.h resource.h wlan.h cardconfig.h
+SOURCES = main.cpp wellenreiterbase.cpp wellenreiter.cpp scanlistitem.cpp scanlist.cpp logwindow.cpp hexwindow.cpp configwindow.cpp resource.cpp wlan.cpp cardconfig.cpp
INCLUDEPATH += ../
DEPENDPATH += ../
-LIBS += -lwellenreiter
+LIBS += -L. -lwellenreiter
INTERFACES = configbase.ui
diff --git a/noncore/net/wellenreiter/gui/gui.pro b/noncore/net/wellenreiter/gui/gui.pro
index b6e884d..ce1c387 100644
--- a/noncore/net/wellenreiter/gui/gui.pro
+++ b/noncore/net/wellenreiter/gui/gui.pro
@@ -4,7 +4,7 @@ CONFIG = qt warn_on debug
#CONFIG = qt warn_on release
-HEADERS = wellenreiterbase.h wellenreiter.h scanlistitem.h scanlist.h logwindow.h hexwindow.h configwindow.h
-SOURCES = main.cpp wellenreiterbase.cpp wellenreiter.cpp scanlistitem.cpp scanlist.cpp logwindow.cpp hexwindow.cpp configwindow.cpp
+HEADERS = wellenreiterbase.h wellenreiter.h scanlistitem.h scanlist.h logwindow.h hexwindow.h configwindow.h wlan.h cardconfig.h
+SOURCES = main.cpp wellenreiterbase.cpp wellenreiter.cpp scanlistitem.cpp scanlist.cpp logwindow.cpp hexwindow.cpp configwindow.cpp wlan.cpp cardconfig.cpp
INCLUDEPATH += $(OPIEDIR)/include ../
DEPENDPATH += $(OPIEDIR)/include ../
-LIBS += -lqpe -lopie -lwellenreiter
+LIBS += -lqpe -lopie -L. -lwellenreiter
INTERFACES = configbase.ui
diff --git a/noncore/net/wellenreiter/gui/scanlist.cpp b/noncore/net/wellenreiter/gui/scanlist.cpp
index f907afc..6d032aa 100644
--- a/noncore/net/wellenreiter/gui/scanlist.cpp
+++ b/noncore/net/wellenreiter/gui/scanlist.cpp
@@ -16,2 +16,102 @@
#include "scanlist.h"
+#include "scanlistitem.h"
+
+#include <assert.h>
+
+MScanListView::MScanListView( QWidget* parent, const char* name )
+ :QListView( parent, name )
+{
+};
+
+MScanListView::~MScanListView()
+{
+};
+
+void MScanListView::addNewItem( QString type, QString essid, QString macaddr, bool wep, int channel, int signal )
+{
+ // FIXME: scanlistitem needs a proper encapsulation and not such a damn dealing with text(...)
+
+ qDebug( "MScanList::addNewItem( %s / %s / %s [%d]",
+ (const char*) type,
+ (const char*) essid,
+ (const char*) macaddr,
+ channel );
+
+ // search, if we already have seen this net
+
+ QString s;
+ MScanListItem* network;
+ MScanListItem* item = static_cast<MScanListItem*> ( firstChild() );
+
+ while ( item && ( item->text( 0 ) != essid ) )
+ {
+ qDebug( "itemtext: %s", (const char*) item->text( 0 ) );
+ item = static_cast<MScanListItem*> ( item->itemBelow() );
+ }
+ if ( item )
+ {
+ // animate the item
+
+ /*
+
+ const QPixmap* pixmap = item->pixmap( 0 );
+ const QPixmap* nextpixmap = ani2;
+ if ( pixmap == ani1 )
+ nextpixmap = ani2;
+ else if ( pixmap == ani2 )
+ nextpixmap = ani3;
+ else if ( pixmap == ani3 )
+ nextpixmap = ani4;
+ else if ( pixmap == ani4 )
+ nextpixmap = ani1;
+ item->setPixmap( 0, *nextpixmap ); */
+
+ //qDebug( "current pixmap %d, next %d", pixmap, nextpixmap );
+
+ // we have already seen this net, check all childs if MAC exists
+
+ network = item;
+
+ item = static_cast<MScanListItem*> ( item->firstChild() );
+ assert( item ); // this shouldn't fail
+
+ while ( item && ( item->text( 2 ) != macaddr ) )
+ {
+ qDebug( "subitemtext: %s", (const char*) item->text( 2 ) );
+ item = static_cast<MScanListItem*> ( item->itemBelow() );
+ }
+
+ if ( item )
+ {
+ // we have already seen this item, it's a dupe
+ qDebug( "%s is a dupe - ignoring...", (const char*) macaddr );
+ return;
+ }
+ }
+ else
+ {
+ s.sprintf( "(i) new network: '%s'", (const char*) essid );
+
+ network = new MScanListItem( this, "networks", essid, QString::null, 0, 0, 0 );
+ }
+
+
+ // insert new station as child from network
+
+ // no essid to reduce clutter, maybe later we have a nick or stationname to display!?
+
+ qDebug( "inserting new station %s", (const char*) macaddr );
+
+ new MScanListItem( network, type, "", macaddr, wep, channel, signal );
+
+ if ( type == "managed" )
+ {
+ s.sprintf( "(i) new AP in '%s' [%d]", (const char*) essid, channel );
+ }
+ else
+ {
+ s.sprintf( "(i) new adhoc station in '%s' [%d]", (const char*) essid, channel );
+ }
+
+}
diff --git a/noncore/net/wellenreiter/gui/scanlist.h b/noncore/net/wellenreiter/gui/scanlist.h
index 5cf3053..6fe6930 100644
--- a/noncore/net/wellenreiter/gui/scanlist.h
+++ b/noncore/net/wellenreiter/gui/scanlist.h
@@ -22,4 +22,13 @@ class QString;
-class MScanList: public QListView
+class MScanListView: public QListView
{
+ Q_OBJECT
+
+ public:
+ MScanListView( QWidget* parent = 0, const char* name = 0 );
+ virtual ~MScanListView();
+
+ public slots:
+ void addNewItem( QString type, QString essid, QString macaddr, bool wep, int channel, int signal );
+
};
diff --git a/noncore/net/wellenreiter/gui/scanlistitem.cpp b/noncore/net/wellenreiter/gui/scanlistitem.cpp
index 1e2a52e..f4b43a6 100644
--- a/noncore/net/wellenreiter/gui/scanlistitem.cpp
+++ b/noncore/net/wellenreiter/gui/scanlistitem.cpp
@@ -78 +78,2 @@ void MScanListItem::decorateItem( QString type, QString essid, QString macaddr,
}
+
diff --git a/noncore/net/wellenreiter/gui/wellenreiter.cpp b/noncore/net/wellenreiter/gui/wellenreiter.cpp
index 0fd929f..2d9bbee 100644
--- a/noncore/net/wellenreiter/gui/wellenreiter.cpp
+++ b/noncore/net/wellenreiter/gui/wellenreiter.cpp
@@ -21,2 +21,3 @@
#include <qspinbox.h>
+#include <qsocketnotifier.h>
@@ -28,2 +29,9 @@
+// Opie
+
+#ifdef QWS
+#include <opie/odevice.h>
+using namespace Opie;
+#endif
+
// Standard
@@ -35,3 +43,5 @@
#include <sys/types.h>
+#include <sys/socket.h>
#include <stdlib.h>
+#include <fcntl.h>
@@ -40,3 +50,3 @@
#include "wellenreiter.h"
-#include "scanlistitem.h"
+#include "scanlist.h"
#include "logwindow.h"
@@ -55,7 +65,15 @@ Wellenreiter::Wellenreiter( QWidget* parent, const char* name, WFlags fl )
- connect( button, SIGNAL( clicked() ), this, SLOT( buttonClicked() ) );
- netview->setColumnWidthMode( 1, QListView::Manual );
-
//
- // setup socket for daemon communication and start poller
+ // detect operating system
+ //
+
+ #ifdef QWS
+ QString sys;
+ sys.sprintf( "(i) Running on '%s'.", (const char*) ODevice::inst()->systemString() );
+ _system = ODevice::inst()->system();
+ logwindow->log( sys );
+ #endif
+
+ //
+ // setup socket for daemon communication, register socket notifier
//
@@ -66,7 +84,18 @@ Wellenreiter::Wellenreiter( QWidget* parent, const char* name, WFlags fl )
logwindow->log( "(E) Couldn't get file descriptor for commsocket." );
- qDebug( "D'oh! Could not get file descriptor for daemon-->gui communication socket." );
}
else
- startTimer( 700 );
+ {
+ int flags;
+ flags = fcntl( daemon_fd, F_GETFL, 0 );
+ fcntl( daemon_fd, F_SETFL, flags | O_NONBLOCK );
+ QSocketNotifier *sn = new QSocketNotifier( daemon_fd, QSocketNotifier::Read, parent );
+ connect( sn, SIGNAL( activated( int ) ), this, SLOT( dataReceived() ) );
+ }
+ // setup GUI
+
+ connect( button, SIGNAL( clicked() ), this, SLOT( buttonClicked() ) );
+ button->setEnabled( false );
+ netview->setColumnWidthMode( 1, QListView::Manual );
+
}
@@ -84,7 +113,22 @@ void Wellenreiter::handleMessage()
- char buffer[128];
-
- int result = wl_recv( &daemon_fd, (char*) &buffer, sizeof(buffer) );
- qDebug( "received %d from recvcomm", result );
+ char buffer[10000];
+ memset( &buffer, 0, sizeof( buffer ) );
+ // int result = #wl_recv( &daemon_fd, (char*) &buffer, sizeof(buffer) );
+
+ struct sockaddr from;
+ socklen_t len;
+
+ int result = recvfrom( daemon_fd, &buffer, 8192, MSG_WAITALL, &from, &len );
+
+ qDebug( "received %d from recv [%d bytes]", result, len );
+
+ if ( result == -1 )
+ {
+ qDebug( "Warning: %s", strerror( errno ) );
+ return;
+ }
+
+ int command = buffer[1] - 48;
+
/*
@@ -100,6 +144,7 @@ typedef struct {
- // qDebug( "Sniffer sent: '%s'", (const char*) buffer );
+ qDebug( "Recv result: %d", ( result ) );
+ qDebug( "Sniffer sent: '%s'", (const char*) buffer );
hexwindow->log( (const char*) &buffer );
- if ( result == NETFOUND ) /* new network found */
+ if ( command == NETFOUND ) /* new network found */
{
@@ -121,3 +166,3 @@ typedef struct {
- addNewItem( type, n.bssid, QString( (const char*) &n.mac ), n.wep, n.channel, 0 );
+ netview->addNewItem( type, n.bssid, QString( (const char*) &n.mac ), n.wep, n.channel, 0 );
@@ -133,121 +178,24 @@ typedef struct {
-
-bool Wellenreiter::hasMessage()
+void Wellenreiter::dataReceived()
{
-
- // FIXME: do this in libwellenreiter, not here!!!
-
- fd_set rfds;
- FD_ZERO( &rfds );
- FD_SET( daemon_fd, &rfds );
- struct timeval tv;
- tv.tv_sec = 0;
- tv.tv_usec = 10;
- int result = select( daemon_fd+1, &rfds, NULL, NULL, &tv );
-
- if ( result == 0 )
- {
- return false;
- }
- else if ( result == -1 )
- {
- qDebug( "selected returned: %s", strerror( errno ) );
- return false;
- }
- else
- return true; //FD_ISSET( daemon_fd, &rfds ); gibbet 'eh nur einen Deskriptor
+ logwindow->log( "(d) Received data from daemon" );
+ handleMessage();
}
-void Wellenreiter::timerEvent( QTimerEvent* e )
-{
- //qDebug( "checking for message..." );
- if ( hasMessage() )
- {
- //qDebug( "got message from daemon" );
- handleMessage();
- }
- else
- {
- //qDebug( "no message..." );
- }
-}
-
-void Wellenreiter::addNewItem( QString type, QString essid, QString macaddr, bool wep, int channel, int signal )
+void Wellenreiter::buttonClicked()
{
- // FIXME: this code belongs in customized QListView, not into this class
- // FIXME: scanlistitem needs a proper encapsulation and not such a damn dealing with text(...)
-
- qDebug( "Wellenreiter::addNewItem( %s / %s / %s [%d]",
- (const char*) type,
- (const char*) essid,
- (const char*) macaddr,
- channel );
-
- // search, if we already have seen this net
-
- QString s;
- MScanListItem* network;
- MScanListItem* item = static_cast<MScanListItem*> ( netview->firstChild() );
-
- while ( item && ( item->text( 0 ) != essid ) )
- {
- qDebug( "itemtext: %s", (const char*) item->text( 0 ) );
- item = static_cast<MScanListItem*> ( item->itemBelow() );
- }
- if ( item )
- {
- // we have already seen this net, check all childs if MAC exists
-
- network = item;
-
- item = static_cast<MScanListItem*> ( item->firstChild() );
- assert( item ); // this shouldn't fail
-
- while ( item && ( item->text( 2 ) != macaddr ) )
- {
- qDebug( "subitemtext: %s", (const char*) item->text( 2 ) );
- item = static_cast<MScanListItem*> ( item->itemBelow() );
- }
-
- if ( item )
- {
- // we have already seen this item, it's a dupe
- qDebug( "%s is a dupe - ignoring...", (const char*) macaddr );
- return;
- }
- }
- else
- {
- s.sprintf( "(i) new network: '%s'", (const char*) essid );
- logwindow->log( s );
-
- network = new MScanListItem( netview, "networks", essid, QString::null, 0, 0, 0 );
- }
-
-
- // insert new station as child from network
-
- // no essid to reduce clutter, maybe later we have a nick or stationname to display!?
-
- qDebug( "inserting new station %s", (const char*) macaddr );
-
- new MScanListItem( network, type, "", macaddr, wep, channel, signal );
-
- if ( type == "managed" )
- {
- s.sprintf( "(i) new AP in '%s' [%d]", (const char*) essid, channel );
- }
- else
- {
- s.sprintf( "(i) new adhoc station in '%s' [%d]", (const char*) essid, channel );
- }
-
- logwindow->log( s );
+ /*
+ // add some test stations, so that we can see if the GUI part works
+ addNewItem( "managed", "Vanille", "04:00:20:EF:A6:43", true, 6, 80 );
+ addNewItem( "managed", "Vanille", "04:00:20:EF:A6:23", true, 11, 10 );
+ addNewItem( "adhoc", "ELAN", "40:03:43:E7:16:22", false, 3, 10 );
+ addNewItem( "adhoc", "ELAN", "40:03:53:E7:56:62", false, 3, 15 );
+ addNewItem( "adhoc", "ELAN", "40:03:63:E7:56:E2", false, 3, 20 );
+ */
-}
-void Wellenreiter::buttonClicked()
-{
if ( daemonRunning )
{
+ daemonRunning = false;
+
logwindow->log( "(i) Daemon has been stopped." );
@@ -318,17 +266,2 @@ void Wellenreiter::buttonClicked()
- /*
-
- // add some test stations, so that we can see if the GUI part works
-
- addNewItem( "managed", "Vanille", "04:00:20:EF:A6:43", true, 6, 80 );
- addNewItem( "managed", "Vanille", "04:00:20:EF:A6:23", true, 11, 10 );
- addNewItem( "adhoc", "ELAN", "40:03:43:E7:16:22", false, 3, 10 );
- addNewItem( "adhoc", "ELAN", "40:03:53:E7:56:62", false, 3, 15 );
- addNewItem( "adhoc", "ELAN", "40:03:63:E7:56:E2", false, 3, 20 );
-
- QString command ("98");
-
- //sendcomm( DAEMONADDR, DAEMONPORT, (const char*) command );
-
- */
}
diff --git a/noncore/net/wellenreiter/gui/wellenreiter.h b/noncore/net/wellenreiter/gui/wellenreiter.h
index 052a242..2296892 100644
--- a/noncore/net/wellenreiter/gui/wellenreiter.h
+++ b/noncore/net/wellenreiter/gui/wellenreiter.h
@@ -20,3 +20,9 @@
+#ifdef QWS
+#include <opie/odevice.h>
+using namespace Opie;
+#endif
+
class QTimerEvent;
+class QPixmap;
@@ -31,3 +37,2 @@ public:
protected:
- virtual void timerEvent( QTimerEvent* );
@@ -37,10 +42,11 @@ public slots:
void buttonClicked();
- void addNewItem( QString type, QString essid, QString ap, bool wep, int channel, int signal );
+ void dataReceived();
private:
- int daemon_fd; // socket filedescriptor for udp communication socket
-
- bool hasMessage();
+ int daemon_fd; // socket filedescriptor for udp communication socket
+ #ifdef QWS
+ OSystem _system; // Opie Operating System identifier
+ #endif
void handleMessage();
-
+
//void readConfig();
diff --git a/noncore/net/wellenreiter/gui/wellenreiterbase.cpp b/noncore/net/wellenreiter/gui/wellenreiterbase.cpp
index 5017b08..d6b9891 100644
--- a/noncore/net/wellenreiter/gui/wellenreiterbase.cpp
+++ b/noncore/net/wellenreiter/gui/wellenreiterbase.cpp
@@ -32,2 +32,3 @@
#include "configwindow.h"
+#include "scanlist.h"
@@ -49,2 +50,7 @@ WellenreiterBase::WellenreiterBase( QWidget* parent, const char* name, WFlags f
{
+ ani1 = new QPixmap( Resource::loadPixmap( "wellenreiter/networks_rot0" ) );
+ ani2 = new QPixmap( Resource::loadPixmap( "wellenreiter/networks_rot90" ) );
+ ani3 = new QPixmap( Resource::loadPixmap( "wellenreiter/networks_rot180" ) );
+ ani4 = new QPixmap( Resource::loadPixmap( "wellenreiter/networks_rot270" ) );
+
if ( !name )
@@ -68,3 +74,3 @@ WellenreiterBase::WellenreiterBase( QWidget* parent, const char* name, WFlags f
- netview = new QListView( ap, "netview" );
+ netview = new MScanListView( ap );
netview->addColumn( tr( "SSID" ) );
diff --git a/noncore/net/wellenreiter/gui/wellenreiterbase.h b/noncore/net/wellenreiter/gui/wellenreiterbase.h
index fce25d1..edb2930 100644
--- a/noncore/net/wellenreiter/gui/wellenreiterbase.h
+++ b/noncore/net/wellenreiter/gui/wellenreiterbase.h
@@ -24,4 +24,4 @@ class QGridLayout;
class QLabel;
-class QListView;
-class QListViewItem;
+class MScanListView;
+class MScanListItem;
class QPushButton;
@@ -51,3 +51,3 @@ public:
QWidget* ap;
- QListView* netview;
+ MScanListView* netview;
MLogWindow* logwindow;
@@ -65,2 +65,9 @@ protected:
bool event( QEvent* );
+
+ QPixmap* ani1;
+ QPixmap* ani2;
+ QPixmap* ani3;
+ QPixmap* ani4;
+
+
};
diff --git a/noncore/net/wellenreiter/gui/wlan.cpp b/noncore/net/wellenreiter/gui/wlan.cpp
new file mode 100644
index 0000000..b046cc8
--- a/dev/null
+++ b/noncore/net/wellenreiter/gui/wlan.cpp
@@ -0,0 +1,57 @@
+/**********************************************************************
+** 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.
+**
+**********************************************************************/
+
+#include "wlan.h"
+#include "cardconfig.h"
+
+// Qt
+#include <qstring.h>
+
+// Qtopia
+#ifdef QWS
+#include <opie/odevice.h>
+using namespace Opie;
+#endif
+
+WLAN::WLAN( const QString& interface )
+{
+ _configuration = new CardConfig( interface );
+}
+
+WLAN::WLAN( const CardConfig* configuration )
+{
+ _configuration = configuration;
+
+}
+
+WLAN::~WLAN()
+{
+ delete _configuration;
+
+}
+
+void WLAN::setMonitorMode( bool enabled )
+{
+
+ /*
+
+ if ( _configuration->system() == System_OpenZaurus && _configuration->type() == CardConfig::Prism )
+ {
+ }
+
+ */
+
+}
+
diff --git a/noncore/net/wellenreiter/gui/wlan.h b/noncore/net/wellenreiter/gui/wlan.h
new file mode 100644
index 0000000..139e218
--- a/dev/null
+++ b/noncore/net/wellenreiter/gui/wlan.h
@@ -0,0 +1,38 @@
+/**********************************************************************
+** 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.
+**
+**********************************************************************/
+
+#ifndef WLAN_H
+#define WLAN_H
+
+class QString;
+class CardConfig;
+
+class WLAN
+{
+ public:
+
+ WLAN( const QString& interface );
+ WLAN( const CardConfig* );
+ virtual ~WLAN();
+ void setMonitorMode( bool enabled );
+
+ private:
+
+ const CardConfig* _configuration;
+
+};
+
+#endif
+