NAME
Clownfish::Type::Arbitrary - An arbitrary type.
DESCRIPTION
The "arbitrary" type class is a hack that spares us from having to support C types with complex declaration syntaxes -- such as unions, structs, enums, or function pointers -- from within Clownfish itself.
The only constraint is that the specifier
must end in "_t". This allows us to create complex types in a C header file...
typedef union { float f; int i; } floatint_t;
... pound-include the C header, then use the resulting typedef in a Clownfish header file and have it parse as an "arbitrary" type.
floatint_t floatint;
METHODS
new
my $type = Clownfish::Type->new(
specifier => 'floatint_t', # required
parcel => 'Crustacean', # default: undef
);
specifier - The name of the type, which must end in "_t".
parcel - A Clownfish::Parcel or a parcel name.
If parcel
is supplied and specifier
begins with a capital letter, the Parcel's prefix will be prepended to the specifier:
foo_t -> foo_t # no prefix prepending
Lobster_foo_t -> crust_Lobster_foo_t # prefix prepended
COPYRIGHT AND LICENSE
Copyright 2008-2011 Marvin Humphrey
This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.