author | mickeyl <mickeyl> | 2004-02-15 18:08:39 (UTC) |
---|---|---|
committer | mickeyl <mickeyl> | 2004-02-15 18:08:39 (UTC) |
commit | 4d467f290f7f42717be14bb0f269570fe5dd07bc (patch) (unidiff) | |
tree | 9c50cc710f7f69f57eceece17635b0b5e5b3a0b9 | |
parent | 76be6ccdc364c609e86d74e6daa72438bc92e911 (diff) | |
download | opie-4d467f290f7f42717be14bb0f269570fe5dd07bc.zip opie-4d467f290f7f42717be14bb0f269570fe5dd07bc.tar.gz opie-4d467f290f7f42717be14bb0f269570fe5dd07bc.tar.bz2 |
s/$1/%1/
-rw-r--r-- | noncore/net/wellenreiter/TODO | 2 | ||||
-rw-r--r-- | noncore/net/wellenreiter/gui/main.cpp | 8 | ||||
-rw-r--r-- | noncore/net/wellenreiter/gui/mainwindow.cpp | 2 |
3 files changed, 8 insertions, 4 deletions
diff --git a/noncore/net/wellenreiter/TODO b/noncore/net/wellenreiter/TODO index b6ec617..01e731f 100644 --- a/noncore/net/wellenreiter/TODO +++ b/noncore/net/wellenreiter/TODO | |||
@@ -1,60 +1,62 @@ | |||
1 | /************************************************************************ | 1 | /************************************************************************ |
2 | /* W e l l e n r e i t e r I I | 2 | /* W e l l e n r e i t e r I I |
3 | /* =============================== | 3 | /* =============================== |
4 | /* | 4 | /* |
5 | /* Version: 1.0.2 | 5 | /* Version: 1.0.2 |
6 | /************************************************************************ | 6 | /************************************************************************ |
7 | 7 | ||
8 | ---------------------------------------------------- | 8 | ---------------------------------------------------- |
9 | Ideas as of Wellenreiter II / December 2003 | 9 | Ideas as of Wellenreiter II / December 2003 |
10 | ---------------------------------------------------- | 10 | ---------------------------------------------------- |
11 | 11 | ||
12 | -------- | 12 | -------- |
13 | ENGINE | 13 | ENGINE |
14 | -------- | 14 | -------- |
15 | 15 | ||
16 | - enable multiple packet sources | 16 | - enable multiple packet sources |
17 | - infrared | 17 | - infrared |
18 | - bluetooth | 18 | - bluetooth |
19 | - usb? | 19 | - usb? |
20 | 20 | ||
21 | - define packet structure in a metalanguage and generate | 21 | - define packet structure in a metalanguage and generate |
22 | the actual parsing code (hmmm) | 22 | the actual parsing code (hmmm) |
23 | 23 | ||
24 | - pester the ethereal folks to settle for an application independant | 24 | - pester the ethereal folks to settle for an application independant |
25 | packet dissection framework... (unlikely) | 25 | packet dissection framework... (unlikely) |
26 | 26 | ||
27 | - adaptive hopping scheme ! | 27 | - adaptive hopping scheme ! |
28 | 28 | ||
29 | - gather interface capabilities | 29 | - gather interface capabilities |
30 | 30 | ||
31 | - enable sniffing in wired networks | 31 | - enable sniffing in wired networks |
32 | 32 | ||
33 | - fix autodetection (interface name) | 33 | - fix autodetection (interface name) |
34 | 34 | ||
35 | --------- | 35 | --------- |
36 | UI | 36 | UI |
37 | --------- | 37 | --------- |
38 | 38 | ||
39 | - display interface capabilities (or rewrite networksettings?) | 39 | - display interface capabilities (or rewrite networksettings?) |
40 | 40 | ||
41 | - distinguish wireless bridges (WDS traffic) | 41 | - distinguish wireless bridges (WDS traffic) |
42 | 42 | ||
43 | - expand/collapse all | 43 | - expand/collapse all |
44 | 44 | ||
45 | - add configuration for scrollback buffer in hex window and log window | 45 | - add configuration for scrollback buffer in hex window and log window |
46 | 46 | ||
47 | - revamp hex window, make it more sophisticated than just a QMultiLineEdit | 47 | - revamp hex window, make it more sophisticated than just a QMultiLineEdit |
48 | - tree view | 48 | - tree view |
49 | 49 | ||
50 | - beep over headphone / customizable | 50 | - beep over headphone / customizable |
51 | 51 | ||
52 | - count/display number of wireless networks / APs since last start/stop | ||
53 | |||
52 | --------- | 54 | --------- |
53 | FILES | 55 | FILES |
54 | --------- | 56 | --------- |
55 | 57 | ||
56 | - write kismet-like .network format and format to be importable into AutoRoute | 58 | - write kismet-like .network format and format to be importable into AutoRoute |
57 | 59 | ||
58 | - implement beacon stripping (the first beacon is enough to detect a | 60 | - implement beacon stripping (the first beacon is enough to detect a |
59 | new network - further beacons just blow up the capture file) | 61 | new network - further beacons just blow up the capture file) |
60 | 62 | ||
diff --git a/noncore/net/wellenreiter/gui/main.cpp b/noncore/net/wellenreiter/gui/main.cpp index d32b362..8ef62e9 100644 --- a/noncore/net/wellenreiter/gui/main.cpp +++ b/noncore/net/wellenreiter/gui/main.cpp | |||
@@ -1,107 +1,109 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2002-2004 Michael 'Mickey' Lauer. All rights reserved. | 2 | ** Copyright (C) 2002-2004 Michael 'Mickey' Lauer. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of Opie Environment. | 4 | ** This file is part of Opie Environment. |
5 | ** | 5 | ** |
6 | ** This file may be distributed and/or modified under the terms of the | 6 | ** This file may be distributed and/or modified under the terms of the |
7 | ** GNU General Public License version 2 as published by the Free Software | 7 | ** GNU General Public License version 2 as published by the Free Software |
8 | ** Foundation and appearing in the file LICENSE.GPL included in the | 8 | ** Foundation and appearing in the file LICENSE.GPL included in the |
9 | ** packaging of this file. | 9 | ** packaging of this file. |
10 | ** | 10 | ** |
11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE | 11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE |
12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. | 12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. |
13 | ** | 13 | ** |
14 | **********************************************************************/ | 14 | **********************************************************************/ |
15 | 15 | ||
16 | #include "mainwindow.h" | 16 | #include "mainwindow.h" |
17 | #ifdef QWS | 17 | #ifdef QWS |
18 | #include <opie2/oapplication.h> | 18 | #include <opie2/oapplication.h> |
19 | #include <opie2/oprocess.h> | 19 | #include <opie2/oprocess.h> |
20 | #else | 20 | #else |
21 | #include <qapplication.h> | 21 | #include <qapplication.h> |
22 | #endif | 22 | #endif |
23 | 23 | ||
24 | #include <qmessagebox.h> | 24 | #include <qmessagebox.h> |
25 | #include <qstringlist.h> | 25 | #include <qstringlist.h> |
26 | 26 | ||
27 | #include <errno.h> | 27 | #include <errno.h> |
28 | #include <signal.h> | 28 | #include <signal.h> |
29 | #include <string.h> | 29 | #include <string.h> |
30 | #include <unistd.h> | 30 | #include <unistd.h> |
31 | 31 | ||
32 | int main( int argc, char **argv ) | 32 | int main( int argc, char **argv ) |
33 | { | 33 | { |
34 | #ifdef QWS | 34 | #ifdef QWS |
35 | OApplication a( argc, argv, "Wellenreiter II" ); | 35 | OApplication a( argc, argv, "Wellenreiter II" ); |
36 | #else | 36 | #else |
37 | QApplication a( argc, argv ); | 37 | QApplication a( argc, argv ); |
38 | #endif | 38 | #endif |
39 | WellenreiterMainWindow* w = new WellenreiterMainWindow(); | 39 | WellenreiterMainWindow* w = new WellenreiterMainWindow(); |
40 | #ifdef QWS | 40 | #ifdef QWS |
41 | a.showMainWidget( w ); | 41 | a.showMainWidget( w ); |
42 | #else | 42 | #else |
43 | a.setMainWidget( w ); | 43 | a.setMainWidget( w ); |
44 | w->setCaption( "Wellenreiter II" ); | 44 | w->setCaption( "Wellenreiter II" ); |
45 | w->show(); | 45 | w->show(); |
46 | #endif | 46 | #endif |
47 | 47 | ||
48 | a.processEvents(); // show the window before doing the safety checks | 48 | a.processEvents(); // show the window before doing the safety checks |
49 | int result = -1; | 49 | int result = -1; |
50 | static int killed = false; | 50 | static int killed = false; |
51 | 51 | ||
52 | bool check = true; | 52 | bool check = true; |
53 | for ( int i = 1; i < argc; ++i ) | 53 | for ( int i = 1; i < argc; ++i ) |
54 | { | 54 | { |
55 | if ( !strcmp( "-nocheck", argv[i] ) ) | 55 | if ( !strcmp( "-nocheck", argv[i] ) ) |
56 | { | 56 | { |
57 | qDebug( "-nocheck found" ); | 57 | qDebug( "-nocheck found" ); |
58 | check = false; | 58 | check = false; |
59 | break; | 59 | break; |
60 | } | 60 | } |
61 | } | 61 | } |
62 | 62 | ||
63 | if ( check ) | 63 | if ( check ) |
64 | { | 64 | { |
65 | // root check | 65 | // root check |
66 | if ( getuid() ) | 66 | if ( getuid() ) |
67 | { | 67 | { |
68 | qWarning( QObject::tr( "Wellenreiter: trying to run as non-root!" ) ); | 68 | qWarning( QObject::tr( "Wellenreiter: trying to run as non-root!" ) ); |
69 | result = QMessageBox::warning( w, " - Wellenreiter II - (non-root)", QObject::tr( "You have started Wellenreiter II\n" | 69 | result = QMessageBox::warning( w, " - Wellenreiter II - (non-root)", QObject::tr( "You have started Wellenreiter II\n" |
70 | "as non-root. You will have\nonly limited functionality.\nProceed anyway?" ), | 70 | "as non-root. You will have\nonly limited functionality.\nProceed anyway?" ), |
71 | QMessageBox::Yes, QMessageBox::No ); | 71 | QMessageBox::Yes, QMessageBox::No ); |
72 | if ( result == QMessageBox::No ) return -1; | 72 | if ( result == QMessageBox::No ) return -1; |
73 | } | 73 | } |
74 | 74 | ||
75 | if ( OProcess::processPID( "dhcpc" ) ) | 75 | int dhcpid = OProcess::processPID( "dhcpc" ); |
76 | |||
77 | if ( dhcpid ) | ||
76 | { | 78 | { |
77 | result = QMessageBox::warning( w, " - Wellenreiter II - (dhcp)", QObject::tr( "You have a dhcp client running.\n" | 79 | result = QMessageBox::warning( w, " - Wellenreiter II - (dhcp)", QObject::tr( "You have a dhcp client running.\n" |
78 | "This can severly limit scanning!\nShould I kill it for you?" ), | 80 | "(PID = %1)\nThis can severly limit scanning!\nShould I kill it for you?" ).arg( dhcpid ), |
79 | QMessageBox::Yes, QMessageBox::No ); | 81 | QMessageBox::Yes, QMessageBox::No ); |
80 | if ( result == QMessageBox::Yes ) | 82 | if ( result == QMessageBox::Yes ) |
81 | { | 83 | { |
82 | if ( -1 == ::kill( OProcess::processPID( "dhcpc" ), SIGTERM ) ) | 84 | if ( -1 == ::kill( dhcpid, SIGTERM ) ) |
83 | qWarning( "Wellenreiter: can't kill process #%d (%s)", result, strerror( errno ) ); | 85 | qWarning( "Wellenreiter: can't kill process #%d (%s)", result, strerror( errno ) ); |
84 | else | 86 | else |
85 | killed = true; | 87 | killed = true; |
86 | } | 88 | } |
87 | } | 89 | } |
88 | } | 90 | } |
89 | 91 | ||
90 | a.exec(); | 92 | a.exec(); |
91 | 93 | ||
92 | if ( check ) | 94 | if ( check ) |
93 | { | 95 | { |
94 | 96 | ||
95 | if ( killed ) | 97 | if ( killed ) |
96 | { | 98 | { |
97 | result = QMessageBox::warning( w, " - Wellenreiter II - (dhcp)", QObject::tr( "Restart your dhcp client?" ), QMessageBox::Yes, QMessageBox::No ); | 99 | result = QMessageBox::warning( w, " - Wellenreiter II - (dhcp)", QObject::tr( "Restart your dhcp client?" ), QMessageBox::Yes, QMessageBox::No ); |
98 | if ( result == QMessageBox::Yes ) | 100 | if ( result == QMessageBox::Yes ) |
99 | { | 101 | { |
100 | ::system( QString().sprintf( "dhclient &; udhcpcd &; dhcpcd &" ) ); | 102 | ::system( QString().sprintf( "dhclient &; udhcpcd &; dhcpcd &" ) ); |
101 | } | 103 | } |
102 | } | 104 | } |
103 | 105 | ||
104 | delete w; | 106 | delete w; |
105 | } | 107 | } |
106 | return 0; | 108 | return 0; |
107 | } | 109 | } |
diff --git a/noncore/net/wellenreiter/gui/mainwindow.cpp b/noncore/net/wellenreiter/gui/mainwindow.cpp index b462afd..72624f7 100644 --- a/noncore/net/wellenreiter/gui/mainwindow.cpp +++ b/noncore/net/wellenreiter/gui/mainwindow.cpp | |||
@@ -117,257 +117,257 @@ WellenreiterMainWindow::WellenreiterMainWindow( QWidget * parent, const char * n | |||
117 | id = file->insertItem( tr( "&Load" ), fileLoad ); | 117 | id = file->insertItem( tr( "&Load" ), fileLoad ); |
118 | file->insertItem( tr( "&Save" ), fileSave ); | 118 | file->insertItem( tr( "&Save" ), fileSave ); |
119 | file->insertSeparator(); | 119 | file->insertSeparator(); |
120 | uploadID = file->insertItem( tr( "&Upload Session" ), this, SLOT( uploadSession() ) ); | 120 | uploadID = file->insertItem( tr( "&Upload Session" ), this, SLOT( uploadSession() ) ); |
121 | file->insertSeparator(); | 121 | file->insertSeparator(); |
122 | file->insertItem( tr( "&Exit" ), qApp, SLOT( quit() ) ); | 122 | file->insertItem( tr( "&Exit" ), qApp, SLOT( quit() ) ); |
123 | 123 | ||
124 | QPopupMenu* view = new QPopupMenu( mb ); | 124 | QPopupMenu* view = new QPopupMenu( mb ); |
125 | view->insertItem( tr( "&Configure..." ) ); | 125 | view->insertItem( tr( "&Configure..." ) ); |
126 | 126 | ||
127 | QPopupMenu* sniffer = new QPopupMenu( mb ); | 127 | QPopupMenu* sniffer = new QPopupMenu( mb ); |
128 | sniffer->insertItem( tr( "&Configure..." ), this, SLOT( showConfigure() ) ); | 128 | sniffer->insertItem( tr( "&Configure..." ), this, SLOT( showConfigure() ) ); |
129 | sniffer->insertSeparator(); | 129 | sniffer->insertSeparator(); |
130 | startID = sniffer->insertItem( tr( "&Start" ), mw, SLOT( startClicked() ) ); | 130 | startID = sniffer->insertItem( tr( "&Start" ), mw, SLOT( startClicked() ) ); |
131 | sniffer->setItemEnabled( startID, false ); | 131 | sniffer->setItemEnabled( startID, false ); |
132 | stopID = sniffer->insertItem( tr( "Sto&p" ), mw, SLOT( stopClicked() ) ); | 132 | stopID = sniffer->insertItem( tr( "Sto&p" ), mw, SLOT( stopClicked() ) ); |
133 | sniffer->setItemEnabled( stopID, false ); | 133 | sniffer->setItemEnabled( stopID, false ); |
134 | 134 | ||
135 | QPopupMenu* demo = new QPopupMenu( mb ); | 135 | QPopupMenu* demo = new QPopupMenu( mb ); |
136 | demo->insertItem( tr( "&Add something" ), this, SLOT( demoAddStations() ) ); | 136 | demo->insertItem( tr( "&Add something" ), this, SLOT( demoAddStations() ) ); |
137 | demo->insertItem( tr( "&Read from GPSd" ), this, SLOT( demoReadFromGps() ) ); | 137 | demo->insertItem( tr( "&Read from GPSd" ), this, SLOT( demoReadFromGps() ) ); |
138 | 138 | ||
139 | id = mb->insertItem( tr( "&File" ), file ); | 139 | id = mb->insertItem( tr( "&File" ), file ); |
140 | //id = mb->insertItem( tr( "&View" ), view ); | 140 | //id = mb->insertItem( tr( "&View" ), view ); |
141 | //mb->setItemEnabled( id, false ); | 141 | //mb->setItemEnabled( id, false ); |
142 | id = mb->insertItem( tr( "&Sniffer" ), sniffer ); | 142 | id = mb->insertItem( tr( "&Sniffer" ), sniffer ); |
143 | 143 | ||
144 | id = mb->insertItem( tr( "&Demo" ), demo ); | 144 | id = mb->insertItem( tr( "&Demo" ), demo ); |
145 | mb->setItemEnabled( id, true ); | 145 | mb->setItemEnabled( id, true ); |
146 | mb->setItemEnabled( uploadID, false ); | 146 | mb->setItemEnabled( uploadID, false ); |
147 | 147 | ||
148 | #ifdef QWS | 148 | #ifdef QWS |
149 | mb->insertItem( startButton ); | 149 | mb->insertItem( startButton ); |
150 | mb->insertItem( stopButton ); | 150 | mb->insertItem( stopButton ); |
151 | mb->insertItem( uploadButton ); | 151 | mb->insertItem( uploadButton ); |
152 | mb->insertItem( d ); | 152 | mb->insertItem( d ); |
153 | #else // Qt3 changed the insertion order. It's now totally random :( | 153 | #else // Qt3 changed the insertion order. It's now totally random :( |
154 | mb->insertItem( d ); | 154 | mb->insertItem( d ); |
155 | mb->insertItem( uploadButton ); | 155 | mb->insertItem( uploadButton ); |
156 | mb->insertItem( stopButton ); | 156 | mb->insertItem( stopButton ); |
157 | mb->insertItem( startButton ); | 157 | mb->insertItem( startButton ); |
158 | #endif | 158 | #endif |
159 | 159 | ||
160 | updateToolButtonState(); | 160 | updateToolButtonState(); |
161 | 161 | ||
162 | // setup status bar (for now only on X11) | 162 | // setup status bar (for now only on X11) |
163 | 163 | ||
164 | #ifndef QWS | 164 | #ifndef QWS |
165 | statusBar()->message( tr( "Ready." ) ); | 165 | statusBar()->message( tr( "Ready." ) ); |
166 | #endif | 166 | #endif |
167 | 167 | ||
168 | connect( mw, SIGNAL( startedSniffing() ), this, SLOT( changedSniffingState() ) ); | 168 | connect( mw, SIGNAL( startedSniffing() ), this, SLOT( changedSniffingState() ) ); |
169 | connect( mw, SIGNAL( stoppedSniffing() ), this, SLOT( changedSniffingState() ) ); | 169 | connect( mw, SIGNAL( stoppedSniffing() ), this, SLOT( changedSniffingState() ) ); |
170 | }; | 170 | }; |
171 | 171 | ||
172 | 172 | ||
173 | 173 | ||
174 | void WellenreiterMainWindow::showConfigure() | 174 | void WellenreiterMainWindow::showConfigure() |
175 | { | 175 | { |
176 | qDebug( "show configure..." ); | 176 | qDebug( "show configure..." ); |
177 | cw->setCaption( tr( "Configure" ) ); | 177 | cw->setCaption( tr( "Configure" ) ); |
178 | #ifdef QWS | 178 | #ifdef QWS |
179 | cw->showMaximized(); | 179 | cw->showMaximized(); |
180 | #endif | 180 | #endif |
181 | int result = cw->exec(); | 181 | int result = cw->exec(); |
182 | 182 | ||
183 | if ( result ) updateToolButtonState(); | 183 | if ( result ) updateToolButtonState(); |
184 | } | 184 | } |
185 | 185 | ||
186 | 186 | ||
187 | void WellenreiterMainWindow::updateToolButtonState() | 187 | void WellenreiterMainWindow::updateToolButtonState() |
188 | { | 188 | { |
189 | const QString& interface = cw->interfaceName->currentText(); | 189 | const QString& interface = cw->interfaceName->currentText(); |
190 | const int cardtype = cw->driverType(); | 190 | const int cardtype = cw->driverType(); |
191 | 191 | ||
192 | if ( ( interface != "<select>" ) && ( cardtype != 0 ) ) | 192 | if ( ( interface != "<select>" ) && ( cardtype != 0 ) ) |
193 | { | 193 | { |
194 | startButton->setEnabled( true ); | 194 | startButton->setEnabled( true ); |
195 | menuBar()->setItemEnabled( startID, true ); | 195 | menuBar()->setItemEnabled( startID, true ); |
196 | } | 196 | } |
197 | else | 197 | else |
198 | { | 198 | { |
199 | startButton->setEnabled( false ); | 199 | startButton->setEnabled( false ); |
200 | menuBar()->setItemEnabled( startID, false ); | 200 | menuBar()->setItemEnabled( startID, false ); |
201 | } | 201 | } |
202 | } | 202 | } |
203 | 203 | ||
204 | 204 | ||
205 | void WellenreiterMainWindow::changedSniffingState() | 205 | void WellenreiterMainWindow::changedSniffingState() |
206 | { | 206 | { |
207 | startButton->setEnabled( !mw->sniffing ); | 207 | startButton->setEnabled( !mw->sniffing ); |
208 | menuBar()->setItemEnabled( startID, !mw->sniffing ); | 208 | menuBar()->setItemEnabled( startID, !mw->sniffing ); |
209 | stopButton->setEnabled( mw->sniffing ); | 209 | stopButton->setEnabled( mw->sniffing ); |
210 | menuBar()->setItemEnabled( stopID, mw->sniffing ); | 210 | menuBar()->setItemEnabled( stopID, mw->sniffing ); |
211 | 211 | ||
212 | if ( !mw->sniffing ) | 212 | if ( !mw->sniffing ) |
213 | { | 213 | { |
214 | menuBar()->setItemEnabled( uploadID, true ); | 214 | menuBar()->setItemEnabled( uploadID, true ); |
215 | uploadButton->setEnabled( true ); | 215 | uploadButton->setEnabled( true ); |
216 | } | 216 | } |
217 | } | 217 | } |
218 | 218 | ||
219 | 219 | ||
220 | WellenreiterMainWindow::~WellenreiterMainWindow() | 220 | WellenreiterMainWindow::~WellenreiterMainWindow() |
221 | { | 221 | { |
222 | qDebug( "Wellenreiter:: bye." ); | 222 | qDebug( "Wellenreiter:: bye." ); |
223 | }; | 223 | }; |
224 | 224 | ||
225 | 225 | ||
226 | void WellenreiterMainWindow::demoAddStations() | 226 | void WellenreiterMainWindow::demoAddStations() |
227 | { | 227 | { |
228 | //mw = 0; // test SIGSEGV handling | 228 | //mw = 0; // test SIGSEGV handling |
229 | 229 | ||
230 | mw->netView()->addNewItem( "managed", "Vanille", OMacAddress::fromString("00:00:20:EF:A6:43"), true, 6, 80, GpsLocation( 39.8794, -94.0936) ); | 230 | mw->netView()->addNewItem( "managed", "Vanille", OMacAddress::fromString("00:00:20:EF:A6:43"), true, 6, 80, GpsLocation( 39.8794, -94.0936) ); |
231 | mw->netView()->addNewItem( "managed", "Vanille", OMacAddress::fromString("00:30:6D:EF:A6:23"), true, 11, 10, GpsLocation( 0.0, 0.0 ) ); | 231 | mw->netView()->addNewItem( "managed", "Vanille", OMacAddress::fromString("00:30:6D:EF:A6:23"), true, 11, 10, GpsLocation( 0.0, 0.0 ) ); |
232 | mw->netView()->addNewItem( "adhoc", "ELAN", OMacAddress::fromString("00:03:F8:E7:16:22"), false, 3, 10, GpsLocation( 5.5, 2.3 ) ); | 232 | mw->netView()->addNewItem( "adhoc", "ELAN", OMacAddress::fromString("00:03:F8:E7:16:22"), false, 3, 10, GpsLocation( 5.5, 2.3 ) ); |
233 | mw->netView()->addNewItem( "adhoc", "ELAN", OMacAddress::fromString("00:04:01:E7:56:62"), false, 3, 15, GpsLocation( 2.3, 5.5 ) ); | 233 | mw->netView()->addNewItem( "adhoc", "ELAN", OMacAddress::fromString("00:04:01:E7:56:62"), false, 3, 15, GpsLocation( 2.3, 5.5 ) ); |
234 | mw->netView()->addNewItem( "adhoc", "ELAN", OMacAddress::fromString("00:05:8E:E7:56:E2"), false, 3, 20, GpsLocation( -10.0, -20.5 ) ); | 234 | mw->netView()->addNewItem( "adhoc", "ELAN", OMacAddress::fromString("00:05:8E:E7:56:E2"), false, 3, 20, GpsLocation( -10.0, -20.5 ) ); |
235 | } | 235 | } |
236 | 236 | ||
237 | 237 | ||
238 | void WellenreiterMainWindow::demoReadFromGps() | 238 | void WellenreiterMainWindow::demoReadFromGps() |
239 | { | 239 | { |
240 | WellenreiterConfigWindow* configwindow = WellenreiterConfigWindow::instance(); | 240 | WellenreiterConfigWindow* configwindow = WellenreiterConfigWindow::instance(); |
241 | GPS* gps = new GPS( this ); | 241 | GPS* gps = new GPS( this ); |
242 | gps->open( configwindow->gpsdHost->currentText(), configwindow->gpsdPort->value() ); | 242 | gps->open( configwindow->gpsdHost->currentText(), configwindow->gpsdPort->value() ); |
243 | GpsLocation loc = gps->position(); | 243 | GpsLocation loc = gps->position(); |
244 | 244 | ||
245 | QMessageBox::information( this, "Wellenreiter/Opie", tr( "GPS said:\n$1" ).arg( loc.dmsPosition() ) ); | 245 | QMessageBox::information( this, "Wellenreiter/Opie", tr( "GPS said:\n%1" ).arg( loc.dmsPosition() ) ); |
246 | } | 246 | } |
247 | 247 | ||
248 | 248 | ||
249 | QString WellenreiterMainWindow::getFileName( bool save ) | 249 | QString WellenreiterMainWindow::getFileName( bool save ) |
250 | { | 250 | { |
251 | QMap<QString, QStringList> map; | 251 | QMap<QString, QStringList> map; |
252 | map.insert( tr("All"), QStringList() ); | 252 | map.insert( tr("All"), QStringList() ); |
253 | QStringList text; | 253 | QStringList text; |
254 | text << "text/*"; | 254 | text << "text/*"; |
255 | map.insert( tr("Text"), text ); | 255 | map.insert( tr("Text"), text ); |
256 | text << "*"; | 256 | text << "*"; |
257 | map.insert( tr("All"), text ); | 257 | map.insert( tr("All"), text ); |
258 | 258 | ||
259 | QString str; | 259 | QString str; |
260 | if ( save ) | 260 | if ( save ) |
261 | { | 261 | { |
262 | #ifdef QWS | 262 | #ifdef QWS |
263 | str = OFileDialog::getSaveFileName( 2, "/", QString::null, map ); | 263 | str = OFileDialog::getSaveFileName( 2, "/", QString::null, map ); |
264 | #else | 264 | #else |
265 | str = QFileDialog::getSaveFileName(); | 265 | str = QFileDialog::getSaveFileName(); |
266 | #endif | 266 | #endif |
267 | if ( str.isEmpty() /*|| QFileInfo(str).isDir()*/ ) | 267 | if ( str.isEmpty() /*|| QFileInfo(str).isDir()*/ ) |
268 | return ""; | 268 | return ""; |
269 | } | 269 | } |
270 | else | 270 | else |
271 | { | 271 | { |
272 | #ifdef QWS | 272 | #ifdef QWS |
273 | str = OFileDialog::getOpenFileName( 2, "/", QString::null, map ); | 273 | str = OFileDialog::getOpenFileName( 2, "/", QString::null, map ); |
274 | #else | 274 | #else |
275 | str = QFileDialog::getOpenFileName(); | 275 | str = QFileDialog::getOpenFileName(); |
276 | #endif | 276 | #endif |
277 | if ( str.isEmpty() || !QFile(str).exists() || QFileInfo(str).isDir() ) | 277 | if ( str.isEmpty() || !QFile(str).exists() || QFileInfo(str).isDir() ) |
278 | return ""; | 278 | return ""; |
279 | } | 279 | } |
280 | return str; | 280 | return str; |
281 | } | 281 | } |
282 | 282 | ||
283 | 283 | ||
284 | void WellenreiterMainWindow::fileSaveLog() | 284 | void WellenreiterMainWindow::fileSaveLog() |
285 | { | 285 | { |
286 | QString fname = getFileName( true ); | 286 | QString fname = getFileName( true ); |
287 | if ( !fname.isEmpty() ) | 287 | if ( !fname.isEmpty() ) |
288 | { | 288 | { |
289 | QFile f( fname ); | 289 | QFile f( fname ); |
290 | if ( f.open(IO_WriteOnly) ) | 290 | if ( f.open(IO_WriteOnly) ) |
291 | { | 291 | { |
292 | QTextStream t( &f ); | 292 | QTextStream t( &f ); |
293 | t << mw->logWindow()->getLog(); | 293 | t << mw->logWindow()->getLog(); |
294 | f.close(); | 294 | f.close(); |
295 | qDebug( "Saved log to file '%s'", (const char*) fname ); | 295 | qDebug( "Saved log to file '%s'", (const char*) fname ); |
296 | } | 296 | } |
297 | else | 297 | else |
298 | { | 298 | { |
299 | qDebug( "Problem saving log to file '%s'", (const char*) fname ); | 299 | qDebug( "Problem saving log to file '%s'", (const char*) fname ); |
300 | } | 300 | } |
301 | } | 301 | } |
302 | } | 302 | } |
303 | 303 | ||
304 | void WellenreiterMainWindow::fileSaveSession() | 304 | void WellenreiterMainWindow::fileSaveSession() |
305 | { | 305 | { |
306 | QString fname = getFileName( true ); | 306 | QString fname = getFileName( true ); |
307 | if ( !fname.isEmpty() ) | 307 | if ( !fname.isEmpty() ) |
308 | { | 308 | { |
309 | 309 | ||
310 | QFile f( fname ); | 310 | QFile f( fname ); |
311 | if ( f.open(IO_WriteOnly) ) | 311 | if ( f.open(IO_WriteOnly) ) |
312 | { | 312 | { |
313 | QDataStream t( &f ); | 313 | QDataStream t( &f ); |
314 | t << *mw->netView(); | 314 | t << *mw->netView(); |
315 | f.close(); | 315 | f.close(); |
316 | qDebug( "Saved session to file '%s'", (const char*) fname ); | 316 | qDebug( "Saved session to file '%s'", (const char*) fname ); |
317 | } | 317 | } |
318 | else | 318 | else |
319 | { | 319 | { |
320 | qDebug( "Problem saving session to file '%s'", (const char*) fname ); | 320 | qDebug( "Problem saving session to file '%s'", (const char*) fname ); |
321 | } | 321 | } |
322 | } | 322 | } |
323 | } | 323 | } |
324 | 324 | ||
325 | void WellenreiterMainWindow::fileSaveHex() | 325 | void WellenreiterMainWindow::fileSaveHex() |
326 | { | 326 | { |
327 | QString fname = getFileName( true ); | 327 | QString fname = getFileName( true ); |
328 | if ( !fname.isEmpty() ) | 328 | if ( !fname.isEmpty() ) |
329 | { | 329 | { |
330 | QFile f( fname ); | 330 | QFile f( fname ); |
331 | if ( f.open(IO_WriteOnly) ) | 331 | if ( f.open(IO_WriteOnly) ) |
332 | { | 332 | { |
333 | QTextStream t( &f ); | 333 | QTextStream t( &f ); |
334 | t << mw->hexWindow()->getLog(); | 334 | t << mw->hexWindow()->getLog(); |
335 | f.close(); | 335 | f.close(); |
336 | qDebug( "Saved hex log to file '%s'", (const char*) fname ); | 336 | qDebug( "Saved hex log to file '%s'", (const char*) fname ); |
337 | } | 337 | } |
338 | else | 338 | else |
339 | { | 339 | { |
340 | qDebug( "Problem saving hex log to file '%s'", (const char*) fname ); | 340 | qDebug( "Problem saving hex log to file '%s'", (const char*) fname ); |
341 | } | 341 | } |
342 | } | 342 | } |
343 | } | 343 | } |
344 | 344 | ||
345 | void WellenreiterMainWindow::fileLoadSession() | 345 | void WellenreiterMainWindow::fileLoadSession() |
346 | { | 346 | { |
347 | QString fname = getFileName( false ); | 347 | QString fname = getFileName( false ); |
348 | if ( !fname.isEmpty() ) | 348 | if ( !fname.isEmpty() ) |
349 | { | 349 | { |
350 | QFile f( fname ); | 350 | QFile f( fname ); |
351 | if ( f.open(IO_ReadOnly) ) | 351 | if ( f.open(IO_ReadOnly) ) |
352 | { | 352 | { |
353 | QDataStream t( &f ); | 353 | QDataStream t( &f ); |
354 | t >> *mw->netView(); | 354 | t >> *mw->netView(); |
355 | f.close(); | 355 | f.close(); |
356 | qDebug( "Loaded session from file '%s'", (const char*) fname ); | 356 | qDebug( "Loaded session from file '%s'", (const char*) fname ); |
357 | } | 357 | } |
358 | else | 358 | else |
359 | { | 359 | { |
360 | qDebug( "Problem loading session from file '%s'", (const char*) fname ); | 360 | qDebug( "Problem loading session from file '%s'", (const char*) fname ); |
361 | } | 361 | } |
362 | } | 362 | } |
363 | } | 363 | } |
364 | 364 | ||
365 | 365 | ||
366 | void WellenreiterMainWindow::fileNew() | 366 | void WellenreiterMainWindow::fileNew() |
367 | { | 367 | { |
368 | mw->netView()->clear(); | 368 | mw->netView()->clear(); |
369 | mw->logWindow()->clear(); | 369 | mw->logWindow()->clear(); |
370 | mw->hexWindow()->clear(); | 370 | mw->hexWindow()->clear(); |
371 | } | 371 | } |
372 | 372 | ||
373 | 373 | ||