Version 6 (modified by 15 years ago) ( diff ) | ,
---|
WebKit2 - High Level Document
WebKit2 is a new API layer for WebKit designed from the ground up to support a split process model, where the web content (JavaScript, HTML, layout, etc) lives in a separate process from the application UI. This model is very similar to what Google Chrome offers, with the major difference being that we have built the process split model directly into the framework, allowing other clients of WebKit to use it.
C API:
WebKit2 will provide a stable C-based non-blocking API that is mostly platform agnostic. In order to achieve the goal of a non-blocking API, several techniques are used to make the API usable while still providing a comprehensive set of features to the embedder. These techniques include:
- Notification style client callbacks (e.g. didFinishLoadForFrame) These inform the embedder that something has happened, but do not give them the chance to do anything about it.
- Policy style clients callbacks (e.g. decidePolicyForNavigationAction) These allow the embedder to decide on an action at their leisure, notifying the page through a listener object.
- Policy settings (e.g. WKContextSetCacheModel, WKContextSetPopupPolicy) These allow the embedder to opt into a predefined policy without any callbacks into the UIProcess. These can either be an enumerated set of specific policies, or something more fine-grained, such as a list of strings with wildcards.
- Injected code (e.g. WebBundle) Code can be loaded into the WebProcess for cases where all the other options fail. This can useful when access to the DOM is required. [Planned, but not currently implemented]
The major API classes are:
WKContextRef
- Encapsulates all pages related to specific use of WebKit. All pages in this context share the same visited link set, local storage set, and preferences.
WKPageNamespaceRef
- Encapsulates all pages that can script each other.
WKPageRef
- Basic unit of browsing. Stays the same as the main frame changes.
WKView[Ref]
- Native view that hooks into the platform's toolkit. On Windows, this wraps a HWND. On the Mac, it inherits from NSView.
Port-Specific APIs
We plan to build a fully noblocking Objective-C API for Mac OS X as a wrapper on top of the C API. We believe a similar approach may be viable for other ports.
We are also not removing or obsoleting any of the existing port-specific APIs. WebCore will remain as-is, and all current APIs will continue to work and be fully supported. Thus, WebKit development and existing ports of WebKit will not be disrupted.
Process Architecture
http://trac.webkit.org/attachment/wiki/WebKit2/mac-webkit-stack.png
http://trac.webkit.org/attachment/wiki/WebKit2/webkit2-stack.png
Internals
There are two key subsystems that support the process division :
- CoreIPC - an abstraction for general message passing, including event handling. The current implementations use mach messages on Mac OS X, and named pipes on Windows.
- DrawingArea - an abstraction for a cross-process drawing area. Multiple drawing strategies are possible, the simplest is just a shared memory bitmap.
Attachments (3)
-
mac-webkit-stack.png
(38.5 KB
) - added by 15 years ago.
mac-webkit-stack
-
webkit2-stack.png
(61.8 KB
) - added by 15 years ago.
webkit2-stack
- chromium-webkit-stack.png (62.0 KB ) - added by 15 years ago.
Download all attachments as: .zip