RESOLVED FIXED85215
[chromium] DomStorage event handling needs TLC
https://bugs.webkit.org/show_bug.cgi?id=85215
Summary [chromium] DomStorage event handling needs TLC
Michael Nordman
Reported 2012-04-30 11:20:06 PDT
Events are handled inconsistently. The dispatch of some events are initiated from within webkit/webcore, the dispatch of other events are initiated from the outside via the WebKit::WebStorageEventDispatcher interface. The existing WebStorageEventDispatcher is not expressive enough to handle initiated all events from the outside. There's a chunk of nearly replicated code in there that shouldn't be. The existing code has several FIXMEs related to making this better. It could use some TLC for those reasons alone, but the current state of things in webkit/webcore is also blocking development of some overall performance improvements to chromium's implemention of this feature (getting rid of sync ipcs for each access and adding a renderer-side caching layer). See http://code.google.com/p/chromium/issues/detail?id=94382 for more details on this aspect of things. To facilitate the perf improvements, event dispatching needs to be initiated from the outside because there may be an async latency between setting an item and receiving the 'oldValue' from the main browser process which is needed to raise the mutation event. This involves a multi-sided sequence of patches in webkit and chromium (and webkit and chromium), to define a new API while retaining the old API, start using the new API then come back to remove support for the old API (and so on).
Attachments
Note You need to log in before you can comment on or make changes to this bug.