From: Kai Uwe Broulik Date: Mon, 8 Jun 2020 20:45:27 +0000 (+0200) Subject: Generalize Player protocol support X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/commitdiff_plain/f2c09faf00e5375bc698732953572841933bb74d Generalize Player protocol support In preparation for AFC support in KFilePlacesModel. This needs to go into stable since otherwise once Solid announces AFC devices Dolphin would see them but try to open them as MTP URL --- diff --git a/src/panels/places/placesitem.cpp b/src/panels/places/placesitem.cpp index b06bac9a6..ea2270020 100644 --- a/src/panels/places/placesitem.cpp +++ b/src/panels/places/placesitem.cpp @@ -37,7 +37,7 @@ PlacesItem::PlacesItem(const KBookmark& bookmark, PlacesItem* parent) : m_access(), m_volume(), m_disc(), - m_mtp(), + m_player(), m_signalHandler(nullptr), m_bookmark() { @@ -140,7 +140,7 @@ void PlacesItem::setBookmark(const KBookmark& bookmark) delete m_access; delete m_volume; delete m_disc; - delete m_mtp; + delete m_player; const QString udi = bookmark.metaDataItem(QStringLiteral("UDI")); if (udi.isEmpty()) { @@ -207,7 +207,7 @@ void PlacesItem::initializeDevice(const QString& udi) m_access = m_device.as(); m_volume = m_device.as(); m_disc = m_device.as(); - m_mtp = m_device.as(); + m_player = m_device.as(); setText(m_device.description()); setIcon(m_device.icon()); @@ -228,8 +228,11 @@ void PlacesItem::initializeDevice(const QString& udi) } else { setUrl(QUrl(QStringLiteral("audiocd:/"))); } - } else if (m_mtp) { - setUrl(QUrl(QStringLiteral("mtp:udi=%1").arg(m_device.udi()))); + } else if (m_player) { + const QStringList protocols = m_player->supportedProtocols(); + if (!protocols.isEmpty()) { + setUrl(QUrl(QStringLiteral("%1:udi=%2").arg(protocols.first(), m_device.udi()))); + } } } diff --git a/src/panels/places/placesitem.h b/src/panels/places/placesitem.h index eccd297fa..1eff7a380 100644 --- a/src/panels/places/placesitem.h +++ b/src/panels/places/placesitem.h @@ -106,7 +106,7 @@ private: QPointer m_access; QPointer m_volume; QPointer m_disc; - QPointer m_mtp; + QPointer m_player; QPointer m_signalHandler; KBookmark m_bookmark;