NAME

    Tie::Handle::Filter - [DEPRECATED] filters filehandle output through a
    coderef

VERSION

    version 0.011

SYNOPSIS

        use Tie::Handle::Filter;
    
        # prefix output to STDERR with standard Greenwich time
        BEGIN {
            tie *STDERR, 'Tie::Handle::Filter', *STDERR,
                sub { scalar(gmtime) . ': ', @_ };
        }

DESCRIPTION

    DEPRECATION NOTICE: This module distribution is deprecated in favor of
    Text::OutputFilter, which is more robust while being functionally
    identical, or PerlIO::via::dynamic, which uses a different mechanism
    that may offer better performance.

    This is a small module for changing output when it is sent to a given
    file handle. By default it passes everything unchanged, but when
    provided a code reference, that reference is passed the string being
    sent to the tied file handle and may return a transformed result.

METHODS

 PRINT

    All arguments to print and say directed at the tied file handle are
    passed to the user-defined function, and the result is then passed to
    print.

 PRINTF

    The second and subsequent arguments to printf (i.e., everything but the
    format string) directed at the tied file handle are passed to the
    user-defined function, and the result is then passed preceded by the
    format string to printf.

    Please note that this does not include calls to sprintf.

 WRITE

    The first argument to syswrite (i.e., the buffer scalar variable)
    directed at the tied file handle is passed to the user-defined
    function, and the result is then passed along with the optional second
    and third arguments (i.e., length of data in bytes and offset within
    the string) to syswrite.

    Note that if you do not provide a length argument to syswrite, it will
    be computed from the result of the user-defined function. However, if
    you do provide a length (and possibly offset), they will be relative to
    the results of the user-defined function, not the input.

EXTENDS

      * Tie::Handle

REQUIRES

      * FileHandle::Fmode

DIAGNOSTICS

    Wherever possible this module attempts to emulate the built-in
    functions it ties, so it will return values as expected from whatever
    function is called. Certain operations may also croak (throw a fatal
    exception) if they fail, such as aliasing the file handle during a tie
    or attempting to perform an unsupported operation on a tied file
    handle.

BUGS AND LIMITATIONS

    If your function needs to know what operation was used to call it,
    consider using (caller 1)[3] to determine the method used to call it,
    which will return Tie::Handle::Filter::PRINT,
    Tie::Handle::Filter::PRINTF, or Tie::Handle::Filter::WRITE per "Tying
    FileHandles" in perltie.

    Currently this module is biased towards write-only file handles, such
    as STDOUT, STDERR, or ones used for logging. It does not (yet) define
    the following methods and their associated functions, so don't do them
    with file handles tied to this class.

 READ

    read

    sysread

 READLINE

    <HANDLE>

    readline

 GETC

    getc

 OPEN

    open (e.g., re-opening the file handle)

 BINMODE

    binmode

 EOF

    eof

 TELL

    tell

 SEEK

    seek

SEE ALSO

    Tie::Handle::Filter::Output::Timestamp

      Prepends filehandle output with a timestamp, optionally formatted via
      strftime.

    Tie::Handle::Filter::Output::Timestamp::EveryLine

      Prepends every line of filehandle output with a timestamp, optionally
      formatted via strftime.

AUTHOR

    Mark Gardner <mjgardner@cpan.org>

COPYRIGHT AND LICENSE

    This software is copyright (c) 2016 by cPanel, Inc.

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