-rw-r--r-- | noncore/settings/sysinfo/devicesinfo.cpp | 192 | ||||
-rw-r--r-- | noncore/settings/sysinfo/devicesinfo.h | 62 |
2 files changed, 244 insertions, 10 deletions
diff --git a/noncore/settings/sysinfo/devicesinfo.cpp b/noncore/settings/sysinfo/devicesinfo.cpp index 38afd54..a1c9e0b 100644 --- a/noncore/settings/sysinfo/devicesinfo.cpp +++ b/noncore/settings/sysinfo/devicesinfo.cpp @@ -1,74 +1,246 @@ /* This file is part of the Opie Project =. Copyright (C) 2005 Michael 'Mickey' Lauer <mickey@Vanille.de> .=l. Copyright (C) The Opie Team <opie-devel@handhelds.org> .>+-= _;:, .> :=|. This program is free software; you can .> <`_, > . <= redistribute it and/or modify it under :`=1 )Y*s>-.-- : the terms of the GNU General Public .="- .-=="i, .._ License as published by the Free Software - . .-<_> .<> Foundation; version 2 of the License. ._= =} : .%`+i> _;_. .i_,=:_. -<s. This program is distributed in the hope that + . -:. = it will be useful, but WITHOUT ANY WARRANTY; : .. .:, . . . without even the implied warranty of =_ + =;=|` MERCHANTABILITY or FITNESS FOR A _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU ..}^=.= = ; General Public License for more ++= -. .` .: details. : = ...= . :.=- -. .:....=;==+<; You should have received a copy of the GNU -_. . . )=. = General Public License along with -- :-=` this application; see the file LICENSE.GPL. If not, write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ #include "devicesinfo.h" /* OPIE */ +#include <opie2/odebug.h> +#include <opie2/oinputsystem.h> #include <opie2/olistview.h> #include <qpe/qpeapplication.h> +using namespace Opie::Core; +using namespace Opie::Ui; /* QT */ #include <qcombobox.h> #include <qfile.h> #include <qlayout.h> -#include <qmessagebox.h> #include <qpushbutton.h> +#include <qtextstream.h> #include <qtextview.h> #include <qtimer.h> #include <qwhatsthis.h> -using namespace Opie::Ui; - +//================================================================================================= DevicesView::DevicesView( QWidget* parent, const char* name, WFlags fl ) - : OListView( parent, name, fl ) + :OListView( parent, name, fl ) { - addColumn( tr( "Module" ) ); + addColumn( tr( "My Computer" ) ); setAllColumnsShowFocus( true ); setRootIsDecorated( true ); QWhatsThis::add( this, tr( "This is a list of all the devices currently recognized on this device." ) ); + + DevicesView* root = this; + ( new CpuCategory( root ) )->populate(); + ( new InputCategory( root ) )->populate(); + ( new CardsCategory( root ) )->populate(); + ( new UsbCategory( root ) )->populate(); } DevicesView::~DevicesView() { } +//================================================================================================= DevicesInfo::DevicesInfo( QWidget* parent, const char* name, WFlags fl ) - : QWidget( parent, name, fl ) + :QWidget( parent, name, fl ) { - QGridLayout *layout = new QGridLayout( this ); + QVBoxLayout *layout = new QVBoxLayout( this ); layout->setSpacing( 4 ); layout->setMargin( 4 ); - view = new DevicesView( this ); - - layout->addMultiCellWidget( view, 0, 0, 0, 1 ); + layout->addWidget( view ); } DevicesInfo::~DevicesInfo() { } + + +Category::Category( DevicesView* parent, const QString& name ) + :OListViewItem( parent, name ) +{ + odebug << "Category '" << name << "' inserted. Scanning for devices..." << oendl; +} + +Category::~Category() +{ +} + +//================================================================================================= +Device::Device( Category* parent, const QString& name ) + :OListViewItem( parent, name ) +{ +} + +Device::~Device() +{ +} + +//================================================================================================= +CpuCategory::CpuCategory( DevicesView* parent ) + :Category( parent, "1. Central Processing Unit" ) +{ +} + +CpuCategory::~CpuCategory() +{ +} + +void CpuCategory::populate() +{ + odebug << "CpuCategory::populate()" << oendl; + QFile cpuinfofile( "/proc/cpuinfo" ); + if ( !cpuinfofile.exists() || !cpuinfofile.open( IO_ReadOnly ) ) + { + new OListViewItem( this, "ERROR: /proc/cpuinfo not found or unaccessible" ); + return; + } + QTextStream cpuinfo( &cpuinfofile ); + + int cpucount = 0; + while ( !cpuinfo.atEnd() ) + { + QString line = cpuinfo.readLine(); + odebug << "got line '" << line << "'" << oendl; + if ( line.startsWith( "processor" ) ) + { + new OListViewItem( this, QString( "CPU #%1" ).arg( cpucount++ ) ); + } + else + { + continue; + } + } +} + +//================================================================================================= +InputCategory::InputCategory( DevicesView* parent ) + :Category( parent, "2. Input Subsystem" ) +{ +} + +InputCategory::~InputCategory() +{ +} + +void InputCategory::populate() +{ + odebug << "InputCategory::populate()" << oendl; + OInputSystem* sys = OInputSystem::instance(); + OInputSystem::DeviceIterator it = sys->iterator(); + while ( it.current() ) + { + OInputDevice* dev = it.current(); + new OListViewItem( this, dev->identity() ); + ++it; + } +} + +//================================================================================================= +CardsCategory::CardsCategory( DevicesView* parent ) + :Category( parent, "3. Removable Cards" ) +{ +} + +CardsCategory::~CardsCategory() +{ +} + +void CardsCategory::populate() +{ + odebug << "CardsCategory::populate()" << oendl; + QString fileName; + if ( QFile::exists( "/var/run/stab" ) ) { fileName = "/var/run/stab"; } + else if ( QFile::exists( "/var/state/pcmcia/stab" ) ) { fileName = "/var/state/pcmcia/stab"; } + else { fileName = "/var/lib/pcmcia/stab"; } + QFile cardinfofile( fileName ); + if ( !cardinfofile.exists() || !cardinfofile.open( IO_ReadOnly ) ) + { + new OListViewItem( this, "ERROR: pcmcia info file not found or unaccessible" ); + return; + } + QTextStream cardinfo( &cardinfofile ); + while ( !cardinfo.atEnd() ) + { + QString line = cardinfo.readLine(); + odebug << "got line '" << line << "'" << oendl; + if ( line.startsWith("Socket") ) + { + new OListViewItem( this, line ); + } + else + { + continue; + } + } +} + +//================================================================================================= +UsbCategory::UsbCategory( DevicesView* parent ) + :Category( parent, "4. Universal Serial Bus" ) +{ +} + +UsbCategory::~UsbCategory() +{ +} + +void UsbCategory::populate() +{ + odebug << "UsbCategory::populate()" << oendl; + QFile usbinfofile( "/proc/bus/usb/devices" ); + if ( !usbinfofile.exists() || !usbinfofile.open( IO_ReadOnly ) ) + { + new OListViewItem( this, "ERROR: /proc/bus/usb/devices not found or unaccessible" ); + return; + } + QTextStream usbinfo( &usbinfofile ); + + int _bus, _level, _parent, _port, _count, _device, _channels, _power; + float _speed; + QString _manufacturer, _product, _serial; + + int usbcount = 0; + while ( !usbinfo.atEnd() ) + { + QString line = usbinfo.readLine(); + odebug << "got line '" << line << "'" << oendl; + if ( line.startsWith("T:") ) + { + sscanf(line.local8Bit().data(), "T: Bus=%2d Lev=%2d Prnt=%2d Port=%d Cnt=%2d Dev#=%3d Spd=%3f MxCh=%2d", &_bus, &_level, &_parent, &_port, &_count, &_device, &_speed, &_channels); + + new OListViewItem( this, QString( "USB Device #%1" ).arg( usbcount++ ) ); + } + else + { + continue; + } + } +} + diff --git a/noncore/settings/sysinfo/devicesinfo.h b/noncore/settings/sysinfo/devicesinfo.h index 082586b..60ec999 100644 --- a/noncore/settings/sysinfo/devicesinfo.h +++ b/noncore/settings/sysinfo/devicesinfo.h @@ -1,56 +1,118 @@ /* This file is part of the Opie Project =. Copyright (C) 2005 Michael 'Mickey' Lauer <mickey@Vanille.de> .=l. Copyright (C) The Opie Team <opie-devel@handhelds.org> .>+-= _;:, .> :=|. This program is free software; you can .> <`_, > . <= redistribute it and/or modify it under :`=1 )Y*s>-.-- : the terms of the GNU General Public .="- .-=="i, .._ License as published by the Free Software - . .-<_> .<> Foundation; version 2 of the License. ._= =} : .%`+i> _;_. .i_,=:_. -<s. This program is distributed in the hope that + . -:. = it will be useful, but WITHOUT ANY WARRANTY; : .. .:, . . . without even the implied warranty of =_ + =;=|` MERCHANTABILITY or FITNESS FOR A _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU ..}^=.= = ; General Public License for more ++= -. .` .: details. : = ...= . :.=- -. .:....=;==+<; You should have received a copy of the GNU -_. . . )=. = General Public License along with -- :-=` this application; see the file LICENSE.GPL. If not, write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ #ifndef DEVICESINFO_H #define DEVICESINFO_H #include <qwidget.h> #include <opie2/olistview.h> using namespace Opie::Ui; +//================================================================================================= class DevicesView : public OListView { Q_OBJECT public: DevicesView( QWidget* parent = 0, const char* name = 0, WFlags f = 0 ); ~DevicesView(); }; +//================================================================================================= class DevicesInfo : public QWidget { Q_OBJECT public: DevicesInfo( QWidget *parent = 0, const char *name = 0, WFlags f = 0 ); ~DevicesInfo(); private: OListView* view; private slots: }; + +//================================================================================================= +class Category : public OListViewItem +{ +public: + Category( DevicesView* parent, const QString& name ); + virtual ~Category(); + + virtual void populate() = 0; +}; + +//================================================================================================= +class Device : public OListViewItem +{ +public: + Device( Category* parent, const QString& name ); + ~Device(); +}; + +//================================================================================================= +class CpuCategory : public Category +{ +public: + CpuCategory( DevicesView* parent ); + virtual ~CpuCategory(); + + virtual void populate(); +}; + +//================================================================================================= +class InputCategory : public Category +{ +public: + InputCategory( DevicesView* parent ); + virtual ~InputCategory(); + + virtual void populate(); +}; + +//================================================================================================= +class CardsCategory : public Category +{ +public: + CardsCategory( DevicesView* parent ); + virtual ~CardsCategory(); + + virtual void populate(); +}; + +//================================================================================================= +class UsbCategory : public Category +{ +public: + UsbCategory( DevicesView* parent ); + virtual ~UsbCategory(); + + virtual void populate(); +}; + + #endif |