WebKit Bugzilla
New
Browse
Search+
Log In
×
Sign in with GitHub
or
Remember my login
Create Account
·
Forgot Password
Forgotten password account recovery
NEW
79327
[meta] Modularize WebKit
https://bugs.webkit.org/show_bug.cgi?id=79327
Summary
[meta] Modularize WebKit
Kentaro Hara
Reported
2012-02-22 21:48:16 PST
We are planning to modularize WebKit. We are planning to split "self-contained" features out of WebCore/ into WebCore/Modules/. For example, we can move WebAudio, WebSocket, IndexedDB, ...etc from WebCore/ to WebCore/Modules/ as self-contained features. The idea is that modules roughly correspond to features/specifications that aren't core to the rendering engine (like a CSS feature might be). Usually a module will be introduced with a corresponding ENABLE flag. Modules do not depend on each other. The dependency rule ensures that nothing outside the module will be burdened with knowledge/complexity of the ENABLE flag. Modules enable us to develop self-contained features without touching WebCore/ code. We hope this will make it easier to develop features in each vendor. Our WebKit modularization plan is here:
https://docs.google.com/a/chromium.org/spreadsheet/ccc?key=0AppchfQ5mBrEdFlodHlLb0prdEd1ZEZyUHdCbEpoc2c#gid=0
The WebKit modularization is realized by the [Supplemental] IDL attribute. You can find more information of [Supplemental] here:
https://trac.webkit.org/wiki/WebKitIDL#Supplemental
Attachments
Add attachment
proposed patch, testcase, etc.
Kentaro Hara
Comment 1
2012-02-23 21:02:56 PST
If you would work on WebKit modularization, - please block this meta bug to track them - please add the bug # to the SpreadSheet (
https://docs.google.com/a/chromium.org/spreadsheet/ccc?key=0AppchfQ5mBrEdFlodHlLb0prdEd1ZEZyUHdCbEpoc2c#gid=0
). Ask me if you need a write permission of the SpreadSheet.
Kentaro Hara
Comment 2
2012-02-24 15:32:18 PST
As pointed out in
bug 79507
, when we make supplemental DOMWindow*.idl, WorkerContext*.idl, Navigator*.idl etc, we should copy & paste the CopyRight of the original DOMWindow.idl, WorkerContext.idl, Navigator.idl etc.
Kentaro Hara
Comment 3
2012-03-02 05:30:00 PST
I updated and colored the SpreadSheet based on the webkit-dev@ discussion (
http://markmail.org/message/kagvswmah67zmrry#query:+page:1+mid:h34vzbiu5suub3ld+state:results
). SpreadSheet:
https://docs.google.com/a/google.com/spreadsheet/ccc?key=0AppchfQ5mBrEdFlodHlLb0prdEd1ZEZyUHdCbEpoc2c#gid=0
Dennis Nezic
Comment 4
2021-10-05 11:35:15 PDT
This is sorely needed!! Especially with the javascript components. That seems to be what takes up the vast majority of compilation. It takes over a day to compile here, far more than any other package I've ever installed. This is the obvious common-sense thing to do, the linux / open-source thing to do, to separate the core components that rarely change, and other ones that often require updating, as separate packages. All the vulnerabilities seem to arise in the javascript code. We shouldn't be recompiling basic stable ossified stuff every month when a new major javascript vulnerability is found. Compiling them as separate packages/libraries will also encourage more people to hack and contribute to the code base. Currently it's much too daunting, in terms of memory and cpu and disk usage, for most people. Even source-based distros like Gentoo are pressured to create ugly binary packages to deal with this. As a tangent, why does the javascript stuff take so many hours/days to compile? It takes way longer than compiling the linux kernel and gcc and the whole gcc toolchain and a window manager combined!
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