An experimental port of WebKit (Specifically, webcore) to JavaScript aimed at running in both node.js and browsers. This is currently non-functional and is intended for developers and contributors.
- Produce a renderer in pure JavaScript that supports rendering to WebGL/Canvas contexts.
- Develop frameworks for image/webpage capturing and automated web testing (similar to PhantomJS).
- Develop a framework for prototyping CSS filters, HTML elements and attributes.
- Experimental harness for pure javascript rendering performance.
- Develop a javascript based browser in nodejs (just for fun).
Toolchain
- (BAD) Currently will only compile with Emscripten 1.8.2 on MacOSX in Xcode.
Building
- (GOOD) Currently the latest nightly WebKit builds.
Linking
- (HORRIFIC) There are plenty of linking issues to be addressed; however visibility into this is minimal. Currently the system links but has quite a few unresolved symbols that will cause the renderer to crash.
Tests
- (NON EXISTANT) Tests for javascript<->C++ needs to be developed (non-layout related code)
- (BAD) Unit tests that integrate with WebKit's LayoutTests
Supported Features
-
(GOOD) Features that are not currently supported:
- Accelerated 2D Canvas
- CSS Image Resolution
- CSS Image Orientation
- CSS3 Text
- Draggable Regions
- Encrypted Media
- Font Load Events
- Input Speech
- Audio
- Video
- Media Streams
- JavaScript Debugger / Inspector
- MHTML
- PDF/PDFKit
- Quota's
- Web Workers
- Web Sockets
- Shadow DOM
- Web Timing
- XSLT
- Native Widgets (IFRAME, Buttons, Text Boxes, etc.)
- Any Resource Loaders
- Font Rendering
Frameworks
- (NON EXISTANT) Frameworks to easily perform common tasks with the renderer under various contexts.
Documentation
- (NON EXISTANT) Lots and lots of documentation, currently this is it.
Requirements
- MacOS X Lion with Xcode 4+
- Emscripten 1.8.2+
- At least 16GB of free space (seriously)
- At least 4GB of RAM
Building webkit.js step-by-step
- Clone the repo.
- Go to WebKitJS/tools and in a terminal run
cp -pa ./WebKitJS/tools/EmscriptenXcode.xcplugin /Applications/Xcode.app/Contents/PlugIns/EmscriptenXcode.plugin
vim /Applications/Xcode.app/Contents/PlugIns/EmscriptenXcode.xcplugin/Contents/Resources/GCC\ 4.5.xcspec
- Modify line 35 and set ExecPath to the path of em++ included with Emscripten.
- Then run:
vim WebKit/Source/WebCore/Configurations/Base.xcconfig
- Replace "EMSCRIPTEN_SYSTEM" with the path to the system headers for emscripten.
- Open WebKit.xcworkspace in Xcode
- Change the Schema to "WebcoreJS" and make sure you build in Release (some systems Normal), not Debug. Hit Play and get some coffee or go do some chores.
- Your linking will most likely fail. If so, just run the terminal command:
em++ -r -isysroot /Path/To/Emscripten/1.8.2/system /Path/To/Your/WebKitBuild/*.o -std=c++11 -s FULL_ES2=1 -O2 -stdlib=libc++ -s LINKABLE=1 -o /Path/To/Your/WebKitBuild/webkit.js
- You can also create individual js files for each class in WebKit to ease debugging. Run:
find . -name "*.o" | xargs -I {} em++ -isysroot /Path/To/Your/Emscripten/1.8.2/system {} -std=c++11 -s FULL_ES2=1 -O2 -stdlib=libc++ -s LINKABLE=1 -s SIDE_MODULE=1 -o /Some/Folder/For/Output/{}.js
There's so much to be done any help is appreciated, at the moment I have a brutal wrapper/harness that can render DIV's with various colors to a WebGL surface in Chrome 32. It's not impressive but its a proof of concept.
Getting around the code
-
/WebKit/
This is a modified version of Apple's official repo. -
/WebKit/Source/WebCore
This is where 90% of the work is done. -
/WebKit/Source/WebCore/bindings/scripts
This is an important folder where WebKit autogenerates bindings -
/WebKit/Source/WTF/
is a cross-platform library for common tasks such as HashMaps, etc. -
/WebKit/Source/WTF/PlatformJS.h
these are C++ pre-process settings for PLATFORM(JS) -
/WebKit/Source/WebCore/Configurations/
these are important compile-time configurations for WebCore -
/WebKitJS/
When compiled the output of WebKit is placed in WebKitJS/webkit.js -
/WebKitJS/tools/
Any helpful tools i've come across (only one for now...) -
/WebKitJS/tools/cppfilter.js
This demangles C++ symbols contained in emscripten.js -
/WebKitJS/tools/EmscriptenXcode.plugin
This is a Xcode plugin, and a temporary hack for using emscripten
It's important to know
-
The code within the WebKit folder is pulled from upstream, be careful not to move any files, remove any files or heavily refactor any source file as it will cause headaches when merging.
-
Place a .gitignore on ./WebKit/WebKitBuild/ so you do not accidently commit build files.
-
Enabling/disabling settings within the Configurations folder in WebCore will have a lot of consequences, most of the disabled features are disabled because there's no possible work around for including the platform specific code (it needs to be created in JS from scratch)
-
A good amount of the bindings and code within the WebCore is auto generated from scripts, be careful when you have build errors to make sure you're not modifying a "Derived Source" otherwise you'll find your changes will be just over-written the next time the derived sources runs.
-
The current webkit.js in WebKitJS folder was compiled exposing its symbols, this results in a heavy file size (current 44MB - 1/15/14). This can come down considerably once a framework/API is developed, tests are created and optimizations can become a priority.
-
Do not modify code within ./WebKitJS/webkit.js or ./WebKitJS/debug/ these files are over-written when WebKit is built, so its somewhat pointless unless you're testing.
What's Desperately Needed
- A build toolchain similar to GYP/gconfig. QtWebkit has one already, possibly re-map that.
- Create "Debug" and "Release" modes that allow for easier debugging. In addition creating anything that helps debug and spot problems easier.
- Scripts to auto-generate code with Emscripten JS Bindings (e.g., IDL generation, and some other bindings/scripts tasks)
- Integration of WTF library into WebCore
- Closer examination of optimization/best practices/guidance on Emscripten.
- Closer examination of optimization/best practices/guidance on compiling WebCore/renderer.
- Removal of "oddity" code (e.g., no mans land code, existing dead code, platform specific code)
- Start smaller with GYP and only develop one pass layout system from CSS/HTML/DOM code with minimal features and build up.
- Take each file one by one in ./webkitjs/debug/ and port?...
- Conversation, topics, discussions on best practices, methods and use cases
- Dependency and/or symbol graph that rebuilds automatically after a compile (expressed as a HTML doc?) The core reason for this is to visualize dependencies between classes, unresolved symbols still to be developed, and spot key integration points. This can be done by regex over the existing ./webkitjs/debug for symbols and building a D3 graph to show the symbols dependency possibly? Is there already key software that does this? Can emscripten/llvm spit this out?
- Identify what key import symbols may require significant retooling.
- Integrate libxml.js (rather than depending on browser pass through decoding to a buffer)
- Integrate libxslt.js (currently unsupported)
- Integrate ffmpeg.js ?.... pure javascript video support?..... .
- Integrate libpng.js (rather than depending on browser pass through decoding to a buffer)
- Integrate libjpeg-turbo.js/libjpeg.js (rather than depending on browser pass through decoding to a buffer)
- Integrate zlib (rather than depending on browser pass through decoding to a buffer)
- Use embind/cppfilter.js to automatically generate all the WebCore C++ interfaces (derived from WebCore.exp) directly into javascript, then simply reuse existing webcore demos/examples.
BSD License (see http://www.webkit.org/coding/bsd-license.html) Use of this source code is governed by a BSD-style license that can be found in the LICENSE files contained in the root of the respective source code.
© True Interactions 2014
[trevor linton]:mailto:trevor dot linton plus github at gmail dot com