X-Git-Url: https://git.gag.com/?a=blobdiff_plain;f=perl%2FAmanda%2FReport.pm;h=8c514614efb6f0e5ccd2d90101075795ea6e49e7;hb=949b8910a5e23c4285d0b1aedacfc82a14dc97a5;hp=94e79e75bc13cc7af8a7374c2da730889a0a89e6;hpb=011a59f5a54864108a16af570a6b287410597cc2;p=debian%2Famanda diff --git a/perl/Amanda/Report.pm b/perl/Amanda/Report.pm index 94e79e7..8c51461 100644 --- a/perl/Amanda/Report.pm +++ b/perl/Amanda/Report.pm @@ -1,4 +1,4 @@ -# Copyright (c) 2010 Zmanda, Inc. All Rights Reserved. +# Copyright (c) 2010-2012 Zmanda, Inc. All Rights Reserved. # # This program is free software; you can redistribute it and/or modify it # under the terms of the GNU General Public License version 2 as published @@ -510,10 +510,22 @@ sub read_line if ( $type == $L_CONT ) { ${$self->{nbline_ref}}++; - push @{$self->{contline}}, $str if ${$self->{nbline_ref}} <= 100; + if ($str =~ /^\|/) { + $self->{nb_strange}++; + push @{$self->{contline}}, $str if $self->{nb_strange} + $self->{nb_error} <= 100; + } elsif ($str =~ /^\?/) { + $self->{nb_error}++; + push @{$self->{contline}}, $str if $self->{nb_error} <= 100; + } else { + $self->{nb_normal}++; + push @{$self->{contline}}, $str if ${$self->{nbline_ref}} <= 100; + } return; } $self->{contline} = undef; + $self->{nb_normal} = 0; + $self->{nb_strange} = 0; + $self->{nb_error} = 0; if ( $prog == $P_PLANNER ) { return $self->_handle_planner_line( $type, $str ); @@ -790,6 +802,7 @@ sub _handle_dumper_line my @info = Amanda::Util::split_quoted_strings($str); my ( $hostname, $disk, $level ) = @info[ 0 .. 2 ]; my ( $sec, $kb, $kps, $orig_kb ) = @info[ 4, 6, 8, 10 ]; + $kb = int($kb/1024) if $info[4] eq 'bytes'; $orig_kb =~ s{\]$}{}; my $dle = $disklist->{$hostname}->{$disk}; @@ -805,6 +818,9 @@ sub _handle_dumper_line $self->{contline} = $dumper->{stranges} ||= []; $dumper->{nb_stranges} = 0; $self->{nbline_ref} = \$dumper->{nb_stranges}; + $self->{nb_normal} = 0; + $self->{nb_strange} = 0; + $self->{nb_error} = 0; return $self->{flags}{exit_status} |= STATUS_STRANGE @@ -817,6 +833,7 @@ sub _handle_dumper_line my @info = Amanda::Util::split_quoted_strings($str); my ( $hostname, $disk, $timestamp, $level ) = @info[ 0 .. 3 ]; my ( $sec, $kb, $kps, $orig_kb ) = @info[ 5, 7, 9, 11 ]; + $kb = int($kb/1024) if $info[6] eq 'bytes'; $orig_kb =~ s{\]$}{}; my $dle = $disklist->{$hostname}->{$disk}; @@ -864,6 +881,7 @@ sub _handle_chunker_line my @info = Amanda::Util::split_quoted_strings($str); my ( $hostname, $disk, $timestamp, $level ) = @info[ 0 .. 3 ]; my ( $sec, $kb, $kps ) = @info[ 5, 7, 9 ]; + $kb = int($kb/1024) if $info[6] eq 'bytes'; $kps =~ s{\]$}{}; my $dle = $disklist->{$hostname}->{$disk}; @@ -930,6 +948,7 @@ sub _handle_taper_line my ( $currpart, $predparts ) = ( $1, $2 ); my ($level, $sec, $kb, $kps, $orig_kb) = @info[ 6, 8, 10, 12, 14 ]; + $kb = int($kb/1024) if $info[9] eq 'bytes'; $kps =~ s{\]$}{}; $orig_kb =~ s{\]$}{} if defined($orig_kb); @@ -967,6 +986,7 @@ sub _handle_taper_line my @info = Amanda::Util::split_quoted_strings($str); my ( $hostname, $disk, $timestamp, $part_ct, $level ) = @info[ 0 .. 4 ]; my ( $sec, $kb, $kps, $orig_kb ) = @info[ 6, 8, 10, 12 ]; + $kb = int($kb/1024) if $info[7] eq 'bytes'; my $error; if ($type == $L_PARTIAL) { if ($kps =~ /\]$/) { @@ -1148,6 +1168,9 @@ sub _handle_fail_line $self->{contline} = $program_d->{errors} ||= []; $program_d->{nb_errors} = 0; $self->{nbline_ref} = \$program_d->{nb_errors}; + $self->{nb_normal} = 0; + $self->{nb_strange} = 0; + $self->{nb_error} = 0; } }