diff options
| author | Peter Penz <[email protected]> | 2012-01-30 12:07:08 +0100 |
|---|---|---|
| committer | Peter Penz <[email protected]> | 2012-01-30 12:09:36 +0100 |
| commit | 1d7088b1ada3de716ff591c22d400198450208d4 (patch) | |
| tree | 98dcb98cb56b1d09f2447acf2b7237eb02c8173e /src/views/draganddrophelper.cpp | |
| parent | 0a33aad3d28048720247faa3acdb4d32849e25b5 (diff) | |
Fix drag & drop issues with non-local URLs
BUG: 292821
BUG: 292355
FIXED-IN: 4.8.1
Diffstat (limited to 'src/views/draganddrophelper.cpp')
| -rw-r--r-- | src/views/draganddrophelper.cpp | 15 |
1 files changed, 6 insertions, 9 deletions
diff --git a/src/views/draganddrophelper.cpp b/src/views/draganddrophelper.cpp index 91eb4267d..83673ad72 100644 --- a/src/views/draganddrophelper.cpp +++ b/src/views/draganddrophelper.cpp @@ -28,13 +28,10 @@ #include <QtDBus> #include <QDropEvent> -QString DragAndDropHelper::dropUrls(const KFileItem& destItem, QDropEvent* event) +QString DragAndDropHelper::dropUrls(const KFileItem& destItem, const KUrl& destUrl, QDropEvent* event) { - Q_ASSERT(!destItem.isNull()); - - const KUrl destination = destItem.url(); - if (!destItem.isWritable()) { - return i18nc("@info:status", "Access denied. Could not write to <filename>%1</filename>", destination.pathOrUrl()); + if (!destItem.isNull() && !destItem.isWritable()) { + return i18nc("@info:status", "Access denied. Could not write to <filename>%1</filename>", destUrl.pathOrUrl()); } const QMimeData* mimeData = event->mimeData(); @@ -42,17 +39,17 @@ QString DragAndDropHelper::dropUrls(const KFileItem& destItem, QDropEvent* event const QString remoteDBusClient = mimeData->data("application/x-kde-dndextract"); QDBusMessage message = QDBusMessage::createMethodCall(remoteDBusClient, "/DndExtract", "org.kde.DndExtract", "extractSelectedFilesTo"); - message.setArguments(QVariantList() << destination.pathOrUrl()); + message.setArguments(QVariantList() << destUrl.pathOrUrl()); QDBusConnection::sessionBus().call(message); } else { const KUrl::List urls = KUrl::List::fromMimeData(event->mimeData()); foreach (const KUrl& url, urls) { - if (url == destination) { + if (url == destUrl) { return i18nc("@info:status", "A folder cannot be dropped into itself"); } } - KonqOperations::doDrop(destItem, destination, event, QApplication::activeWindow()); + KonqOperations::doDrop(destItem, destUrl, event, QApplication::activeWindow()); } return QString(); |
