NAME
X11::Xlib::Struct - Base class for X11 packed structures
DESCRIPTION
Base class for the various exposed C-structs of Xlib, which are represented as a blessed scalar-ref of the raw bytes of the struct. This makes them more efficient than fully inflating/deflating perl hashrefs for every Xlib call.
All attribute accessors are defined in XS.
METHODS
new
my $struct= X11::Xlib::....->new( %optional_fields );
The constructor sets all fields to their initial value (i.e. zero) and then applies the list of key/value pairs. Warns on un-known fields names.
initialize
Set all struct fields to a sensible initial value (like zero)
pack
$struct->pack( \%fields, $consume, $warn );
Pack field values into the bytes of the struct. Only %fields
is required.
If $consume
is true, then remove any key of %fields
that was processed.
If $warn
is true, then emit a warning if any un-recognized field was given.
apply
$struct->apply( \%fields );
$struct->apply( field => $val, ... );
Alias for pack(\%fields, 1, 1)
. For each given field, update that member of the struct. Emits a warning if the hash contains unknown fields.
unpack
my $hashref= $struct->unpack();
Extract all fields as Perl data.
bytes
Access the scalar holding the bytes of the struct.
AUTHOR
Olivier Thauvin, <nanardon@nanardon.zarb.org>
Michael Conrad, <mike@nrdvana.net>
COPYRIGHT AND LICENSE
Copyright (C) 2009-2010 by Olivier Thauvin
Copyright (C) 2017 by Michael Conrad
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself, either Perl version 5.10.0 or, at your option, any later version of Perl 5 you may have available.