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 46773e75a8 Create symlinks properly. Fixes #19. 10 years ago
cross Fix ARM strip binary path. 11 years ago
man Bump version number for release. 10 years ago
test cases Allow getting builtin options with get_option. Fixes #23. 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 attribution. 10 years ago
backends.py Workaround for Clang linker bug where it can not find shared libraries in rpath directories. The solution is to specify all linker targets every time. 10 years ago
build.py Minor tweak. 10 years ago
commandrunner.py New version name for new development. 10 years ago
coredata.py Allow getting builtin options with get_option. Fixes #23. 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 Pkg-config detection cleanup. 10 years ago
depfixer.py Updated copyright years. 10 years ago
environment.py Workaround for Clang pch include bug with help from Masashi Fujita. 10 years ago
install_meson.py Delete old symlinks if they exist. 10 years ago
interpreter.py Allow getting builtin options with get_option. Fixes #23. 10 years ago
meson.py Kill end of line whitespace dead. 10 years ago
meson_install.py Create symlinks properly. Fixes #19. 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 Dafuq? 10 years ago
ninjabackend.py Do not quote $out or $in because Ninja does it by itself. 10 years ago
optinterpreter.py Can specify project options on the command line and the override defaults. 10 years ago
readme.txt Trademark info. 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/

Meson is a registered trademark of Jussi Pakkanen