Beefy Boxes and Bandwidth Generously Provided by pair Networks
There's more than one way to do things

Re^2: Array size issue

by hmb104 (Sexton)
on Oct 15, 2012 at 18:17 UTC ( #999147=note: print w/replies, xml ) Need Help??

in reply to Re: Array size issue
in thread Array size issue

That is not what I want. I want to save the line to the array if it matches the expression. I don't want to print anything this is just for debugging to make sure my array is containing the proper lines.

Replies are listed 'Best First'.
Re^3: Array size issue
by blue_cowdawg (Monsignor) on Oct 15, 2012 at 18:45 UTC
        That is not what I want.

    Sorry.... could have fooled me considering the logic in your original post.

    If I break your code down into pseudo-code it reads like this:

      open a pipe to the tail -f command for a logfile (unnamed)
      iterate over the pipe
        if less than 3 files are in array
          if the line matches a (undetermined) IP address
            push the line into an array
            exit the program
        Iterate over the contents of the array
          print line

    Part of the art of getting good answers on Perl Monks is being concise about your questions and not leaving what you are after up to the interpretation of the reader.

    Once again I will attempt to extrapolate what you are after. You code will work better if you don't put the print lines in and change the exit for last.

    Peter L. Berghold -- Unix Professional
    Peter -at- Berghold -dot- Net; AOL IM redcowdawg Yahoo IM: blue_cowdawg

      I apologize for not being clear and I do appreciate all the valuable input I get from this community.

      Without the print statement I will not be able to debug my code. I want to make sure my array is carrying the proper line/data before attempting to process it. This is what I got after reading all the comments. I think I'm missing a small piece and I can't figure it out.

      open my $tailf, "tail -f $logFile |" or die; while (<$tailf>) { chomp; my $line = $_; if($line =~ m/ on $ipaddress/) { if (scalar(@matches) <= 2){ push(@matches, $line); } else { last; } } } foreach $line (@matches){ print "$line\n"; } close $tailf;

        myself I'd rewrite two of your "ifs."

        next unless ($line =~ m@on $ipaddress@); last if scalar(@matches) >= 2;
        At least to my eye that's more readable.

        Peter L. Berghold -- Unix Professional
        Peter -at- Berghold -dot- Net; AOL IM redcowdawg Yahoo IM: blue_cowdawg

Log In?

What's my password?
Create A New User
Node Status?
node history
Node Type: note [id://999147]
[Discipulus]: found translate only good from or possibly to english.. in any other case i use double way translation

How do I use this? | Other CB clients
Other Users?
Others browsing the Monastery: (8)
As of 2018-06-19 07:37 GMT
Find Nodes?
    Voting Booth?
    Should cpanminus be part of the standard Perl release?

    Results (111 votes). Check out past polls.