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 8f5a51f0c7 Warn on unknown kwargs on custom targets. 10 years ago
cross Fix ARM strip binary path. 11 years ago
man Commit number 1000 is release number 0.19.0. 10 years ago
test cases Handle Fortran sources with dependencies to themselves. 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
backends.py Updated copyright years. 10 years ago
build.py Warn on unknown kwargs on custom targets. 10 years ago
commandrunner.py Add in this file that I forgot. 11 years ago
coredata.py Bump version number 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 Updated copyright years. 10 years ago
depfixer.py Updated copyright years. 10 years ago
environment.py Updated copyright years. 10 years ago
install_meson.py Updated copyright years. 10 years ago
interpreter.py Updated copyright years. 10 years ago
meson.py Kill end of line whitespace dead. 10 years ago
meson_install.py Updated copyright years. 10 years ago
meson_test.py Check if executables need to be run with Mono. 10 years ago
mesonconf.py One more off by one error. 11 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 Kill end of line whitespace dead. 10 years ago
ninjabackend.py Ignore missing Fortran modules as they may come from the compiler itself. 10 years ago
optinterpreter.py Can specify project options on the command line and the override defaults. 10 years ago
readme.txt Can specify project options on the command line and the override defaults. 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.


Further info

The home page of Meson can be found here:

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