X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/4d81aabd1ee78c2fca61452ef3a866cfad0c88a5..c74d844ec269adc63111363cd6da99e4deaaf083:/src/global.cpp diff --git a/src/global.cpp b/src/global.cpp index cd1409d9e..d5fbec6bc 100644 --- a/src/global.cpp +++ b/src/global.cpp @@ -15,6 +15,7 @@ #include #include #include +#include #include @@ -56,11 +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; - if (inputUrls.isEmpty() || !GeneralSettings::openExternallyCalledFolderInNewTab()) { + if (inputUrls.isEmpty()) { return false; } @@ -81,19 +82,20 @@ bool Dolphin::attachToExistingInstance(const QList& inputUrls, bool openFi } // check to see if any instances already have any of the given URLs or their parents open - const auto urls = QUrl::toStringList(inputUrls); - for (const QString& url : urls) { + QList newWindowURLs; + for (const QUrl& url : inputUrls) { bool urlFound = false; + 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(url) : interface.first->isUrlOpen(url); + 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; } @@ -103,7 +105,11 @@ bool Dolphin::attachToExistingInstance(const QList& inputUrls, bool openFi while (i != activeWindowIndex); if (!urlFound) { - dolphinInterfaces[activeWindowIndex].second.append(url); + if (GeneralSettings::openExternallyCalledFolderInNewTab()) { + dolphinInterfaces[activeWindowIndex].second.append(urlString); + } else { + newWindowURLs.append(url); + } } } @@ -116,10 +122,18 @@ bool Dolphin::attachToExistingInstance(const QList& inputUrls, bool openFi interface.first->openDirectories(interface.second, splitView); reply.waitForFinished(); if (!reply.isError()) { - interface.first->activateWindow(); + interface.first->activateWindow(activationToken); attached = true; } } + if (attached && !newWindowURLs.isEmpty()) { + if (openFiles) { + openNewWindow(newWindowURLs, nullptr, Dolphin::OpenNewWindowFlag::Select); + } else { + openNewWindow(newWindowURLs); + } + } + return attached; }