Skip to content

Latest commit

 

History

History
80 lines (53 loc) · 1.81 KB

README.md

File metadata and controls

80 lines (53 loc) · 1.81 KB

ℹ️ Check out https://github.com/arunanshub/preload-rs for preload implemented in Rust

preload

This is currently a WIP

This preload is a clone of Behdad Esfahbod's preload. The only difference is that this project uses meson as its build system.

Note that this is a work in progress. So, if you're going to use it, make sure that you check meson.build first.

Configuration file for preload is generated from buildfile (meson.build) itself.

Building

It is highly recommended that you use prefix as /usr.

The proper way to build is:

meson build --prefix=/usr
# ...
ninja -C build

Even if you don't use --prefix, it is /usr by default.

Manpage Generation

Optionally, you'd require help2man for dynamic manpage generation, which is handled directly by Meson.

Testing

Since preload is an executable, the tests are defined in a bash script runtests.sh, and are run via meson.

You can use

ninja -C build test

or

meson test -C build

to run the tests.

Why meson?

  • Because it is easier to configure.
  • Also because I hate Make, CMake and all other shit.
  • Also because I had no intention to understand how the author's build config worked/works.
  • Because I wanted a cleaner codebase.

Style Guide

Chromium Style Guide is used with some minor modifications:

  • Maximum column length: 79
  • Indent width: 4

Use this to generate a .clang-format file:

clang-format \
    -style="{BasedOnStyle: Chromium, ColumnLimit: 79, IndentWidth: 4}" \
    --dump-config > .clang-format

Check Mesonbuild's guide on clang-format for more info.