Scroll to navigation

Mail::Message::Field::Address(3pm) User Contributed Perl Documentation Mail::Message::Field::Address(3pm)

NAME

Mail::Message::Field::Address - One e-mail address

INHERITANCE

 Mail::Message::Field::Address
   is a Mail::Identity
   is a User::Identity::Item

SYNOPSIS

 my $addr = Mail::Message::Field::Address->new(...);
 my $ui   = User::Identity->new(...);
 my $addr = Mail::Message::Field::Address->coerce($ui);
 my $mi   = Mail::Identity->new(...);
 my $addr = Mail::Message::Field::Address->coerce($mi);
 print $addr->address;
 print $addr->fullName;   # possibly unicode!
 print $addr->domain;

DESCRIPTION

Many header fields can contain e-mail addresses. Each e-mail address can be represented by an object of this class. These objects will handle interpretation and character set encoding and decoding for you.

Extends "DESCRIPTION" in Mail::Identity.

OVERLOADED

The object used as boolean will always return "true"
Two address objects are the same when their email addresses are the same.
When the object is used in string context, it will return the encoded representation of the e-mail address, just like string() does.

METHODS

Extends "METHODS" in Mail::Identity.

Constructors

Extends "Constructors" in Mail::Identity.

$obj->coerce( <STRING|$object>, %options )
Try to coerce the $object into a "Mail::Message::Field::Address". In case of a STRING, it is interpreted as an email address.

The %options are passed to the object creation, and overrule the values found in the $object. The result may be "undef" or a newly created object. If the $object is already of the correct type, it is returned unmodified.

The $object may currently be a Mail::Address, a Mail::Identity, or a User::Identity. In case of the latter, one of the user's addresses is chosen at random.

Inherited, see "Constructors" in Mail::Identity
$obj->parse(STRING)
Parse the string for an address. You never know whether one or more addresses are specified on a line (often applications are wrong), therefore, the STRING is first parsed for as many addresses as possible and then the one is taken at random.

Attributes

Extends "Attributes" in Mail::Identity.

$obj->address()
Inherited, see "Attributes" in Mail::Identity
$obj->charset()
Inherited, see "Attributes" in Mail::Identity
$obj->comment( [STRING] )
Inherited, see "Attributes" in Mail::Identity
$obj->description()
Inherited, see "Attributes" in User::Identity::Item
$obj->domain()
Inherited, see "Attributes" in Mail::Identity
$obj->language()
Inherited, see "Attributes" in Mail::Identity
$obj->location()
Inherited, see "Attributes" in Mail::Identity
$obj->name( [NEWNAME] )
Inherited, see "Attributes" in User::Identity::Item
$obj->organization()
Inherited, see "Attributes" in Mail::Identity
$obj->phrase()
Inherited, see "Attributes" in Mail::Identity
$obj->username()
Inherited, see "Attributes" in Mail::Identity

Collections

Extends "Collections" in Mail::Identity.

$obj->add(COLLECTION, ROLE)
Inherited, see "Collections" in User::Identity::Item
$obj->addCollection(OBJECT | ([TYPE], OPTIONS))
Inherited, see "Collections" in User::Identity::Item
$obj->collection(NAME)
Inherited, see "Collections" in User::Identity::Item
$obj->find(COLLECTION, ROLE)
Inherited, see "Collections" in User::Identity::Item
$obj->parent( [PARENT] )
Inherited, see "Collections" in User::Identity::Item
$obj->removeCollection(OBJECT|NAME)
Inherited, see "Collections" in User::Identity::Item
$obj->type()
Inherited, see "Collections" in User::Identity::Item
$obj->user()
Inherited, see "Collections" in User::Identity::Item

Accessors

$obj->encoding()
Character-set encoding, like 'q' and 'b', to be used when non-ascii characters are to be transmitted.

Access to the content

$obj->string()
Returns an RFC compliant e-mail address, which will have character set encoding if needed. The objects are also overloaded to call this method in string context.

example:

 print $address->string;
 print $address;          # via overloading
    

DIAGNOSTICS

The first argument is an object, but not of a class which extends User::Identity::Collection.
When addresses are specified to be included in header fields, they may be coerced into Mail::Message::Field::Address objects first. What you specify is not accepted as address specification. This may be an internal error.
Either the specified $type does not exist, or that module named $class returns compilation errors. If the type as specified in the warning is not the name of a package, you specified a nickname which was not defined. Maybe you forgot the 'require' the package which defines the nickname.
The $class did compile, but it was not possible to create an object of that class using the options you specified.
If you add a collection, it must either by a collection object or a list of options which can be used to create a collection object. In the latter case, the type of collection must be specified.
The collection with $name does not exist and can not be created.

SEE ALSO

This module is part of Mail-Box distribution version 2.120, built on September 21, 2016. Website: http://perl.overmeer.net/mailbox/

LICENSE

Copyrights 2001-2016 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 http://www.perl.com/perl/misc/Artistic.html

2016-12-27 perl v5.24.1