-rw-r--r-- | libopie2/opiecore/linux/opcmciasystem.cpp | 92 | ||||
-rw-r--r-- | libopie2/opiecore/linux/opcmciasystem.h | 74 |
2 files changed, 135 insertions, 31 deletions
diff --git a/libopie2/opiecore/linux/opcmciasystem.cpp b/libopie2/opiecore/linux/opcmciasystem.cpp index 34e4477..c4b5316 100644 --- a/libopie2/opiecore/linux/opcmciasystem.cpp +++ b/libopie2/opiecore/linux/opcmciasystem.cpp @@ -40,8 +40,9 @@ using namespace Opie::Core; /* STD */ #include <errno.h> #include <fcntl.h> #include <string.h> +#include <stdlib.h> #include <sys/ioctl.h> #include <sys/types.h> #include <sys/stat.h> @@ -76,16 +77,18 @@ void OPcmciaSystem::synchronize() } QTextStream cardinfo( &cardinfofile ); while ( !cardinfo.atEnd() ) { - QString line = cardinfo.readLine(); - // qDebug( "line = '%s'", (const char*) line ); - if ( line.startsWith( "Socket" ) && ! line.contains( "empty" ) ) + QString strSocket; + int numSocket; + char colon; + QString cardName; + cardinfo >> strSocket >> numSocket >> colon; + cardName = cardinfo.readLine().stripWhiteSpace(); + qDebug( "strSocket = '%s', numSocket = '%d', colon = '%c', cardName = '%s'", (const char*) strSocket, numSocket, colon, ( const char*) cardName ); + if ( strSocket == "Socket" && colon == ':' ) { - int mid = line.find( ':' ); - QString name = line.right( line.length() - mid - 1 ); - QString id = line.right( line.length() - mid + 1 ); - if ( mid ) _interfaces.insert( name.stripWhiteSpace(), new OPcmciaCard( this, (const char*) id.stripWhiteSpace() ) ); + _interfaces.append( new OPcmciaSocket( numSocket, this, (const char*) cardName ) ); } else { continue; @@ -99,11 +102,24 @@ int OPcmciaSystem::count() const return _interfaces.count(); } -OPcmciaCard* OPcmciaSystem::card( const QString& iface ) const +int OPcmciaSystem::cardCount() const { - return _interfaces[iface]; + int nonEmpty = 0; + OPcmciaSystem::CardIterator it = iterator(); + while ( it.current() ) + { + if ( !it.current()->isEmpty() ) nonEmpty++; + ++it; + } + return nonEmpty; +} + + +OPcmciaSocket* OPcmciaSystem::socket( unsigned int number ) +{ + return _interfaces.at( number ); } OPcmciaSystem* OPcmciaSystem::instance() @@ -119,25 +135,71 @@ OPcmciaSystem::CardIterator OPcmciaSystem::iterator() const } /*====================================================================================== - * OPcmciaCard + * OPcmciaSocket *======================================================================================*/ -OPcmciaCard::OPcmciaCard( QObject* parent, const char* name ) - :QObject( parent, name ) +OPcmciaSocket::OPcmciaSocket( int socket, QObject* parent, const char* name ) + :QObject( parent, name ), _socket( socket ) { - odebug << "OPcmciaCard::OPcmciaCard()" << oendl; + odebug << "OPcmciaSocket::OPcmciaSocket()" << oendl; init(); } -OPcmciaCard::~OPcmciaCard() +OPcmciaSocket::~OPcmciaSocket() +{ +} + + +/* internal */ void OPcmciaSocket::init() +{ +} + +/* internal */ bool OPcmciaSocket::command( const QString& cmd ) +{ + QString cmdline = QString().sprintf( "cardctl %s %d &", (const char*) cmd, _socket ); + ::system( (const char*) cmdline ); +} + +int OPcmciaSocket::number() const +{ + return _socket; +} + + +QString OPcmciaSocket::identity() const { + return ( strcmp( name(), "empty" ) == 0 ) ? "<Empty Socket>" : name(); } -void OPcmciaCard::init() +bool OPcmciaSocket::isEmpty() const { + return ( strcmp( name(), "empty" ) == 0 ); } +bool OPcmciaSocket::isSuspended() const +{ +} + +bool OPcmciaSocket::eject() +{ + return command( "eject" ); +} + +bool OPcmciaSocket::insert() +{ + return command( "insert" ); +} + +bool OPcmciaSocket::suspend() +{ + return command( "suspend" ); +} + +bool OPcmciaSocket::resume() +{ + return command( "resume "); +} diff --git a/libopie2/opiecore/linux/opcmciasystem.h b/libopie2/opiecore/linux/opcmciasystem.h index 694bf16..4b445aa 100644 --- a/libopie2/opiecore/linux/opcmciasystem.h +++ b/libopie2/opiecore/linux/opcmciasystem.h @@ -30,15 +30,14 @@ #ifndef OPCMCIASYSTEM_H #define OPCMCIASYSTEM_H #include <qobject.h> -#include <qdict.h> -#include <qmap.h> +#include <qlist.h> namespace Opie { namespace Core { -class OPcmciaCard; +class OPcmciaSocket; /*====================================================================================== * OPcmciaSystem *======================================================================================*/ @@ -54,31 +53,35 @@ class OPcmciaSystem : public QObject { Q_OBJECT public: - typedef QDict<OPcmciaCard> CardMap; - typedef QDictIterator<OPcmciaCard> CardIterator; + typedef QList<OPcmciaSocket> CardList; + typedef QListIterator<OPcmciaSocket> CardIterator; public: /** - * @returns the number of available interfaces + * @returns the number of available sockets */ int count() const; /** + * @returns the number of populated sockets + */ + int cardCount() const; + /** * @returns a pointer to the (one and only) @ref OSystem instance. */ static OPcmciaSystem* instance(); /** * @returns an iterator usable for iterating through all sound cards. */ CardIterator iterator() const; /** - * @returns a pointer to the @ref OAudioInterface object for the specified @a interface or 0, if not found - * @see OAudioInterface + * @returns a pointer to the @ref OPcmciaSocket object correspinding to socket number n, or 0, if not found + * @see OPcmciaSocket */ - OPcmciaCard* card( const QString& interface ) const; + OPcmciaSocket* socket( unsigned int number ); /** - * @internal Rebuild the internal interface database + * @internal Rebuild the internal database * @note Sometimes it might be useful to call this from client code, * e.g. after issuing a cardctl insert */ void synchronize(); @@ -87,37 +90,76 @@ class OPcmciaSystem : public QObject OPcmciaSystem(); private: static OPcmciaSystem* _instance; - CardMap _interfaces; + CardList _interfaces; class Private; Private *d; }; /*====================================================================================== - * OPcmciaCard + * OPcmciaSocket *======================================================================================*/ -class OPcmciaCard : public QObject +class OPcmciaSocket : public QObject { Q_OBJECT public: /** - * Constructor. Normally you don't create @ref OPcmciaCard objects yourself, + * Constructor. Normally you don't create @ref OPcmciaSocket objects yourself, * but access them via @ref OPcmciaSystem::card(). */ - OPcmciaCard( QObject* parent, const char* name ); + OPcmciaSocket( int socket, QObject* parent, const char* name ); /** * Destructor. */ - virtual ~OPcmciaCard(); + virtual ~OPcmciaSocket(); + /** + * @returns the corresponding socket number + */ + int number() const; + /** + * @returns the identification string of the card in this socket, or "<Empty Socket>" + */ + QString identity() const; + /** + * @returns true, if the socket is empty + */ + bool isEmpty() const; + /** + * @returns true, if the socket is suspended + */ + bool isSuspended() const; + /** + * Eject card. @returns true, if operation succeeded + * @note: This operation needs root privileges + */ + bool eject(); + /** + * Insert card. @returns true, if operation succeeded + * @note: This operation needs root privileges + */ + bool insert(); + /** + * Suspend card. @returns true, if operation succeeded + * @note: This operation needs root privileges + */ + bool suspend(); + /** + * Resume card. @returns true, if operation succeeded + * @note: This operation needs root privileges + */ + bool resume(); protected: private: void init(); + bool command( const QString& cmd ); + int _socket; + private: class Private; Private *d; }; |