NAME

FFI::Platypus::Record::StringArray - Array of strings for your FFI record

VERSION

version 0.01

SYNOPSIS

my $a = FFI::Platypus::Record::StringArray->new(qw( foo bar baz ));
my $opaque = $a->opaque;

DESCRIPTION

Experimental interface for an array of C strings, useful for FFI record classes.

The Platypus record class doesn't easily support an array of strings, and trying to use an opaque type to implement this is possible but more than a little arcane. This class provides an interface for creating a C array of strings which can be used to provide an opaque pointer than can be used by an FFI::Platypus::Record object.

Care needs to be taken! Because Perl has no way of knowing if/when the opaque pointer is no longer being used by C, you have to make sure that the FFI::Platypus::Record::StringArray instance remains in scope for as long as the opaque pointer is in use by C.

CONSTRUCTOR

new

my $a = FFI::Platypus::Record::StringArray->new(@a);

Creates a new array of C strings.

METHODS

opaque

my $opaque = $a->opaque;

Returns the opaque pointer to the array of C strings.

size

my $size = $a->size;

Returns the number of elements in the array of C strings.

element

my $element = $a->element($index);

Returns the string in the array of C strings at the given index.

AUTHOR

Graham Ollis <plicease@cpan.org>

COPYRIGHT AND LICENSE

This software is copyright (c) 2019 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.