summaryrefslogtreecommitdiff
path: root/docs/markdown/Comparisons.md
diff options
context:
space:
mode:
Diffstat (limited to 'docs/markdown/Comparisons.md')
-rw-r--r--docs/markdown/Comparisons.md57
1 files changed, 57 insertions, 0 deletions
diff --git a/docs/markdown/Comparisons.md b/docs/markdown/Comparisons.md
new file mode 100644
index 000000000..ede3cf947
--- /dev/null
+++ b/docs/markdown/Comparisons.md
@@ -0,0 +1,57 @@
+---
+title: Comparisions
+...
+
+# 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, ununderstandable 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](https://bazel.build/contributing.html).
+
+## Meson ##
+
+### Pros ###
+
+The fastest build system [see measurements](Performance comparison), 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.