mirror of
https://invent.kde.org/system/dolphin
synced 2024-11-05 18:47:12 +00:00
Merge branch 'release/20.04'
This commit is contained in:
commit
b65c5c3bc2
7 changed files with 59 additions and 21 deletions
|
@ -269,6 +269,10 @@ kconfig_add_kcfg_files(dolphinstatic_SRCS GENERATE_MOC
|
||||||
|
|
||||||
qt5_add_resources(dolphinstatic_SRCS dolphin.qrc)
|
qt5_add_resources(dolphinstatic_SRCS dolphin.qrc)
|
||||||
|
|
||||||
|
qt5_generate_dbus_interface(${CMAKE_CURRENT_SOURCE_DIR}/dolphinmainwindow.h org.kde.DolphinMainWindow.xml)
|
||||||
|
qt5_add_dbus_adaptor(dolphinstatic_SRCS ${CMAKE_CURRENT_BINARY_DIR}/org.kde.DolphinMainWindow.xml dolphinmainwindow.h DolphinMainWindow)
|
||||||
|
qt5_add_dbus_interface(dolphinstatic_SRCS ${CMAKE_CURRENT_BINARY_DIR}/org.kde.DolphinMainWindow.xml dolphinmainwindowinterface)
|
||||||
|
|
||||||
add_library(dolphinstatic STATIC ${dolphinstatic_SRCS})
|
add_library(dolphinstatic STATIC ${dolphinstatic_SRCS})
|
||||||
|
|
||||||
target_include_directories(dolphinstatic SYSTEM PRIVATE ${PHONON_INCLUDES})
|
target_include_directories(dolphinstatic SYSTEM PRIVATE ${PHONON_INCLUDES})
|
||||||
|
|
|
@ -44,7 +44,7 @@ void DBusInterface::ShowFolders(const QStringList& uriList, const QString& start
|
||||||
if (urls.isEmpty()) {
|
if (urls.isEmpty()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
const auto serviceName = QStringLiteral("org.kde.dolphin-%1").arg(QCoreApplication::applicationPid());
|
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)) {
|
||||||
Dolphin::openNewWindow(urls);
|
Dolphin::openNewWindow(urls);
|
||||||
}
|
}
|
||||||
|
@ -57,7 +57,7 @@ void DBusInterface::ShowItems(const QStringList& uriList, const QString& startUp
|
||||||
if (urls.isEmpty()) {
|
if (urls.isEmpty()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
const auto serviceName = QStringLiteral("org.kde.dolphin-%1").arg(QCoreApplication::applicationPid());
|
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)) {
|
||||||
Dolphin::openNewWindow(urls, nullptr, Dolphin::OpenNewWindowFlag::Select);
|
Dolphin::openNewWindow(urls, nullptr, Dolphin::OpenNewWindowFlag::Select);
|
||||||
};
|
};
|
||||||
|
@ -71,3 +71,13 @@ void DBusInterface::ShowItemProperties(const QStringList& uriList, const QString
|
||||||
KPropertiesDialog::showDialog(urls);
|
KPropertiesDialog::showDialog(urls);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void DBusInterface::setAsDaemon()
|
||||||
|
{
|
||||||
|
m_isDaemon = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool DBusInterface::isDaemon() const
|
||||||
|
{
|
||||||
|
return m_isDaemon;
|
||||||
|
}
|
||||||
|
|
|
@ -32,6 +32,19 @@ public:
|
||||||
Q_SCRIPTABLE void ShowFolders(const QStringList& uriList, const QString& startUpId);
|
Q_SCRIPTABLE void ShowFolders(const QStringList& uriList, const QString& startUpId);
|
||||||
Q_SCRIPTABLE void ShowItems(const QStringList& uriList, const QString& startUpId);
|
Q_SCRIPTABLE void ShowItems(const QStringList& uriList, const QString& startUpId);
|
||||||
Q_SCRIPTABLE void ShowItemProperties(const QStringList& uriList, const QString& startUpId);
|
Q_SCRIPTABLE void ShowItemProperties(const QStringList& uriList, const QString& startUpId);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set whether this interface has been created by dolphin --deamon.
|
||||||
|
*/
|
||||||
|
void setAsDaemon();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return Whether this interface has been created by dolphin --deamon.
|
||||||
|
*/
|
||||||
|
bool isDaemon() const;
|
||||||
|
|
||||||
|
private:
|
||||||
|
bool m_isDaemon = false;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // DBUSINTERFACE_H
|
#endif // DBUSINTERFACE_H
|
||||||
|
|
|
@ -21,6 +21,7 @@
|
||||||
|
|
||||||
#include "dolphinmainwindow.h"
|
#include "dolphinmainwindow.h"
|
||||||
|
|
||||||
|
#include "dolphinmainwindowadaptor.h"
|
||||||
#include "config-terminal.h"
|
#include "config-terminal.h"
|
||||||
#include "global.h"
|
#include "global.h"
|
||||||
#include "dolphinbookmarkhandler.h"
|
#include "dolphinbookmarkhandler.h"
|
||||||
|
@ -118,6 +119,9 @@ DolphinMainWindow::DolphinMainWindow() :
|
||||||
m_forwardAction(nullptr)
|
m_forwardAction(nullptr)
|
||||||
{
|
{
|
||||||
Q_INIT_RESOURCE(dolphin);
|
Q_INIT_RESOURCE(dolphin);
|
||||||
|
|
||||||
|
new MainWindowAdaptor(this);
|
||||||
|
|
||||||
#ifndef Q_OS_WIN
|
#ifndef Q_OS_WIN
|
||||||
setWindowFlags(Qt::WindowContextHelpButtonHint);
|
setWindowFlags(Qt::WindowContextHelpButtonHint);
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -21,14 +21,13 @@
|
||||||
|
|
||||||
#include "dolphin_generalsettings.h"
|
#include "dolphin_generalsettings.h"
|
||||||
#include "dolphindebug.h"
|
#include "dolphindebug.h"
|
||||||
|
#include "dolphinmainwindowinterface.h"
|
||||||
|
|
||||||
#include <KRun>
|
#include <KRun>
|
||||||
#include <KWindowSystem>
|
#include <KWindowSystem>
|
||||||
|
|
||||||
#include <QApplication>
|
#include <QApplication>
|
||||||
#include <QIcon>
|
#include <QIcon>
|
||||||
#include <QDBusInterface>
|
|
||||||
#include <QDBusConnectionInterface>
|
|
||||||
|
|
||||||
QList<QUrl> Dolphin::validateUris(const QStringList& uriList)
|
QList<QUrl> Dolphin::validateUris(const QStringList& uriList)
|
||||||
{
|
{
|
||||||
|
@ -72,18 +71,19 @@ void Dolphin::openNewWindow(const QList<QUrl> &urls, QWidget *window, const Open
|
||||||
|
|
||||||
bool Dolphin::attachToExistingInstance(const QList<QUrl>& inputUrls, bool openFiles, bool splitView, const QString& preferredService)
|
bool Dolphin::attachToExistingInstance(const QList<QUrl>& inputUrls, bool openFiles, bool splitView, const QString& preferredService)
|
||||||
{
|
{
|
||||||
|
bool attached = false;
|
||||||
|
|
||||||
// TODO: once Wayland clients can raise or activate themselves remove check from conditional
|
// TODO: once Wayland clients can raise or activate themselves remove check from conditional
|
||||||
if (KWindowSystem::isPlatformWayland() || inputUrls.isEmpty() || !GeneralSettings::openExternallyCalledFolderInNewTab()) {
|
if (KWindowSystem::isPlatformWayland() || inputUrls.isEmpty() || !GeneralSettings::openExternallyCalledFolderInNewTab()) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
QVector<QPair<QSharedPointer<QDBusInterface>, QStringList>> dolphinInterfaces;
|
QVector<QPair<QSharedPointer<OrgKdeDolphinMainWindowInterface>, QStringList>> dolphinInterfaces;
|
||||||
if (!preferredService.isEmpty()) {
|
if (!preferredService.isEmpty()) {
|
||||||
QSharedPointer<QDBusInterface> preferredInterface(
|
QSharedPointer<OrgKdeDolphinMainWindowInterface> preferredInterface(
|
||||||
new QDBusInterface(preferredService,
|
new OrgKdeDolphinMainWindowInterface(preferredService,
|
||||||
QStringLiteral("/dolphin/Dolphin_1"),
|
QStringLiteral("/dolphin/Dolphin_1"),
|
||||||
QString()) // #414402: use empty interface name to prevent QtDBus from caching the interface.
|
QDBusConnection::sessionBus()));
|
||||||
);
|
|
||||||
if (preferredInterface->isValid() && !preferredInterface->lastError().isValid()) {
|
if (preferredInterface->isValid() && !preferredInterface->lastError().isValid()) {
|
||||||
dolphinInterfaces.append(qMakePair(preferredInterface, QStringList()));
|
dolphinInterfaces.append(qMakePair(preferredInterface, QStringList()));
|
||||||
}
|
}
|
||||||
|
@ -98,11 +98,10 @@ bool Dolphin::attachToExistingInstance(const QList<QUrl>& inputUrls, bool openFi
|
||||||
for (const QString& service : dbusServices) {
|
for (const QString& service : dbusServices) {
|
||||||
if (service.startsWith(pattern) && !service.endsWith(myPid)) {
|
if (service.startsWith(pattern) && !service.endsWith(myPid)) {
|
||||||
// Check if instance can handle our URLs
|
// Check if instance can handle our URLs
|
||||||
QSharedPointer<QDBusInterface> interface(
|
QSharedPointer<OrgKdeDolphinMainWindowInterface> interface(
|
||||||
new QDBusInterface(service,
|
new OrgKdeDolphinMainWindowInterface(service,
|
||||||
QStringLiteral("/dolphin/Dolphin_1"),
|
QStringLiteral("/dolphin/Dolphin_1"),
|
||||||
QStringLiteral("org.kde.dolphin.MainWindow"))
|
QDBusConnection::sessionBus()));
|
||||||
);
|
|
||||||
if (interface->isValid() && !interface->lastError().isValid()) {
|
if (interface->isValid() && !interface->lastError().isValid()) {
|
||||||
dolphinInterfaces.append(qMakePair(interface, QStringList()));
|
dolphinInterfaces.append(qMakePair(interface, QStringList()));
|
||||||
}
|
}
|
||||||
|
@ -120,8 +119,9 @@ bool Dolphin::attachToExistingInstance(const QList<QUrl>& inputUrls, bool openFi
|
||||||
for (const QString& url : urls) {
|
for (const QString& url : urls) {
|
||||||
bool urlFound = false;
|
bool urlFound = false;
|
||||||
for (auto& interface: dolphinInterfaces) {
|
for (auto& interface: dolphinInterfaces) {
|
||||||
QDBusReply<bool> isUrlOpenReply = interface.first->call(QStringLiteral("isUrlOpen"), url);
|
auto isUrlOpenReply = interface.first->isUrlOpen(url);
|
||||||
if (isUrlOpenReply.isValid() && isUrlOpenReply.value()) {
|
isUrlOpenReply.waitForFinished();
|
||||||
|
if (!isUrlOpenReply.isError() && isUrlOpenReply.value()) {
|
||||||
interface.second.append(url);
|
interface.second.append(url);
|
||||||
urlFound = true;
|
urlFound = true;
|
||||||
break;
|
break;
|
||||||
|
@ -135,9 +135,13 @@ bool Dolphin::attachToExistingInstance(const QList<QUrl>& inputUrls, bool openFi
|
||||||
|
|
||||||
for (const auto& interface: dolphinInterfaces) {
|
for (const auto& interface: dolphinInterfaces) {
|
||||||
if (!interface.second.isEmpty()) {
|
if (!interface.second.isEmpty()) {
|
||||||
interface.first->call(openFiles ? QStringLiteral("openFiles") : QStringLiteral("openDirectories"), interface.second, splitView);
|
auto reply = openFiles ? interface.first->openFiles(interface.second, splitView) : interface.first->openDirectories(interface.second, splitView);
|
||||||
interface.first->call(QStringLiteral("activateWindow"));
|
reply.waitForFinished();
|
||||||
|
if (!reply.isError()) {
|
||||||
|
interface.first->activateWindow();
|
||||||
|
attached = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return true;
|
}
|
||||||
|
return attached;
|
||||||
}
|
}
|
||||||
|
|
|
@ -45,7 +45,9 @@ namespace Dolphin {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Attaches URLs to an existing Dolphin instance if possible.
|
* Attaches URLs to an existing Dolphin instance if possible.
|
||||||
* Returns true if URLs were successfully attached
|
* If @p preferredService is a valid dbus service, it will be tried first.
|
||||||
|
* @p preferredService needs to support the org.kde.dolphin.MainWindow dbus interface with the /dolphin/Dolphin_1 path.
|
||||||
|
* Returns true if the URLs were successfully attached.
|
||||||
*/
|
*/
|
||||||
bool attachToExistingInstance(const QList<QUrl>& inputUrls, bool openFiles, bool splitView, const QString& preferredService = QString());
|
bool attachToExistingInstance(const QList<QUrl>& inputUrls, bool openFiles, bool splitView, const QString& preferredService = QString());
|
||||||
|
|
||||||
|
|
|
@ -143,6 +143,7 @@ extern "C" Q_DECL_EXPORT int kdemain(int argc, char **argv)
|
||||||
if (parser.isSet(QStringLiteral("daemon"))) {
|
if (parser.isSet(QStringLiteral("daemon"))) {
|
||||||
KDBusService dolphinDBusService;
|
KDBusService dolphinDBusService;
|
||||||
DBusInterface interface;
|
DBusInterface interface;
|
||||||
|
interface.setAsDaemon();
|
||||||
return app.exec();
|
return app.exec();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue