NAME
Alien::Meson - Find or build meson build tool
SYNOPSIS
Command line tool:
use Alien::Meson;
use Env qw( @PATH );
unshift @PATH, Alien::Meson->bin_dir;
system "@{[ Alien::Meson->exe ]}";
Use in alienfile:
share {
requires 'Alien::Meson';
requires 'Alien::Ninja';
# ...
my $build_dir = '_build';
build [
sub {
my $build = shift;
Alien::Build::CommandSequence->new([
Alien::Meson->exe, 'setup',
'--prefix=%{.install.prefix}',
$build_dir,
])->execute($build);
},
[ '%{ninja}', qw(-C), $build_dir, "test" ],
[ '%{ninja}', qw(-C), $build_dir, 'install' ],
];
}
DESCRIPTION
This distribution provides meson so that it can be used by other Perl distributions that are on CPAN. It does this by first trying to detect an existing install of meson on your system. If found it will use that. If it cannot be found, the source code will be downloaded from the internet and it will be installed in a private share location for the use of other modules.
METHODS
exe
Alien::Meson->exe
Returns the command name for running meson.
_apply_destdir_prefix_hack
use alienfile;
eval {
require Alien::Meson;
Alien::Meson->_apply_destdir_prefix_hack;
};
share { ... }
Applies a hack to fix how the DESTDIR
and prefix are joined to follow the approach that Meson takes. See issue at https://github.com/PerlAlien/Alien-Build/issues/407 for more information.
WARNING: This is a hack. It is not expected to work long-term and if a better solution is possible, it will be deprecated then removed.
HELPERS
meson
%{meson}
WARNING: This interpolation is deprecated. This will be removed in a future version as some share installs of Meson are not callable as a single executable (they need to be prefixed with the Python interpreter). Instead use Alien::Meson->exe
directly.
Returns 'meson', 'meson.py', or appropriate command for platform.
SEE ALSO
- Meson
-
The Meson Build system home page.
- Alien
-
Documentation on the Alien concept itself.
- Alien::Base
-
The base class for this Alien.
- Alien::Build::Manual::AlienUser
-
Detailed manual for users of Alien classes.