Try using POE, the following code and other goodies are available at http://poe.perl.org in the POE_Cookbook directory under Watching_Logs.
POE is arrow that is definitely worth the effor of learning IMHO. But this code should get you tail functionality on threaded AS :0)
#!/usr/bin/perl -w
# http://poe.perl.org/?POE_Cookbook/Watching_Logs
use POE qw/Wheel::FollowTail/;
use strict;
$| = 1;
my $filename = $ARGV[0];
die "Usage: $0 <filename>\n" unless $filename;
die "$0: $filename: No such file or directory\n" unless -e $filename;
die "$0: $filename: Permission denied\n" unless -r $filename;
POE::Session->create
( inline_states =>
{ _start => sub { $_[HEAP]->{wheel} =
POE::Wheel::FollowTail->new(
Filename => $_[ARG0],
InputEvent => 'got_line',
ErrorEvent => 'got_error',
SeekBack => 1024,
);
$_[HEAP]->{first} = 0;
},
got_line => sub { print "$_[ARG0]\n" if $_[HEAP]->{first}++ },
got_error => sub { warn "$_[ARG0]\n" },
},
args => [$filename],
);
$poe_kernel->run();
Happy Thanksgiving!
JamesNC
-
Are you posting in the right place? Check out Where do I post X? to know for sure.
-
Posts may use any of the Perl Monks Approved HTML tags. Currently these include the following:
<code> <a> <b> <big>
<blockquote> <br /> <dd>
<dl> <dt> <em> <font>
<h1> <h2> <h3> <h4>
<h5> <h6> <hr /> <i>
<li> <nbsp> <ol> <p>
<small> <strike> <strong>
<sub> <sup> <table>
<td> <th> <tr> <tt>
<u> <ul>
-
Snippets of code should be wrapped in
<code> tags not
<pre> tags. In fact, <pre>
tags should generally be avoided. If they must
be used, extreme care should be
taken to ensure that their contents do not
have long lines (<70 chars), in order to prevent
horizontal scrolling (and possible janitor
intervention).
-
Want more info? How to link
or How to display code and escape characters
are good places to start.
|