Provided by: libsvn-notify-perl_2.84-2_all bug

Name

       SVN::Notify - Subversion activity notification

Synopsis

       Use svnnotify in post-commit:

         svnnotify --repos-path "$1" --revision "$2" \
           --to developers@example.com [options]

         svnnotify --repos-path "$1" --revision "$2" \
           --to-cx-regex i10n@example.com=I10N [options]

       Use the class in a custom script:

         use SVN::Notify;

         my $notifier = SVN::Notify->new(%params);
         $notifier->prepare;
         $notifier->execute;

Description

       This class may be used for sending email messages for Subversion repository activity.
       There are a number of different modes supported, and SVN::Notify is fully subclassable, to
       add new functionality, and offers comprehensive content filtering to easily modify the
       format of its messages. By default, A list of all the files affected by the commit will be
       assembled and listed in a single message. An additional option allows diffs to be
       calculated for the changes and either appended to the message or added as an attachment.
       See the "with_diff" and "attach_diff" options below.

Usage

       To use SVN::Notify, simply add a call to svnnotify to your Subversion repository's post-
       commit script. This script lives in the hooks directory at the root of the repository
       directory; consult the documentation in post-commit.tmpl for details. Make sure that you
       specify the complete path to svnnotify, as well as to svnlook and sendmail in the options
       passed to svnnotify so that everything executes properly. And if you specify any string
       options, be sure that they are in the encoding specified by the "--encoding" option, or
       UTF-8 if you have not specified "--encoding".

   Windows Usage
       To get SVN::Notify to work properly in a post-commit script, you must set the following
       environment variables, as they will likely not be present inside Apache:

       PATH=C:\perl\bin
       OS=Windows_NT
       SystemRoot=C:\WINDOWS

       See Windows Subversion + Apache + TortoiseSVN + SVN::Notify HOWTO
       <http://svn.haxx.se/users/archive-2006-05/0593.shtml> for more detailed information on
       getting SVN::Notify running on Windows. If you have issues with asynchronous execution,
       try using HookStart.exe
       <http://www.koders.com/csharp/fidE2724F44EF2D47F1C0FE76C538006435FA20051D.aspx> to run
       svnnotify.

