The Meson Build System http://mesonbuild.com/
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
Jussi Pakkanen baa0782a22 Use argparse in introspector. 10 years ago
cross Fix ARM strip binary path. 11 years ago
data Create simple Emacs major mode. 10 years ago
man Bumped version number for release. 10 years ago
manual tests A few tweaks for msvc. 10 years ago
test cases Use fallback if git is not installed. Closes #44. 10 years ago
tools Convert project name. 11 years ago
.gitattributes Created a git attributes file. 11 years ago
.gitignore Can install files created with configure_file. 10 years ago
COPYING Start of project. 12 years ago
authors.txt An implementation of build_always as slightly modified from the original by Axel Waggershauser. 10 years ago
backends.py Harmonised copyright declarations. 10 years ago
build.py I meant to do this originally. 10 years ago
commandrunner.py Harmonised copyright declarations. 10 years ago
compilers.py Add thread_link_flags to static linkers. 10 years ago
contributing.txt Tests are fun. 10 years ago
coredata.py New version number for new development. 10 years ago
create_release.sh A script to create source tarballs. 11 years ago
delwithsuffix.py Harmonised copyright declarations. 10 years ago
dependencies.py Fix gmock when compiling from source on Debian derivatives. 10 years ago
depfixer.py Harmonised copyright declarations. 10 years ago
environment.py Made gtest and gmock work properly on 64 bit Fedora, which uses /usr/lib64. Fixes #40. 10 years ago
install_meson.py Use argparse in install script. 10 years ago
interpreter.py Added found method to dependencies. 10 years ago
meson.py Use argparse in introspector. 10 years ago
meson_install.py Fix destdir for install targets. Closes #32. 10 years ago
meson_test.py Print message when no tests are defined. 10 years ago
mesonconf.py Use argparse in mesonconf.py. 10 years ago
mesongui.py Harmonised copyright declarations. 10 years ago
mesonintrospect.py Use argparse in introspector. 10 years ago
mesonlib.py Made gtest and gmock work properly on 64 bit Fedora, which uses /usr/lib64. Fixes #40. 10 years ago
mesonmain.ui Display options in a form. 11 years ago
mesonrunner.ui UI file for external program runner. 11 years ago
mesonstart.ui Set up directories with launcher. 11 years ago
mlog.py Harmonised copyright declarations. 10 years ago
mparser.py Removed shebang lines from files that are not executable. 10 years ago
ninjabackend.py Do not use linker arguments of dependencies' dependencies if the target is a static library because the static linker does not understand them. 10 years ago
optinterpreter.py Verify that option names do not have invalid characters. 10 years ago
readme.txt Created a contribution info file. 10 years ago
run_cross_test.py Use lib as library path in unit tests. 10 years ago
run_tests.py Use argparse instead of optparse in run_tests. 10 years ago
rustrunner.py Harmonised copyright declarations. 10 years ago
symbolextractor.py User optparse in symbolextractor. 10 years ago
vcstagger.py added support for optional custom command and replace_string parameter of vcs_tag 10 years ago
vs2010backend.py Harmonised copyright declarations. 10 years ago
wrap.py Make directories in build tree, too. 10 years ago
xcodebackend.py Harmonised copyright declarations. 10 years ago

readme.txt

Meson® is project to create the best possible next-generation
build system.


Dependencies

Python http://python.org (version 3.3 or newer)
Ninja http://martine.github.com/ninja/


Installing from source

You can run Meson directly from a revision control checkout or an
extracted tarball. Installing it system-wide is simple.

Configure step: None
Compile step: None
Unit test step: ./run_tests.py
Install step: [sudo] ./install_meson.py --prefix /your/prefix --destdir /destdir/path

The default value of prefix is /usr/local. The default value of destdir
is empty.


Running

Meson requires that you have a source directory and a build directory
and that these two are different. In your source root must exist a file
called 'meson.build'. To generate the build system run this command:

meson <source directory> <build directory>

You can omit either of the two directories, and Meson will substitute
the current directory and autodetect what you mean. This mean that you
can do things like this:

cd source_root; mkdir build; cd build; meson.py ..
cd source_root; mkdir build; meson.py build

To compile, cd into your build directory and type 'ninja'. To run unit
tests, type 'ninja test'.

Install is the same but it can take an extra argument:

DESTDIR=/destdir/path ninja install

DESTDIR can be omitted. If you are installing to system directories,
you may need to run this command with sudo.


Contributing

We love code contributions. See the contributing.txt file for
details.


Further info

The home page of Meson can be found here:

https://jpakkane.github.io/meson/

Meson is a registered trademark of Jussi Pakkanen