forked from mirrors/gio-qt
feat: add interfaces for DGioDrive
This commit is contained in:
parent
1912f6f4e0
commit
8ddb30527b
4 changed files with 97 additions and 10 deletions
|
@ -24,6 +24,8 @@
|
||||||
#include <QObject>
|
#include <QObject>
|
||||||
#include <QSharedData>
|
#include <QSharedData>
|
||||||
|
|
||||||
|
#define DGIODRIVE_IDENTIFIER_KIND_UNIX_DEVICE "unix-device"
|
||||||
|
|
||||||
namespace Gio {
|
namespace Gio {
|
||||||
class Drive;
|
class Drive;
|
||||||
}
|
}
|
||||||
|
@ -36,6 +38,11 @@ public:
|
||||||
~DGioDrive();
|
~DGioDrive();
|
||||||
|
|
||||||
QString name() const;
|
QString name() const;
|
||||||
|
QString identifier(const QString & kind = DGIODRIVE_IDENTIFIER_KIND_UNIX_DEVICE) const;
|
||||||
|
bool hasVolumes() const;
|
||||||
|
bool canStart() const;
|
||||||
|
bool canStop() const;
|
||||||
|
bool canEject() const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
QScopedPointer<DGioDrivePrivate> d_ptr;
|
QScopedPointer<DGioDrivePrivate> d_ptr;
|
||||||
|
|
|
@ -47,6 +47,9 @@ Q_SIGNALS:
|
||||||
void volumeAdded(QExplicitlySharedDataPointer<DGioVolume> volume);
|
void volumeAdded(QExplicitlySharedDataPointer<DGioVolume> volume);
|
||||||
void volumeRemoved(QExplicitlySharedDataPointer<DGioVolume> volume);
|
void volumeRemoved(QExplicitlySharedDataPointer<DGioVolume> volume);
|
||||||
void volumeChanged(QExplicitlySharedDataPointer<DGioVolume> volume);
|
void volumeChanged(QExplicitlySharedDataPointer<DGioVolume> volume);
|
||||||
|
void driveConnected(QExplicitlySharedDataPointer<DGioDrive> drive);
|
||||||
|
void driveDisconnected(QExplicitlySharedDataPointer<DGioDrive> drive);
|
||||||
|
void driveChanged(QExplicitlySharedDataPointer<DGioDrive> drive);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
QScopedPointer<DGioVolumeManagerPrivate> d_ptr;
|
QScopedPointer<DGioVolumeManagerPrivate> d_ptr;
|
||||||
|
|
|
@ -9,7 +9,7 @@ class DGioDrivePrivate{
|
||||||
public:
|
public:
|
||||||
DGioDrivePrivate(DGioDrive *qq, Drive *gmmDrivePtr);
|
DGioDrivePrivate(DGioDrive *qq, Drive *gmmDrivePtr);
|
||||||
|
|
||||||
Glib::RefPtr<Drive> getGmmDriveInstence();
|
Glib::RefPtr<Drive> getGmmDriveInstence() const;
|
||||||
|
|
||||||
QString name() const;
|
QString name() const;
|
||||||
|
|
||||||
|
@ -27,7 +27,7 @@ DGioDrivePrivate::DGioDrivePrivate(DGioDrive *qq, Drive *gmmDrivePtr)
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Glib::RefPtr<Drive> DGioDrivePrivate::getGmmDriveInstence()
|
Glib::RefPtr<Drive> DGioDrivePrivate::getGmmDriveInstence() const
|
||||||
{
|
{
|
||||||
return m_gmmDrivePtr;
|
return m_gmmDrivePtr;
|
||||||
}
|
}
|
||||||
|
@ -59,5 +59,52 @@ DGioDrive::~DGioDrive()
|
||||||
QString DGioDrive::name() const
|
QString DGioDrive::name() const
|
||||||
{
|
{
|
||||||
Q_D(const DGioDrive);
|
Q_D(const DGioDrive);
|
||||||
|
|
||||||
return d->name();
|
return d->name();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Gets the identifier of the given kind for drive.
|
||||||
|
*
|
||||||
|
* Wrapper of Gio::Drive::get_identifier()
|
||||||
|
*
|
||||||
|
* The only identifier currently available is DGIODRIVE_IDENTIFIER_KIND_UNIX_DEVICE.
|
||||||
|
*
|
||||||
|
* \param kind the kind of identifier to return
|
||||||
|
*
|
||||||
|
* \return A string containing the requested identfier, or empty string if the drive doesn't have this kind of identifier.
|
||||||
|
*/
|
||||||
|
QString DGioDrive::identifier(const QString &kind) const
|
||||||
|
{
|
||||||
|
Q_D(const DGioDrive);
|
||||||
|
|
||||||
|
return QString::fromStdString(d->getGmmDriveInstence()->get_identifier(kind.toStdString()));
|
||||||
|
}
|
||||||
|
|
||||||
|
bool DGioDrive::hasVolumes() const
|
||||||
|
{
|
||||||
|
Q_D(const DGioDrive);
|
||||||
|
|
||||||
|
return d->getGmmDriveInstence()->has_volumes();
|
||||||
|
}
|
||||||
|
|
||||||
|
bool DGioDrive::canStart() const
|
||||||
|
{
|
||||||
|
Q_D(const DGioDrive);
|
||||||
|
|
||||||
|
return d->getGmmDriveInstence()->can_start();
|
||||||
|
}
|
||||||
|
|
||||||
|
bool DGioDrive::canStop() const
|
||||||
|
{
|
||||||
|
Q_D(const DGioDrive);
|
||||||
|
|
||||||
|
return d->getGmmDriveInstence()->can_stop();
|
||||||
|
}
|
||||||
|
|
||||||
|
bool DGioDrive::canEject() const
|
||||||
|
{
|
||||||
|
Q_D(const DGioDrive);
|
||||||
|
|
||||||
|
return d->getGmmDriveInstence()->can_eject();
|
||||||
|
}
|
||||||
|
|
|
@ -46,6 +46,9 @@ private:
|
||||||
void slot_volumeAdded(const Glib::RefPtr< Volume >& gmmVolume);
|
void slot_volumeAdded(const Glib::RefPtr< Volume >& gmmVolume);
|
||||||
void slot_volumeRemoved(const Glib::RefPtr< Volume >& gmmVolume);
|
void slot_volumeRemoved(const Glib::RefPtr< Volume >& gmmVolume);
|
||||||
void slot_volumeChanged(const Glib::RefPtr< Volume >& gmmVolume);
|
void slot_volumeChanged(const Glib::RefPtr< Volume >& gmmVolume);
|
||||||
|
void slot_driveConnected(const Glib::RefPtr< Drive >& gmmDrive);
|
||||||
|
void slot_driveDisconnected(const Glib::RefPtr< Drive >& gmmDrive);
|
||||||
|
void slot_driveChanged(const Glib::RefPtr< Drive >& gmmDrive);
|
||||||
|
|
||||||
Q_DECLARE_PUBLIC(DGioVolumeManager)
|
Q_DECLARE_PUBLIC(DGioVolumeManager)
|
||||||
};
|
};
|
||||||
|
@ -67,6 +70,10 @@ DGioVolumeManagerPrivate::DGioVolumeManagerPrivate(DGioVolumeManager *qq)
|
||||||
m_gmmVolumeMonitorPtr->signal_volume_added().connect(sigc::mem_fun(*this, &DGioVolumeManagerPrivate::slot_volumeAdded));
|
m_gmmVolumeMonitorPtr->signal_volume_added().connect(sigc::mem_fun(*this, &DGioVolumeManagerPrivate::slot_volumeAdded));
|
||||||
m_gmmVolumeMonitorPtr->signal_volume_removed().connect(sigc::mem_fun(*this, &DGioVolumeManagerPrivate::slot_volumeRemoved));
|
m_gmmVolumeMonitorPtr->signal_volume_removed().connect(sigc::mem_fun(*this, &DGioVolumeManagerPrivate::slot_volumeRemoved));
|
||||||
m_gmmVolumeMonitorPtr->signal_volume_changed().connect(sigc::mem_fun(*this, &DGioVolumeManagerPrivate::slot_volumeChanged));
|
m_gmmVolumeMonitorPtr->signal_volume_changed().connect(sigc::mem_fun(*this, &DGioVolumeManagerPrivate::slot_volumeChanged));
|
||||||
|
|
||||||
|
m_gmmVolumeMonitorPtr->signal_drive_connected().connect(sigc::mem_fun(*this, &DGioVolumeManagerPrivate::slot_driveConnected));
|
||||||
|
m_gmmVolumeMonitorPtr->signal_drive_disconnected().connect(sigc::mem_fun(*this, &DGioVolumeManagerPrivate::slot_driveDisconnected));
|
||||||
|
m_gmmVolumeMonitorPtr->signal_drive_changed().connect(sigc::mem_fun(*this, &DGioVolumeManagerPrivate::slot_driveChanged));
|
||||||
}
|
}
|
||||||
|
|
||||||
void DGioVolumeManagerPrivate::slot_mountAdded(const Glib::RefPtr<Mount> &gmmMount)
|
void DGioVolumeManagerPrivate::slot_mountAdded(const Glib::RefPtr<Mount> &gmmMount)
|
||||||
|
@ -74,7 +81,6 @@ void DGioVolumeManagerPrivate::slot_mountAdded(const Glib::RefPtr<Mount> &gmmMou
|
||||||
Q_Q(DGioVolumeManager);
|
Q_Q(DGioVolumeManager);
|
||||||
|
|
||||||
Glib::RefPtr<Mount> copy(gmmMount);
|
Glib::RefPtr<Mount> copy(gmmMount);
|
||||||
|
|
||||||
QExplicitlySharedDataPointer<DGioMount> mount(new DGioMount(copy.release()));
|
QExplicitlySharedDataPointer<DGioMount> mount(new DGioMount(copy.release()));
|
||||||
|
|
||||||
Q_EMIT q->mountAdded(mount);
|
Q_EMIT q->mountAdded(mount);
|
||||||
|
@ -85,7 +91,6 @@ void DGioVolumeManagerPrivate::slot_mountRemoved(const Glib::RefPtr<Mount> &gmmM
|
||||||
Q_Q(DGioVolumeManager);
|
Q_Q(DGioVolumeManager);
|
||||||
|
|
||||||
Glib::RefPtr<Mount> copy(gmmMount);
|
Glib::RefPtr<Mount> copy(gmmMount);
|
||||||
|
|
||||||
QExplicitlySharedDataPointer<DGioMount> mount(new DGioMount(copy.release()));
|
QExplicitlySharedDataPointer<DGioMount> mount(new DGioMount(copy.release()));
|
||||||
|
|
||||||
Q_EMIT q->mountRemoved(mount);
|
Q_EMIT q->mountRemoved(mount);
|
||||||
|
@ -96,7 +101,6 @@ void DGioVolumeManagerPrivate::slot_mountPreRemoved(const Glib::RefPtr<Mount> &g
|
||||||
Q_Q(DGioVolumeManager);
|
Q_Q(DGioVolumeManager);
|
||||||
|
|
||||||
Glib::RefPtr<Mount> copy(gmmMount);
|
Glib::RefPtr<Mount> copy(gmmMount);
|
||||||
|
|
||||||
QExplicitlySharedDataPointer<DGioMount> mount(new DGioMount(copy.release()));
|
QExplicitlySharedDataPointer<DGioMount> mount(new DGioMount(copy.release()));
|
||||||
|
|
||||||
Q_EMIT q->mountPreRemoved(mount);
|
Q_EMIT q->mountPreRemoved(mount);
|
||||||
|
@ -107,7 +111,6 @@ void DGioVolumeManagerPrivate::slot_mountChanged(const Glib::RefPtr<Mount> &gmmM
|
||||||
Q_Q(DGioVolumeManager);
|
Q_Q(DGioVolumeManager);
|
||||||
|
|
||||||
Glib::RefPtr<Mount> copy(gmmMount);
|
Glib::RefPtr<Mount> copy(gmmMount);
|
||||||
|
|
||||||
QExplicitlySharedDataPointer<DGioMount> mount(new DGioMount(copy.release()));
|
QExplicitlySharedDataPointer<DGioMount> mount(new DGioMount(copy.release()));
|
||||||
|
|
||||||
Q_EMIT q->mountChanged(mount);
|
Q_EMIT q->mountChanged(mount);
|
||||||
|
@ -118,7 +121,6 @@ void DGioVolumeManagerPrivate::slot_volumeAdded(const Glib::RefPtr<Volume> &gmmV
|
||||||
Q_Q(DGioVolumeManager);
|
Q_Q(DGioVolumeManager);
|
||||||
|
|
||||||
Glib::RefPtr<Volume> copy(gmmVolume);
|
Glib::RefPtr<Volume> copy(gmmVolume);
|
||||||
|
|
||||||
QExplicitlySharedDataPointer<DGioVolume> volume(new DGioVolume(copy.release()));
|
QExplicitlySharedDataPointer<DGioVolume> volume(new DGioVolume(copy.release()));
|
||||||
|
|
||||||
Q_EMIT q->volumeAdded(volume);
|
Q_EMIT q->volumeAdded(volume);
|
||||||
|
@ -129,7 +131,6 @@ void DGioVolumeManagerPrivate::slot_volumeRemoved(const Glib::RefPtr<Volume> &gm
|
||||||
Q_Q(DGioVolumeManager);
|
Q_Q(DGioVolumeManager);
|
||||||
|
|
||||||
Glib::RefPtr<Volume> copy(gmmVolume);
|
Glib::RefPtr<Volume> copy(gmmVolume);
|
||||||
|
|
||||||
QExplicitlySharedDataPointer<DGioVolume> volume(new DGioVolume(copy.release()));
|
QExplicitlySharedDataPointer<DGioVolume> volume(new DGioVolume(copy.release()));
|
||||||
|
|
||||||
Q_EMIT q->volumeRemoved(volume);
|
Q_EMIT q->volumeRemoved(volume);
|
||||||
|
@ -140,12 +141,41 @@ void DGioVolumeManagerPrivate::slot_volumeChanged(const Glib::RefPtr<Volume> &gm
|
||||||
Q_Q(DGioVolumeManager);
|
Q_Q(DGioVolumeManager);
|
||||||
|
|
||||||
Glib::RefPtr<Volume> copy(gmmVolume);
|
Glib::RefPtr<Volume> copy(gmmVolume);
|
||||||
|
|
||||||
QExplicitlySharedDataPointer<DGioVolume> volume(new DGioVolume(copy.release()));
|
QExplicitlySharedDataPointer<DGioVolume> volume(new DGioVolume(copy.release()));
|
||||||
|
|
||||||
Q_EMIT q->volumeChanged(volume);
|
Q_EMIT q->volumeChanged(volume);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void DGioVolumeManagerPrivate::slot_driveConnected(const Glib::RefPtr<Drive> &gmmDrive)
|
||||||
|
{
|
||||||
|
Q_Q(DGioVolumeManager);
|
||||||
|
|
||||||
|
Glib::RefPtr<Drive> copy(gmmDrive);
|
||||||
|
QExplicitlySharedDataPointer<DGioDrive> drive(new DGioDrive(copy.release()));
|
||||||
|
|
||||||
|
Q_EMIT q->driveConnected(drive);
|
||||||
|
}
|
||||||
|
|
||||||
|
void DGioVolumeManagerPrivate::slot_driveDisconnected(const Glib::RefPtr<Drive> &gmmDrive)
|
||||||
|
{
|
||||||
|
Q_Q(DGioVolumeManager);
|
||||||
|
|
||||||
|
Glib::RefPtr<Drive> copy(gmmDrive);
|
||||||
|
QExplicitlySharedDataPointer<DGioDrive> drive(new DGioDrive(copy.release()));
|
||||||
|
|
||||||
|
Q_EMIT q->driveDisconnected(drive);
|
||||||
|
}
|
||||||
|
|
||||||
|
void DGioVolumeManagerPrivate::slot_driveChanged(const Glib::RefPtr<Drive> &gmmDrive)
|
||||||
|
{
|
||||||
|
Q_Q(DGioVolumeManager);
|
||||||
|
|
||||||
|
Glib::RefPtr<Drive> copy(gmmDrive);
|
||||||
|
QExplicitlySharedDataPointer<DGioDrive> drive(new DGioDrive(copy.release()));
|
||||||
|
|
||||||
|
Q_EMIT q->driveChanged(drive);
|
||||||
|
}
|
||||||
|
|
||||||
// -------------------------------------------------------------
|
// -------------------------------------------------------------
|
||||||
|
|
||||||
DGioVolumeManager::DGioVolumeManager(QObject *parent)
|
DGioVolumeManager::DGioVolumeManager(QObject *parent)
|
||||||
|
|
Loading…
Reference in a new issue