NAME
Email::MIME::RFC2047::Encoder - Encoding of non-ASCII MIME headers
VERSION
version 0.93
SYNOPSIS
use Email::MIME::RFC2047::Encoder;
my $encoder = Email::MIME::RFC2047::Encoder->new(
encoding => 'utf-8',
method => 'Q',
);
my $encoded_text = $encoder->encode_text($string);
my $encoded_phrase = $encoder->encode_phrase($string);
DESCRIPTION
This module encodes non-ASCII text for MIME email message headers according to RFC 2047.
CONSTRUCTOR
new
my $encoder = Email::MIME::RFC2047::Encoder->new(
encoding => $encoding,
method => $method,
);
Creates a new encoder object.
encoding specifies the encoding ("character set" in the RFC) to use. This is passed to the Encode module. See Encode::Supported for supported encodings.
method specifies the encoding method ("encoding" in the RFC). Must be either 'B' or 'Q'.
If both encoding and method are omitted, encoding defaults to 'utf-8' and method to 'Q'. If only encoding is omitted it defaults to 'utf-8'. If only method is omitted it defaults to 'B'.
METHODS
encode_text
my $encoded_text = $encoder->encode_text($string);
Encodes a string that may replace a sequence of 'text' tokens (as defined by RFC 822) in any Subject or Comments header field, any extension message header field, or any MIME body part field for which the field body is defined as '*text'. $string is expected to be an unencoded perl string.
This method tries to use the MIME encoding for as few characters of the input string as possible. So the result may consist of a mix of 'encoded-words' and '*text'.
The source string is trimmed and any whitespace is collapsed. The words in the result are separated by single space characters without folding of long lines.
encode_phrase
my $encoded_phrase = $encoder->encode_phrase($string);
Encodes a string that may replace a 'phrase' token (as defined by RFC 822), for example, one that precedes an address in a From, To, or Cc header.
This method works like encode_text but additionally converts remaining text that contains special characters to 'quoted-strings'.
AUTHOR
Nick Wellnhofer <wellnhofer@aevum.de>
COPYRIGHT AND LICENSE
This software is copyright (c) 2015 by Nick Wellnhofer.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.