X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/954e8c47906c12edaaf6e6aebdd41516eceb0d44..4102ccb80457eea44ea280f0ace2a419602bc34b:/src/dbusinterface.cpp diff --git a/src/dbusinterface.cpp b/src/dbusinterface.cpp index cf1ad53ad..18544493c 100644 --- a/src/dbusinterface.cpp +++ b/src/dbusinterface.cpp @@ -5,60 +5,72 @@ */ #include "dbusinterface.h" -#include "global.h" #include "dolphin_generalsettings.h" +#include "global.h" #include +#include -#include #include -#include #include -DBusInterface::DBusInterface() : - QObject() +DBusInterface::DBusInterface() + : QObject() { - QDBusConnection::sessionBus().registerObject(QStringLiteral("/org/freedesktop/FileManager1"), this, - QDBusConnection::ExportScriptableContents | QDBusConnection::ExportAdaptors); - QDBusConnection::sessionBus().interface()->registerService(QStringLiteral("org.freedesktop.FileManager1"), - QDBusConnectionInterface::QueueService); + QDBusConnection::sessionBus().registerObject(QStringLiteral("/org/freedesktop/FileManager1"), + this, + QDBusConnection::ExportScriptableContents | QDBusConnection::ExportAdaptors); + QDBusConnectionInterface *sessionInterface = QDBusConnection::sessionBus().interface(); + if (sessionInterface) { + sessionInterface->registerService(QStringLiteral("org.freedesktop.FileManager1"), QDBusConnectionInterface::QueueService); + } } -void DBusInterface::ShowFolders(const QStringList& uriList, const QString& startUpId) +void DBusInterface::ShowFolders(const QStringList &uriList, const QString &startUpId) { - Q_UNUSED(startUpId) const QList urls = Dolphin::validateUris(uriList); if (urls.isEmpty()) { return; } const auto serviceName = isDaemon() ? QString() : QStringLiteral("org.kde.dolphin-%1").arg(QCoreApplication::applicationPid()); - if(!Dolphin::attachToExistingInstance(urls, false, GeneralSettings::splitView(), serviceName)) { + if (!Dolphin::attachToExistingInstance(urls, false, GeneralSettings::splitView(), serviceName, startUpId)) { Dolphin::openNewWindow(urls); } } -void DBusInterface::ShowItems(const QStringList& uriList, const QString& startUpId) +void DBusInterface::ShowItems(const QStringList &uriList, const QString &startUpId) { - Q_UNUSED(startUpId) const QList urls = Dolphin::validateUris(uriList); if (urls.isEmpty()) { return; } const auto serviceName = isDaemon() ? QString() : QStringLiteral("org.kde.dolphin-%1").arg(QCoreApplication::applicationPid()); - if(!Dolphin::attachToExistingInstance(urls, true, GeneralSettings::splitView(), serviceName)) { + if (!Dolphin::attachToExistingInstance(urls, true, GeneralSettings::splitView(), serviceName, startUpId)) { Dolphin::openNewWindow(urls, nullptr, Dolphin::OpenNewWindowFlag::Select); }; } -void DBusInterface::ShowItemProperties(const QStringList& uriList, const QString& startUpId) +void DBusInterface::ShowItemProperties(const QStringList &uriList, const QString &startUpId) { - Q_UNUSED(startUpId) const QList urls = Dolphin::validateUris(uriList); if (!urls.isEmpty()) { + KWindowSystem::setCurrentXdgActivationToken(startUpId); KPropertiesDialog::showDialog(urls); } } +void DBusInterface::SortOrderForUrl(const QString &url, QString &role, QString &order) +{ + QUrl qurl(url); + auto sort = Dolphin::sortOrderForUrl(qurl); + role = sort.first; + if (sort.second == Qt::AscendingOrder) { + order = QStringLiteral("ascending"); + } else { + order = QStringLiteral("descending"); + } +} + void DBusInterface::setAsDaemon() { m_isDaemon = true; @@ -68,3 +80,5 @@ bool DBusInterface::isDaemon() const { return m_isDaemon; } + +#include "moc_dbusinterface.cpp"