NAME
FFI::Build - Build shared libraries for use with FFI::Platypus
VERSION
version 0.11
SYNOPSIS
use FFI::Platypus;
use FFI::Build;
my $build = FFI::Build->new(
'frooble',
source => 'ffi/*.c',
);
# $lib is an instance of FFI::Build::File::Library
my $lib = $build->build;
my $ffi = FFI::Platypus->new;
# The filename will be platform dependant, but something like libfrooble.so or frooble.dll
$ffi->lib($lib->path);
... # use $ffi to attach functions in ffi/*.c
DESCRIPTION
WARNING: Alpha quality software, expect a somewhat unstable API until it stabilizes. Documentation may be missing or inaccurate.
Using libffi based FFI::Platypus is a great alternative to XS for writing library bindings for Perl. Sometimes, however, you need to bundle a little C code with your FFI module, but this has never been that easy to use. Module::Build::FFI was an early attempt to address this use case, but it uses the now out of fashion Module::Build.
This module itself doesn't directly integrate with CPAN installers like ExtUtils::MakeMaker or Module::Build, but there is a light weight layer FFI::Build::MM that will allow you to easily use this module with ExtUtils::MakeMaker. If you are using Dist::Zilla as your dist builder, then there is also Dist::Zilla::Plugin::FFI::Build, which will help with the connections.
There is some functional overlap with ExtUtils::CBuilder, which was in fact used by Module::Build::FFI. For this iteration I have decided not to use that module because although it will generate dynamic libraries that can sometimes be used by FFI::Platypus, it is really designed for building XS modules, and trying to coerce it into a more general solution has proved difficult in the past.
Supported languages out of the box are C, C++ and Fortran. In the future I plan on also supporting other languages like Rust, and maybe Go, but the machinery for that will eventually live in FFI::Build::Foreign.
The hope is that this module will be merged into FFI::Platypus, if and when this module becomes appropriately stable.
CONSTRUCTOR
new
my $build = FFI::Build->new($name, %options);
Create an instance of this class. The $name
argument is used when computing the file name for the library. The actual name will be something like lib$name.so
or $name.dll
. The following options are supported:
- alien
-
List of Aliens to compile/link against. FFI::Build will work with any Alien::Base based alien, or modules that provide a compatible API.
- buildname
-
Directory name that will be used for building intermediate files, such as object files. This is
_build
by default. - cflags
-
Extra compiler flags to use. Things like
-I/foo/include
or-DFOO=1
. - dir
-
The directory where the library will be written. This is
.
by default. - file
-
An instance of FFI::Build::File::Library to which the library will be written. Normally not needed.
- libs
-
Extra library flags to use. Things like
-L/foo/lib -lfoo
. - platform
-
An instance of FFI::Build::Platform. Usually you want to omit this and use the default instance.
- source
-
List of source files. You can use wildcards supported by
bsd_glob
from File::Glob. - verbose
-
By default this class does not print out the actual compiler and linker commands used in building the library unless there is a failure. If this option is set to true, then these commands will always be printed.
METHODS
dir
my $dir = $build->dir;
Returns the directory where the library will be written.
buildname
my $builddir = $build->builddir;
Returns the build name. This is used in computing a directory to save intermediate files like objects. For example, if you specify a file like ffi/foo.c
, then the object file will be stored in ffi/_build/foo.o
by default. _build
in this example (the default) is the build name.
file
my $file = $build->file;
Returns an instance of FFI::Build::File::Library corresponding to the library being built. This is also returned by the build
method below.
platform
my $platform = $build->platform;
An instance of FFI::Build::Platform, which contains information about the platform on which you are building. The default is usually reasonable.
verbose
my $verbose = $build->verbose;
Returns the verbose flag.
cflags
my $cflags = $build->cflags;
Returns the compiler flags.
libs
my $libs = $build->libs;
Returns the library flags.
alien
my @aliens = @{ $build->alien };
Returns a the list of aliens being used.
source
$build->source(@files);
Add the @files
to the list of source files that will be used in building the library. The format is the same as with the source
attribute above.
build
my $lib = $build->build;
This compiles the source files and links the library. Files that have already been compiled or linked may be reused without recompiling/linking if the timestamps are newer than the source files. An instance of FFI::Build::File::Library is returned which can be used to get the path to the library, which can be feed into FFI::Platypus or similar.
clean
$build->clean;
Removes the library and intermediate files.
AUTHOR
Graham Ollis <plicease@cpan.org>
COPYRIGHT AND LICENSE
This software is copyright (c) 2018 by Graham Ollis.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.