Closed Bug 338478 (CF_HDROP) Opened 14 years ago Closed 11 years ago
Support dragging and dropping files on windows
Component: Extension/Theme Manager → General
QA Contact: extension.manager → general
Assignee: nobody → win32
Severity: normal → enhancement
Component: General → Widget: Win32
Product: Firefox → Core
QA Contact: general → ian
Summary: It's impossible to copy a file link to clipboard for paste or. drag&drop → Support copying a file to clipboard for paste or drag and drop
Version: unspecified → Trunk
I would like to be able to drag and drop files, so this would be nice to have! This explains the CF_HDROP structure: http://msdn.microsoft.com/library/default.asp?url=/library/en-us/shellcc/platform/shell/programmersguide/shell_basics/shell_basics_programming/transferring/clipboard.asp Also see: http://www.codeproject.com/shell/explorerdragdrop.asp
ClipSpy.exe A program that can show the data structure of clipboard or drag and drop operation Credits to original author Michael Dunn http://www.codeproject.com/clipboard/clipspy.asp
I'll note that it appears the windows nsDataObj.cpp already has code to build the necessary CF_HDROP structure, but it will only do this for image files of the content type "application/x-moz-nativeimage" http://mxr.mozilla.org/mozilla-central/source/widget/src/windows/nsDataObj.cpp#1357 Perhaps this function can be generalized
I'm working on this intermittently, hope to have something done in a week or two.
Assignee: nobody → me
Status: UNCONFIRMED → NEW
Ever confirmed: true
Brain dump to myself for when I pick this back up this weekend. Gecko implements the IDataObject interface needed for OLE drag and drop through nsDataObj. nsDataObj contains most of the code needed to do this. Retrofitting the GetFile function tagged in comment 3 is fairly easy (and is already complete). What is more difficult is handling drag and drop of multiple objects at once. Gecko "handles" dragging and dropping multiple objects by wrapping the nsDataObj for each object in an nsDataObjCollection. nsDataObjCollection implements IDataObject too, so the nsDataObjCollection instance is passed to the outside world and when IDataObject::GetData is called on nsDataObjCollection is passes that through to its children. Very good idea, unfortunately, nsDataObjCollection was never fully implemented. At least two major changes need to be made, the nsDataObj classes need to realize when they're chained and receiving a STGMEDIUM structure that has already been written to to avoid overwriting each other's data, and nsDataObjCollection needs to properly advertise the flavors it provides. (Currently drag and drop flavors are set by nsClipboard::CreateNativeDataObject which never sees nsDataObjCollection. As far as I can see the add flavor's method on nsDataObjCollection is never called.) Note that all of the GetXXXXXX methods need to recognize when they are being called in a chain and play nicely. That may be a project for another bug though (and I filed another one, don't have the number handy though). Also need to investigate whether all of the D&D formats support multiple objects. Thunderbird has the ability to drag and drop attachments because it uses the "application/x-moz-file-promise". "application/x-moz-file-promise" maps to the native CFSTR_FILECONTENTS which is intended for virtual files, not for actual filesystem objects so we probably shouldn't go that route here. Probably need to spend a decent amount of time reading all the MSDN docs too, some of this stuff is downright ancient (designed for Windows 3.1)
Status: NEW → ASSIGNED
Target Milestone: --- → mozilla1.9.3a1
Not sure if it's related, but judging from https://developer.mozilla.org/en/DragDrop/Recommended_Drag_Types#Dragging_Files file D&D should be supported in the recent Geckos.
(In reply to comment #6) > Not sure if it's related, but judging from > https://developer.mozilla.org/en/DragDrop/Recommended_Drag_Types#Dragging_Files > file D&D should be supported in the recent Geckos. Gecko supports it internally, it's just the interfacing with Windows (and potentially other platforms, haven't looked at Linux or Mac) that's missing.
This patch is alpha quality at best (there's a ridiculous amount of cleanup to do) but it works. This also contains some patches to the download manager to let you drag and drop files out of it (to say the desktop). It works with one or multiple files. There's a lot of work remaining to be done. All of the other GetXXX functions need to be updated to support being part of an nsDataObjContainer, and there's plenty of code cleanup to do. I'll pick this up again next weekend. And btw, Devon, thanks for that clipboard program. It's incredibly useful when playing with this stuff.
Woops, forgot my comments on that: This patch makes all of the existing data formats work correctly on a nsDataObj that is wrapped by an nsDataObjCollection. As before, some download manager modifications are included so that this can be tested. Not every native format accepts multiple objects, so for those that don't nsDataObjCollection just passes GetData along to the first object. There is some hackery involved with IStreams because we need to know what index to respond to. There is also a problem because this patch uses GlobalSize to figure out where to start writing, which seems to work ok on my system but the msdn docs say pretty clearly "the size of a memory block may be larger than the size requested when the memory was allocated." It looks like there will need to be some more communication/synchronization between nsDataObj/*Collection or the concatenation of responses will need to be done in the nsDataObjCollection and not in the nsDataObj. (I'm actually leaning towards the latter). Also updated the bug summary to make it clear that this has little to do with the clipboard.
Summary: Support copying a file to clipboard for paste or drag and drop → Support dragging and dropping multiple files on windows ( CF_HDROP, etc)
Depends on: 528731
Sorry to edit the title again, I'm going to spin off the nsDataObjCollection changes to another bug.
Summary: Support dragging and dropping multiple files on windows ( CF_HDROP, etc) → Support dragging and dropping files on windows
For review. I split out all of the nsDataObjCollection changes and all of the miscellaneous cleanup, so what's left should be pretty straightforward.
Attachment #411796 - Attachment is obsolete: true
This is not for review, but is useful for testing the drag and drop functionality. It allows you to drag files out of the download manager.
Fixed a couple whitespace nits.
Attachment #413016 - Flags: review?(roc) → review+
What can we do to get an automated test for this? It seems to me we might be able to test it with a unit test.
(In reply to comment #16) > What can we do to get an automated test for this? It seems to me we might be > able to test it with a unit test. Maybe. To test the native code we need to drag the file to another OLE drop target (otherwise Gecko will handle it internally). It may be sufficient to drag it between different windows within one process. MXR is being goofy right now, but I will investigate. There aren't any existing DnD tests are there? I didn't see any but I could be looking in the wrong place.
There are some, but I don't know if they test dragging to external apps. Is the Explorer shell such a drop target? I wonder if we could open an Explorer window, simulate dragging the file into it, and test that Explorer did the right thing. We do have the ability to simulate native mouse events at a low level on Windows, see nsDOMWindowUtils::SendNativeMouseEvent.
(In reply to comment #18) > Is the Explorer shell such a drop target? Yes, that's the primary use case for this. I'll play around with it and see what I can come up with.
This obviously needs more work and is not ready for an r+, but I wanted to get some feedback on whether I'm going in the right direction here. nsIDOMWindowUtils unfortunately doesn't have the ability to fake input to other program's windows so we'll have to use a compiled test. What I've done is link against the compiled result of /widget/src/windows and its dependencies. Then we can play fake nsDragService: make the transferables and pass them to nsClipboard which creates the data objects which we can test. I think this is the best way to go about it. Suggestions and comments welcome. I'll expand this to cover other DnD scenarios too.
This looks good, thanks!
Comment on attachment 413828 [details] [diff] [review] Compiled test Cool, I'll clean it up and expand.
This tests this patch and also dragging single strings of data. I've structured it so it'll be a lot easier to add tests of more types and tests of multiple objects which we'll need later in Bug 513464.
Attachment #414153 - Flags: review?(roc)
Attachment #414153 - Flags: review?(roc) → review+
Test does not build with --enable-libxul. Clearing checkin-needed while I fix it.
--enable-libxul doesn't build a lot of the intermediate libraries I linked against. The xpcom tests seem to #ifndef MOZ_ENABLE_LIBXUL their tests that rely on internal bits, so I may end up doing that, because it doesn't appear that I can link my way out of this.
Attachment #414153 - Attachment is obsolete: true
Attachment #413013 - Attachment is obsolete: true
Attachment #413016 - Attachment is obsolete: true
--enable-libxul doesn't expose a lot of the symbols we need for this so just skip this test on an --enable-libxul build. There are also a couple other cleanups here too. This is a diff based off of what what already reviewed.
Attachment #416872 - Flags: review?(roc)
This includes the two patches already r+'d and the makefile changes I just uploaded.
Attachment #416872 - Flags: review?(roc) → review+
Kyle, I think you need to r+ the patch and indicate it is forwarding r+=roc and replace those patches with this one. see bug 450861 comment 47.
Comment on attachment 416873 [details] [diff] [review] Cumulative patch for checkin Thanks Phil. In case it's not clear, this patch is a combination of three individual diffs that have all been r+'d by roc.
Attachment #416873 - Flags: review+
Attachment #416872 - Attachment is obsolete: true
Status: ASSIGNED → RESOLVED
Closed: 11 years ago
Resolution: --- → FIXED
(In reply to comment #31) > http://hg.mozilla.org/mozilla-central/rev/e2f9cde1e66d Thanks Phil!
You need to log in before you can comment on or make changes to this bug.