summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/settings/networksettings2/networksettings2/system.cpp7
-rw-r--r--noncore/settings/networksettings2/opie-networksettings2.control2
-rw-r--r--noncore/settings/networksettings2/opietooth2/OTSniffGUI.ui15
-rw-r--r--noncore/settings/networksettings2/opietooth2/Opietooth.cpp46
-rw-r--r--noncore/settings/networksettings2/opietooth2/Opietooth.h2
5 files changed, 43 insertions, 29 deletions
diff --git a/noncore/settings/networksettings2/networksettings2/system.cpp b/noncore/settings/networksettings2/networksettings2/system.cpp
index 9512579..e642c08 100644
--- a/noncore/settings/networksettings2/networksettings2/system.cpp
+++ b/noncore/settings/networksettings2/networksettings2/system.cpp
@@ -1,292 +1,293 @@
1#include <sys/types.h> 1#include <sys/types.h>
2#include <sys/wait.h> 2#include <sys/wait.h>
3 3
4#include <net/if.h> 4#include <net/if.h>
5#include <net/if_arp.h> 5#include <net/if_arp.h>
6#include <netinet/in.h> 6#include <netinet/in.h>
7#include <arpa/inet.h> 7#include <arpa/inet.h>
8#include <sys/ioctl.h> 8#include <sys/ioctl.h>
9#include <sys/socket.h> 9#include <sys/socket.h>
10#include <stdlib.h> 10#include <stdlib.h>
11#include <stdio.h> 11#include <stdio.h>
12#include <fcntl.h> 12#include <fcntl.h>
13#include <errno.h> 13#include <errno.h>
14#include <unistd.h> 14#include <unistd.h>
15 15
16#include <opie2/oprocess.h> 16#include <opie2/oprocess.h>
17 17
18#include <qdir.h> 18#include <qdir.h>
19#include <qregexp.h> 19#include <qregexp.h>
20#include <qstringlist.h> 20#include <qstringlist.h>
21#include <qfile.h> 21#include <qfile.h>
22#include <qtextstream.h> 22#include <qtextstream.h>
23#include <qapplication.h> 23#include <qapplication.h>
24 24
25#include "resources.h" 25#include "resources.h"
26#include "system.h" 26#include "system.h"
27 27
28#define PROCNETDEV "/proc/net/dev" 28#define PROCNETDEV "/proc/net/dev"
29 29
30#ifndef ARPHRD_IEEE80211 30#ifndef ARPHRD_IEEE80211
31#define ARPHRD_IEEE80211 801 31#define ARPHRD_IEEE80211 801
32#endif 32#endif
33 33
34static char Dig2Hex[] = { 34static char Dig2Hex[] = {
35 '0', '1', '2', '3', 35 '0', '1', '2', '3',
36 '4', '5', '6', '7', 36 '4', '5', '6', '7',
37 '8', '9', 'A', 'B', 37 '8', '9', 'A', 'B',
38 'C', 'D', 'E', 'F' 38 'C', 'D', 'E', 'F'
39}; 39};
40 40
41// get HIGH nibble of byte 41// get HIGH nibble of byte
42#define HN(x) Dig2Hex[(((x)&0xf0)>>4)] 42#define HN(x) Dig2Hex[(((x)&0xf0)>>4)]
43// get LOW nibble of byte 43// get LOW nibble of byte
44#define LN(x) Dig2Hex[((x)&0x0f)] 44#define LN(x) Dig2Hex[((x)&0x0f)]
45 45
46System::System( void ) : QObject(), ProbedInterfaces() { 46System::System( void ) : QObject(), ProbedInterfaces() {
47 ProcDevNet = 0;
47} 48}
48 49
49System::~System( void ) { 50System::~System( void ) {
50 if( ProcDevNet ) 51 if( ProcDevNet )
51 delete ProcDevNet; 52 delete ProcDevNet;
52} 53}
53 54
54QDict<InterfaceInfo> & System::interfaces( void ) { 55QDict<InterfaceInfo> & System::interfaces( void ) {
55 if( ProbedInterfaces.count() == 0 ) { 56 if( ProbedInterfaces.count() == 0 ) {
56 probeInterfaces(); 57 probeInterfaces();
57 } 58 }
58 return ProbedInterfaces; 59 return ProbedInterfaces;
59} 60}
60 61
61int System::runAsRoot( QStringList & S, MyProcess * Prc ) { 62int System::runAsRoot( QStringList & S, MyProcess * Prc ) {
62 char * usr = getenv("USER"); 63 char * usr = getenv("USER");
63 64
64 if( S.count() == 0 ) { 65 if( S.count() == 0 ) {
65 // loophole to start shell 66 // loophole to start shell
66 return 8888; 67 return 8888;
67 } 68 }
68 if( usr == 0 || strcmp( usr, "root" ) ) { 69 if( usr == 0 || strcmp( usr, "root" ) ) {
69 // unknown or non-root user -> use SUDO 70 // unknown or non-root user -> use SUDO
70 S.prepend( "sudo" ); 71 S.prepend( "sudo" );
71 } 72 }
72 73
73 if( getenv( "NS2TESTMODE" ) ) { 74 if( getenv( "NS2TESTMODE" ) ) {
74 owarn << "TESTMODE !!! execute " 75 owarn << "TESTMODE !!! execute "
75 << S.join( " ") 76 << S.join( " ")
76 << oendl; 77 << oendl;
77 } else { 78 } else {
78 MyProcess * P; 79 MyProcess * P;
79 80
80 if( Prc ) { 81 if( Prc ) {
81 P = Prc; 82 P = Prc;
82 } else { 83 } else {
83 P = new MyProcess(); 84 P = new MyProcess();
84 emit processEvent( tr("Command : ") + S.join( " " ) ); 85 emit processEvent( tr("Command : ") + S.join( " " ) );
85 86
86 connect( P, 87 connect( P,
87 SIGNAL( stdoutLine( const QString & ) ), 88 SIGNAL( stdoutLine( const QString & ) ),
88 this, 89 this,
89 SIGNAL( stdoutLine( const QString & ) ) ); 90 SIGNAL( stdoutLine( const QString & ) ) );
90 91
91 connect( P, 92 connect( P,
92 SIGNAL( stderrLine( const QString & ) ), 93 SIGNAL( stderrLine( const QString & ) ),
93 this, 94 this,
94 SIGNAL( stderrLine( const QString & ) ) ); 95 SIGNAL( stderrLine( const QString & ) ) );
95 96
96 connect( P, 97 connect( P,
97 SIGNAL(processExited(MyProcess*) ), 98 SIGNAL(processExited(MyProcess*) ),
98 this, SLOT 99 this, SLOT
99 (SLOT_ProcessExited(MyProcess*) ) ); 100 (SLOT_ProcessExited(MyProcess*) ) );
100 } 101 }
101 102
102 P->process() << S; 103 P->process() << S;
103 104
104 Log(("Executing %s\n", S.join( " " ).latin1() )); 105 Log(("Executing %s\n", S.join( " " ).latin1() ));
105 106
106 if( ! P->process().start( OProcess::DontCare, 107 if( ! P->process().start( OProcess::DontCare,
107 OProcess::AllOutput ) ) { 108 OProcess::AllOutput ) ) {
108 owarn << "Error starting " << S << oendl; 109 owarn << "Error starting " << S << oendl;
109 if( ! Prc ) 110 if( ! Prc )
110 delete P; 111 delete P;
111 // error starting app 112 // error starting app
112 return 1; 113 return 0;
113 } 114 }
114 owarn << "Started " << S << oendl; 115 owarn << "Started " << S << oendl;
115 } 116 }
116 117
117 // all is fine 118 // all is fine
118 return 0; 119 return 1;
119} 120}
120 121
121int System::execAsUser( QStringList & SL ) { 122int System::execAsUser( QStringList & SL ) {
122 MyProcess * P = new MyProcess(); 123 MyProcess * P = new MyProcess();
123 CurrentQPEUser CU = NSResources->currentUser(); 124 CurrentQPEUser CU = NSResources->currentUser();
124 char * usr = getenv("USER"); 125 char * usr = getenv("USER");
125 126
126 if( strcmp( usr, "root" ) == 0 ) { 127 if( strcmp( usr, "root" ) == 0 ) {
127 // find user running qpe 128 // find user running qpe
128 if( CU.UserName.isEmpty() ) { 129 if( CU.UserName.isEmpty() ) {
129 // if we come here, the exec was not successfull 130 // if we come here, the exec was not successfull
130 Log(("User not known \n" )); 131 Log(("User not known \n" ));
131 return 0; 132 return 0;
132 } 133 }
133 } 134 }
134 135
135 // now we are ready to exec the requested command 136 // now we are ready to exec the requested command
136 setuid( CU.Uid ); 137 setuid( CU.Uid );
137 setgid( CU.Gid ); 138 setgid( CU.Gid );
138 139
139 for( unsigned int i = 0 ; i < CU.EnvList.count() ; i ++ ) { 140 for( unsigned int i = 0 ; i < CU.EnvList.count() ; i ++ ) {
140 QString X; 141 QString X;
141 QStringList SL; 142 QStringList SL;
142 X = CU.EnvList[i]; 143 X = CU.EnvList[i];
143 SL = QStringList::split( "=", X ); 144 SL = QStringList::split( "=", X );
144 P->process().setEnvironment( SL[0], SL[1] ); 145 P->process().setEnvironment( SL[0], SL[1] );
145 } 146 }
146 147
147 P->process() << SL; 148 P->process() << SL;
148 149
149 emit processEvent( tr("Command : ") + SL.join( " " ) ); 150 emit processEvent( tr("Command : ") + SL.join( " " ) );
150 151
151 Log(("Executing as user %s : %s\n", 152 Log(("Executing as user %s : %s\n",
152 CU.UserName.latin1(), 153 CU.UserName.latin1(),
153 SL.join( " " ).latin1() )); 154 SL.join( " " ).latin1() ));
154 155
155 int rv = ( P->process().start( OProcess::DontCare, 156 int rv = ( P->process().start( OProcess::DontCare,
156 OProcess::NoCommunication ) ); 157 OProcess::NoCommunication ) );
157 delete P; 158 delete P;
158 159
159 if( rv ) { 160 if( rv ) {
160 // if we come here, the exec was not successfull 161 // if we come here, the exec was not successfull
161 Log(("Could not exec : %d\n", errno )); 162 Log(("Could not exec : %d\n", errno ));
162 } 163 }
163 164
164 return rv; 165 return ! rv;
165} 166}
166 167
167void System::SLOT_ProcessExited( MyProcess * P ) { 168void System::SLOT_ProcessExited( MyProcess * P ) {
168 QString R; 169 QString R;
169 170
170 for( QValueListConstIterator<QCString> it = P->process().args().begin(); 171 for( QValueListConstIterator<QCString> it = P->process().args().begin();
171 it != P->process().args().end(); 172 it != P->process().args().end();
172 ++it ) { 173 ++it ) {
173 R += (*it); 174 R += (*it);
174 R += " "; 175 R += " ";
175 } 176 }
176 177
177 R += "Returned with " + QString().setNum( P->process().exitStatus() ); 178 R += "Returned with " + QString().setNum( P->process().exitStatus() );
178 emit processEvent( R ); 179 emit processEvent( R );
179 delete P; 180 delete P;
180} 181}
181 182
182void System::refreshStatistics( InterfaceInfo & I ) { 183void System::refreshStatistics( InterfaceInfo & I ) {
183 if( ! ProcDevNet ) { 184 if( ! ProcDevNet ) {
184 return; 185 return;
185 } 186 }
186 // cannot seek on dev 187 // cannot seek on dev
187 ProcDevNet->close(); 188 ProcDevNet->close();
188 ProcDevNet->open( IO_ReadOnly ); 189 ProcDevNet->open( IO_ReadOnly );
189 190
190 QString line; 191 QString line;
191 QTextStream procTs(ProcDevNet); 192 QTextStream procTs(ProcDevNet);
192 QStringList SL; 193 QStringList SL;
193 int loc = -1; 194 int loc = -1;
194 int version; 195 int version;
195 196
196 procTs.readLine(); 197 procTs.readLine();
197 line = procTs.readLine(); 198 line = procTs.readLine();
198 // get version 199 // get version
199 if( line.find("compressed") ) 200 if( line.find("compressed") )
200 version = 3; 201 version = 3;
201 else if( line.find( "bytes" ) ) 202 else if( line.find( "bytes" ) )
202 version = 2; 203 version = 2;
203 else 204 else
204 version = 1; 205 version = 1;
205 while((line = procTs.readLine().simplifyWhiteSpace()) != QString::null) { 206 while((line = procTs.readLine().simplifyWhiteSpace()) != QString::null) {
206 if( (loc = line.find(":") ) == -1) { 207 if( (loc = line.find(":") ) == -1) {
207 continue; 208 continue;
208 } 209 }
209 210
210 if( I.Name != line.left(loc) ) 211 if( I.Name != line.left(loc) )
211 continue; 212 continue;
212 213
213 // tokenize 214 // tokenize
214 SL = QStringList::split( ' ', line, FALSE ); 215 SL = QStringList::split( ' ', line, FALSE );
215 216
216 // update data 217 // update data
217 switch( version ) { 218 switch( version ) {
218 case 1 : 219 case 1 :
219 I.RcvBytes = SL[1]; 220 I.RcvBytes = SL[1];
220 I.RcvErrors = SL[3]; 221 I.RcvErrors = SL[3];
221 I.RcvDropped = SL[4]; 222 I.RcvDropped = SL[4];
222 I.SndBytes = SL[6]; 223 I.SndBytes = SL[6];
223 I.SndErrors = SL[8]; 224 I.SndErrors = SL[8];
224 I.SndDropped = SL[9]; 225 I.SndDropped = SL[9];
225 I.Collisions = SL[11]; 226 I.Collisions = SL[11];
226 break; 227 break;
227 case 2 : 228 case 2 :
228 I.RcvBytes = SL[1]; 229 I.RcvBytes = SL[1];
229 I.RcvErrors = SL[3]; 230 I.RcvErrors = SL[3];
230 I.RcvDropped = SL[4]; 231 I.RcvDropped = SL[4];
231 I.SndBytes = SL[7]; 232 I.SndBytes = SL[7];
232 I.SndErrors = SL[9]; 233 I.SndErrors = SL[9];
233 I.SndDropped = SL[10]; 234 I.SndDropped = SL[10];
234 I.Collisions = SL[12]; 235 I.Collisions = SL[12];
235 break; 236 break;
236 case 3 : 237 case 3 :
237 I.RcvBytes = SL[1]; 238 I.RcvBytes = SL[1];
238 I.RcvErrors = SL[3]; 239 I.RcvErrors = SL[3];
239 I.RcvDropped = SL[4]; 240 I.RcvDropped = SL[4];
240 I.SndBytes = SL[9]; 241 I.SndBytes = SL[9];
241 I.SndErrors = SL[11]; 242 I.SndErrors = SL[11];
242 I.SndDropped = SL[12]; 243 I.SndDropped = SL[12];
243 I.Collisions = SL[14]; 244 I.Collisions = SL[14];
244 break; 245 break;
245 } 246 }
246 break; 247 break;
247 } 248 }
248} 249}
249 250
250// 251//
251// THIS UPDATES THE LIST -> INTERFACES ARE NOT DELETED BUT 252// THIS UPDATES THE LIST -> INTERFACES ARE NOT DELETED BUT
252// FLAGGED AS ! 'IsUp' IF NO LONGER PRESENT 253// FLAGGED AS ! 'IsUp' IF NO LONGER PRESENT
253// 254//
254 255
255void System::probeInterfaces( void ) { 256void System::probeInterfaces( void ) {
256 257
257 // probe interfaces 258 // probe interfaces
258 int sockfd; 259 int sockfd;
259 // get list of all interfaces 260 // get list of all interfaces
260 struct ifreq ifrs; 261 struct ifreq ifrs;
261 InterfaceInfo * IFI; 262 InterfaceInfo * IFI;
262 263
263 // flag all as 'down' 264 // flag all as 'down'
264 for( QDictIterator<InterfaceInfo> it( ProbedInterfaces ); 265 for( QDictIterator<InterfaceInfo> it( ProbedInterfaces );
265 it.current(); 266 it.current();
266 ++it ) { 267 ++it ) {
267 it.current()->IsUp = 0; 268 it.current()->IsUp = 0;
268 } 269 }
269 270
270 sockfd = socket(PF_INET, SOCK_DGRAM, 0); 271 sockfd = socket(PF_INET, SOCK_DGRAM, 0);
271 if(sockfd == -1) { 272 if(sockfd == -1) {
272 owarn << "Cannot open INET socket " 273 owarn << "Cannot open INET socket "
273 << errno 274 << errno
274 << " " 275 << " "
275 << strerror( errno ) 276 << strerror( errno )
276 << oendl; 277 << oendl;
277 return; 278 return;
278 } 279 }
279 280
280 // read interfaces from /proc/dev/net 281 // read interfaces from /proc/dev/net
281 // SIOCGIFCONF does not return ALL interfaces ???!? 282 // SIOCGIFCONF does not return ALL interfaces ???!?
282 ProcDevNet = new QFile(PROCNETDEV); 283 ProcDevNet = new QFile(PROCNETDEV);
283 if( ! ProcDevNet->open(IO_ReadOnly) ) { 284 if( ! ProcDevNet->open(IO_ReadOnly) ) {
284 owarn << "Cannot open " 285 owarn << "Cannot open "
285 << PROCNETDEV 286 << PROCNETDEV
286 << " " 287 << " "
287 << errno 288 << errno
288 << " " 289 << " "
289 << strerror( errno ) 290 << strerror( errno )
290 << oendl; 291 << oendl;
291 delete ProcDevNet; 292 delete ProcDevNet;
292 ProcDevNet =0; 293 ProcDevNet =0;
diff --git a/noncore/settings/networksettings2/opie-networksettings2.control b/noncore/settings/networksettings2/opie-networksettings2.control
index e4bd29c..874833c 100644
--- a/noncore/settings/networksettings2/opie-networksettings2.control
+++ b/noncore/settings/networksettings2/opie-networksettings2.control
@@ -1,10 +1,10 @@
1Package: opie-networksettings2 1Package: opie-networksettings2
2Files: bin/networksettings2 apps/Settings/networksettings2.desktop pics/networksettings2/*.png lib/libnetworksettings2.so* pics/networksettings2/Devices/*.png 2Files: bin/networksettings2 apps/Settings/networksettings2.desktop pics/networksettings2/*.png lib/libnetworksettings2.so* pics/networksettings2/Devices/*.png etc/NS2templates/* etc/NS2templates/*/*
3Priority: optional 3Priority: optional
4Section: opie/settings 4Section: opie/settings
5Maintainer: wim delvaux <wimpie@handhelds.org> 5Maintainer: wim delvaux <wimpie@handhelds.org>
6Architecture: arm 6Architecture: arm
7Depends: task-opie-minimal, libopietooth2 7Depends: task-opie-minimal, libopietooth2
8Description: Network settings. 8Description: Network settings.
9Replaces: opie-networksetup 9Replaces: opie-networksetup
10Version: $QPE_VERSION$EXTRAVERSION 10Version: $QPE_VERSION$EXTRAVERSION
diff --git a/noncore/settings/networksettings2/opietooth2/OTSniffGUI.ui b/noncore/settings/networksettings2/opietooth2/OTSniffGUI.ui
index 9ef540e..ec0b387 100644
--- a/noncore/settings/networksettings2/opietooth2/OTSniffGUI.ui
+++ b/noncore/settings/networksettings2/opietooth2/OTSniffGUI.ui
@@ -1,261 +1,260 @@
1<!DOCTYPE UI><UI> 1<!DOCTYPE UI><UI>
2<class>OTSniffGUI</class> 2<class>OTSniffGUI</class>
3<widget> 3<widget>
4 <class>QWidget</class> 4 <class>QWidget</class>
5 <property stdset="1"> 5 <property stdset="1">
6 <name>name</name> 6 <name>name</name>
7 <cstring>OTSniffGUI</cstring> 7 <cstring>OTSniffGUI</cstring>
8 </property> 8 </property>
9 <property stdset="1"> 9 <property stdset="1">
10 <name>geometry</name> 10 <name>geometry</name>
11 <rect> 11 <rect>
12 <x>0</x> 12 <x>0</x>
13 <y>0</y> 13 <y>0</y>
14 <width>274</width> 14 <width>274</width>
15 <height>160</height> 15 <height>173</height>
16 </rect> 16 </rect>
17 </property> 17 </property>
18 <property stdset="1"> 18 <property stdset="1">
19 <name>caption</name> 19 <name>caption</name>
20 <string>Bluetooth Sniffing</string> 20 <string>Bluetooth Sniffing</string>
21 </property> 21 </property>
22 <property> 22 <property>
23 <name>layoutMargin</name> 23 <name>layoutMargin</name>
24 </property> 24 </property>
25 <property>
26 <name>layoutSpacing</name>
27 </property>
25 <vbox> 28 <vbox>
26 <property stdset="1"> 29 <property stdset="1">
27 <name>margin</name> 30 <name>margin</name>
28 <number>3</number> 31 <number>3</number>
29 </property> 32 </property>
30 <property stdset="1"> 33 <property stdset="1">
31 <name>spacing</name> 34 <name>spacing</name>
32 <number>6</number> 35 <number>2</number>
33 </property> 36 </property>
34 <widget> 37 <widget>
35 <class>QLayoutWidget</class> 38 <class>QLayoutWidget</class>
36 <property stdset="1"> 39 <property stdset="1">
37 <name>name</name> 40 <name>name</name>
38 <cstring>Layout3</cstring> 41 <cstring>Layout3</cstring>
39 </property> 42 </property>
40 <hbox> 43 <hbox>
41 <property stdset="1"> 44 <property stdset="1">
42 <name>margin</name> 45 <name>margin</name>
43 <number>0</number> 46 <number>0</number>
44 </property> 47 </property>
45 <property stdset="1"> 48 <property stdset="1">
46 <name>spacing</name> 49 <name>spacing</name>
47 <number>6</number> 50 <number>6</number>
48 </property> 51 </property>
49 <widget> 52 <widget>
50 <class>QLabel</class> 53 <class>QLabel</class>
51 <property stdset="1"> 54 <property stdset="1">
52 <name>name</name> 55 <name>name</name>
53 <cstring>TextLabel1</cstring> 56 <cstring>TextLabel1</cstring>
54 </property> 57 </property>
55 <property stdset="1"> 58 <property stdset="1">
56 <name>sizePolicy</name> 59 <name>sizePolicy</name>
57 <sizepolicy> 60 <sizepolicy>
58 <hsizetype>0</hsizetype> 61 <hsizetype>0</hsizetype>
59 <vsizetype>1</vsizetype> 62 <vsizetype>1</vsizetype>
60 </sizepolicy> 63 </sizepolicy>
61 </property> 64 </property>
62 <property stdset="1"> 65 <property stdset="1">
63 <name>text</name> 66 <name>text</name>
64 <string>Display data</string> 67 <string>Display data</string>
65 </property> 68 </property>
66 </widget> 69 </widget>
67 <widget> 70 <widget>
68 <class>QComboBox</class> 71 <class>QComboBox</class>
69 <item> 72 <item>
70 <property> 73 <property>
71 <name>text</name> 74 <name>text</name>
72 <string>Hex</string> 75 <string>Hex</string>
73 </property> 76 </property>
74 </item> 77 </item>
75 <item> 78 <item>
76 <property> 79 <property>
77 <name>text</name> 80 <name>text</name>
78 <string>Ascii</string> 81 <string>Ascii</string>
79 </property> 82 </property>
80 </item> 83 </item>
81 <item> 84 <item>
82 <property> 85 <property>
83 <name>text</name> 86 <name>text</name>
84 <string>Both</string> 87 <string>Both</string>
85 </property> 88 </property>
86 </item> 89 </item>
87 <property stdset="1"> 90 <property stdset="1">
88 <name>name</name> 91 <name>name</name>
89 <cstring>DataFormat_CB</cstring> 92 <cstring>DataFormat_CB</cstring>
90 </property> 93 </property>
91 </widget> 94 </widget>
92 <spacer> 95 <spacer>
93 <property> 96 <property>
94 <name>name</name> 97 <name>name</name>
95 <cstring>Spacer1</cstring> 98 <cstring>Spacer1</cstring>
96 </property> 99 </property>
97 <property stdset="1"> 100 <property stdset="1">
98 <name>orientation</name> 101 <name>orientation</name>
99 <enum>Horizontal</enum> 102 <enum>Horizontal</enum>
100 </property> 103 </property>
101 <property stdset="1"> 104 <property stdset="1">
102 <name>sizeType</name> 105 <name>sizeType</name>
103 <enum>Expanding</enum> 106 <enum>Expanding</enum>
104 </property> 107 </property>
105 <property> 108 <property>
106 <name>sizeHint</name> 109 <name>sizeHint</name>
107 <size> 110 <size>
108 <width>20</width> 111 <width>20</width>
109 <height>20</height> 112 <height>20</height>
110 </size> 113 </size>
111 </property> 114 </property>
112 </spacer> 115 </spacer>
113 <widget> 116 <widget>
114 <class>QCheckBox</class> 117 <class>QCheckBox</class>
115 <property stdset="1"> 118 <property stdset="1">
116 <name>name</name> 119 <name>name</name>
117 <cstring>EnableTrace_CB</cstring> 120 <cstring>EnableTrace_CB</cstring>
118 </property> 121 </property>
119 <property stdset="1"> 122 <property stdset="1">
120 <name>text</name> 123 <name>text</name>
121 <string>Trace</string> 124 <string>Trace</string>
122 </property> 125 </property>
123 </widget> 126 </widget>
124 </hbox> 127 </hbox>
125 </widget> 128 </widget>
126 <widget> 129 <widget>
127 <class>QListBox</class> 130 <class>QTextView</class>
128 <property stdset="1"> 131 <property stdset="1">
129 <name>name</name> 132 <name>name</name>
130 <cstring>Output_LB</cstring> 133 <cstring>Output_TV</cstring>
131 </property>
132 <property stdset="1">
133 <name>selectionMode</name>
134 <enum>NoSelection</enum>
135 </property> 134 </property>
136 </widget> 135 </widget>
137 <widget> 136 <widget>
138 <class>QLayoutWidget</class> 137 <class>QLayoutWidget</class>
139 <property stdset="1"> 138 <property stdset="1">
140 <name>name</name> 139 <name>name</name>
141 <cstring>Layout3</cstring> 140 <cstring>Layout3</cstring>
142 </property> 141 </property>
143 <hbox> 142 <hbox>
144 <property stdset="1"> 143 <property stdset="1">
145 <name>margin</name> 144 <name>margin</name>
146 <number>0</number> 145 <number>0</number>
147 </property> 146 </property>
148 <property stdset="1"> 147 <property stdset="1">
149 <name>spacing</name> 148 <name>spacing</name>
150 <number>6</number> 149 <number>6</number>
151 </property> 150 </property>
152 <widget> 151 <widget>
153 <class>QPushButton</class> 152 <class>QPushButton</class>
154 <property stdset="1"> 153 <property stdset="1">
155 <name>name</name> 154 <name>name</name>
156 <cstring>Save_But</cstring> 155 <cstring>Save_But</cstring>
157 </property> 156 </property>
158 <property stdset="1"> 157 <property stdset="1">
159 <name>text</name> 158 <name>text</name>
160 <string>Save</string> 159 <string>Save</string>
161 </property> 160 </property>
162 </widget> 161 </widget>
163 <spacer> 162 <spacer>
164 <property> 163 <property>
165 <name>name</name> 164 <name>name</name>
166 <cstring>Spacer2_2</cstring> 165 <cstring>Spacer2_2</cstring>
167 </property> 166 </property>
168 <property stdset="1"> 167 <property stdset="1">
169 <name>orientation</name> 168 <name>orientation</name>
170 <enum>Horizontal</enum> 169 <enum>Horizontal</enum>
171 </property> 170 </property>
172 <property stdset="1"> 171 <property stdset="1">
173 <name>sizeType</name> 172 <name>sizeType</name>
174 <enum>Expanding</enum> 173 <enum>Expanding</enum>
175 </property> 174 </property>
176 <property> 175 <property>
177 <name>sizeHint</name> 176 <name>sizeHint</name>
178 <size> 177 <size>
179 <width>20</width> 178 <width>20</width>
180 <height>20</height> 179 <height>20</height>
181 </size> 180 </size>
182 </property> 181 </property>
183 </spacer> 182 </spacer>
184 <widget> 183 <widget>
185 <class>QPushButton</class> 184 <class>QPushButton</class>
186 <property stdset="1"> 185 <property stdset="1">
187 <name>name</name> 186 <name>name</name>
188 <cstring>Load_But</cstring> 187 <cstring>Load_But</cstring>
189 </property> 188 </property>
190 <property stdset="1"> 189 <property stdset="1">
191 <name>text</name> 190 <name>text</name>
192 <string>Load</string> 191 <string>Load</string>
193 </property> 192 </property>
194 </widget> 193 </widget>
195 <spacer> 194 <spacer>
196 <property> 195 <property>
197 <name>name</name> 196 <name>name</name>
198 <cstring>Spacer2</cstring> 197 <cstring>Spacer2</cstring>
199 </property> 198 </property>
200 <property stdset="1"> 199 <property stdset="1">
201 <name>orientation</name> 200 <name>orientation</name>
202 <enum>Horizontal</enum> 201 <enum>Horizontal</enum>
203 </property> 202 </property>
204 <property stdset="1"> 203 <property stdset="1">
205 <name>sizeType</name> 204 <name>sizeType</name>
206 <enum>Expanding</enum> 205 <enum>Expanding</enum>
207 </property> 206 </property>
208 <property> 207 <property>
209 <name>sizeHint</name> 208 <name>sizeHint</name>
210 <size> 209 <size>
211 <width>20</width> 210 <width>20</width>
212 <height>20</height> 211 <height>20</height>
213 </size> 212 </size>
214 </property> 213 </property>
215 </spacer> 214 </spacer>
216 <widget> 215 <widget>
217 <class>QPushButton</class> 216 <class>QPushButton</class>
218 <property stdset="1"> 217 <property stdset="1">
219 <name>name</name> 218 <name>name</name>
220 <cstring>ClearLog_But</cstring> 219 <cstring>ClearLog_But</cstring>
221 </property> 220 </property>
222 <property stdset="1"> 221 <property stdset="1">
223 <name>text</name> 222 <name>text</name>
224 <string>Clear log</string> 223 <string>Clear log</string>
225 </property> 224 </property>
226 </widget> 225 </widget>
227 </hbox> 226 </hbox>
228 </widget> 227 </widget>
229 </vbox> 228 </vbox>
230</widget> 229</widget>
231<connections> 230<connections>
232 <connection> 231 <connection>
233 <sender>EnableTrace_CB</sender> 232 <sender>EnableTrace_CB</sender>
234 <signal>toggled(bool)</signal> 233 <signal>toggled(bool)</signal>
235 <receiver>OTSniffGUI</receiver> 234 <receiver>OTSniffGUI</receiver>
236 <slot>SLOT_Trace( bool )</slot> 235 <slot>SLOT_Trace( bool )</slot>
237 </connection> 236 </connection>
238 <connection> 237 <connection>
239 <sender>ClearLog_But</sender> 238 <sender>ClearLog_But</sender>
240 <signal>clicked()</signal> 239 <signal>clicked()</signal>
241 <receiver>OTSniffGUI</receiver> 240 <receiver>OTSniffGUI</receiver>
242 <slot>SLOT_ClearLog()</slot> 241 <slot>SLOT_ClearLog()</slot>
243 </connection> 242 </connection>
244 <connection> 243 <connection>
245 <sender>Save_But</sender> 244 <sender>Save_But</sender>
246 <signal>clicked()</signal> 245 <signal>clicked()</signal>
247 <receiver>OTSniffGUI</receiver> 246 <receiver>OTSniffGUI</receiver>
248 <slot>SLOT_Save()</slot> 247 <slot>SLOT_Save()</slot>
249 </connection> 248 </connection>
250 <connection> 249 <connection>
251 <sender>Load_But</sender> 250 <sender>Load_But</sender>
252 <signal>clicked()</signal> 251 <signal>clicked()</signal>
253 <receiver>OTSniffGUI</receiver> 252 <receiver>OTSniffGUI</receiver>
254 <slot>SLOT_Load()</slot> 253 <slot>SLOT_Load()</slot>
255 </connection> 254 </connection>
256 <slot access="public">SLOT_ClearLog()</slot> 255 <slot access="public">SLOT_ClearLog()</slot>
257 <slot access="public">SLOT_Save()</slot> 256 <slot access="public">SLOT_Save()</slot>
258 <slot access="public">SLOT_Trace( bool )</slot> 257 <slot access="public">SLOT_Trace( bool )</slot>
259 <slot access="public">SLOT_Load()</slot> 258 <slot access="public">SLOT_Load()</slot>
260</connections> 259</connections>
261</UI> 260</UI>
diff --git a/noncore/settings/networksettings2/opietooth2/Opietooth.cpp b/noncore/settings/networksettings2/opietooth2/Opietooth.cpp
index 5a890da..b14cc2f 100644
--- a/noncore/settings/networksettings2/opietooth2/Opietooth.cpp
+++ b/noncore/settings/networksettings2/opietooth2/Opietooth.cpp
@@ -1,364 +1,380 @@
1#include <opie2/odebug.h> 1#include <opie2/odebug.h>
2#include <opie2/oledbox.h> 2#include <opie2/oledbox.h>
3#include <opie2/ofiledialog.h> 3#include <opie2/ofiledialog.h>
4 4
5using namespace Opie::Core; 5using namespace Opie::Core;
6using namespace Opie::Ui; 6using namespace Opie::Ui;
7 7
8#include <qpe/resource.h> 8#include <qpe/resource.h>
9#include <qapplication.h> 9#include <qapplication.h>
10#include <qcheckbox.h> 10#include <qcheckbox.h>
11#include <qcombobox.h> 11#include <qcombobox.h>
12#include <qdialog.h> 12#include <qdialog.h>
13#include <qdir.h> 13#include <qdir.h>
14#include <qfile.h> 14#include <qfile.h>
15#include <qgroupbox.h> 15#include <qgroupbox.h>
16#include <qheader.h> 16#include <qheader.h>
17#include <qlabel.h> 17#include <qlabel.h>
18#include <qlayout.h> 18#include <qlayout.h>
19#include <qlistbox.h> 19#include <qlistbox.h>
20#include <qlistview.h> 20#include <qlistview.h>
21#include <qmessagebox.h> 21#include <qmessagebox.h>
22#include <qprogressbar.h> 22#include <qprogressbar.h>
23#include <qpushbutton.h> 23#include <qpushbutton.h>
24#include <qscrollbar.h>
24#include <qtextstream.h> 25#include <qtextstream.h>
26#include <qtextview.h>
25 27
26#include <Opietooth.h> 28#include <Opietooth.h>
27#include <OTDriver.h> 29#include <OTDriver.h>
28#include <OTPeer.h> 30#include <OTPeer.h>
29#include <OTGateway.h> 31#include <OTGateway.h>
30#include <OTSDPAttribute.h> 32#include <OTSDPAttribute.h>
31#include <OTSDPService.h> 33#include <OTSDPService.h>
32#include <OTInquiry.h> 34#include <OTInquiry.h>
33 35
34#include <system.h> 36#include <system.h>
35 37
36using namespace Opietooth2; 38using namespace Opietooth2;
37 39
38namespace Opietooth2 { 40namespace Opietooth2 {
39 41
40class PeerLVI : public QListViewItem { 42class PeerLVI : public QListViewItem {
41 43
42public : 44public :
43 45
44 PeerLVI( OTPeer * P, QListView * it ) : QListViewItem (it) { 46 PeerLVI( OTPeer * P, QListView * it ) : QListViewItem (it) {
45 Peer = P; 47 Peer = P;
46 } 48 }
47 ~PeerLVI( void ) { 49 ~PeerLVI( void ) {
48 } 50 }
49 51
50 inline OTPeer * peer( void ) 52 inline OTPeer * peer( void )
51 { return Peer; } 53 { return Peer; }
52 54
53private : 55private :
54 56
55 OTPeer * Peer; 57 OTPeer * Peer;
56}; 58};
57 59
58class ChannelLVI : public QListViewItem { 60class ChannelLVI : public QListViewItem {
59 61
60public : 62public :
61 63
62 ChannelLVI( int Ch, QListViewItem * it ) : QListViewItem (it) { 64 ChannelLVI( int Ch, QListViewItem * it ) : QListViewItem (it) {
63 Channel = Ch; 65 Channel = Ch;
64 } 66 }
65 ~ChannelLVI( void ) { 67 ~ChannelLVI( void ) {
66 } 68 }
67 69
68 inline int channel( void ) 70 inline int channel( void )
69 { return Channel; } 71 { return Channel; }
70 72
71private : 73private :
72 74
73 int Channel; 75 int Channel;
74}; 76};
75 77
76class DriverLVI : public QListViewItem { 78class DriverLVI : public QListViewItem {
77 79
78public : 80public :
79 81
80 DriverLVI( OTDriver * P, QListView * it ) : QListViewItem (it) { 82 DriverLVI( OTDriver * P, QListView * it ) : QListViewItem (it) {
81 Driver = P; 83 Driver = P;
82 } 84 }
83 ~DriverLVI( void ) { 85 ~DriverLVI( void ) {
84 } 86 }
85 87
86 inline OTDriver * driver( void ) 88 inline OTDriver * driver( void )
87 { return Driver; } 89 { return Driver; }
88 90
89private : 91private :
90 92
91 OTDriver * Driver; 93 OTDriver * Driver;
92}; 94};
93 95
94class LinkKeyLVI : public QListViewItem { 96class LinkKeyLVI : public QListViewItem {
95 97
96public : 98public :
97 99
98 LinkKeyLVI( int Ch, QListView * it ) : QListViewItem (it) { 100 LinkKeyLVI( int Ch, QListView * it ) : QListViewItem (it) {
99 LinkKey = Ch; 101 LinkKey = Ch;
100 } 102 }
101 ~LinkKeyLVI( void ) { 103 ~LinkKeyLVI( void ) {
102 } 104 }
103 105
104 inline int index( void ) 106 inline int index( void )
105 { return LinkKey; } 107 { return LinkKey; }
106 108
107private : 109private :
108 110
109 int LinkKey; 111 int LinkKey;
110}; 112};
111}; 113};
112 114
113// 115//
114// 116//
115// 117//
116// 118//
117// 119//
118 120
119OTSniffing::OTSniffing( QWidget * parent ) : OTSniffGUI( parent ) { 121OTSniffing::OTSniffing( QWidget * parent ) : OTSniffGUI( parent ) {
120 122
121 OT = OTGateway::getOTGateway(); 123 OT = OTGateway::getOTGateway();
122 HciDump = 0; 124 HciDump = 0;
123 Sys = new System();
124} 125}
125 126
126OTSniffing::~OTSniffing() { 127OTSniffing::~OTSniffing() {
127 printf( "CLOSE \n" ); 128 SLOT_Trace( 0 );
128 if ( HciDump ) {
129 HciDump->process().kill();
130 delete HciDump;
131 }
132 delete Sys;
133} 129}
134 130
135void OTSniffing::SLOT_Trace( bool ) { 131void OTSniffing::SLOT_Trace( bool Run ) {
132
133 if( ! Run ) {
134 if ( HciDump ) {
135 HciDump->process().kill();
136 delete HciDump;
137 }
138 HciDump = 0;
139 return;
140 }
141
136 HciDump = new MyProcess(); 142 HciDump = new MyProcess();
137 QStringList SL; 143 QStringList SL;
138 144
139 SL << "hcidump"; 145 SL << "/usr/sbin/hcidump";
140 switch( DataFormat_CB->currentItem() ) { 146 switch( DataFormat_CB->currentItem() ) {
141 case 0 : // Hex 147 case 0 : // Hex
142 SL << "-x"; 148 SL << "-x";
143 break; 149 break;
144 case 1 : // Ascii 150 case 1 : // Ascii
145 SL << "-a"; 151 SL << "-a";
146 break; 152 break;
147 case 2 : // both 153 case 2 : // both
148 SL << "-X"; 154 SL << "-X";
149 break; 155 break;
150 } 156 }
151 157
152 SL << "-i"; 158 SL << "-i";
153 SL << OT->scanWith()->devname(); 159 SL << OT->scanWith()->devname();
154 160
155 connect( HciDump, 161 connect( HciDump,
156 SIGNAL( stdoutLine( const QString & ) ), 162 SIGNAL( stdoutLine( const QString & ) ),
157 this, 163 this,
158 SLOT( SLOT_Show( const QString & ) ) ); 164 SLOT( SLOT_Show( const QString & ) ) );
159 165
160 connect( HciDump, 166 connect( HciDump,
161 SIGNAL(processExited(MyProcess*) ), 167 SIGNAL(processExited(MyProcess*) ),
162 this, 168 this,
163 SLOT( SLOT_ProcessExited(MyProcess*) ) ); 169 SLOT( SLOT_ProcessExited(MyProcess*) ) );
164 170
165 if( ! Sys->runAsRoot( SL, HciDump ) ) { 171 HciDump->process() << SL;
172
173 if( ! HciDump->process().start( OProcess::DontCare,
174 OProcess::AllOutput )
175 ) {
166 QMessageBox::warning(0, 176 QMessageBox::warning(0,
167 tr("Run hcidump"), 177 tr("Run hcidump"),
168 tr("Cannot start %1").arg(SL.join(" ")) 178 tr("Cannot start %1").arg(SL.join(" "))
169 ); 179 );
170 delete HciDump; 180 delete HciDump;
171 HciDump = 0; 181 HciDump = 0;
172 } 182 }
173 183
174} 184}
175 185
176void OTSniffing::SLOT_Show( const QString & S ) { 186void OTSniffing::SLOT_Show( const QString & S ) {
177 printf( "%s\n", S.latin1() ); 187 printf( "%s\n", S.latin1() );
178 Output_LB->insertItem( S ); 188 Output_TV->setText( Output_TV->text() + S + "\n" );
179 Output_LB->setCurrentItem( Output_LB->count()-1 ); 189
180 Output_LB->ensureCurrentVisible(); 190 QScrollBar *scroll = Output_TV->verticalScrollBar();
191 scroll->setValue(scroll->maxValue());
192 //Output_LB->insertItem( S );
193 //Output_LB->setCurrentItem( Output_LB->count()-1 );
194 //Output_LB->ensureCurrentVisible();
181} 195}
182 196
183void OTSniffing::SLOT_ProcessExited( MyProcess * ) { 197void OTSniffing::SLOT_ProcessExited( MyProcess * ) {
184 printf( "Exited\n" ); 198 printf( "Exited\n" );
185 delete HciDump; 199 delete HciDump;
186 HciDump = 0; 200 HciDump = 0;
187} 201}
188 202
189void OTSniffing::SLOT_Save( void ) { 203void OTSniffing::SLOT_Save( void ) {
190 QString S = OFileDialog::getSaveFileName( 204 QString S = OFileDialog::getSaveFileName(
191 OFileSelector::Extended, 205 OFileSelector::Extended,
192 QDir::home().path(), 206 QDir::home().path(),
193 QString::null, 207 QString::null,
194 MimeTypes(), 208 MimeTypes(),
195 this ); 209 this );
196 210
197 if( ! S.isEmpty() ) { 211 if( ! S.isEmpty() ) {
198 QFile F( S ); 212 QFile F( S );
199 if( ! F.open( IO_WriteOnly ) ) { 213 if( ! F.open( IO_WriteOnly ) ) {
200 QMessageBox::warning(0, 214 QMessageBox::warning(0,
201 tr("Save log"), 215 tr("Save log"),
202 tr("Cannot open %1").arg(S) 216 tr("Cannot open %1").arg(S)
203 ); 217 );
204 return; 218 return;
205 } 219 }
206 QTextStream TS( &F ); 220 QTextStream TS( &F );
207 TS << S << endl; 221 TS << S << endl;
208 } 222 }
209} 223}
210 224
211void OTSniffing::SLOT_Load( void ) { 225void OTSniffing::SLOT_Load( void ) {
212 QString S = OFileDialog::getOpenFileName( 226 QString S = OFileDialog::getOpenFileName(
213 OFileSelector::Extended, 227 OFileSelector::Extended,
214 QDir::home().path(), 228 QDir::home().path(),
215 QString::null, 229 QString::null,
216 MimeTypes(), 230 MimeTypes(),
217 this ); 231 this );
218 232
219 if( ! S.isEmpty() ) { 233 if( ! S.isEmpty() ) {
220 QFile F( S ); 234 QFile F( S );
221 if( ! F.open( IO_ReadOnly ) ) { 235 if( ! F.open( IO_ReadOnly ) ) {
222 QMessageBox::warning(0, 236 QMessageBox::warning(0,
223 tr("Save log"), 237 tr("Save log"),
224 tr("Cannot open %1").arg(S) 238 tr("Cannot open %1").arg(S)
225 ); 239 );
226 return; 240 return;
227 } 241 }
228 QTextStream TS ( &F ); 242 QTextStream TS ( &F );
229 SLOT_ClearLog(); 243 SLOT_ClearLog();
230 S = TS.read(); 244 S = TS.read();
231 Output_LB->insertStringList( QStringList::split( "\n", S ) ); 245 // Output_LB->insertStringList( QStringList::split( "\n", S ) );
246 Output_TV->setText( S );
232 } 247 }
233} 248}
234 249
235void OTSniffing::SLOT_ClearLog( void ) { 250void OTSniffing::SLOT_ClearLog( void ) {
236 Output_LB->clear(); 251 // Output_LB->clear();
252 Output_TV->setText( "" );
237} 253}
238 254
239// 255//
240// 256//
241// 257//
242// 258//
243// 259//
244 260
245OTPairing::OTPairing( QWidget * parent, OTIcons * _IC ) : 261OTPairing::OTPairing( QWidget * parent, OTIcons * _IC ) :
246 OTPairingGUI( parent ) { 262 OTPairingGUI( parent ) {
247 263
248 OT = OTGateway::getOTGateway(); 264 OT = OTGateway::getOTGateway();
249 Icons = (_IC ) ? _IC : new OTIcons(); 265 Icons = (_IC ) ? _IC : new OTIcons();
250 MyIcons = (_IC == 0 ); 266 MyIcons = (_IC == 0 );
251 267
252 // unpairing can only be done if bluetooth is disabled 268 // unpairing can only be done if bluetooth is disabled
253 Unpair_But->setEnabled( ! OT->isEnabled() ); 269 Unpair_But->setEnabled( ! OT->isEnabled() );
254 if( ! OT->isEnabled() ) { 270 if( ! OT->isEnabled() ) {
255 Unpair_LBL->hide(); 271 Unpair_LBL->hide();
256 } else { 272 } else {
257 Unpair_LBL->show(); 273 Unpair_LBL->show();
258 } 274 }
259 275
260 // open linkkey file and load pairs 276 // open linkkey file and load pairs
261 LinkKeyArray Keys = OT->getLinkKeys(); 277 LinkKeyArray Keys = OT->getLinkKeys();
262 LinkKeyLVI * it; 278 LinkKeyLVI * it;
263 OTPeer * P; 279 OTPeer * P;
264 OTDriver * D; 280 OTDriver * D;
265 281
266 for( unsigned int i = 0 ; 282 for( unsigned int i = 0 ;
267 i < Keys.count(); 283 i < Keys.count();
268 i ++ ) { 284 i ++ ) {
269 285
270 it = new LinkKeyLVI( i, Pairs_LV ); 286 it = new LinkKeyLVI( i, Pairs_LV );
271 287
272 P = 0; 288 P = 0;
273 D = OT->findDriver( Keys[i].from() ); 289 D = OT->findDriver( Keys[i].from() );
274 290
275 if( D ) { 291 if( D ) {
276 it->setText( 0, D->devname() ); 292 it->setText( 0, D->devname() );
277 293
278 // we are source 294 // we are source
279 P = OT->findPeer( Keys[i].to() ); 295 P = OT->findPeer( Keys[i].to() );
280 296
281 if( P ) { 297 if( P ) {
282 // put name 298 // put name
283 it->setText( 1, P->name() ); 299 it->setText( 1, P->name() );
284 } else { 300 } else {
285 // unknown 301 // unknown
286 it->setText( 1, Keys[i].to().toString() ); 302 it->setText( 1, Keys[i].to().toString() );
287 } 303 }
288 304
289 // and put address as sub 305 // and put address as sub
290 QListViewItem * Sub = new QListViewItem( it ); 306 QListViewItem * Sub = new QListViewItem( it );
291 Sub->setText( 0, D->address().toString() ); 307 Sub->setText( 0, D->address().toString() );
292 Sub->setText( 1, Keys[i].to().toString() ); 308 Sub->setText( 1, Keys[i].to().toString() );
293 } else { 309 } else {
294 // perhaps we are destination 310 // perhaps we are destination
295 D = OT->findDriver( Keys[i].to() ); 311 D = OT->findDriver( Keys[i].to() );
296 312
297 if( D ) { 313 if( D ) {
298 it->setText( 1, D->devname() ); 314 it->setText( 1, D->devname() );
299 315
300 // we are source 316 // we are source
301 P = OT->findPeer( Keys[i].from() ); 317 P = OT->findPeer( Keys[i].from() );
302 318
303 if( P ) { 319 if( P ) {
304 // put name 320 // put name
305 it->setText( 0, P->name() ); 321 it->setText( 0, P->name() );
306 } else { 322 } else {
307 // unknown 323 // unknown
308 it->setText( 0, Keys[i].from().toString() ); 324 it->setText( 0, Keys[i].from().toString() );
309 } 325 }
310 326
311 // and put address as sub 327 // and put address as sub
312 QListViewItem * Sub = new QListViewItem( it ); 328 QListViewItem * Sub = new QListViewItem( it );
313 Sub->setText( 0, Keys[i].from().toString() ); 329 Sub->setText( 0, Keys[i].from().toString() );
314 Sub->setText( 1, D->address().toString() ); 330 Sub->setText( 1, D->address().toString() );
315 } else { 331 } else {
316 // nor source nor destination -> unknown 332 // nor source nor destination -> unknown
317 it->setText( 0, Keys[i].from().toString() ); 333 it->setText( 0, Keys[i].from().toString() );
318 it->setText( 1, Keys[i].to().toString() ); 334 it->setText( 1, Keys[i].to().toString() );
319 } 335 }
320 } 336 }
321 } 337 }
322} 338}
323 339
324 340
325OTPairing::~OTPairing() { 341OTPairing::~OTPairing() {
326 if( MyIcons ) 342 if( MyIcons )
327 delete Icons; 343 delete Icons;
328 OTGateway::releaseOTGateway(); 344 OTGateway::releaseOTGateway();
329} 345}
330 346
331void OTPairing::SLOT_Unpair( ) { 347void OTPairing::SLOT_Unpair( ) {
332 // find selected pair 348 // find selected pair
333 349
334 QListViewItem * it = Pairs_LV->firstChild(); 350 QListViewItem * it = Pairs_LV->firstChild();
335 while( it ) { 351 while( it ) {
336 if( it->isSelected() ) { 352 if( it->isSelected() ) {
337 // confirm ? 353 // confirm ?
338 if( QMessageBox::warning(0, 354 if( QMessageBox::warning(0,
339 tr("Break pairing"), 355 tr("Break pairing"),
340 tr("Sure ?"), 356 tr("Sure ?"),
341 tr("Yes, break"), 357 tr("Yes, break"),
342 tr("No, don't break") ) == 0 ) { 358 tr("No, don't break") ) == 0 ) {
343 LinkKeyLVI * KPIt = (LinkKeyLVI *)it; 359 LinkKeyLVI * KPIt = (LinkKeyLVI *)it;
344 // break 360 // break
345 OT->removeLinkKey( KPIt->index() ); 361 OT->removeLinkKey( KPIt->index() );
346 delete KPIt; 362 delete KPIt;
347 } 363 }
348 return; 364 return;
349 } 365 }
350 it= it->nextSibling(); 366 it= it->nextSibling();
351 } 367 }
352} 368}
353 369
354// 370//
355// 371//
356// 372//
357// 373//
358// 374//
359 375
360OTScan::OTScan( QWidget * parent, OTIcons * _IC ) : 376OTScan::OTScan( QWidget * parent, OTIcons * _IC ) :
361 OTScanGUI( parent ), Filter() { 377 OTScanGUI( parent ), Filter() {
362 378
363 OT = OTGateway::getOTGateway(); 379 OT = OTGateway::getOTGateway();
364 Icons = (_IC ) ? _IC : new OTIcons(); 380 Icons = (_IC ) ? _IC : new OTIcons();
diff --git a/noncore/settings/networksettings2/opietooth2/Opietooth.h b/noncore/settings/networksettings2/opietooth2/Opietooth.h
index 2b20975..e66787f 100644
--- a/noncore/settings/networksettings2/opietooth2/Opietooth.h
+++ b/noncore/settings/networksettings2/opietooth2/Opietooth.h
@@ -1,182 +1,180 @@
1#ifndef OPIETOOTH_H 1#ifndef OPIETOOTH_H
2#define OPIETOOTH_H 2#define OPIETOOTH_H
3 3
4#include <OTIcons.h> 4#include <OTIcons.h>
5 5
6class MyProcess; 6class MyProcess;
7class System;
8 7
9namespace Opie { 8namespace Opie {
10 9
11 namespace Ui { 10 namespace Ui {
12 11
13 class OLedBox; 12 class OLedBox;
14 13
15 }; 14 };
16 15
17}; 16};
18 17
19#include <OTSniffGUI.h> 18#include <OTSniffGUI.h>
20namespace Opietooth2 { 19namespace Opietooth2 {
21 20
22class OTGateway; 21class OTGateway;
23class OTDriver; 22class OTDriver;
24class OTInquiry; 23class OTInquiry;
25class OTPeer; 24class OTPeer;
26class PeerLVI; 25class PeerLVI;
27 26
28class OTSniffing : public OTSniffGUI { 27class OTSniffing : public OTSniffGUI {
29 28
30 Q_OBJECT 29 Q_OBJECT
31 30
32public : 31public :
33 32
34 OTSniffing( QWidget * parent ); 33 OTSniffing( QWidget * parent );
35 ~OTSniffing(); 34 ~OTSniffing();
36 35
37private slots : 36private slots :
38 37
39 void SLOT_Trace( bool ); 38 void SLOT_Trace( bool );
40 void SLOT_ClearLog( void ); 39 void SLOT_ClearLog( void );
41 void SLOT_Load( void ); 40 void SLOT_Load( void );
42 void SLOT_Save( void ); 41 void SLOT_Save( void );
43 void SLOT_ProcessExited( MyProcess * ); 42 void SLOT_ProcessExited( MyProcess * );
44 void SLOT_Show( const QString & ); 43 void SLOT_Show( const QString & );
45 44
46signals : 45signals :
47 46
48protected : 47protected :
49 48
50private : 49private :
51 50
52 OTGateway * OT; 51 OTGateway * OT;
53 MyProcess * HciDump; 52 MyProcess * HciDump;
54 System * Sys;
55}; 53};
56}; 54};
57 55
58#include <OTPairingGUI.h> 56#include <OTPairingGUI.h>
59 57
60namespace Opietooth2 { 58namespace Opietooth2 {
61class OTPairing : public OTPairingGUI { 59class OTPairing : public OTPairingGUI {
62 60
63 Q_OBJECT 61 Q_OBJECT
64 62
65public : 63public :
66 64
67 OTPairing( QWidget * parent, 65 OTPairing( QWidget * parent,
68 OTIcons * _Ic = 0 ); 66 OTIcons * _Ic = 0 );
69 ~OTPairing(); 67 ~OTPairing();
70 68
71private slots : 69private slots :
72 70
73 void SLOT_Unpair( void ); 71 void SLOT_Unpair( void );
74 72
75signals : 73signals :
76 74
77protected : 75protected :
78 76
79private : 77private :
80 78
81 bool MyIcons; 79 bool MyIcons;
82 OTIcons * Icons; 80 OTIcons * Icons;
83 OTGateway * OT; 81 OTGateway * OT;
84}; 82};
85}; 83};
86 84
87#include <OTScanGUI.h> 85#include <OTScanGUI.h>
88 86
89namespace Opietooth2 { 87namespace Opietooth2 {
90 88
91class OTGateway; 89class OTGateway;
92class OTDriver; 90class OTDriver;
93class OTInquiry; 91class OTInquiry;
94class OTPeer; 92class OTPeer;
95 93
96class OTScan : public OTScanGUI { 94class OTScan : public OTScanGUI {
97 95
98 Q_OBJECT 96 Q_OBJECT
99 97
100public : 98public :
101 99
102 OTScan( QWidget * parent, 100 OTScan( QWidget * parent,
103 OTIcons * _Ic = 0 ); 101 OTIcons * _Ic = 0 );
104 ~OTScan(); 102 ~OTScan();
105 103
106 // static function to return a device and a channel 104 // static function to return a device and a channel
107 static int getDevice( OTPeer *& Peer, 105 static int getDevice( OTPeer *& Peer,
108 int & Channel, 106 int & Channel,
109 OTGateway * OT, 107 OTGateway * OT,
110 const UUIDVector & Filter = 0, 108 const UUIDVector & Filter = 0,
111 QWidget* Parent = 0); 109 QWidget* Parent = 0);
112 110
113 // show only services that match any of the filter 111 // show only services that match any of the filter
114 void setScanFilter( const UUIDVector & Filter ); 112 void setScanFilter( const UUIDVector & Filter );
115 void resetScanFilter( void ); 113 void resetScanFilter( void );
116 114
117 inline OTPeer * selectedPeer( void ) 115 inline OTPeer * selectedPeer( void )
118 { return SelectedPeer; } 116 { return SelectedPeer; }
119 inline int selectedChannel( void ) 117 inline int selectedChannel( void )
120 { return SelectedChannel; } 118 { return SelectedChannel; }
121 119
122public slots : 120public slots :
123 121
124private slots : 122private slots :
125 123
126 void SLOT_DoScan( bool ); 124 void SLOT_DoScan( bool );
127 void SLOT_NewPeer( OTPeer *, bool ); 125 void SLOT_NewPeer( OTPeer *, bool );
128 void SLOT_FinishedDetecting(); 126 void SLOT_FinishedDetecting();
129 void SLOT_Show( QListViewItem *); 127 void SLOT_Show( QListViewItem *);
130 void SLOT_RefreshServices( void ); 128 void SLOT_RefreshServices( void );
131 void SLOT_RefreshState( void ); 129 void SLOT_RefreshState( void );
132 void SLOT_CleanupOld( void ); 130 void SLOT_CleanupOld( void );
133 void SLOT_UpdateStrength( void ); 131 void SLOT_UpdateStrength( void );
134 void SLOT_PeerState( OTPeer * ); 132 void SLOT_PeerState( OTPeer * );
135 void SLOT_Selected( QListViewItem * ); 133 void SLOT_Selected( QListViewItem * );
136 134
137signals : 135signals :
138 136
139 void selected( void ); 137 void selected( void );
140 138
141protected : 139protected :
142 140
143private : 141private :
144 142
145 void refreshState( PeerLVI *, bool ); 143 void refreshState( PeerLVI *, bool );
146 void scanMode( bool ); 144 void scanMode( bool );
147 145
148 // load scanned devices 146 // load scanned devices
149 147
150 bool MyIcons; 148 bool MyIcons;
151 OTIcons * Icons; 149 OTIcons * Icons;
152 OTGateway * OT; 150 OTGateway * OT;
153 OTInquiry * Scanning; 151 OTInquiry * Scanning;
154 UUIDVector Filter; 152 UUIDVector Filter;
155 153
156 Opie::Ui::OLedBox * Paired_Led; 154 Opie::Ui::OLedBox * Paired_Led;
157 QTimer * StrengthTimer; 155 QTimer * StrengthTimer;
158 PeerLVI * Current; 156 PeerLVI * Current;
159 157
160 OTPeer * SelectedPeer; 158 OTPeer * SelectedPeer;
161 int SelectedChannel; 159 int SelectedChannel;
162}; 160};
163}; 161};
164 162
165#include <OTManageGUI.h> 163#include <OTManageGUI.h>
166namespace Opietooth2 { 164namespace Opietooth2 {
167 165
168class OTManage : public OTManageGUI { 166class OTManage : public OTManageGUI {
169 167
170 Q_OBJECT 168 Q_OBJECT
171 169
172public : 170public :
173 171
174 OTManage( QWidget * parent, 172 OTManage( QWidget * parent,
175 OTIcons * _IC = 0 ); 173 OTIcons * _IC = 0 );
176 ~OTManage(); 174 ~OTManage();
177 175
178public slots : 176public slots :
179 177
180private slots : 178private slots :
181 179
182 void SLOT_ShowDriver( QListViewItem * ); 180 void SLOT_ShowDriver( QListViewItem * );