WebKit Bugzilla
New
Browse
Log In
×
Sign in with GitHub
or
Remember my login
Create Account
·
Forgot Password
Forgotten password account recovery
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
Details
Formatted Diff
Diff
Patch
(17.35 KB, patch)
2015-08-13 15:44 PDT
,
Andy Estes
beidson
: review+
Details
Formatted Diff
Diff
Show Obsolete
(1)
View All
Add attachment
proposed patch, testcase, etc.
Andy Estes
Comment 1
2015-08-13 12:49:43 PDT
rdar://problem/22222453
Andy Estes
Comment 2
2015-08-13 13:04:00 PDT
Created
attachment 258919
[details]
Patch
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
Created
attachment 258942
[details]
Patch
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
Committed
r188486
: <
http://trac.webkit.org/changeset/188486
>
Note
You need to
log in
before you can comment on or make changes to this bug.
Top of Page
Format For Printing
XML
Clone This Bug