X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/de7c7ca274d2ce0c54eaf2d86a6b26f58d7bc26e..b0a9907b9cb18e7c1a566f67a90206f067b7eb5e:/src/global.cpp diff --git a/src/global.cpp b/src/global.cpp index 0712aa173..c91046efb 100644 --- a/src/global.cpp +++ b/src/global.cpp @@ -18,13 +18,12 @@ #include #include -#include -QList Dolphin::validateUris(const QStringList& uriList) +QList Dolphin::validateUris(const QStringList &uriList) { const QString currentDir = QDir::currentPath(); QList urls; - for (const QString& str : uriList) { + for (const QString &str : uriList) { const QUrl url = QUrl::fromUserInput(str, currentDir, QUrl::AssumeLocalFile); if (url.isValid()) { urls.append(url); @@ -58,11 +57,15 @@ 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; } @@ -71,46 +74,76 @@ bool Dolphin::attachToExistingInstance(const QList& inputUrls, bool openFi return false; } - QStringList newUrls; + int activeWindowIndex = -1; + for (const auto &interface : std::as_const(dolphinInterfaces)) { + ++activeWindowIndex; - // 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) { + 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 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); + } } } - for (const auto& interface: qAsConst(dolphinInterfaces)) { - auto reply = openFiles ? interface.first->openFiles(newUrls, splitView) : interface.first->openDirectories(newUrls, splitView); + for (const auto &interface : std::as_const(dolphinInterfaces)) { + 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(); + interface.first->activateWindow(activationToken); attached = true; - break; } } + if (attached && !newWindowURLs.isEmpty()) { + if (openFiles) { + openNewWindow(newWindowURLs, nullptr, Dolphin::OpenNewWindowFlag::Select); + } else { + openNewWindow(newWindowURLs); + } + } + return attached; } -QVector, QStringList>> Dolphin::dolphinGuiInstances(const QString& preferredService) +QVector, QStringList>> Dolphin::dolphinGuiInstances(const QString &preferredService) { QVector, QStringList>> dolphinInterfaces; if (!preferredService.isEmpty()) { QSharedPointer preferredInterface( - new OrgKdeDolphinMainWindowInterface(preferredService, - QStringLiteral("/dolphin/Dolphin_1"), - QDBusConnection::sessionBus())); + new OrgKdeDolphinMainWindowInterface(preferredService, QStringLiteral("/dolphin/Dolphin_1"), QDBusConnection::sessionBus())); if (preferredInterface->isValid() && !preferredInterface->lastError().isValid()) { dolphinInterfaces.append(qMakePair(preferredInterface, QStringList())); } @@ -123,13 +156,11 @@ QVector, QStringList>> Do const QString pattern = QStringLiteral("org.kde.dolphin-"); // Don't match the pid without leading "-" const QString myPid = QLatin1Char('-') + QString::number(QCoreApplication::applicationPid()); - for (const QString& service : dbusServices) { + for (const QString &service : dbusServices) { if (service.startsWith(pattern) && !service.endsWith(myPid)) { // Check if instance can handle our URLs QSharedPointer interface( - new OrgKdeDolphinMainWindowInterface(service, - QStringLiteral("/dolphin/Dolphin_1"), - QDBusConnection::sessionBus())); + new OrgKdeDolphinMainWindowInterface(service, QStringLiteral("/dolphin/Dolphin_1"), QDBusConnection::sessionBus())); if (interface->isValid() && !interface->lastError().isValid()) { dolphinInterfaces.append(qMakePair(interface, QStringList())); } @@ -155,18 +186,17 @@ double GlobalConfig::animationDurationFactor() updateAnimationDurationFactor(kdeGlobalsConfig, {"AnimationDurationFactor"}); KConfigWatcher::Ptr configWatcher = KConfigWatcher::create(KSharedConfig::openConfig()); - connect(configWatcher.data(), &KConfigWatcher::configChanged, - &GlobalConfig::updateAnimationDurationFactor); + connect(configWatcher.data(), &KConfigWatcher::configChanged, &GlobalConfig::updateAnimationDurationFactor); return s_animationDurationFactor; } void GlobalConfig::updateAnimationDurationFactor(const KConfigGroup &group, const QByteArrayList &names) { - if (group.name() == QLatin1String("KDE") && - names.contains(QByteArrayLiteral("AnimationDurationFactor"))) { - s_animationDurationFactor = std::max(0.0, - group.readEntry("AnimationDurationFactor", 1.0)); + if (group.name() == QLatin1String("KDE") && names.contains(QByteArrayLiteral("AnimationDurationFactor"))) { + s_animationDurationFactor = std::max(0.0, group.readEntry("AnimationDurationFactor", 1.0)); } } double GlobalConfig::s_animationDurationFactor = -1.0; + +#include "moc_global.cpp"