author | mickeyl <mickeyl> | 2003-03-30 02:48:55 (UTC) |
---|---|---|
committer | mickeyl <mickeyl> | 2003-03-30 02:48:55 (UTC) |
commit | 1d5a00fa8db662c4a5f6490d26d4e2ef1836f118 (patch) (unidiff) | |
tree | f805788cab0fb5395e1e2e9c6e18b3644c9b91e6 /libopie2 | |
parent | 35e4d0b2a71b8ca15baeb0b0383af21fc1d8d3ae (diff) | |
download | opie-1d5a00fa8db662c4a5f6490d26d4e2ef1836f118.zip opie-1d5a00fa8db662c4a5f6490d26d4e2ef1836f118.tar.gz opie-1d5a00fa8db662c4a5f6490d26d4e2ef1836f118.tar.bz2 |
yet more fixes for gcc 2.9x and for our ancient wireless extensions on the Z... *sigh*
-rw-r--r-- | libopie2/opiecore/oglobalsettings.cpp | 6 | ||||
-rw-r--r-- | libopie2/opienet/onetwork.cpp | 3 | ||||
-rw-r--r-- | libopie2/opienet/onetwork.h | 8 |
3 files changed, 13 insertions, 4 deletions
diff --git a/libopie2/opiecore/oglobalsettings.cpp b/libopie2/opiecore/oglobalsettings.cpp index 184ee69..1799529 100644 --- a/libopie2/opiecore/oglobalsettings.cpp +++ b/libopie2/opiecore/oglobalsettings.cpp | |||
@@ -427,99 +427,99 @@ void OGlobalSettings::initStatic() // should be called initPaths(). Don't put an | |||
427 | s_desktopPath->prepend( QDir::homeDirPath() + "/" ); | 427 | s_desktopPath->prepend( QDir::homeDirPath() + "/" ); |
428 | *s_desktopPath = QDir::cleanDirPath( *s_desktopPath ); | 428 | *s_desktopPath = QDir::cleanDirPath( *s_desktopPath ); |
429 | if ( s_desktopPath->right(1) != "/") | 429 | if ( s_desktopPath->right(1) != "/") |
430 | *s_desktopPath += "/"; | 430 | *s_desktopPath += "/"; |
431 | 431 | ||
432 | // Trash Path | 432 | // Trash Path |
433 | *s_trashPath = *s_desktopPath + QObject::tr("Trash") + "/"; | 433 | *s_trashPath = *s_desktopPath + QObject::tr("Trash") + "/"; |
434 | *s_trashPath = config->readEntry( "Trash" , *s_trashPath); | 434 | *s_trashPath = config->readEntry( "Trash" , *s_trashPath); |
435 | if ( (*s_trashPath)[0] != '/' ) | 435 | if ( (*s_trashPath)[0] != '/' ) |
436 | s_trashPath->prepend( QDir::homeDirPath() + "/" ); | 436 | s_trashPath->prepend( QDir::homeDirPath() + "/" ); |
437 | *s_trashPath = QDir::cleanDirPath( *s_trashPath ); | 437 | *s_trashPath = QDir::cleanDirPath( *s_trashPath ); |
438 | if ( s_trashPath->right(1) != "/") | 438 | if ( s_trashPath->right(1) != "/") |
439 | *s_trashPath += "/"; | 439 | *s_trashPath += "/"; |
440 | // We need to save it in any case, in case the language changes later on, | 440 | // We need to save it in any case, in case the language changes later on, |
441 | if ( !config->hasKey( "Trash" ) ) | 441 | if ( !config->hasKey( "Trash" ) ) |
442 | { | 442 | { |
443 | //config->writePathEntry( "Trash", *s_trashPath, true, true ); | 443 | //config->writePathEntry( "Trash", *s_trashPath, true, true ); |
444 | config->writeEntry( "Trash", *s_trashPath ); | 444 | config->writeEntry( "Trash", *s_trashPath ); |
445 | //config->sync(); | 445 | //config->sync(); |
446 | } | 446 | } |
447 | 447 | ||
448 | /* // Autostart Path | 448 | /* // Autostart Path |
449 | *s_autostartPath = OGlobal::dirs()->localkdedir() + "Autostart" + "/"; | 449 | *s_autostartPath = OGlobal::dirs()->localkdedir() + "Autostart" + "/"; |
450 | *s_autostartPath = config->readEntry( "Autostart" , *s_autostartPath); | 450 | *s_autostartPath = config->readEntry( "Autostart" , *s_autostartPath); |
451 | if ( (*s_autostartPath)[0] != '/' ) | 451 | if ( (*s_autostartPath)[0] != '/' ) |
452 | s_autostartPath->prepend( QDir::homeDirPath() + "/" ); | 452 | s_autostartPath->prepend( QDir::homeDirPath() + "/" ); |
453 | *s_autostartPath = QDir::cleanDirPath( *s_autostartPath ); | 453 | *s_autostartPath = QDir::cleanDirPath( *s_autostartPath ); |
454 | if ( s_autostartPath->right(1) != "/") | 454 | if ( s_autostartPath->right(1) != "/") |
455 | *s_autostartPath += "/"; | 455 | *s_autostartPath += "/"; |
456 | */ | 456 | */ |
457 | // Document Path | 457 | // Document Path |
458 | *s_documentPath = QString::null; | 458 | *s_documentPath = QString::null; |
459 | *s_documentPath = config->readEntry( "Documents" , *s_documentPath); | 459 | *s_documentPath = config->readEntry( "Documents" , *s_documentPath); |
460 | if ( (*s_documentPath)[0] != '/' ) | 460 | if ( (*s_documentPath)[0] != '/' ) |
461 | s_documentPath->prepend( QDir::homeDirPath() + "/" ); | 461 | s_documentPath->prepend( QDir::homeDirPath() + "/" ); |
462 | *s_documentPath = QDir::cleanDirPath( *s_documentPath ); | 462 | *s_documentPath = QDir::cleanDirPath( *s_documentPath ); |
463 | if ( s_documentPath->right(1) != "/") | 463 | if ( s_documentPath->right(1) != "/") |
464 | *s_documentPath += "/"; | 464 | *s_documentPath += "/"; |
465 | 465 | ||
466 | //config->setDollarExpansion(dollarExpansion); | 466 | //config->setDollarExpansion(dollarExpansion); |
467 | 467 | ||
468 | // Make sure this app gets the notifications about those paths | 468 | // Make sure this app gets the notifications about those paths |
469 | //if (kapp) | 469 | //if (kapp) |
470 | //kapp->addKipcEventMask(KIPC::SettingsChanged); | 470 | //kapp->addKipcEventMask(KIPC::SettingsChanged); |
471 | } | 471 | } |
472 | 472 | ||
473 | void OGlobalSettings::initColors() | 473 | void OGlobalSettings::initColors() |
474 | { | 474 | { |
475 | if ( not OpieHighlight ) OpieHighlight = new QColor( 156, 118, 32 ); | 475 | if ( !OpieHighlight ) OpieHighlight = new QColor( 156, 118, 32 ); |
476 | if ( not OpieAlternate ) OpieAlternate = new QColor( 238, 246, 255 ); | 476 | if ( !OpieAlternate ) OpieAlternate = new QColor( 238, 246, 255 ); |
477 | if ( not OpieGray ) OpieGray = new QColor( 220, 210, 215 ); | 477 | if ( !OpieGray ) OpieGray = new QColor( 220, 210, 215 ); |
478 | } | 478 | } |
479 | 479 | ||
480 | void OGlobalSettings::rereadFontSettings() | 480 | void OGlobalSettings::rereadFontSettings() |
481 | { | 481 | { |
482 | delete _generalFont; | 482 | delete _generalFont; |
483 | _generalFont = 0L; | 483 | _generalFont = 0L; |
484 | delete _fixedFont; | 484 | delete _fixedFont; |
485 | _fixedFont = 0L; | 485 | _fixedFont = 0L; |
486 | delete _menuFont; | 486 | delete _menuFont; |
487 | _menuFont = 0L; | 487 | _menuFont = 0L; |
488 | delete _toolBarFont; | 488 | delete _toolBarFont; |
489 | _toolBarFont = 0L; | 489 | _toolBarFont = 0L; |
490 | delete _windowTitleFont; | 490 | delete _windowTitleFont; |
491 | _windowTitleFont = 0L; | 491 | _windowTitleFont = 0L; |
492 | delete _taskbarFont; | 492 | delete _taskbarFont; |
493 | _taskbarFont = 0L; | 493 | _taskbarFont = 0L; |
494 | } | 494 | } |
495 | 495 | ||
496 | void OGlobalSettings::rereadPathSettings() | 496 | void OGlobalSettings::rereadPathSettings() |
497 | { | 497 | { |
498 | qDebug( "OGlobalSettings::rereadPathSettings" ); | 498 | qDebug( "OGlobalSettings::rereadPathSettings" ); |
499 | delete s_autostartPath; | 499 | delete s_autostartPath; |
500 | s_autostartPath = 0L; | 500 | s_autostartPath = 0L; |
501 | delete s_trashPath; | 501 | delete s_trashPath; |
502 | s_trashPath = 0L; | 502 | s_trashPath = 0L; |
503 | delete s_desktopPath; | 503 | delete s_desktopPath; |
504 | s_desktopPath = 0L; | 504 | s_desktopPath = 0L; |
505 | delete s_documentPath; | 505 | delete s_documentPath; |
506 | s_documentPath = 0L; | 506 | s_documentPath = 0L; |
507 | } | 507 | } |
508 | 508 | ||
509 | OGlobalSettings::OMouseSettings & OGlobalSettings::mouseSettings() | 509 | OGlobalSettings::OMouseSettings & OGlobalSettings::mouseSettings() |
510 | { | 510 | { |
511 | if ( ! s_mouseSettings ) | 511 | if ( ! s_mouseSettings ) |
512 | { | 512 | { |
513 | s_mouseSettings = new OMouseSettings; | 513 | s_mouseSettings = new OMouseSettings; |
514 | OMouseSettings & s = *s_mouseSettings; // for convenience | 514 | OMouseSettings & s = *s_mouseSettings; // for convenience |
515 | 515 | ||
516 | OConfigGroupSaver cgs( OGlobal::config(), "Mouse" ); | 516 | OConfigGroupSaver cgs( OGlobal::config(), "Mouse" ); |
517 | QString setting = OGlobal::config()->readEntry("MouseButtonMapping"); | 517 | QString setting = OGlobal::config()->readEntry("MouseButtonMapping"); |
518 | if (setting == "RightHanded") | 518 | if (setting == "RightHanded") |
519 | s.handed = OMouseSettings::RightHanded; | 519 | s.handed = OMouseSettings::RightHanded; |
520 | else if (setting == "LeftHanded") | 520 | else if (setting == "LeftHanded") |
521 | s.handed = OMouseSettings::LeftHanded; | 521 | s.handed = OMouseSettings::LeftHanded; |
522 | else | 522 | else |
523 | { | 523 | { |
524 | 524 | ||
525 | // FIXME: Implement for Opie / Qt Embedded | 525 | // FIXME: Implement for Opie / Qt Embedded |
diff --git a/libopie2/opienet/onetwork.cpp b/libopie2/opienet/onetwork.cpp index 25c70e0..998b50e 100644 --- a/libopie2/opienet/onetwork.cpp +++ b/libopie2/opienet/onetwork.cpp | |||
@@ -6,96 +6,97 @@ | |||
6 | Michael 'Mickey' Lauer <mickey@tm.informatik.uni-frankfurt.de> | 6 | Michael 'Mickey' Lauer <mickey@tm.informatik.uni-frankfurt.de> |
7 | =. | 7 | =. |
8 | .=l. | 8 | .=l. |
9 | .>+-= | 9 | .>+-= |
10 | _;:, .> :=|. This program is free software; you can | 10 | _;:, .> :=|. This program is free software; you can |
11 | .> <`_, > . <= redistribute it and/or modify it under | 11 | .> <`_, > . <= redistribute it and/or modify it under |
12 | :`=1 )Y*s>-.-- : the terms of the GNU Library General Public | 12 | :`=1 )Y*s>-.-- : the terms of the GNU Library General Public |
13 | .="- .-=="i, .._ License as published by the Free Software | 13 | .="- .-=="i, .._ License as published by the Free Software |
14 | - . .-<_> .<> Foundation; either version 2 of the License, | 14 | - . .-<_> .<> Foundation; either version 2 of the License, |
15 | ._= =} : or (at your option) any later version. | 15 | ._= =} : or (at your option) any later version. |
16 | .%`+i> _;_. | 16 | .%`+i> _;_. |
17 | .i_,=:_. -<s. This program is distributed in the hope that | 17 | .i_,=:_. -<s. This program is distributed in the hope that |
18 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; | 18 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; |
19 | : .. .:, . . . without even the implied warranty of | 19 | : .. .:, . . . without even the implied warranty of |
20 | =_ + =;=|` MERCHANTABILITY or FITNESS FOR A | 20 | =_ + =;=|` MERCHANTABILITY or FITNESS FOR A |
21 | _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU | 21 | _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU |
22 | ..}^=.= = ; Library General Public License for more | 22 | ..}^=.= = ; Library General Public License for more |
23 | ++= -. .` .: details. | 23 | ++= -. .` .: details. |
24 | : = ...= . :.=- | 24 | : = ...= . :.=- |
25 | -. .:....=;==+<; You should have received a copy of the GNU | 25 | -. .:....=;==+<; You should have received a copy of the GNU |
26 | -_. . . )=. = Library General Public License along with | 26 | -_. . . )=. = Library General Public License along with |
27 | -- :-=` this library; see the file COPYING.LIB. | 27 | -- :-=` this library; see the file COPYING.LIB. |
28 | If not, write to the Free Software Foundation, | 28 | If not, write to the Free Software Foundation, |
29 | Inc., 59 Temple Place - Suite 330, | 29 | Inc., 59 Temple Place - Suite 330, |
30 | Boston, MA 02111-1307, USA. | 30 | Boston, MA 02111-1307, USA. |
31 | 31 | ||
32 | */ | 32 | */ |
33 | 33 | ||
34 | /* OPIE */ | 34 | /* OPIE */ |
35 | 35 | ||
36 | #include <opie2/onetwork.h> | 36 | #include <opie2/onetwork.h> |
37 | 37 | ||
38 | /* QT */ | 38 | /* QT */ |
39 | 39 | ||
40 | #include <qfile.h> | 40 | #include <qfile.h> |
41 | #include <qtextstream.h> | 41 | #include <qtextstream.h> |
42 | 42 | ||
43 | /* UNIX */ | 43 | /* UNIX */ |
44 | 44 | ||
45 | #include <arpa/inet.h> | 45 | #include <arpa/inet.h> |
46 | #include <cerrno> | 46 | #include <cerrno> |
47 | #include <cstring> | 47 | #include <cstring> |
48 | #include <cstdlib> | 48 | #include <cstdlib> |
49 | #include <math.h> | 49 | #include <math.h> |
50 | #include <sys/ioctl.h> | 50 | #include <sys/ioctl.h> |
51 | #include <sys/socket.h> | 51 | #include <sys/socket.h> |
52 | #include <sys/types.h> | 52 | #include <sys/types.h> |
53 | #include <unistd.h> | 53 | #include <unistd.h> |
54 | #include <linux/sockios.h> | ||
54 | #include <linux/wireless.h> | 55 | #include <linux/wireless.h> |
55 | 56 | ||
56 | using namespace std; | 57 | using namespace std; |
57 | 58 | ||
58 | /*====================================================================================== | 59 | /*====================================================================================== |
59 | * ONetwork | 60 | * ONetwork |
60 | *======================================================================================*/ | 61 | *======================================================================================*/ |
61 | 62 | ||
62 | ONetwork* ONetwork::_instance = 0; | 63 | ONetwork* ONetwork::_instance = 0; |
63 | 64 | ||
64 | ONetwork::ONetwork() | 65 | ONetwork::ONetwork() |
65 | { | 66 | { |
66 | qDebug( "ONetwork::ONetwork()" ); | 67 | qDebug( "ONetwork::ONetwork()" ); |
67 | synchronize(); | 68 | synchronize(); |
68 | } | 69 | } |
69 | 70 | ||
70 | void ONetwork::synchronize() | 71 | void ONetwork::synchronize() |
71 | { | 72 | { |
72 | // gather available interfaces by inspecting /proc/net/dev | 73 | // gather available interfaces by inspecting /proc/net/dev |
73 | // we could use SIOCGIFCONF here, but we aren't interested in virtual (e.g. eth0:0) devices | 74 | // we could use SIOCGIFCONF here, but we aren't interested in virtual (e.g. eth0:0) devices |
74 | 75 | ||
75 | _interfaces.clear(); | 76 | _interfaces.clear(); |
76 | QString str; | 77 | QString str; |
77 | QFile f( "/proc/net/dev" ); | 78 | QFile f( "/proc/net/dev" ); |
78 | bool hasFile = f.open( IO_ReadOnly ); | 79 | bool hasFile = f.open( IO_ReadOnly ); |
79 | if ( !hasFile ) | 80 | if ( !hasFile ) |
80 | { | 81 | { |
81 | qDebug( "ONetwork: /proc/net/dev not existing. No network devices available" ); | 82 | qDebug( "ONetwork: /proc/net/dev not existing. No network devices available" ); |
82 | return; | 83 | return; |
83 | } | 84 | } |
84 | QTextStream s( &f ); | 85 | QTextStream s( &f ); |
85 | s.readLine(); | 86 | s.readLine(); |
86 | s.readLine(); | 87 | s.readLine(); |
87 | while ( !s.atEnd() ) | 88 | while ( !s.atEnd() ) |
88 | { | 89 | { |
89 | s >> str; | 90 | s >> str; |
90 | str.truncate( str.find( ':' ) ); | 91 | str.truncate( str.find( ':' ) ); |
91 | qDebug( "ONetwork: found interface '%s'", (const char*) str ); | 92 | qDebug( "ONetwork: found interface '%s'", (const char*) str ); |
92 | ONetworkInterface* iface; | 93 | ONetworkInterface* iface; |
93 | if ( isWirelessInterface( str ) ) | 94 | if ( isWirelessInterface( str ) ) |
94 | { | 95 | { |
95 | iface = new OWirelessNetworkInterface( str ); | 96 | iface = new OWirelessNetworkInterface( str ); |
96 | qDebug( "ONetwork: interface '%s' has Wireless Extensions", (const char*) str ); | 97 | qDebug( "ONetwork: interface '%s' has Wireless Extensions", (const char*) str ); |
97 | } | 98 | } |
98 | else | 99 | else |
99 | { | 100 | { |
100 | iface = new ONetworkInterface( str ); | 101 | iface = new ONetworkInterface( str ); |
101 | } | 102 | } |
@@ -680,97 +681,97 @@ OWlanNGMonitoringInterface::~OWlanNGMonitoringInterface() | |||
680 | void OWlanNGMonitoringInterface::setEnabled( bool b ) | 681 | void OWlanNGMonitoringInterface::setEnabled( bool b ) |
681 | { | 682 | { |
682 | //FIXME: do nothing if its already in the same mode | 683 | //FIXME: do nothing if its already in the same mode |
683 | 684 | ||
684 | QString enable = b ? "true" : "false"; | 685 | QString enable = b ? "true" : "false"; |
685 | QString cmd; | 686 | QString cmd; |
686 | cmd.sprintf( "$(which wlanctl-ng) %s lnxreq_wlansniff channel=%d enable=%s", (const char*) _if->name(), 1, (const char*) enable ); | 687 | cmd.sprintf( "$(which wlanctl-ng) %s lnxreq_wlansniff channel=%d enable=%s", (const char*) _if->name(), 1, (const char*) enable ); |
687 | system( cmd ); | 688 | system( cmd ); |
688 | 689 | ||
689 | OMonitoringInterface::setEnabled( b ); | 690 | OMonitoringInterface::setEnabled( b ); |
690 | } | 691 | } |
691 | 692 | ||
692 | 693 | ||
693 | QString OWlanNGMonitoringInterface::name() const | 694 | QString OWlanNGMonitoringInterface::name() const |
694 | { | 695 | { |
695 | return "wlan-ng"; | 696 | return "wlan-ng"; |
696 | } | 697 | } |
697 | 698 | ||
698 | 699 | ||
699 | void OWlanNGMonitoringInterface::setChannel( int ) | 700 | void OWlanNGMonitoringInterface::setChannel( int ) |
700 | { | 701 | { |
701 | // wlan-ng devices automatically switch channels when in monitor mode | 702 | // wlan-ng devices automatically switch channels when in monitor mode |
702 | } | 703 | } |
703 | 704 | ||
704 | 705 | ||
705 | /*====================================================================================== | 706 | /*====================================================================================== |
706 | * OHostAPMonitoringInterface | 707 | * OHostAPMonitoringInterface |
707 | *======================================================================================*/ | 708 | *======================================================================================*/ |
708 | 709 | ||
709 | OHostAPMonitoringInterface::OHostAPMonitoringInterface( ONetworkInterface* iface ) | 710 | OHostAPMonitoringInterface::OHostAPMonitoringInterface( ONetworkInterface* iface ) |
710 | :OMonitoringInterface( iface ) | 711 | :OMonitoringInterface( iface ) |
711 | { | 712 | { |
712 | iface->setMonitoring( this ); | 713 | iface->setMonitoring( this ); |
713 | } | 714 | } |
714 | 715 | ||
715 | OHostAPMonitoringInterface::~OHostAPMonitoringInterface() | 716 | OHostAPMonitoringInterface::~OHostAPMonitoringInterface() |
716 | { | 717 | { |
717 | } | 718 | } |
718 | 719 | ||
719 | void OHostAPMonitoringInterface::setEnabled( bool b ) | 720 | void OHostAPMonitoringInterface::setEnabled( bool b ) |
720 | { | 721 | { |
721 | // IW_MODE_MONITOR was introduced in Wireless Extensions Version 15 | 722 | // IW_MODE_MONITOR was introduced in Wireless Extensions Version 15 |
722 | // Wireless Extensions < Version 15 need iwpriv commandos for monitoring | 723 | // Wireless Extensions < Version 15 need iwpriv commandos for monitoring |
723 | 724 | ||
724 | #if WIRELESS_EXT > 14 | 725 | #if WIRELESS_EXT > 14 |
725 | _if->_iwr.u.mode = IW_MODE_MONITOR; | 726 | _if->_iwr.u.mode = IW_MODE_MONITOR; |
726 | _if->wioctl( SIOCSIWMODE ); | 727 | _if->wioctl( SIOCSIWMODE ); |
727 | #else | 728 | #else |
728 | int* args = (int*) &_if._iwr.u.name; | 729 | int* args = (int*) &_if->_iwr.u.name; |
729 | args[0] = 2; | 730 | args[0] = 2; |
730 | args[1] = 0; | 731 | args[1] = 0; |
731 | _if->wioctl( SIOCDEVPRIVATE ); | 732 | _if->wioctl( SIOCDEVPRIVATE ); |
732 | #endif | 733 | #endif |
733 | 734 | ||
734 | OMonitoringInterface::setEnabled( b ); | 735 | OMonitoringInterface::setEnabled( b ); |
735 | } | 736 | } |
736 | 737 | ||
737 | 738 | ||
738 | QString OHostAPMonitoringInterface::name() const | 739 | QString OHostAPMonitoringInterface::name() const |
739 | { | 740 | { |
740 | return "hostap"; | 741 | return "hostap"; |
741 | } | 742 | } |
742 | 743 | ||
743 | 744 | ||
744 | /*====================================================================================== | 745 | /*====================================================================================== |
745 | * OOrinocoNetworkInterface | 746 | * OOrinocoNetworkInterface |
746 | *======================================================================================*/ | 747 | *======================================================================================*/ |
747 | 748 | ||
748 | OOrinocoMonitoringInterface::OOrinocoMonitoringInterface( ONetworkInterface* iface ) | 749 | OOrinocoMonitoringInterface::OOrinocoMonitoringInterface( ONetworkInterface* iface ) |
749 | :OMonitoringInterface( iface ) | 750 | :OMonitoringInterface( iface ) |
750 | { | 751 | { |
751 | iface->setMonitoring( this ); | 752 | iface->setMonitoring( this ); |
752 | } | 753 | } |
753 | 754 | ||
754 | 755 | ||
755 | OOrinocoMonitoringInterface::~OOrinocoMonitoringInterface() | 756 | OOrinocoMonitoringInterface::~OOrinocoMonitoringInterface() |
756 | { | 757 | { |
757 | } | 758 | } |
758 | 759 | ||
759 | 760 | ||
760 | void OOrinocoMonitoringInterface::setChannel( int c ) | 761 | void OOrinocoMonitoringInterface::setChannel( int c ) |
761 | { | 762 | { |
762 | // call iwpriv <device> monitor 2 <channel> | 763 | // call iwpriv <device> monitor 2 <channel> |
763 | int* args = (int*) &_if->_iwr.u.name; | 764 | int* args = (int*) &_if->_iwr.u.name; |
764 | args[0] = 2; | 765 | args[0] = 2; |
765 | args[1] = c; | 766 | args[1] = c; |
766 | _if->wioctl( SIOCIWFIRSTPRIV + 0x8 ); | 767 | _if->wioctl( SIOCIWFIRSTPRIV + 0x8 ); |
767 | } | 768 | } |
768 | 769 | ||
769 | 770 | ||
770 | void OOrinocoMonitoringInterface::setEnabled( bool b ) | 771 | void OOrinocoMonitoringInterface::setEnabled( bool b ) |
771 | { | 772 | { |
772 | if ( b ) | 773 | if ( b ) |
773 | { | 774 | { |
774 | setChannel( 1 ); | 775 | setChannel( 1 ); |
775 | } | 776 | } |
776 | else | 777 | else |
diff --git a/libopie2/opienet/onetwork.h b/libopie2/opienet/onetwork.h index 936ac85..56da5f4 100644 --- a/libopie2/opienet/onetwork.h +++ b/libopie2/opienet/onetwork.h | |||
@@ -3,100 +3,108 @@ | |||
3 | Copyright (C) 2003 by the Wellenreiter team: | 3 | Copyright (C) 2003 by the Wellenreiter team: |
4 | Martin J. Muench <mjm@remote-exploit.org> | 4 | Martin J. Muench <mjm@remote-exploit.org> |
5 | Max Moser <mmo@remote-exploit.org | 5 | Max Moser <mmo@remote-exploit.org |
6 | Michael 'Mickey' Lauer <mickey@tm.informatik.uni-frankfurt.de> | 6 | Michael 'Mickey' Lauer <mickey@tm.informatik.uni-frankfurt.de> |
7 | =. | 7 | =. |
8 | .=l. | 8 | .=l. |
9 | .>+-= | 9 | .>+-= |
10 | _;:, .> :=|. This program is free software; you can | 10 | _;:, .> :=|. This program is free software; you can |
11 | .> <`_, > . <= redistribute it and/or modify it under | 11 | .> <`_, > . <= redistribute it and/or modify it under |
12 | :`=1 )Y*s>-.-- : the terms of the GNU Library General Public | 12 | :`=1 )Y*s>-.-- : the terms of the GNU Library General Public |
13 | .="- .-=="i, .._ License as published by the Free Software | 13 | .="- .-=="i, .._ License as published by the Free Software |
14 | - . .-<_> .<> Foundation; either version 2 of the License, | 14 | - . .-<_> .<> Foundation; either version 2 of the License, |
15 | ._= =} : or (at your option) any later version. | 15 | ._= =} : or (at your option) any later version. |
16 | .%`+i> _;_. | 16 | .%`+i> _;_. |
17 | .i_,=:_. -<s. This program is distributed in the hope that | 17 | .i_,=:_. -<s. This program is distributed in the hope that |
18 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; | 18 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; |
19 | : .. .:, . . . without even the implied warranty of | 19 | : .. .:, . . . without even the implied warranty of |
20 | =_ + =;=|` MERCHANTABILITY or FITNESS FOR A | 20 | =_ + =;=|` MERCHANTABILITY or FITNESS FOR A |
21 | _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU | 21 | _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU |
22 | ..}^=.= = ; Library General Public License for more | 22 | ..}^=.= = ; Library General Public License for more |
23 | ++= -. .` .: details. | 23 | ++= -. .` .: details. |
24 | : = ...= . :.=- | 24 | : = ...= . :.=- |
25 | -. .:....=;==+<; You should have received a copy of the GNU | 25 | -. .:....=;==+<; You should have received a copy of the GNU |
26 | -_. . . )=. = Library General Public License along with | 26 | -_. . . )=. = Library General Public License along with |
27 | -- :-=` this library; see the file COPYING.LIB. | 27 | -- :-=` this library; see the file COPYING.LIB. |
28 | If not, write to the Free Software Foundation, | 28 | If not, write to the Free Software Foundation, |
29 | Inc., 59 Temple Place - Suite 330, | 29 | Inc., 59 Temple Place - Suite 330, |
30 | Boston, MA 02111-1307, USA. | 30 | Boston, MA 02111-1307, USA. |
31 | 31 | ||
32 | */ | 32 | */ |
33 | 33 | ||
34 | #ifndef ONETWORK_H | 34 | #ifndef ONETWORK_H |
35 | #define ONETWORK_H | 35 | #define ONETWORK_H |
36 | 36 | ||
37 | /* QT */ | 37 | /* QT */ |
38 | 38 | ||
39 | #include <qdict.h> | 39 | #include <qdict.h> |
40 | #include <qmap.h> | 40 | #include <qmap.h> |
41 | #include <qobject.h> | 41 | #include <qobject.h> |
42 | #include <qhostaddress.h> | 42 | #include <qhostaddress.h> |
43 | 43 | ||
44 | /* OPIE */ | 44 | /* OPIE */ |
45 | 45 | ||
46 | #include <opie2/onetutils.h> | 46 | #include <opie2/onetutils.h> |
47 | 47 | ||
48 | // ML: Yeah, I hate to include kernel headers, but it's necessary here | 48 | // ML: Yeah, I hate to include kernel headers, but it's necessary here |
49 | // ML: Recent RedHat and MandrakePatches to the Kernel and WE broke something | 49 | // ML: Recent RedHat and MandrakePatches to the Kernel and WE broke something |
50 | // ML: #include <net/if.h> e.g. conflicts with #include <linux/wireless.h> | 50 | // ML: #include <net/if.h> e.g. conflicts with #include <linux/wireless.h> |
51 | |||
52 | #ifndef IFNAMSIZ | ||
51 | #define IFNAMSIZ 16 | 53 | #define IFNAMSIZ 16 |
54 | #endif | ||
55 | |||
52 | #include <linux/wireless.h> | 56 | #include <linux/wireless.h> |
53 | #include <net/if.h> | 57 | #include <net/if.h> |
54 | 58 | ||
59 | #ifndef SIOCIWFIRSTPRIV | ||
60 | #define SIOCIWFIRSTPRIV SIOCDEVPRIVATE | ||
61 | #endif | ||
62 | |||
55 | class ONetworkInterface; | 63 | class ONetworkInterface; |
56 | class OWirelessNetworkInterface; | 64 | class OWirelessNetworkInterface; |
57 | class OChannelHopper; | 65 | class OChannelHopper; |
58 | class OMonitoringInterface; | 66 | class OMonitoringInterface; |
59 | 67 | ||
60 | typedef struct ifreq ifreqstruct; | 68 | typedef struct ifreq ifreqstruct; |
61 | typedef struct iwreq iwreqstruct; | 69 | typedef struct iwreq iwreqstruct; |
62 | typedef struct iw_event iweventstruct; | 70 | typedef struct iw_event iweventstruct; |
63 | typedef struct iw_freq iwfreqstruct; | 71 | typedef struct iw_freq iwfreqstruct; |
64 | typedef struct iw_priv_args iwprivargsstruct; | 72 | typedef struct iw_priv_args iwprivargsstruct; |
65 | typedef struct iw_range iwrangestruct; | 73 | typedef struct iw_range iwrangestruct; |
66 | 74 | ||
67 | /*====================================================================================== | 75 | /*====================================================================================== |
68 | * ONetwork | 76 | * ONetwork |
69 | *======================================================================================*/ | 77 | *======================================================================================*/ |
70 | 78 | ||
71 | class ONetwork : public QObject | 79 | class ONetwork : public QObject |
72 | { | 80 | { |
73 | Q_OBJECT | 81 | Q_OBJECT |
74 | 82 | ||
75 | public: | 83 | public: |
76 | typedef QDict<ONetworkInterface> InterfaceMap; | 84 | typedef QDict<ONetworkInterface> InterfaceMap; |
77 | typedef QDictIterator<ONetworkInterface> InterfaceIterator; | 85 | typedef QDictIterator<ONetworkInterface> InterfaceIterator; |
78 | 86 | ||
79 | public: | 87 | public: |
80 | static ONetwork* instance(); | 88 | static ONetwork* instance(); |
81 | InterfaceIterator iterator() const; | 89 | InterfaceIterator iterator() const; |
82 | bool isWirelessInterface( const char* ) const; | 90 | bool isWirelessInterface( const char* ) const; |
83 | ONetworkInterface* interface( QString ) const; | 91 | ONetworkInterface* interface( QString ) const; |
84 | 92 | ||
85 | protected: | 93 | protected: |
86 | ONetwork(); | 94 | ONetwork(); |
87 | void synchronize(); | 95 | void synchronize(); |
88 | 96 | ||
89 | private: | 97 | private: |
90 | static ONetwork* _instance; | 98 | static ONetwork* _instance; |
91 | InterfaceMap _interfaces; | 99 | InterfaceMap _interfaces; |
92 | }; | 100 | }; |
93 | 101 | ||
94 | 102 | ||
95 | /*====================================================================================== | 103 | /*====================================================================================== |
96 | * ONetworkInterface | 104 | * ONetworkInterface |
97 | *======================================================================================*/ | 105 | *======================================================================================*/ |
98 | 106 | ||
99 | class ONetworkInterface | 107 | class ONetworkInterface |
100 | { | 108 | { |
101 | friend class OMonitoringInterface; | 109 | friend class OMonitoringInterface; |
102 | friend class OCiscoMonitoringInterface; | 110 | friend class OCiscoMonitoringInterface; |