Bug 110841

Summary: Add WebStreamRegistry for managing Streams
Product: WebKit Reporter: Zachary Kuznia <zork>
Component: New BugsAssignee: Zachary Kuznia <zork>
Status: RESOLVED INVALID    
Severity: Normal CC: abarth, buildbot, darin, dglazkov, fishd, jamesr, kinuko, michaeln, rniwa, syoichi, tkent+wkapi, webkit.review.bot
Priority: P2    
Version: 528+ (Nightly build)   
Hardware: Unspecified   
OS: Unspecified   
Bug Depends on:    
Bug Blocks: 110194    
Attachments:
Description Flags
Patch
none
Patch none

Zachary Kuznia
Reported 2013-02-25 20:56:46 PST
Add API to WebBlobRegistry for managing Streams
Attachments
Patch (2.21 KB, patch)
2013-02-25 20:57 PST, Zachary Kuznia
no flags
Patch (3.55 KB, patch)
2013-02-26 20:05 PST, Zachary Kuznia
no flags
Zachary Kuznia
Comment 1 2013-02-25 20:57:05 PST
Zachary Kuznia
Comment 2 2013-02-25 20:58:43 PST
This is to allow support of the Stream API. The complete version is at: https://bugs.webkit.org/show_bug.cgi?id=110194
WebKit Review Bot
Comment 3 2013-02-26 01:59:21 PST
Please wait for approval from abarth@webkit.org, dglazkov@chromium.org, fishd@chromium.org, jamesr@chromium.org or tkent@chromium.org before submitting, as this patch contains changes to the Chromium public API. See also https://trac.webkit.org/wiki/ChromiumWebKitAPI.
Darin Fisher (:fishd, Google)
Comment 4 2013-02-26 07:55:57 PST
Comment on attachment 190195 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=190195&action=review > Source/Platform/chromium/public/WebBlobRegistry.h:56 > + // Registers a stream URL referring to the specified stream data. I'm a little confused by these changes. Can you say more about why we need to differentiate streams and blobs at this layer? (Given that this interface is the WebBlobRegistry, it seems a bit awkward to add stream concepts.) Maybe what is going on here is that you need the ability to define a Blob that does not have WebBlobData yet? And, then you need to be able to asynchronously supply that data in chunks, as it arrives from XMLHttpRequest? Have you looked into ways of avoiding the round-trip through the renderer to support responseType="stream"? Maybe we could inform the content/browser/loader/ system to accumulate the data for us, so we don't have to echo it back to the browser process? nit: What stream data is the comment referring to?
Zachary Kuznia
Comment 5 2013-02-26 09:02:04 PST
(In reply to comment #4) > (From update of attachment 190195 [details]) > View in context: https://bugs.webkit.org/attachment.cgi?id=190195&action=review > > > Source/Platform/chromium/public/WebBlobRegistry.h:56 > > + // Registers a stream URL referring to the specified stream data. > > I'm a little confused by these changes. Can you say more about why we need to differentiate streams and blobs at this layer? (Given that this interface is the WebBlobRegistry, it seems a bit awkward to add stream concepts.) > I can move these functions to a WebStreamRegistry instead, if that would make more sense. I put it here because of the conceptual relation to blobs, as you mention. The differentiation between a blob and a stream at this point is to indicate that it should allow access before the data is finalized. > Maybe what is going on here is that you need the ability to define a Blob that does not have WebBlobData yet? And, then you need to be able to asynchronously supply that data in chunks, as it arrives from XMLHttpRequest? Have you looked into ways of avoiding the round-trip through the renderer to support responseType="stream"? Maybe we could inform the content/browser/loader/ system to accumulate the data for us, so we don't have to echo it back to the browser process? As you say, the idea is pretty much to register a "blob:" URL for a stream, and then chunk data to it. It's currently setup to match the BlobRegistry (or StreamRegistry) implementation I have. As to skipping the round trip with XHR, I'd like to make the initial implementation of this layer require minimal refactoring so that I can get tests in place, and then optimize. > > nit: What stream data is the comment referring to? I'll fix that comment. I originally sent the first chunk of data with the creation message.
Zachary Kuznia
Comment 6 2013-02-26 20:05:25 PST
Build Bot
Comment 7 2013-02-26 21:58:37 PST
Comment on attachment 190426 [details] Patch Attachment 190426 [details] did not pass mac-wk2-ews (mac-wk2): Output: http://webkit-commit-queue.appspot.com/results/16774588 New failing tests: svg/as-image/img-preserveAspectRatio-support-2.html
Michael Nordman
Comment 8 2013-02-27 16:44:59 PST
> Maybe what is going on here is that you need the ability to define > a Blob that does not have WebBlobData yet? At the level of the interface between renderer and browser, we basically do have that ability, it's just not exposed to webcore in the WebBlobRegistry interface. Blobs currently come into existence fully formed and so that all the interface lets you do. There's pretty good reason to have blobs be incrementally built up (not just in the context of Streams). Would it help to extend the WebBlobRegistry api to more closely match the IPC messages (which do allow incremental building: StartBuilding, AddStuff, FinishBuilding). I think that could live in parallel with the existing 'fully formed' registry interface. Also, heads up... I've got some refactoring in the works in this area that I'm part way thru landing. These changes scrap using URLs as identifiers for WebCore::Blob instances, and instead coins GUID string identifiers which map to the underlying blob data (such that many Blob instances can refer to the same data). Switching around what the identifier identifies has made this challenging to land so I've been breaking off small parts and whittling down on it. WK - https://codereview.chromium.org/11192017/ CR - https://codereview.chromium.org/11410019/ The next chunks for me to land are sitting in here and here. https://bugs.webkit.org/show_bug.cgi?id=108851 https://codereview.chromium.org/12330162/ The meta bug I'm using to track these changes is here. https://code.google.com/p/chromium/issues/detail?id=174200
Zachary Kuznia
Comment 9 2013-02-28 01:28:07 PST
(In reply to comment #8) > > Maybe what is going on here is that you need the ability to define > > a Blob that does not have WebBlobData yet? > > At the level of the interface between renderer and browser, we basically do have that ability, it's just not exposed to webcore in the WebBlobRegistry interface. Blobs currently come into existence fully formed and so that all the interface lets you do. There's pretty good reason to have blobs be incrementally built up (not just in the context of Streams). > > Would it help to extend the WebBlobRegistry api to more closely match the IPC messages (which do allow incremental building: StartBuilding, AddStuff, FinishBuilding). I think that could live in parallel with the existing 'fully formed' registry interface. At this point, I don't think exposing those functions would help, as we would still have to add an extra set of APIs to change the semantics of the blob to match streams. > > > > Also, heads up... I've got some refactoring in the works in this area that I'm part way thru landing. These changes scrap using URLs as identifiers for WebCore::Blob instances, and instead coins GUID string identifiers which map to the underlying blob data (such that many Blob instances can refer to the same data). Switching around what the identifier identifies has made this challenging to land so I've been breaking off small parts and whittling down on it. > > WK - https://codereview.chromium.org/11192017/ > CR - https://codereview.chromium.org/11410019/ > > The next chunks for me to land are sitting in here and here. > https://bugs.webkit.org/show_bug.cgi?id=108851 > https://codereview.chromium.org/12330162/ > > The meta bug I'm using to track these changes is here. > https://code.google.com/p/chromium/issues/detail?id=174200 Thanks for the heads up! I'll look through those to figure out how it will effect my patches.
Darin Adler
Comment 10 2013-04-08 10:27:01 PDT
Comment on attachment 190426 [details] Patch Clearing review flag from this Chromium-specific patch.
Darin Adler
Comment 11 2013-04-08 10:27:26 PDT
Chromium-specific. Closing.
Note You need to log in before you can comment on or make changes to this bug.