X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/393c659c9a0ffc5f6ddb4ee161b9b3937ead0145..6c19e733673e24684707836fb2c9e0f45d1ac3f9:/src/global.cpp diff --git a/src/global.cpp b/src/global.cpp index d217a67ec..d5fbec6bc 100644 --- a/src/global.cpp +++ b/src/global.cpp @@ -18,7 +18,6 @@ #include #include -#include QList Dolphin::validateUris(const QStringList& uriList) { @@ -58,12 +57,11 @@ void Dolphin::openNewWindow(const QList &urls, QWidget *window, const Open job->start(); } -bool Dolphin::attachToExistingInstance(const QList& inputUrls, bool openFiles, bool splitView, const QString& preferredService) +bool Dolphin::attachToExistingInstance(const QList& inputUrls, bool openFiles, bool splitView, const QString& preferredService, const QString &activationToken) { bool attached = false; - // TODO: once Wayland clients can raise or activate themselves remove check from conditional - if (KWindowSystem::isPlatformWayland() || inputUrls.isEmpty() || !GeneralSettings::openExternallyCalledFolderInNewTab()) { + if (inputUrls.isEmpty()) { return false; } @@ -72,37 +70,70 @@ bool Dolphin::attachToExistingInstance(const QList& inputUrls, bool openFi return false; } - QStringList newUrls; + int activeWindowIndex = -1; + for (const auto& interface: qAsConst(dolphinInterfaces)) { + ++activeWindowIndex; + + auto isActiveWindowReply = interface.first->isActiveWindow(); + isActiveWindowReply.waitForFinished(); + if (!isActiveWindowReply.isError() && isActiveWindowReply.value()) { + break; + } + } - // check to see if any instances already have any of the given URLs open - const auto urls = QUrl::toStringList(inputUrls); - for (const QString& url : urls) { + // check to see if any instances already have any of the given URLs or their parents open + QList newWindowURLs; + for (const QUrl& url : inputUrls) { bool urlFound = false; - for (auto& interface: dolphinInterfaces) { - auto isUrlOpenReply = interface.first->isUrlOpen(url); + const QString urlString = url.toString(); + + // looping through the windows starting from the active one + int i = activeWindowIndex; + do { + auto &interface = dolphinInterfaces[i]; + + auto isUrlOpenReply = openFiles ? interface.first->isItemVisibleInAnyView(urlString) : interface.first->isUrlOpen(urlString); isUrlOpenReply.waitForFinished(); if (!isUrlOpenReply.isError() && isUrlOpenReply.value()) { - interface.second.append(url); + interface.second.append(urlString); urlFound = true; break; } + + i = (i + 1) % dolphinInterfaces.size(); } + while (i != activeWindowIndex); + if (!urlFound) { - newUrls.append(url); + if (GeneralSettings::openExternallyCalledFolderInNewTab()) { + dolphinInterfaces[activeWindowIndex].second.append(urlString); + } else { + newWindowURLs.append(url); + } } } - dolphinInterfaces.front().second << newUrls; for (const auto& interface: qAsConst(dolphinInterfaces)) { - if (!interface.second.isEmpty()) { - auto reply = openFiles ? interface.first->openFiles(interface.second, splitView) : interface.first->openDirectories(interface.second, splitView); - reply.waitForFinished(); - if (!reply.isError()) { - interface.first->activateWindow(); - attached = true; - } + if (interface.second.isEmpty()) { + continue; + } + auto reply = openFiles ? + interface.first->openFiles(interface.second, splitView) : + interface.first->openDirectories(interface.second, splitView); + reply.waitForFinished(); + if (!reply.isError()) { + interface.first->activateWindow(activationToken); + attached = true; } } + if (attached && !newWindowURLs.isEmpty()) { + if (openFiles) { + openNewWindow(newWindowURLs, nullptr, Dolphin::OpenNewWindowFlag::Select); + } else { + openNewWindow(newWindowURLs); + } + } + return attached; }