=head1 NAME Mail::Message::Body::Delayed - body of a Mail::Message but not read yet. =head1 INHERITANCE Mail::Message::Body::Delayed realizes a Mail::Message::Body Mail::Message::Body::Delayed is a Mail::Reporter =head1 SYNOPSIS See Mail::Message::Body =head1 DESCRIPTION Message bodies of this type will be replaced by another type the moment you access the content. In this documentation you will find the description of how a message body gets delay loaded. =head1 OVERLOADED =over 4 =item overload: B<"">() (stringification) Returns the body as string --which will trigger completion-- unless called to produce a string for C<Carp>. The latter to avoid deep recursions. example: stringification of delayed body print $msg->body; # implicit by print my $body = $msg->body; my $x = "$body"; # explicit by interpolation =item overload: B<@{}>() When a body object is used as being an array reference, the lines of the body are returned. This is the same as using the C<lines> method. =item overload: B<bool>() Always returns a true value, which is needed to have overloaded objects to be used as in C<if($body)>. Otherwise, C<if(defined $body)> would be needed to avoid a runtime error. =back =head1 METHODS =head2 Constructors =over 4 =item Mail::Message::Body::Delayed-E<gt>B<new>(OPTIONS) -Option --Defined in --Default log Mail::Reporter 'WARNINGS' message <required> trace Mail::Reporter 'WARNINGS' =over 2 =item log => LEVEL =item message => MESSAGE The MESSAGE object which contains this delayed body. =item trace => LEVEL =back =back =head2 The body =over 4 =item $obj-E<gt>B<message>() =back =head2 About to the payload =over 4 =item $obj-E<gt>B<guessSize>() =item $obj-E<gt>B<isDelayed>() =item $obj-E<gt>B<isModified>() =item $obj-E<gt>B<isMultipart>() =item $obj-E<gt>B<modified>() =item $obj-E<gt>B<nrLines>() =back =head2 Internals =over 4 =item $obj-E<gt>B<fileLocation>([BEGIN, END]) =item $obj-E<gt>B<load>() Returns the loaded version of this body. =item $obj-E<gt>B<moveLocation>(DISTANCE) =item $obj-E<gt>B<read>(PARSER, HEAD, BODYTYPE) =back =head2 Error handling =over 4 =item $obj-E<gt>B<AUTOLOAD>() See L<Mail::Reporter/"Error handling"> =item $obj-E<gt>B<addReport>(OBJECT) See L<Mail::Reporter/"Error handling"> =item $obj-E<gt>B<defaultTrace>([LEVEL]|[LOGLEVEL, TRACELEVEL]|[LEVEL, CALLBACK]) =item Mail::Message::Body::Delayed-E<gt>B<defaultTrace>([LEVEL]|[LOGLEVEL, TRACELEVEL]|[LEVEL, CALLBACK]) See L<Mail::Reporter/"Error handling"> =item $obj-E<gt>B<errors>() See L<Mail::Reporter/"Error handling"> =item $obj-E<gt>B<log>([LEVEL [,STRINGS]]) =item Mail::Message::Body::Delayed-E<gt>B<log>([LEVEL [,STRINGS]]) See L<Mail::Reporter/"Error handling"> =item $obj-E<gt>B<logPriority>(LEVEL) =item Mail::Message::Body::Delayed-E<gt>B<logPriority>(LEVEL) See L<Mail::Reporter/"Error handling"> =item $obj-E<gt>B<logSettings>() See L<Mail::Reporter/"Error handling"> =item $obj-E<gt>B<notImplemented>() See L<Mail::Reporter/"Error handling"> =item $obj-E<gt>B<report>([LEVEL]) See L<Mail::Reporter/"Error handling"> =item $obj-E<gt>B<reportAll>([LEVEL]) See L<Mail::Reporter/"Error handling"> =item $obj-E<gt>B<trace>([LEVEL]) See L<Mail::Reporter/"Error handling"> =item $obj-E<gt>B<warnings>() See L<Mail::Reporter/"Error handling"> =back =head2 Cleanup =over 4 =item $obj-E<gt>B<DESTROY>() See L<Mail::Reporter/"Cleanup"> =item $obj-E<gt>B<inGlobalDestruction>() See L<Mail::Reporter/"Cleanup"> =back =head1 DIAGNOSTICS =over 4 =item Error: Package $package does not implement $method. Fatal error: the specific package (or one of its superclasses) does not implement this method where it should. This message means that some other related classes do implement this method however the class at hand does not. Probably you should investigate this and probably inform the author of the package. =back =head1 SEE ALSO This module is part of Mail-Box distribution version 2.103, built on April 20, 2012. Website: F<http://perl.overmeer.net/mailbox/> =head1 LICENSE Copyrights 2001-2012 by [Mark Overmeer]. For other contributors see ChangeLog. This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself. See F<http://www.perl.com/perl/misc/Artistic.html>