FFI::C::Util(3pm) | User Contributed Perl Documentation | FFI::C::Util(3pm) |
FFI::C::Util - Utility functions for dealing with structured C data
version 0.15
use FFI::C::Util qw( perl_to_c take ); use FFI::C::StructDef; use FFI::Platypus::Memory qw( free ); my $def = FFI::C::StructDef->new( members => [ x => 'uint8', y => 'sint64', ], ); my $inst = $def->create; # initialize members perl_to_c($inst, { x => 1, y => 2 }); # take ownership my $ptr = take $inst; # since we took ownership, we are responsible for freeing the memory: free $ptr;
This module provides some useful utility functions for dealing with the various def instances provided by FFI::C
perl_to_c $instance, \%values; # for Struct/Union perl_to_c $instance, \@values; # for Array
This function initializes the members of an instance.
my $perl = c_to_perl $instance;
This function takes an instance and returns the nested members as Perl data structures.
my $bool = owned $instance;
Returns true of the $instance owns its allocated memory. That is, it will free up the allocated memory when it falls out of scope. Reasons an instance might not be owned are:
my $ptr = take $instance;
This function takes ownership of the instance pointer, and returns the opaque pointer. This means a couple of things:
The returned pointer can be cast into something else or passed into a function that takes an "opaque" argument.
[version 0.11]
my $ptr = addressof $instance;
This function returns the address (as an "opaque" type) of the instance object. This is similar to "take" above in that it gets you the address of the object, but doesn't take ownership of it, so care needs to be taken when using $ptr that the object is still allocated.
set_array_count $inst, $count;
This function sets the element count on a variable array returned from C (where normally there is no way to know from just the return value). If you try to set a count on a non-array or a fixed sized array an exception will be thrown.
Graham Ollis <plicease@cpan.org>
This software is copyright (c) 2020-2022 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.
2023-02-06 | perl v5.36.0 |