NAME
Mail::Box::Tie - Acces an existing message-folder as array or hash
SYNOPSIS
As array:
use Mail::Box::Tie;
tie my(@inbox), 'Mail::Box::Tie', $folder;
foreach (@inbox) {print $_->short}
print $inbox[3];
push @inbox, Mail::Box::Message->new(...);
my $folder = tied @inbox;
or as hash:
tie my(%inbox), 'Mail::Box::Tie', $folder;
foreach my $msgid (keys %inbox)
{ print $inbox{$msgid};
delete $inbox{$msgid};
}
$inbox{$msg->messageID} = $msg;
DESCRIPTION
Read Mail::Box::Manager first.
Folders certainly look like an array of messages, so why not just access them as one? Or, the order is not important, but the message-ids are (give relations): why not access them from a hash based on this message-id? Programs using one of these ties will look simpler than programs using the more traditional method-calls.
A full example:
use Mail::Box::Manager;
use Mail::Box::Tie;
my $mgr = Mail::Box::Manager->new;
my $folder = $mgr->open(folder => 'inbox');
tie my(@inbox), 'Mail::Box::Tie', $folder;
print scalar @inbox, " messages.\n";
print $_->print foreach @inbox;
untie @inbox; # force destroy tie
TIE-ING ARRAYS
Access the folder as if it is an array of messages (of course, there is much more involved like reading, writing, and locking).
DESCRIPTION for tied array
Not all operations on arrays are supported. Actually, most functions which would reduce the size of the array are modified to signal messages as ready for removal.
Examples of what you can do:
tie my(@inbox), 'Mail::Box::Tie', ...;
my $message = new Mail::Box::Message(...);
push @inbox, $message;
delete $inbox[2]; # performed when folder is written
$inbox[3] = $message;
print $inbox[0]->head->get('status');
my $emails = @inbox;
untie @inbox; # calls write()
# Direct access to the Mail::Box object.
my $folder = tied @inbox;
$folder->write;
Examples what you cannot do:
shift/unshift/pop/splice @inbox;
METHODS for tied array
- tie ARRAY, 'Mail::Box::Tie', FOLDER
-
Create the tie on an existing folder.
Example:
my $mgr = Mail::Box::Manager->new; my $inbox = $mgr->new(folder => $ENV{MAIL}); tie my(@inbox), ref $inbox, $inbox;
- FETCH INDEX
-
Get the message which is on the indicated location in the list of messages contained in this folder. Deleted message will count.
Example:
print $inbox[3];
- STORE INDEX, MESSAGE
-
It is not permitted to randomly replace messages: it would disturb threads etc. The only thing what is allowed is to store a message on the first free index behind the folder (which is also achievable with PUSH -see below).
If you want to replace one message is a folder, then do the following:
$inbox[3]->delete; push @inbox, $replacement;
- FETCHSIZE
-
Return the total number of messages in a folder. This is called when the folder-array is used in scalar context, for instance
if(@inbox > 10) # contains more than 10 messages my $nrmsgs = @inbox;
- PUSH [MESSAGES]
-
Add messages to the (end of the) folder.
push @inbox, $newmsg;
- DELETE
-
Flag a message to be removed. Be warned that the message stays in the folder, and is not removed before the folder is written.
Examples:
delete $inbox[5]; $inbox[5]->delete; #same
LIMITATIONS for arrays
This module implements TIEARRAY
, FETCH
, STORE
, FETCHSIZE
, DELETE
, PUSH
, and DESTROY
.
This module does not implement all other methods as described in the Tie::Array manual-page.
TIE-ING HASHES
For a tied-hash, the message-id is used as key. The message-id is usually unique, but when two or more instances of the same message are in the same folder, one will be flagged for deletion and the other will show.
This implementation uses basic folder-access routines which are related to the message-id.
DESCRIPTION for tied hash
METHODS for tied hash
#-------------------------------------------
- TIEHASH FOLDERTYPE, INIT-PARAMETERS
- TIEHASH 'Mail::Box::Tie', FOLDER
-
Connects the object to a hash.
Examples:
my $mgr = Mail::Box::Manager->new; my $folder = $mgr->open(access => 'rw'); tie my(%inbox), 'Mail::Box::Tie', $folder;
- FETCH MESSAGEID
-
Get the message with the specified id. The returned message may be a dummy, when message-thread detection is used. Returns undef when no message with the specified id is known.
Examples:
my $msg = $inbox{$msgid}; if($inbox{$msgid}->isDummy) ...
- STORE MESSAGEID, MESSAGE
-
Store a message in the hash, on the specified id. The message-id must be equivalent the message-id as contained in the message.
If the message does not have a message-id assigned yet, it will get the specified one. When message-id is undef, the key will be taken from the message.
Examples:
$inbox{$msg->messageID} = $msg; $inbox{undef} = $msg;
- FIRSTKEY
- NEXTKEY
-
Returns the first respecitively sequential pair of message-id/message from the folder. The messages will be returned in the order as stored in the folder. Messages flagged for deletion WILL be taken.
Examples:
foreach my $msgid (keys %inbox) ... foreach my $msg (values %inbox) ... while(my ($msgid, $msg) = each %inbox) { $msg->print unless $msg->deleted; }
- EXISTS MESSAGE-ID
-
Check whether a message with a certain MESSAGE-ID exists.
Example:
if(exists $inbox{$msgid}) ...
- DELETE MESSAGE-ID
-
Remove the message with the specified MESSAGE-ID.
Example:
delete $inbox{$msgid};
- CLEAR
-
Remove the contents of the hash. Not really possible, but all the messages will be set to be deleted.
Example:
%inbox = (); %inbox = ($msg->messageID, $msg); #before adding msg
AUTHOR
Mark Overmeer (Mark@Overmeer.net). All rights reserved. This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.
VERSION
This code is beta, version 1.200
2 POD Errors
The following errors were encountered while parsing the POD:
- Around line 260:
'=item' outside of any '=over'
- Around line 414:
You forgot a '=back' before '=head1'