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 8aa45655b7 Renamed data() to install_data(). 10 years ago
cross Fix ARM strip binary path. 11 years ago
man Bump version number for release. 10 years ago
test cases Renamed data() to install_data(). 10 years ago
tools Convert project name. 11 years ago
.gitattributes Created a git attributes file. 11 years ago
.gitignore Ignore file grooming. 11 years ago
COPYING Start of project. 12 years ago
authors.txt Added author info file and instructions on how to add names to it. 10 years ago
backends.py Made include args always return arrays for consistency. 10 years ago
build.py Can have arrays of stuff. 10 years ago
commandrunner.py New version name for new development. 10 years ago
coredata.py New version name for new development. 10 years ago
create_release.sh A script to create source tarballs. 11 years ago
delwithsuffix.py Helper app to delete files with a given suffix. 12 years ago
dependencies.py A few suffix fixes. 10 years ago
depfixer.py Updated copyright years. 10 years ago
environment.py Nag Fortran compiler definition from Peter Koval. 10 years ago
install_meson.py Updated copyright years. 10 years ago
interpreter.py Renamed data() to install_data(). 10 years ago
meson.py Kill end of line whitespace dead. 10 years ago
meson_install.py A few suffix fixes. 10 years ago
meson_test.py Print test command lines to logs. 10 years ago
mesonconf.py One more off by one error. 10 years ago
mesongui.py Kill end of line whitespace dead. 10 years ago
mesonintrospect.py Introspect script understands runtargets. 11 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 Updated copyright years. 10 years ago
mparser.py Can chain multiple logical operations in a row. 10 years ago
ninjabackend.py Fortran dep fix on Windows. 10 years ago
optinterpreter.py Can specify project options on the command line and the override defaults. 10 years ago
readme.txt Added author info file and instructions on how to add names to it. 10 years ago
run_cross_test.py Updated copyright years. 10 years ago
run_tests.py Updated copyright years. 10 years ago
rustrunner.py Deal with Rust static libraries, too. 11 years ago
symbolextractor.py Updated symbolextractor to work with cross builds. 11 years ago
vs2010backend.py Some vs2010 fixes. 11 years ago
xcodebackend.py The mass flags -> args renaming for consistency. 11 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 community contributions. There are two simple ways to submit your
patches. The preferred way is to send a github pull request. You can
also send patches as emails to the Meson mailing list. Remember to add
your name to the list of contributors in authors.txt.


Further info

The home page of Meson can be found here:

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