serenity/Meta/gn
Timothy Flynn 6056428cb5 LibWeb: Support unbuffered fetch requests
Supporting unbuffered fetches is actually part of the fetch spec in its
HTTP-network-fetch algorithm. We had previously implemented this method
in a very ad-hoc manner as a simple wrapper around ResourceLoader. This
is still the case, but we now implement a good amount of these steps
according to spec, using ResourceLoader's unbuffered API. The response
data is forwarded through to the fetch response using streams.

This will eventually let us remove the use of ResourceLoader's buffered
API, as all responses should just be streamed this way. The streams spec
then supplies ways to wait for completion, thus allowing fully buffered
responses. However, we have more work to do to make the other parts of
our fetch implementation (namely, Body::fully_read) use streams before
we can do this.
2024-05-26 18:29:24 +02:00
..
build Meta: Add support for verifying downloaded files with their SHA-256 hash 2024-05-24 08:47:26 -04:00
secondary LibWeb: Support unbuffered fetch requests 2024-05-26 18:29:24 +02:00
.gitignore Meta: Add the start of a gn build based on the LLVM gn build 2023-07-09 16:22:58 -06:00
README.md Meta: Fix detection of default compiler versions 2024-05-23 00:56:37 -06:00

gn build for SerenityOS and Ladybird

Warning! The GN build is experimental and best-effort. It might not work, and if you use it you're expected to feel comfortable to unbreak it if necessary. Serenity's official build system is CMake, if in doubt use that. If you add files, you're expected to update the CMake build but you don't need to update GN build files. Reviewers should not ask authors to update GN build files. Keeping the GN build files up-to-date is on the people who use the GN build.

GN is a metabuild system. It always creates ninja files, but it can create some IDE projects (MSVC, Xcode, ...) which then shell out to ninja for the actual build.

This is a good overview of GN.

For more information, motivation, philosophy, and inspiration, see the LLVM documentation on its GN build

Creating a gn build

To create a GN build, you need to have GN installed. You can install it via homebrew on macOS, or via your package manager on Linux. On Ubuntu 22.04, the main package repos do not have an up to date enough package for GN, so you will need to build it from source or get a binary from Google.

The easiest way to build GN from source is to use our Toolchain/BuildGN.sh script, which will drop the built binary into the Toolchain/Local/gn/bin directory. The instructions for downloading a prebuilt binary from Google are here.

Once you have GN installed, you can create a build directory by running the following commands:

gn gen out

gn gen creates a ninja build in the out directory. You can then build the project with ninja:

ninja -C out

If GN or ninja report a bunch of errors, it's likely that you need to create an args.gn that points to all the required tools. args.gn belongs at the root of the build directory, and can be placed there before running gn gen, or modified with gn args <build dir>. See the section below for a typical args.gn.

If you modify args.gn outside of gn args, be sure to run gn gen again to regenerate the ninja files.

Typical gn args

On macOS, the default args should work out of the box. For compiling Ladybird there won't be any tailoring needed if you have Qt6 installed via homebrew and the Xcode tools installed.

On Ubuntu, it's likely that the default cc and c++ will not be able to compile the project. For compiling Ladybird, a typical args.gn might look like the below:

args.gn

# Set build arguments here. See `gn help buildargs`.
# Chosen clang must be >= version 15.0.0
host_cc="clang"
host_cxx="clang++"
is_clang=true
use_lld=true
qt_install_headers="/usr/include/x86_64-linux-gnu/qt6/"
qt_install_lib="/usr/lib/x86_64-linux-gnu"
qt_install_libexec="/usr/lib/qt6/libexec/"

As with any gn project, gn args <build dir> --list is your best friend.

Running binaries from the GN build

Targets in the gn build are prefixed by the directory they are declared in. For example, to build the default target in the Ladybird/ directory and LibWeb, you would run:

ninja -C out Ladybird
ninja -C out Userland/Libraries/LibWeb

Binaries are placed in the out/bin directory, and can be run from there.

./out/bin/Ladybird
# or on macOS
open -W --stdout $(tty) --stderr $(tty) ./out/bin/Ladybird.app --args https://ladybird.dev

There is also an incomplete target for SerenityOS, which can be tested with:

ninja -C out serenity