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.
 
 
 
 
 
 

221 lines
7.5 KiB

---
short-description: Installing targets
...
# Installing
Invoked via the [following command](Commands.md#install) *(available
since 0.47.0)*:
```sh
meson install
```
or alternatively (on older Meson versions with `ninja` backend):
```sh
ninja install
```
By default Meson will not install anything. Build targets can be
installed by tagging them as installable in the definition.
```meson
project('install', 'c')
shared_library('mylib', 'libfile.c', install : true)
```
There is usually no need to specify install paths or the like. Meson
will automatically install it to the standards-conforming location. In
this particular case the executable is installed to the `bin`
subdirectory of the install prefix. However if you wish to override
the install dir, you can do that with the `install_dir` argument.
```meson
executable('prog', 'prog.c', install : true, install_dir : 'my/special/dir')
```
Other install commands are the following.
```meson
install_headers('header.h', subdir : 'projname') # -> include/projname/header.h
install_man('foo.1') # -> share/man/man1/foo.1
install_data('datafile.dat', install_dir : get_option('datadir') / 'progname')
# -> share/progname/datafile.dat
```
`install_data()` supports rename of the file *since 0.46.0*.
```meson
# file.txt -> {datadir}/{projectname}/new-name.txt
install_data('file.txt', rename : 'new-name.txt')
# file1.txt -> share/myapp/dir1/data.txt
# file2.txt -> share/myapp/dir2/data.txt
install_data(['file1.txt', 'file2.txt'],
rename : ['dir1/data.txt', 'dir2/data.txt'],
install_dir : 'share/myapp')
```
Sometimes you want to copy an entire subtree directly. For this use
case there is the `install_subdir` command, which can be used like
this.
```meson
install_subdir('mydir', install_dir : 'include') # mydir subtree -> include/mydir
```
Most of the time you want to install files relative to the install
prefix. Sometimes you need to go outside of the prefix (such as writing
files to `/etc` instead of `/usr/etc`. This can be accomplished by
giving an absolute install path.
```meson
install_data(sources : 'foo.dat', install_dir : '/etc') # -> /etc/foo.dat
```
## Custom install script
Sometimes you need to do more than just install basic targets. Meson
makes this easy by allowing you to specify a custom script to execute
at install time. As an example, here is a script that generates an
empty file in a custom directory.
```bash
#!/bin/sh
mkdir "${DESTDIR}/${MESON_INSTALL_PREFIX}/mydir"
touch "${DESTDIR}/${MESON_INSTALL_PREFIX}/mydir/file.dat"
```
As you can see, Meson sets up some environment variables to help you
write your script (`DESTDIR` is not set by Meson, it is inherited from
the outside environment). In addition to the install prefix, Meson
also sets the variables `MESON_SOURCE_ROOT` and `MESON_BUILD_ROOT`.
Telling Meson to run this script at install time is a one-liner.
```meson
[[#meson.add_install_script]]('myscript.sh')
```
The argument is the name of the script file relative to the current
subdirectory.
## Installing as the superuser
When building as a non-root user, but installing to root-owned locations via
e.g. `sudo ninja install`, ninja will attempt to rebuild any out of date
targets as root. This results in various bad behaviors due to build outputs and
ninja internal files being owned by root.
Running `meson install` is preferred for several reasons. It can rebuild out of
date targets and then re-invoke itself as root. *(since 1.1.0)* Additionally,
running `sudo meson install` will drop permissions and rebuild out of date
targets as the original user, not as root.
*(since 1.1.0)* Re-invoking as root will try to guess the user's preferred method for
re-running commands as root. The order of precedence is: sudo, doas, pkexec
(polkit). An elevation tool can be forced by setting `$MESON_ROOT_CMD`.
## DESTDIR support
Sometimes you need to install to a different directory than the
install prefix. This is most common when building rpm or deb
packages. This is done with the `DESTDIR` environment variable and it
is used just like with other build systems:
```console
$ DESTDIR=/path/to/staging/area meson install
```
Since *0.57.0* `--destdir` argument can be used instead of environment. In that
case Meson will set `DESTDIR` into environment when running install scripts.
Since *0.60.0* `DESTDIR` and `--destdir` can be a path relative to build
directory. An absolute path will be set into environment when executing scripts.
## Custom install behaviour
Installation behaviour can be further customized using additional
arguments.
For example, if you wish to install the current setup without
rebuilding the code (which the default install target always does) and
only installing those files that have changed, you would run this
command in the build tree:
```console
$ meson install --no-rebuild --only-changed
```
## Installation tags
*Since 0.60.0*
It is possible to install only a subset of the installable files using
`meson install --tags tag1,tag2` command line. When `--tags` is specified, only
files that have been tagged with one of the tags are going to be installed.
This is intended to be used by packagers (e.g. distributions) who typically
want to split `libfoo`, `libfoo-dev` and `libfoo-doc` packages. Instead of
duplicating the list of installed files per category in each packaging system,
it can be maintained in a single place, directly in upstream `meson.build` files.
Meson sets predefined tags on some files. More tags are likely to be added over
time, please help extending the list of well known categories.
- `devel`:
* [[static_library]],
* [[install_headers]],
* `pkgconfig.generate()`,
* `gnome.generate_gir()` - `.gir` file,
* `gnome.generate_vapi()` - `.vapi` file (*Since 0.64.0*),
* Files installed into `libdir` and with `.a` or `.pc` extension,
* File installed into `includedir`,
* Generated header files installed with `gnome.compile_resources()`,
`gnome.genmarshal()`, `gnome.mkenums()`, `gnome.mkenums_simple()`
and `gnome.gdbus_codegen()` (*Since 0.64.0*).
- `runtime`:
* [[executable]],
* [[shared_library]],
* [[shared_module]],
* [[jar]],
* `gnome.compile_resources()` - `.gresource` file (*Since 0.64.0*),
* Files installed into `bindir`,
* Files installed into `libdir` and with `.so` or `.dll` extension.
- `python-runtime`:
* `python.install_sources()`.
- `man`:
* [[install_man]].
- `doc`:
* `gnome.gtkdoc()`,
* `gnome.yelp()`,
* `hotdoc.generate_doc()`.
- `i18n`:
* `i18n.gettext()`,
* `qt.compile_translations()`,
* Files installed into `localedir`.
- `typelib`:
* `gnome.generate_gir()` - `.typelib` file.
- `bin`:
* Scripts and executables bundled with a library meant to be used by end
users.
- `bin-devel`:
* Scripts and executables bundled with a library meant to be used by
developers (i.e. build tools).
- `tests`:
* Files installed into `installed-tests` subdir (*Since 0.64.0*).
- `systemtap`:
* Files installed into `systemtap` subdir (*Since 0.64.0*).
Custom installation tag can be set using the `install_tag` keyword argument
on various functions such as [[custom_target]], [[configure_file]],
[[install_subdir]] and [[install_data]]. See their respective documentation
in the reference manual for details. It is recommended to use one of the
predefined tags above when possible.
Installable files that have not been tagged either automatically by Meson, or
manually using `install_tag` keyword argument won't be installed when `--tags`
is used. They are reported at the end of `<builddir>/meson-logs/meson-log.txt`,
it is recommended to add missing `install_tag` to have a tag on each installable
files.