Comparing Meson with other build systems

A common question is Why should I choose Meson over a different build system X? There is no one true answer to this as it depends on the use case. Almost all build systems have all the functionality needed to build medium-to-large projects so the decision is usually made on other points. Here we list some pros and cons of various build systems to help you do the decision yourself.

GNU Autotools

Pros

Excellent support for legacy Unix platforms, large selection of existing modules.

Cons

Needlessly slow, complicated, hard to use correctly, unreliable, painful to debug, incomprehensible for most people, poor support for non-Unix platforms (especially Windows).

CMake

Pros

Great support for multiple backends (Visual Studio, XCode, etc).

Cons

The scripting language is cumbersome to work with. Some simple things are more complicated than necessary.

SCons

Pros

Full power of Python available for defining your build.

Cons

Slow. Requires you to pass your configuration settings on every invocation. That is, if you do scons OPT1 OPT2 and then just scons, it will reconfigure everything without settings OPT1 and OPT2. Every other build system remembers build options from the previous invocation.

Bazel

Pros

Proven to scale to very large projects.

Cons

Implemented in Java. Poor Windows support. Heavily focused on Google's way of doing things (which may be a good or a bad thing). Contributing code requires signing a CLA.

Meson

Pros

The fastest build system see measurements, user friendly, designed to be as invisible to the developer as possible, native support for modern tools (precompiled headers, coverage, Valgrind etc). Not Turing complete so build definition files are easy to read and understand.

Cons

Relatively new so it does not have a large user base yet, and may thus contain some unknown bugs. Visual Studio and XCode backends not as high quality as Ninja one.

The results of the search are