#include <KWindowSystem>
#include <QApplication>
-#include <QIcon>
QList<QUrl> Dolphin::validateUris(const QStringList& uriList)
{
job->start();
}
-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, const QString &activationToken)
{
bool attached = false;
- if (inputUrls.isEmpty() || !GeneralSettings::openExternallyCalledFolderInNewTab()) {
+ if (inputUrls.isEmpty()) {
return false;
}
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<QUrl> 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;
}