RESOLVED FIXED 147985
[Cocoa] Downloads do not start if policy decision is made asynchronously
https://bugs.webkit.org/show_bug.cgi?id=147985
Summary [Cocoa] Downloads do not start if policy decision is made asynchronously
Andy Estes
Reported 2015-08-13 12:47:57 PDT
[Cocoa] Downloads do not start if policy decision is made asynchronously
Attachments
Patch (16.73 KB, patch)
2015-08-13 13:04 PDT, Andy Estes
no flags
Patch (17.35 KB, patch)
2015-08-13 15:44 PDT, Andy Estes
beidson: review+
Andy Estes
Comment 1 2015-08-13 12:49:43 PDT
Andy Estes
Comment 2 2015-08-13 13:04:00 PDT
Alexey Proskuryakov
Comment 3 2015-08-13 15:38:21 PDT
Comment on attachment 258919 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=258919&action=review > Source/WebCore/ChangeLog:11 > + asynchronously. If a client chooses to download a response asynchronously, we can no longer convert the > + connection to a download, so we should start a new download instead. This is surely not a permanent solution to this, is it? In the general case, it is not possible to start a new download. We need to delay responding to willSendRequest until the decision is made.
Andy Estes
Comment 4 2015-08-13 15:42:14 PDT
(In reply to comment #3) > Comment on attachment 258919 [details] > Patch > > View in context: > https://bugs.webkit.org/attachment.cgi?id=258919&action=review > > > Source/WebCore/ChangeLog:11 > > + asynchronously. If a client chooses to download a response asynchronously, we can no longer convert the > > + connection to a download, so we should start a new download instead. > > This is surely not a permanent solution to this, is it? In the general case, > it is not possible to start a new download. > > We need to delay responding to willSendRequest until the decision is made. didReceiveResponse in this case, but you're right, that's the correct solution. This is a stopgap measure until that solution can be implemented. I included more information about this in the linked radar.
Andy Estes
Comment 5 2015-08-13 15:44:36 PDT
Brady Eidson
Comment 6 2015-08-14 12:33:11 PDT
Comment on attachment 258942 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=258942&action=review > Source/WebCore/loader/SubresourceLoader.cpp:80 > + , m_callingDidReceiveResponse(false) Default value can be in the class declaration in the header. > Source/WebCore/loader/SubresourceLoader.h:129 > + bool m_callingDidReceiveResponse; ...right here. > Source/WebKit/mac/WebCoreSupport/WebFrameLoaderClient.mm:292 > // The resource has already been cached, start a new download. Inaccurate comment
Andy Estes
Comment 7 2015-08-14 14:08:37 PDT
Note You need to log in before you can comment on or make changes to this bug.