summaryrefslogtreecommitdiff
Side-by-side diff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--libopie2/opiecore/oinputsystem.cpp38
-rw-r--r--libopie2/opiecore/oinputsystem.h19
2 files changed, 43 insertions, 14 deletions
diff --git a/libopie2/opiecore/oinputsystem.cpp b/libopie2/opiecore/oinputsystem.cpp
index d1a28f5..a2306ca 100644
--- a/libopie2/opiecore/oinputsystem.cpp
+++ b/libopie2/opiecore/oinputsystem.cpp
@@ -32,2 +32,3 @@ using namespace Opie::Core;
/* QT */
+#include <qdir.h>
#include <qfile.h>
@@ -39,2 +40,3 @@ using namespace Opie::Core;
#include <sys/ioctl.h>
+#include <unistd.h>
@@ -63,7 +65,18 @@ void OInputSystem::synchronize()
qDebug( "OInputSystem::synchronize()" );
- if ( QFile::exists( "/dev/input/event0" ) ) _devices.insert( "0", new OInputDevice( this, "/dev/input/event0" ) );
- if ( QFile::exists( "/dev/input/event1" ) ) _devices.insert( "1", new OInputDevice( this, "/dev/input/event1" ) );
- if ( QFile::exists( "/dev/input/event2" ) ) _devices.insert( "2", new OInputDevice( this, "/dev/input/event2" ) );
- if ( QFile::exists( "/dev/input/event3" ) ) _devices.insert( "3", new OInputDevice( this, "/dev/input/event3" ) );
+ QDir devInput( "/dev/input/" );
+ if ( devInput.exists() )
+ {
+ QStringList devInputFiles = devInput.entryList( QDir::System, QDir::Name );
+ for ( QStringList::Iterator it = devInputFiles.begin(); it != devInputFiles.end(); ++it )
+ {
+ QString absPath = devInput.absFilePath( *it );
+ bool isValid = OInputDevice::isValid( absPath );
+ qDebug( "OInputSystem::synchronize() - checking if '%s' is a valid input system node... '%s'",
+ (const char*) absPath, isValid ? "yes" : "no" );
+ if ( isValid ) _devices.insert( *it, new OInputDevice( this, absPath ) );
+ }
+ }
qDebug( "OInputSystem::synchronize() done" );
+ if ( !_devices.count() )
+ qWarning( "OInputSystem::no devices found" );
}
@@ -108,3 +121,3 @@ OInputDevice::OInputDevice( QObject* parent, const char* name ) : QObject( paren
qDebug( "OInputDevice::OInputDevice( '%s' )", name );
-
+
_fd = ::open( name, O_RDONLY );
@@ -150,3 +163,3 @@ bool OInputDevice::hasFeature( Feature bit ) const
BIT_MASK( features, EV_MAX );
-
+
if( ioctl( _fd, EVIOCGBIT( 0, EV_MAX ), features) < 0 )
@@ -193,3 +206,3 @@ QString OInputDevice::globalKeyMask() const
return keymask;
-
+
}
@@ -197 +210,12 @@ QString OInputDevice::globalKeyMask() const
+
+bool OInputDevice::isValid( const QString& path )
+{
+ char buf[BUFSIZE] = "<unknown>";
+ int fd = ::open( (const char*) path, O_RDONLY );
+ if ( fd < 0 ) return false;
+ int res = ::ioctl( fd, EVIOCGNAME(sizeof buf), buf );
+ ::close( fd );
+ return res >= 0;
+}
+
diff --git a/libopie2/opiecore/oinputsystem.h b/libopie2/opiecore/oinputsystem.h
index 7919610..6f822a1 100644
--- a/libopie2/opiecore/oinputsystem.h
+++ b/libopie2/opiecore/oinputsystem.h
@@ -79,8 +79,8 @@ class OInputSystem : public QObject
* @internal destructor
- */
+ */
~OInputSystem();
-
+
protected:
OInputSystem();
-
+
static OInputSystem* _instance;
@@ -91,3 +91,3 @@ class OInputSystem : public QObject
class OInputDevice : public QObject
-{
+{
public:
@@ -96,4 +96,4 @@ class OInputDevice : public QObject
- #include "oinputsystemenums.h"
-
+ #include "oinputsystemenums.h"
+
public:
@@ -125,3 +125,8 @@ class OInputDevice : public QObject
QString globalKeyMask() const;
-
+ /**
+ * @internal
+ * @returns whether a certain @a path corresponds to an input device
+ */
+ static bool isValid( const QString& path );
+
private: