|
NAMEMac::PropertyList::WriteBinary - pack data into a Mac "binary property list"SYNOPSISuse Mac::PropertyList::WriteBinary; my $data = Mac::PropertyList::dict->new( { ... => ... } ); my $buf = Mac::PropertyList::WriteBinary::as_string($data); DESCRIPTIONThe "as_string" function converts a property list structure (composed of instances of "Mac::PropertyList::dict", "Mac::PropertyList::integer", etc.) into a binary format compatible with the Apple CoreFoundation binary property list functions.It takes a single argument, the top-level object to write, and returns a byte string. The property list can contain the following perl objects:
Strings are uniqued (two equal strings will be written as references to the same object). If the same reference appears more than once in the structure, it will likewise only be represented once in the output. Although the bplist format can represent circular data structures, they cannot be written by this module (they will be detected and result in an error — they wouldn't be read correctly by CoreFoundation anyway, so you aren't missing much). BUGS"Mac::PropertyList::date" objects are not handled yet.Objects other than strings (and null) are not uniqued by value, only by reference equality. This may change in a future version. Perl's dictionary keys can only be strings, but a bplist's can be any scalar object. There is no way to write the "UID" objects used by the keyed archiver. Perls that do not use IEEE-754 format internally for floating point numbers will produce incorrect output. AUTHORWim Lewis, "<wiml@cpan.org>"Copyright © 2012-2021 Wim Lewis. All rights reserved. Tom Wyant added support for UID types. This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself. SEE ALSOMac::PropertyList::ReadBinary for the inverse operation.Apple's partial published CoreFoundation source code: <http://opensource.apple.com/source/CF/>
Visit the GSP FreeBSD Man Page Interface. |