NAME File::SAUCE - A library to manipulate SAUCE metadata SYNOPSIS use File::SAUCE; # Read the data... # file, handle or string my $sauce = File::SAUCE->new( file => 'myansi.ans' ); # Does the file have a SAUCE record? print $sauce->has_sauce ? "has SAUCE" : "does not have SAUCE"; # Print the metadata... $sauce->print; # Get a value... my $title = $sauce->title; # Set a value... $sauce->title( 'ANSi is 1337' ); # Get the SAUCE record as a string... my $output = $sauce->as_string; # Write the data... # file, handle or string $sauce->write( file => 'myansi.ans' ); # Clear the in-memory data... $sauce->clear; # Read the data... # file, handle or string $sauce->read( file => 'myansi.ans' ); # Remove the data... # file, handle or string $sauce->remove( file => 'myansi.ans' ); DESCRIPTION SAUCE stands for Standard Architecture for Universal Comment Extentions. It is used as metadata to describe the file to which it is associated. It's most common use has been with the ANSI and ASCII "art scene." A file containing a SAUCE record looks like this: +----------------+ | FILE Data | +----------------+ | EOF Marker | +----------------+ | SAUCE Comments | +----------------+ | SAUCE Record | +----------------+ The SAUCE Comments block holds up to 255 comment lines, each 64 characters wide. It looks like this: +----------------+------+------+---------+-------------+ | Field | Size | Type | Default | set / get | +----------------+------+------+---------+-------------+ | ID | 5 | Char | COMNT | commment_id | +----------------+------+------+---------+-------------+ | Comment Line 1 | 64 | Char | | comments* | +----------------+------+------+---------+-------------+ | ... | +----------------+------+------+---------+-------------+ | Comment Line X | 64 | Char | | comments | +----------------+------+------+---------+-------------+ * Comments are stored as an array ref And lastly, the SAUCE Record. It is exactly 128 bytes long: +----------------+------+------+---------+-------------+ | Field | Size | Type | Default | set / get | +----------------+------+------+---------+-------------+ | ID | 5 | Char | SAUCE | sauce_id | +----------------+------+------+---------+-------------+ | SAUCE Version | 2 | Char | 00 | version | +----------------+------+------+---------+-------------+ | Title | 35 | Char | | title | +----------------+------+------+---------+-------------+ | Author | 20 | Char | | author | +----------------+------+------+---------+-------------+ | Group | 20 | Char | | group | +----------------+------+------+---------+-------------+ | Date | 8 | Char | | date | +----------------+------+------+---------+-------------+ | FileSize | 4 | Long | | filesize | +----------------+------+------+---------+-------------+ | DataType | 1 | Byte | | datatype_id | +----------------+------+------+---------+-------------+ | FileType | 1 | Byte | | filetype_id | +----------------+------+------+---------+-------------+ | TInfo1 | 2 | Word | | tinfo1 | +----------------+------+------+---------+-------------+ | TInfo2 | 2 | Word | | tinfo2 | +----------------+------+------+---------+-------------+ | TInfo3 | 2 | Word | | tinfo3 | +----------------+------+------+---------+-------------+ | TInfo4 | 2 | Word | | tinfo4 | +----------------+------+------+---------+-------------+ | Comments | 1 | Byte | | comments | +----------------+------+------+---------+-------------+ | Flags | 1 | Byte | | flags_id | +----------------+------+------+---------+-------------+ | Filler | 22 | Byte | | filler | +----------------+------+------+---------+-------------+ For more information see ACiD.org's SAUCE page at http://www.acid.org/info/sauce/sauce.htm WARNING From the SAUCE documenation: SAUCE was initially created for supporting only the ANSi & RIP screens. Since both ANSi and RIP are in effect text-based and have no other form of control but the End-Of-File marker, SAUCE should never interfere with the workings of a program using either ANSi or RIP. If it does, the program is not functionning the way it should. This is NOT true for the other types of files however. Adding SAUCE to some of the other filetypes supported in the SAUCE specifications may have serious consequences on the proper functionning of programs using those files, In the worst case, they'll simply refuse the file, stating it is invalid. The author(s) of this software take no resposibility for loss of data! INSTALLATION perl Makefile.PL make make test make install PUBLIC METHODS new( [ %OPTIONS ] ) Creates a new File::SAUCE object. All arguments are optional. You can pass one of two groups of options (as a hash). If you wish to read a SAUCE record from a source, you can pass a file, handle or string. my $sauce = File::SAUCE->new( file => 'filename.ext' ); my $sauce = File::SAUCE->new( handle => \*FILEHANDLE ); my $sauce = File::SAUCE->new( string => $string ); If you want to create a new record with certain metadata values, just pass them in as a hash. my $sauce = File::SAUCE->new( author => 'Me', title => 'My Work', group => 'My Group' ); clear( ) Resets the in-memory SAUCE data to the default information. read( %OPTIONS ) Tries to read a SAUCE record from a source. Uses the same options as "new()". write( %OPTIONS ) Writes the in-memory SAUCE data to a destination. Uses the same options as "new". It calls "remove" before writing the data. remove( %OPTIONS ) Removes any SAUCE data from the destination. This module enforces spoon (ftp://ftp.artpacks.acid.org/pub/artpacks/programs/dos/editors/spn2d161. zip) compatibility. The following calculation is used to determine how big the file should be after truncation: if( Filesize on disk - Filesize in SAUCE rec - Size of SAUCE rec ( w/ comments ) == 0 or 1 ) { truncate to Filesize in SAUCE rec } else { truncate to Filesize on disk - Size of SAUCE rec - 1 (EOF char) } as_string( ) Returns the SAUCE record (including EOF char and comments) as a string. print( ) View the SAUCE structure (including comments) in a "pretty" format. datatype( ) Return the string version of the file's datatype. Use datatype_id to get the integer version. filetype( ) Return the string version of the file's filetype. Use filetype_id to get the integer version. flags( ) Return the string version of the file's flags. Use flags_id to get the integer version. tinfo1_name( ) Return an english description of what this info value represents (returns undef if there isn't one) tinfo2_name( ) Return an english description of what this info value represents (returns undef if there isn't one) tinfo3_name( ) Return an english description of what this info value represents (returns undef if there isn't one) tinfo4_name( ) Return an english description of what this info value represents (returns undef if there isn't one) date( [ $date ] ) This is an overloaded date accessor. It accepts two types of dates as inputs: a Time::Piece object or a string in the format of 'YYYYMMDD'. It always returns a Time::Piece object. PRIVATE METHODS _create_io_object( { OPTIONS }, MODE ) Generates an IO object. Uses FileHandle or IO::String. AUTHOR Brian Cassidy <bricas@cpan.org> COPYRIGHT AND LICENSE Copyright 2003-2009 by Brian Cassidy This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.