Class Interface

   Constructor
       new

         my $notifier = SVN::Notify->new(%params);

       Constructs and returns a new SVN::Notify object. This object is a handle on the whole
       process of collecting meta data and content for the commit email and then sending it. As
       such, it takes a number of parameters to affect that process.

       Each of these parameters has a corresponding command-line option that can be passed to
       svnnotify. The options have the same names as these parameters, but any underscores you
       see here should be replaced with dashes when passed to svnnotify. Most also have a
       corresponding single-character option. On Perl 5.8 and higher, If you pass parameters to
       "new()", they must be decoded into Perl's internal form if they have any non-ASCII
       characters.

       Supported parameters:

       repos_path
             svnnotify --repos-path "$PATH"
             svnnotify -p "$PATH"

           The path to the Subversion repository. The path is passed as the first argument when
           Subversion executes post-commit. So you can simply pass $1 to this parameter if you
           like. See the documentation in post-commit for details. Required.

       revision
             svnnotify --revision "$REV"
             svnnotify -r "$REV"

           The revision number for the current commit. The revision number is passed as the
           second argument when Subversion executes post-commit. So you can simply pass $2 to
           this parameter if you like. See the documentation in post-commit for details.
           Required.

       to
             svnnotify --to commiters@example.com
             svnnotify -t commiters@example.com --to managers@example.com

           The address or addresses to which to send the notification email. Can be used multiple
           times to specify multiple addresses. This parameter is required unless either
           "to_regex_map" or "to_email_map" is specified.

       to_regex_map
             svnnotify --to-regex-map translate@example.com=L18N \
                       -x legal@example.com=License

           This parameter specifies a hash reference of email addresses to regular expression
           strings. SVN::Notify will compile the regular expression strings into regular
           expression objects, and then send notification messages if and only if the name of one
           or more of the paths affected by a commit matches the regular expression. This is a
           good way to have a notification email sent to a particular mail address (or comma-
           delimited list of addresses) only for certain parts of the subversion tree. This
           parameter is required unless "to" or "to_email_map" is specified.

           The command-line options, "--to-regex_map" and "-x", can be specified any number of
           times, once for each entry in the hash to be passed to "new()". The value passed to
           the option must be in the form of the key and the value separated by an equal sign.
           Consult the Getopt::Long documentation for more information.

           Here's an example complements of Matt Doar of how to use "to_regex_map" to do per-
           branch matching:

             author=`svnlook author $REPOS -r $REV`

             # The mail regexes should match all the top-level directories
             /usr/bin/svnnotify --repos-path "$REPOS" --revision "$REV" \
             -x eng-bar@example.com,${EXTRAS}="^Bar" \
             -x eng-foo@example.com,${EXTRAS}="^trunk/Foo|^branches/Foo|^tags/Foo" \
             -x $author@example.com="^users" --subject-cx

       to_email_map
             svnnotify --to-email-map L18N=translate@example.com \
                       --to-email-map License=legal@example.com

           The inverse of "to_regex_map": The regular expression is the hash key and the email
           address or addresses are the value.

       from
             svnnotify --from somewhere@example.com
             svnnotify -f elsewhere@example.com

           The email address to use in the "From" line of the email. If not specified,
           SVN::Notify will use the username from the commit, as returned by "svnlook info".

       user_domain
             svnnotify --user-domain example.com
             svnnotify -D example.net

           A domain name to append to the username for the "From" header of the email.  During a
           Subversion commit, the username returned by "svnlook info" is usually something like a
           Unix login name. SVN::Notify will use this username in the email "From" header unless
           the "from" parameter is specified. If you wish to have the username take the form of a
           real email address, specify a domain name and SVN::Notify will append "\@$domain_name"
           to the username in order to create a real email address. This can be useful if all of
           your committers have an email address that corresponds to their username at the domain
           specified by the "user_domain" parameter.

       svnlook
             svnnotify --svnlook /path/to/svnlook
             svnnotify -l /path/to/svnlook

           The location of the svnlook executable. If not specified, SVN::Notify will search
           through the directories in the $PATH environment variable, plus in /usr/local/bin and
           /usr/sbin, for an svnlook executable. Specify a full path to svnlook via this option
           or by setting the $SVNLOOK environment variable if svnlook isn't in your path or to
           avoid loading File::Spec.

           It's important to provide a complete path to svnlook because the environment during
           the execution of post-commit is anemic, with nary a $PATH environment variable to be
           found. So if svnnotify appears not to be working at all (and Subversion seems loathe
           to log when it dies!), make sure that you have specified the complete path to a
           working svnlook executable.

       sendmail
             svnnotify --sendmail /path/to/sendmail
             svnnotify -s /path/to/sendmail

           The location of the sendmail executable. If neither the "sendmail" nor the "smtp"
           parameter is specified, SVN::Notify will search through the directories in the $PATH
           environment variable, plus in /usr/local/bin and /usr/sbin, for an sendmail
           executable. Specify a full path to sendmail via this option or by setting the
           $SENDMAIL environment variable if sendmail isn't in your path or to avoid loading
           File::Spec. The same caveats as applied to the location of the svnlook executable
           apply here.

       set_sender
             svnnotify --set-sender
             svnnotify -E

           Uses the "-f" option to "sendmail" to set the envelope sender address of the email to
           the same address as is used for the "From" header. If you're also using the "from"
           option, be sure to make it only an email address. Don't include any other junk in it,
           like a sender's name. Ignored when using "smtp".

       smtp
             svnnotify --smtp smtp.example.com

           The address for an SMTP server through which to send the notification email.  If
           unspecified, SVN::Notify will use sendmail to send the message. If sendmail is not
           installed locally (such as on Windows boxes!), you must specify an SMTP server.

       smtp_tls
             svnnotify --smtp-tls

           Use TLS authentication and encrypted channels for connecting with the server.
           Usually, TLS servers will require user/password authentication.

       smtp_user
             svnnotify --smtp-user myuser

           The user name for SMTP authentication. If this option is specified, SVN::Notify will
           use Net::SMTP_auth to send the notification message, and will of course authenticate
           to the SMTP server.

       smtp_pass
             svnnotify --smtp-pass mypassword

           The password for SMTP authentication. Use in parallel with "smtp_user".

       smtp_port
             svnnotify --smtp-port 465

           The port for an SMTP server through which to send the notification email. The default
           port is 25.

       smtp_authtype
             svnnotify --smtp-authtype authtype

           Deprecated in SVN::Notify 2.83, where it has become a no-op. The auth type is
           determined by the contents returned by the SMTP server's response to the "EHLO"
           command. See "TLS and AUTHentication" in Net::SMTP::TLS for details.

       encoding
             svnnotify --encoding UTF-8
             svnnotify -c Big5

           The character set typically used on the repository for log messages, file names, and
           file contents. Used to specify the character set in the email Content-Type headers
           and, when the "language" parameter is specified, the $LANG environment variable when
           launching "sendmail". See "Character Encoding Support" for more information. Defaults
           to "UTF-8".

       charset
             svnnotify --charset UTF-8

           Deprecated. Use "encoding" instead.

       svn_encoding
             svnnotify --svn-encoding euc-jp

           The character set used in files and log messages managed in Subversion. It's useful to
           set this option if you store files in Subversion using one character set but want to
           send notification messages in a different character set.  Therefore "encoding" would
           be used for the notification message, and "svn_encoding" would be used to read in data
           from Subversion. See "Character Encoding Support" for more information. Defaults to
           the value stored in "encoding".

       diff_encoding
             svnnotify --diff-encoding iso-2022-jp

           The character set used by files in Subversion, and thus present in the the diff. It's
           useful to set this option if you store files in Subversion using one character write
           log messages in a different character set. Therefore "svn_encoding" would be used to
           read the log message and "diff_encoding" would be used to read the diff from
           Subversion. See "Character Encoding Support" for more information. Defaults to the
           value stored in "svn_encoding".

       language
             svnnotify --language fr
             svnnotify -g i-klingon

           The language typically used on the repository for log messages, file names, and file
           contents. Used to specify the email Content-Language header and to set the $LANG
           environment variable to "$notify->language . '.' .  $notify->encoding" before
           executing "svnlook" and "sendmail" (but not for sending data to Net::SMTP). Undefined
           by default, meaning that no Content-Language header is output and the $LANG
           environment variable will not be set. See "Character Encoding Support" for more
           information.

       with_diff
             svnnotify --with-diff
             svnnotify -d

           A boolean value specifying whether or not to include the output of "svnlook diff" in
           the notification email. The diff will be inline at the end of the email unless the
           "attach_diff" parameter specifies a true value.

       attach_diff
             svnnotify --attach-diff
             svnnotify -a

           A boolean value specifying whether or not to attach the output of "svnlook diff" to
           the notification email. Rather than being inline in the body of the email, this
           parameter causes SVN::Notify to attach the diff as a separate file, named for the user
           who triggered the commit and the date and time UTC at which the commit took place.
           Specifying this parameter to a true value implicitly sets the "with_diff" parameter to
           a true value.

       diff_switches
             svnnotify --diff-switches '--no-diff-added'
             svnnotify -w '--no-diff-deleted'

           Switches to pass to "svnlook diff", such as "--no-diff-deleted" and "--no-diff-added".
           And who knows, maybe someday it will support the same options as "svn diff", such as
           "--diff-cmd" and "--extensions". Only relevant when used with "with_diff" or
           "attach_diff".

       diff_content_type
             svnnotify --diff-content-type 'text/x-diff'

           Sets the Content-Type header for attached diffs.  The default, if this parameter is
           not passed, is 'text/plain'.  This parameter has no effect if '--attach-diff' is not
           specified.

       reply_to
             svnnotify --reply-to devlist@example.com
             svnnotify -R developers@example.net

           The email address to use in the "Reply-To" header of the notification email.  No
           "Reply-To" header will be added to the email if no value is specified for the
           "reply_to" parameter.

       add_headers
             svnnotify --add-header X-Approve=letMeIn

           Add a header to the notification email message. The header name and its value must be
           separated by an equals sign. Specify the option multiple times in order to add
           multiple headers. Headers with the same names are allowed. Not to be confused with the
           "--header" option, which adds introductory text to the beginning of the email body.

       subject_prefix
             svnnotify --subject-prefix [Devlist]
             svnnotify -P [%d (Our-Developers)]

           An optional string to prepend to the beginning of the subject line of the notification
           email. If it contains '%d', it will be used to place the revision number; otherwise it
           will simply be prepended to the subject, which will contain the revision number in
           brackets.

       subject_cx
             svnnotify --subject-cx
             svnnotify -C

           A boolean value indicating whether or not to include a the context of the commit in
           the subject line of the email. In a commit that affects multiple files, the context
           will be the name of the shortest directory affected by the commit. This should
           indicate up to how high up the Subversion repository tree the commit had an effect. If
           the commit affects a single file, then the context will simply be the name of that
           file.

       strip_cx_regex
             svnnotify --strip-cx-regex '^trunk/'
             svnnotify --strip-cx-regex '^trunk/' --strip-cx-regex '^branches/'
             svnnotify -X '^trunk'
             svnnotify -X '^trunk' -X '^branches'

           One or more regular expressions to be used to strip out parts of the subject context.
           This can be useful for very deep Subversion trees, where the commits you're sending
           will always be sent from a particular subtree, so you'd like to remove part of the
           tree. Used only if "subject_cx" is set to a true value.  Pass an array reference if
           calling "new()" directly.

       no_first_line
             svnnotify --no-first-line
             svnnotify -O

           Omits the first line of the log message from the subject. This is most useful when
           used in combination with the "subject_cx" parameter, so that just the commit context
           is displayed in the subject and no part of the log message.

       header
             svnnotify --header 'SVN::Notify is brought to you by Kineticode.

           Adds a specified text to each message as a header at the beginning of the body of the
           message. Not to be confused with the "--add-header" option, which adds a header to the
           headers section of the email.

       footer
             svnnotify --footer 'Copyright (R) by Kineticode, Inc.'

           Adds a specified text to each message as a footer at the end of the body of the
           message.

       max_sub_length
             svnnotify --max-sub-length 72
             svnnotify -i 76

           The maximum length of the notification email subject line. SVN::Notify includes the
           first line of the commit log message, or the first sentence of the message (defined as
           any text up to the string ". "), whichever is shorter. This could potentially be quite
           long. To prevent the subject from being over a certain number of characters, specify a
           maximum length here, and SVN::Notify will truncate the subject to the last word under
           that length.

       max_diff_length
             svnnotify --max-diff-length 1024

           The maximum length of the diff (attached or in the body). The diff output is truncated
           at the last line under the maximum character count specified and then outputs an
           additional line indicating that the maximum diff size was reached and output
           truncated. This is helpful when a large diff output could cause a message to bounce
           due to message size.

       handler
             svnnotify --handler HTML
             svnnotify -H HTML

           Specify the subclass of SVN::Notify to be constructed and returned, and therefore to
           handle the notification. Of course you can just use a subclass directly, but this
           parameter is designed to make it easy to just use "SVN::Notify->new" without worrying
           about loading subclasses, such as in svnnotify. Be sure to read the documentation for
           your subclass of choice, as there may be additional parameters and existing parameters
           may behave differently.

       filters
             svnnotify --filter Trac -F My::Filter

             SVN::Notify->new( %params, filters => ['Markdown', 'My::Filter'] );

           Specify a more module to be loaded in the expectation that it defines output filters.
           For example, SVN::Notify::Filter::Trac loads a filter that converts log messages from
           Trac's markup format to HTML.  SVN::Notify::Filter::Markdown, available on CPAN, does
           the same for Markdown format. Check CPAN for other SVN::Notify filter modules.

           This command-line option can be specified more than once to load multiple filters. The
           "filters" parameter to "new()" should be an array reference of modules names. If a
           value contains "::", it is assumed to be a complete module name. Otherwise, it is
           assumed to be in the SVN::Notify::Filter name space.  See SVN::Notify::Filter for
           details on writing your own output filters (it's really easy, I promise!).

       author_url
             svnnotify --author-url 'http://svn.example.com/changelog/~author=%s/repos'
             svnnotify --A 'mailto:%s@example.com'

           If a URL is specified for this parameter, then it will be used to create a link for
           the current author. The URL can have the "%s" format where the author's username
           should be put into the URL.

       revision_url
             svnnotify --revision-url 'http://svn.example.com/changelog/?cs=%s'
             svnnotify -U 'http://svn.example.com/changelog/?cs=%s'

           If a URL is specified for this parameter, then it will be used to create a link to the
           Subversion browser URL corresponding to the current revision number. It will also be
           used to create links to any other revision numbers mentioned in the commit message.
           The URL must have the "%s" format where the Subversion revision number should be put
           into the URL.

       svnweb_url
             svnnotify --svnweb-url 'http://svn.example.com/index.cgi/revision/?rev=%s'
             svnnotify -S 'http://svn.example.net/index.cgi/revision/?rev=%s'

           Deprecated. Use "revision_url" instead.

       viewcvs_url
             svnnotify --viewcvs-url 'http://svn.example.com/viewcvs/?rev=%s&view=rev'

           Deprecated. Use "revision_url" instead.

       ticket_map
             svnnotify --ticket-map '\[?#\s*(\d+)\s*\]?=http://example.com/ticket?id=%s' \
                       --ticket-map 'rt=http://rt.cpan.org/NoAuth/Bugs.html?id=%s' \
                       --ticket-map '\b([A-Z0-9]+-\d+)\b=http://jira/browse/%s'

           Specifies a mapping between a regular expression and a URL. The regular expression
           should return a single match to be interpolated into the URL, which should be a
           "sprintf" format using "%s" to place the match (usually the ticket identifier) from
           the regex. The command-line option may be specified any number of times for different
           ticketing systems. To the API, it must be passed as a hash reference.

           The first example matches "[#1234]" or "#1234" or "[# 1234]". This regex should be as
           specific as possible, preferably wrapped in "\b" to match word boundaries. If you're
           using SVN::Notify::HTML, be sure to read its documentation for a different regular
           expression requirement!

           Optionally, the key value can be a placeholder for a regular expression used
           internally by SVN::Notify to match strings typically used for well-known ticketing
           systems. Those keys are:

           rt  Matches Request Tracker (RT) ticket references of the form "Ticket # 12", "ticket
               6", "RT # 52", "rt 52", "RT-Ticket # 213" or even "Ticket#1066".

           bugzilla
               Matches Bugzilla bug references of the form "Bug # 12" or "bug 6" or even
               "Bug#1066".

           jira
               Matches JIRA references of the form "JRA-1234".

           gnats
               Matches GnatsWeb references of the form "PR 1234".

       rt_url
             svnnotify --rt-url 'http://rt.cpan.org/NoAuth/Bugs.html?id=%s'
             svnnotify -T 'http://rt.perl.org/NoAuth/Bugs.html?id=%s'

           A shortcut for "--ticket-map 'rt=$url'" provided for backwards compatibility.

       bugzilla_url
             svnnotify --bugzilla-url 'http://bugzilla.mozilla.org/show_bug.cgi?id=%s'
             svnnotify -B 'http://bugs.bricolage.cc/show_bug.cgi?id=%s'

           A shortcut for "--ticket-map 'bugzilla=$url'" provided for backwards compatibility.

       jira_url
             svnnotify --jira-url 'http://jira.atlassian.com/secure/ViewIssue.jspa?key=%s'
             svnnotify -J 'http://nagoya.apache.org/jira/secure/ViewIssue.jspa?key=%s'

           A shortcut for "--ticket-map 'jira=$url'" provided for backwards compatibility.

       gnats_url
             svnnotify --gnats-url 'http://gnatsweb.example.com/cgi-bin/gnatsweb.pl?cmd=view&pr=%s'
             svnnotify -G 'http://gnatsweb.example.com/cgi-bin/gnatsweb.pl?cmd=view&pr=%s'

           A shortcut for "--ticket-map 'gnats=$url'" provided for backwards compatibility.

       ticket_url
             svnnotify --ticket-url 'http://ticket.example.com/showticket.html?id=%s'

           Deprecated. Use "ticket_map", instead.

       ticket_regex
             svnnotify --ticket-regex '\[?#\s*(\d+)\s*\]?'

           Deprecated. Use "ticket_map", instead.

       verbose
             svnnotify --verbose -V

           A value between 0 and 3 specifying how verbose SVN::Notify should be. The default is
           0, meaning that SVN::Notify will be silent. A value of 1 causes SVN::Notify to output
           some information about what it's doing, while 2 and 3 each cause greater verbosity. To
           set the verbosity on the command line, simply pass the "--verbose" or "-V" option once
           for each level of verbosity, up to three times. Output from SVN::Notify is sent to
           "STDOUT".

       boundary
           The boundary to use between email body text and attachments. This is normally
           generated by SVN::Notify.

       subject
           The subject of the email to be sent. This attribute is normally generated by
           "prepare_subject()".

   Class Methods
       content_type

         my $content_type = SVN::Notify->content_type;

       Returns the content type of the notification message, "text/plain". Used to set the
       Content-Type header for the message.

       register_attributes

         SVN::Notify::Subclass->register_attributes(
             foo_attr => 'foo-attr=s',
             bar      => 'bar',
             bat      => undef,
         );

       This class method is used by subclasses to register new attributes. Pass in a list of
       key/value pairs, where the keys are the attribute names and the values are option
       specifications in the format required by Getopt::Long. SVN::Notify will create accessors
       for each attribute, and if the corresponding value is defined, it will be used by the
       "get_options()" class method to get a command-line option value.

       See <LSVN::Notify::HTML|SVN::Notify::HTML> for an example usage of
       "register_attributes()".

       get_options

         my $options = SVN::Notify->get_options;

       Parses the command-line options in @ARGV to a hash reference suitable for passing as the
       parameters to "new()". See "new" for a complete list of the supported parameters and their
       corresponding command-line options.

       This method use Getopt::Long to parse @ARGV. It then looks for any "handler" and "filter"
       options and, if it finds any, loads the appropriate classes and parses any options they
       requires from @ARGV. Subclasses and filter classes should use "register_attributes()" to
       register any attributes and options they require.

       After that, on Perl 5.8 and later, it decodes all of the string option from the encoding
       specified by the "encoding" option or UTF-8. This allows options to be passed to
       SVN::Notify in that encoding and end up being displayed properly in the resulting
       notification message.

       file_label_map

         my $map = SVN::Notify->file_label_map;

       Returns a hash reference of the labels to be used for the lists of files. A hash reference
       of file lists is stored in the "files" attribute after "prepare_files()" has been called.
       The hash keys in that list correspond to Subversion status codes, and these are mapped to
       their appropriate labels by the hash reference returned by this method:

         { U => 'Modified Paths',
           A => 'Added Paths',
           D => 'Removed Paths',
           _ => 'Property Changed'
         }

       find_exe

         my $exe = SVN::Notify->find_exe($exe_name);

       This method searches through the system path, as well as the extra directories
       /usr/local/bin and /usr/sbin (because they're common paths for "svnlook" and "sendmail"
       for an executable file with the name $exe_name.  The first one it finds is returned with
       its full path. If none is found, "find_exe()" returns undef.

Instance Interface

   Instance Methods
       prepare

         $notifier->prepare;

       Prepares the SVN::Notify object, collecting all the data it needs in preparation for
       sending the notification email. Really it's just a shortcut for:

         $notifier->prepare_recipients;
         $notifier->prepare_contents;
         $notifier->prepare_files;
         $notifier->prepare_subject;

       Only it returns after the call to "prepare_recipients()" if there are no recipients (that
       is, as when recipients are specified solely by the "to_regex_map" or "to_email_map"
       parameter and none of the regular expressions match any of the affected directories).

       prepare_recipients

         $notifier->prepare_recipients;

       Collects and prepares a list of the notification recipients. The recipients are a
       combination of the value passed to the "to" parameter as well as any email addresses
       specified as keys in the hash reference passed "to_regex_map" parameter or values passed
       to the "to_email_map" parameter, where the corresponding regular expressions stored in the
       hash matches one or more of the names of the directories affected by the commit.

       If the subject_cx parameter to "new()" has a true value, "prepare_recipients()" also
       determines the directory name to use for the context.

       prepare_contents

         $notifier->prepare_contents;

       Prepares the contents of the commit message, including the name of the user who triggered
       the commit (and therefore the contents of the "From" header to be used in the email) and
       the log message.

       prepare_files

         $notifier->prepare_files;

       Prepares the lists of files affected by the commit, sorting them into their categories:
       modified files, added files, and deleted files. It also compiles a list of files wherein a
       property was set, which might have some overlap with the list of modified files (if a
       single commit both modified a file and set a property on it).

       If the "subject_cx" parameter was specified and a single file was affected by the commit,
       then "prepare_files()" will also specify that file name as the context to be used in the
       subject line of the commit email.

       prepare_subject

         $notifier->prepare_subject;

       Prepares the subject line for the notification email. This method must be called after
       "prepare_recipients()" and "prepare_files()", since each of those methods potentially sets
       up the context for use in the the subject line. The subject may have a prefix defined by
       the "subject_prefix" parameter to "new()", it has the revision number, it might have the
       context if the "subject_cx" specified a true value, and it will have the first sentence or
       line of the commit, whichever is shorter. The subject may then be truncated to the maximum
       length specified by the "max_sub_length" parameter.

       execute

         $notifier->execute;

       Sends the notification message. This involves opening a file handle to sendmail or a tied
       file handle connected to an SMTP server and passing it to "output()". This is the main
       method used to send notifications or execute any other actions in response to Subversion
       activity.

       output

         $notifier->output($file_handle);
         $notifier->output($file_handle, $no_headers);

       Called internally by "execute()" to output a complete email message. The file a file
       handle, so that "output()" and its related methods can print directly to the email
       message. The optional second argument, if true, will suppress the output of the email
       headers.

       Really "output()" is a simple wrapper around a number of other method calls.  It is thus
       essentially a shortcut for:

           $notifier->output_headers($out) unless $no_headers;
           $notifier->output_content_type($out);
           $notifier->start_body($out);
           $notifier->output_metadata($out);
           $notifier->output_log_message($out);
           $notifier->output_file_lists($out);
           if ($notifier->with_diff) {
               my $diff_handle = $self->diff_handle;
               if ($notifier->attach_diff) {
                   $notifier->end_body($out);
                   $notifier->output_attached_diff($out, $diff_handle);
               } else {
                   $notifier->output_diff($out, $diff_handle);
                   $notifier->end_body($out);
               }
           } else {
               $notifier->end_body($out);
           }
           $notifier->end_message($out);

       output_headers

         $notifier->output_headers($file_handle);

       Outputs the headers for the notification message headers. Should be called only once for a
       single email message.

       output_content_type

         $notifier->output_content_type($file_handle);

       Outputs the content type and transfer encoding headers. These demarcate the body of the
       message. If the "attach_diff" parameter was set to true, then a boundary string will be
       generated and the Content-Type set to "multipart/mixed" and stored as the "boundary"
       attribute.

       After that, this method outputs the content type returned by "content_type()", the
       character set specified by the "encoding" attribute, and a Content-Transfer-Encoding of
       "8bit". Subclasses can either rely on this functionality or override this method to
       provide their own content type headers.

       start_body

         $notifier->start_body($file_handle);

       This method starts the body of the notification message, which means that it outputs the
       contents of the "header" attribute, if there are any. Otherwise it outputs nothing, but
       see subclasses for other behaviors.

       output_metadata

         $notifier->output_metadata($file_handle);

       This method outputs the metadata of the commit, including the revision number, author
       (user), and date of the revision. If the "author_url" or "revision_url" attributes have
       been set, then the appropriate URL(s) for the revision will also be output.

       output_log_message

         $notifier->output_log_message($file_handle);

       Outputs the commit log message, as well as the label "Log Message".

       output_file_lists

         $notifier->output_file_lists($file_handle);

       Outputs the lists of modified, added, and deleted files, as well as the list of files for
       which properties were changed. The labels used for each group are pulled in from the
       "file_label_map()" class method.

       end_body

         $notifier->end_body($file_handle);

       Closes out the body of the email by outputting the contents of the "footer" attribute, if
       any, and then a couple of newlines. Designed to be called when the body of the message is
       complete, and before any call to "output_attached_diff()".

       output_diff

         $notifier->output_diff($out_file_handle, $diff_file_handle);

       Reads diff data from $diff_file_handle and outputs it to to $out_file_handle.

       output_attached_diff

         $notifier->output_attached_diff($out_file_handle, $diff_file_handle);

       Reads diff data from $diff_file_handle and outputs it to to $out_file_handle as an
       attachment.

       end_message

         $notifier->end_message($file_handle);

       Outputs the final part of the message,. In this case, that means only a boundary if the
       "attach_diff" parameter is true. Designed to be called after any call to
       "output_attached_diff()".

       run_ticket_map

         $notifier->run_ticket_map( \&callback, @params );

       Loops over the ticket systems you have defined, calling the $callback function for each
       one, passing to it the regex, url and @params specified as its parameters.

       run_filters

         $data = $notifier->run_filters( $output_type => $data );

       Runs the filters for $output_type on $data. Used internally by SVN::Notify and by
       subclasses.

       filters_for

         my $filters = $notifier->filters_for( $output_type );

       Returns an array reference of of the filters loaded for $output_type.  Returns "undef" if
       there are no filters have been loaded for $output_type.

       diff_handle

         my $diff = $notifier->diff_handle;
         while (<$diff>) { print }

       Returns a file handle reference providing access to the the commit diff. It will usually
       be passed as the second argument to "output_diff()" or "output_attached_diff()".

   Accessors
       repos_path

         my $repos_path = $notifier->repos_path;
         $notifier = $notifier->repos_path($repos_path);

       Gets or sets the value of the "repos_path" attribute.

       revision

         my $revision = $notifier->revision;
         $notifier = $notifier->revision($revision);

       Gets or sets the value of the "revision" attribute.

       to

         my $to = $notifier->to;
         $notifier = $notifier->to($to);
         my @tos = $notifier->to;
         $notifier = $notifier->to(@tos);

       Gets or sets the list of values stored in the "to" attribute. In a scalar context, it
       returns only the first value in the list, for backwards compatibility with older versions
       of SVN::Notify. In list context, it of course returns the entire list. Pass in one or more
       values to set all of the values for the "to" attribute.

       to_regex_map

         my $to_regex_map = $notifier->to_regex_map;
         $notifier = $notifier->to_regex_map($to_regex_map);

       Gets or sets the value of the "to_regex_map" attribute, which is a hash reference of email
       addresses mapped to regular expressions.

       to_email_map

         my $to_email_map = $notifier->to_email_map;
         $notifier = $notifier->to_email_map($to_email_map);

       Gets or sets the value of the "to_email_map" attribute, which is a hash reference of
       regular expressions mapped to email addresses.

       from

         my $from = $notifier->from;
         $notifier = $notifier->from($from);

       Gets or sets the value of the "from" attribute.

       user_domain

         my $user_domain = $notifier->user_domain;
         $notifier = $notifier->user_domain($user_domain);

       Gets or sets the value of the "user_domain" attribute.

       svnlook

         my $svnlook = $notifier->svnlook;
         $notifier = $notifier->svnlook($svnlook);

       Gets or sets the value of the "svnlook" attribute.

       sendmail

         my $sendmail = $notifier->sendmail;
         $notifier = $notifier->sendmail($sendmail);

       Gets or sets the value of the "sendmail" attribute.

       set_sender

         my $set_sender = $notifier->set_sender;
         $notifier = $notifier->set_sender($set_sender);

       Gets or sets the value of the "set_sender" attribute.

       smtp

         my $smtp = $notifier->smtp;
         $notifier = $notifier->smtp($smtp);

       Gets or sets the value of the "smtp" attribute.

       encoding

         my $encoding = $notifier->encoding;
         $notifier = $notifier->encoding($encoding);

       Gets or sets the value of the "encoding" attribute. "charset" is an alias preserved for
       backward compatibility.

       svn_encoding

         my $svn_encoding = $notifier->svn_encoding;
         $notifier = $notifier->svn_encoding($svn_encoding);

       Gets or sets the value of the "svn_encoding" attribute.

       diff_encoding

         my $diff_encoding = $notifier->diff_encoding;
         $notifier = $notifier->diff_encoding($diff_encoding);

       Gets or sets the value of the "diff_encoding" attribute.

       language

         my $language = $notifier->language;
         $notifier = $notifier->language($language);

       Gets or sets the value of the "language" attribute.

       env_lang

         my $env_lang = $notifier->env_lang;
         $notifier = $notifier->env_lang($env_lang);

       Gets or sets the value of the "env_lang" attribute, which is set to "$notify->language .
       '.' . $notify->encoding" when "language" is set, and otherwise is "undef". This attribute
       is used to set the $LANG environment variable, if it is not already set by the
       environment, before executing "sendmail".

       svn_env_lang

         my $svn_env_lang = $notifier->svn_env_lang;
         $notifier = $notifier->svn_env_lang($svn_env_lang);

       Gets or sets the value of the "svn_env_lang" attribute, which is set to "$notify->language
       . '.' . $notify->svn_encoding" when "language" is set, and otherwise is "undef". This
       attribute is used to set the $LANG environment variable, if it is not already set by the
       environment, before executing "svnlook". It is not used for "svnlook diff", however, as
       the diff itself will be emitted in raw octets except for headers such as "Modified", which
       need to be in English so that subclasses can parse them. Thus, $LANG is always set to "C"
       for the execution of "svnlook diff".

       with_diff

         my $with_diff = $notifier->with_diff;
         $notifier = $notifier->with_diff($with_diff);

       Gets or sets the value of the "with_diff" attribute.

       attach_diff

         my $attach_diff = $notifier->attach_diff;
         $notifier = $notifier->attach_diff($attach_diff);

       Gets or sets the value of the "attach_diff" attribute.

       diff_switches

         my $diff_switches = $notifier->diff_switches;
         $notifier = $notifier->diff_switches($diff_switches);

       Gets or sets the value of the "diff_switches" attribute.

       reply_to

         my $reply_to = $notifier->reply_to;
         $notifier = $notifier->reply_to($reply_to);

       Gets or sets the value of the "reply_to" attribute.

       add_headers

         my $add_headers = $notifier->add_headers;
         $notifier = $notifier->add_headers({
             'X-Accept' => [qw(This That)],
             'X-Reject' => 'Me!',
         });

       Gets or sets the value of the "add_headers" attribute, which is a hash reference of the
       headers to be added to the email message. If one header needs to appear multiple times,
       simply pass the corresponding hash value as an array reference of each value for the
       header. Not to be confused with the "header" accessor, which gets and sets text to be
       included at the beginning of the body of the email message.

       subject_prefix

         my $subject_prefix = $notifier->subject_prefix;
         $notifier = $notifier->subject_prefix($subject_prefix);

       Gets or sets the value of the "subject_prefix" attribute.

       subject_cx

         my $subject_cx = $notifier->subject_cx;
         $notifier = $notifier->subject_cx($subject_cx);

       Gets or sets the value of the "subject_cx" attribute.

       strip_cx_regex

         my $strip_cx_regex = $notifier->strip_cx_regex;
         $notifier = $notifier->strip_cx_regex($strip_cx_regex);
         my @strip_cx_regexs = $notifier->strip_cx_regex;
         $notifier = $notifier->strip_cx_regex(@strip_cx_regexs);

       Gets or sets the list of values stored in the "strip_cx_regex" attribute. In a scalar
       context, it returns only the first value in the list; in list context, it of course
       returns the entire list. Pass in one or more values to set all of the values for the
       "strip_cx_regex" attribute.

       max_sub_length

         my $max_sub_length = $notifier->max_sub_length;
         $notifier = $notifier->max_sub_length($max_sub_length);

       Gets or sets the value of the "max_sub_length" attribute.

       max_diff_length

         my $max_diff_length = $notifier->max_diff_length;
         $notifier = $notifier->max_diff_length($max_diff_length);

       Gets or set the value of the "max_diff_length" attribute.

       author_url

         my $author_url = $notifier->author_url;
         $notifier = $notifier->author_url($author_url);

       Gets or sets the value of the "author_url" attribute.

       revision_url

         my $revision_url = $notifier->revision_url;
         $notifier = $notifier->revision_url($revision_url);

       Gets or sets the value of the "revision_url" attribute.

       svnweb_url

       Deprecated. Pleas use "revision_url()", instead.

       viewcvs_url

       Deprecated. Pleas use "revision_url()", instead.

       verbose

         my $verbose = $notifier->verbose;
         $notifier = $notifier->verbose($verbose);

       Gets or sets the value of the "verbose" attribute.

       boundary

         my $boundary = $notifier->boundary;
         $notifier = $notifier->boundary($boundary);

       Gets or sets the value of the "boundary" attribute. This string is normally set by a call
       to "output_headers()", but may be set ahead of time.

       user

         my $user = $notifier->user;
         $notifier = $notifier->user($user);

       Gets or sets the value of the "user" attribute, which is set to the value pulled in from
       svnlook by the call to "prepare_contents()".

       date

         my $date = $notifier->date;
         $notifier = $notifier->date($date);

       Gets or sets the value of the "date" attribute, which is set to the value pulled in from
       svnlook by the call to "prepare_contents()".

       message

         my $message = $notifier->message;
         $notifier = $notifier->message($message);

       Gets or sets the value of the "message" attribute, which is set to an array reference of
       strings by the call to "prepare_contents()".

       message_size

         my $message_size = $notifier->message_size;
         $notifier = $notifier->message_size($message_size);

       Gets or sets the value of the "message_size" attribute, which is set to the value pulled
       in from svnlook by the call to "prepare_contents()".

       subject

         my $subject = $notifier->subject;
         $notifier = $notifier->subject($subject);

       Gets or sets the value of the "subject" attribute, which is normally set by a call to
       "prepare_subject()", but may be set explicitly.

       files

         my $files = $notifier->files;
         $notifier = $notifier->files($files);

       Gets or sets the value of the "files" attribute, which is set to a hash reference of
       change type mapped to arrays of strings by the call to "prepare_files()".

       header

         my $header = $notifier->header;
         $notifier = $notifier->header($header);

       Gets or set the value of the "header" attribute. Not to be confused with the "add_headers"
       attribute, which manages headers to be inserted into the notification email message
       headers.

       footer

         my $footer = $notifier->footer;
         $notifier = $notifier->footer($footer);

       Gets or set the value of the "footer" attribute.

   Character Encoding Support
       SVN::Notify has comprehensive support for character encodings, but since it cannot always
       know what encodings your system supports or in which your data is stored in Subversion, it
       needs your help. In plain English, here's what you need to know to make non-ASCII
       characters look right in SVN::Notify's messages:

       •   The encoding for messages

           To tell SVN::Notify what character encoding to use when it sends messages, use the
           "--encoding" option. It defaults to "UTF-8", which should cover the vast majority of
           needs. You're using it in your code already, right?

       •   The character set you use in your log messages

           To tell SVN::Notify the character encoding that you use in Subversion commit log
           messages, as well as the names of the files in Subversion, use the "--svn-encoding"
           option, which defaults to the same value as "--encoding".  If, for example, you write
           log messages in Big5, pass "--svn-encoding Big5".

       •   The character set you use in your code

           To tell SVN::Notify the character encoding that you use in the files stored in
           Subversion, and therefore that will be output in diffs, use the "--diff-encoding"
           option, which defaults to the same value as "--svn-encoding". If, for example, you
           write code in euc-jp but write your commit log messages in some other encoding, pass
           "--diff-encoding euc-jp".

       •   The locales supported by your OS

           SVN::Notify uses the values passed to "--encoding", "--svn-encoding", and
           "--diff-encoding" to read in data from svnlook, convert it to Perl's internal
           encoding, and to output messages in the proper encoding. Most of the time, if you
           write code in UTF-8 and want messages delivered in UTF-8, you can ignore these
           options.

           Sometimes, however, svnlook converts its output to some other encoding.  That encoding
           is controlled by the $LANG environment variable, which corresponds to a locale
           supported by your OS. (See perllocale for instructions for finding the locales
           supported by your system.) If your system supports UTF-8 locales but defaults to using
           some other locale (causing svnlook to output log messages in the wrong encoding), then
           all you have to do is pass the "--language" option to get SVN::Notify to tell svnlook
           to use it. For example, if all of your data is in UTF-8, pass "--language en_US" to
           get SVN::Notify to use the en_US.UTF-8 locale. Likewise, pass "--language sv_SE" to
           force the use of the sv_SE.UTF-8 locale.

           Sometimes, however, the system does not support UTF-8 locales. Or perhaps you use
           something other than UTF-8 in your log messages or source code. This should be no
           problem, as SVN::Notify uses the encoding options to determine the locales to use. For
           example, if your OS offers the en_US.ISO88591 locale, pass both "--svn-encoding" and
           "--language", like so:

             --svn-encoding ISO-8859-1 --language en_US

           SVN::Notify will set the $LANG environment variable to "en_US.ISO88591", which svnlook
           will use to convert log messages from its internal form to ISO-8859-1. SVN::Notify
           will convert the output from svnlook to UTF-8 (or whatever "--encoding" you've
           specified) before sending the message. Of course, if you have characters that don't
           correspond to ISO-8859-1, you'll still get some garbage characters. It is ideal when
           the OS locale supports the same encodings as you use in your source code and log
           messages, though that's not always the case.

           And finally, because the names and spellings that OS vendors use for locales can vary
           widely, SVN::Notify will occasionally get the name of the encoding wrong, in which
           case you'll see warnings such as this:

             svnlook: warning: cannot set LC_CTYPE locale
             svnlook: warning: environment variable LANG is en_US.ISO88591
             svnlook: warning: please check that your locale name is correct

           In such a case, if all of your data and your log messages are stored in the same
           encoding, you can set the $LANG environment variable directly in your post-commit
           script before running svnnotify:

             LANG=en_US.ISO-88591 svnnotify -p "$1" -r "$2"

           If the $LANG environment variable is already set in this way, SVN::Notify will not set
           it before shelling out to svnlook.

       This looks like a lot of information, and it is. But in most cases, if you exclusively use
       UTF-8 (or ASCII!) in your source code and log messages, and your OS defaults to a UTF-8
       locale, things should just work.

See Also

       SVN::Notify::HTML
           HTML notification.

       SVN::Notify::HTML::ColorDiff
           HTML notification with colorized diff.

       SVN::Notify::Filter
           How to write output filters for SVN::Notify.

       SourceForge Hook Scripts
       <http://sourceforge.net/apps/trac/sourceforge/wiki/Subversion%20hook%20scripts>
           SourceForge.net support for SVN::Notify.

       Windows Subversion + Apache + TortoiseSVN + SVN::Notify HOWTO
       <http://svn.haxx.se/users/archive-2006-05/0593.shtml>
           Essential for Windows Subversion users.

Support

       This module is stored in an open GitHub repository <http://github.com/theory/svn-notify/>.
       Yes, I'm aware of the irony.  Nevertheless, feel free to fork and contribute!

       Please file bug reports via GitHub Issues <http://github.com/theory/svn-notify/issues/> or
       by sending mail to bug-SVN-Notify@rt.cpan.org <mailto:bug-SVN-Notify@rt.cpan.org>.

Author

       David E. Wheeler <david@justatheory.com>

Copyright and License

       Copyright (c) 2004-2011 David E. Wheeler. Some Rights Reserved.

       This module is free software; you can redistribute it and/or modify it under the same
       terms as Perl itself.