/webkit-flatpak-sdk

A Flatpak SDK and Runtime for WebKit developers

Primary LanguageMakefileGNU Lesser General Public License v2.1LGPL-2.1

⚠⚠⚠⚠ To install the WebKit Flatpak SDK run this:

flatpak remote-add --user --if-not-exists webkit https://software.igalia.com/flatpak-refs/webkit-sdk.flatpakrepo
flatpak --user install org.webkit.{Sdk,Platform}

The informations provided below are outdated. ⚠⚠⚠⚠

WebKit developer SDK and platform runtime

This repository contains a BuildStream project that produces the Platform and SDK Flatpak runtimes suitable for WebKit development.

Compiling

The easiest way to compile this project is with the included Makefile. You may need to install BuildStream, which is explained later in this section.

To build and install for your host system:

make

Compiles the BuildStream project, using saved artifacts where possible. This fetches many gigabytes of data over the Internet and may take several hours. The resulting flatpak runtimes and extensions are exported to separate ostree repos in cache, and then pulled into the ostree repo at repo.

Usually the SDK will be installed in your WebKitBuild/ directory by the usual WebKit tooling scripts, such as update-webkitgtk-libs, but if you want to manually install the SDK outside of your WebKit checkout, the following commands can be executed:

flatpak remote-add --user --no-gpg-verify endless-sdk-flatpak-repo repo
flatpak remote-ls --user endless-sdk-flatpak-repo --all

You can export to an existing repo by setting the REPO variable:

make REPO=/path/to/repo

In addition, you can use the ARCH variable to build for a different architecture:

make ARCH=aarch64

Installing BuildStream

If you do not have BuildStream available on your system, you can try installing the newest version using pip. A virtualenv is highly recommended because the latest stable release (1.4.1) of BuildStream doesn't support Python 3.8.

pip3 install --user BuildStream BuildStream-external

BuildStream also has several runtime dependencies which you will need to install. For example, using apt on Debian 10:

apt install bubblewrap python3-pip libostree-dev lzip libgirepository1.0-dev

Using BuildStream

The Makefile is mostly intended for a CI system, so for some tasks you will have a better experience using BuildStream directly.

Building the runtime

To build flatpak runtimes, use bst build:

bst build flatpak-runtimes.bst

Next, you can checkout the runtimes to an ostree repository:

bst checkout -f flatpak-runtimes.bst /path/to/repo/
ostree summary --repo=/path/to/repo --view

Other development information

Tracking upstream runtimes

This project includes customized versions of elements included in the upstream freedesktop-sdk BuildStream project, using junctions defined in elements/freedesktop-sdk.bst. However, certain elements are replaced with our own modified versions. These modified BuildStream files are organized into directories such as elements/freedesktop-sdk-components, as well as elements/sdk.bst and elements/sdk-platform.bst. When updating junction files, make sure these elements correspond with their upstream counterparts to avoid conflicts.

Testing changes to the SDK

TODO