diff options
author | Jun Kuriyama <kuriyama@FreeBSD.org> | 2009-02-06 07:16:32 +0000 |
---|---|---|
committer | Jun Kuriyama <kuriyama@FreeBSD.org> | 2009-02-06 07:16:32 +0000 |
commit | 2c0c9683099dd48ff2139916cf0580acaf46d716 (patch) | |
tree | 4c7ec334da8c82a05a630e1bd59362ca1d6ef8b5 /misc/amanda26-server/files/extra-patch-application-src::amzfs-sendrecv.pl | |
parent | Update to 0.2.29 (diff) |
Grr, I forgot to add patch files in previous commit...
Diffstat (limited to 'misc/amanda26-server/files/extra-patch-application-src::amzfs-sendrecv.pl')
-rw-r--r-- | misc/amanda26-server/files/extra-patch-application-src::amzfs-sendrecv.pl | 52 |
1 files changed, 52 insertions, 0 deletions
diff --git a/misc/amanda26-server/files/extra-patch-application-src::amzfs-sendrecv.pl b/misc/amanda26-server/files/extra-patch-application-src::amzfs-sendrecv.pl new file mode 100644 index 000000000000..0a19153747d9 --- /dev/null +++ b/misc/amanda26-server/files/extra-patch-application-src::amzfs-sendrecv.pl @@ -0,0 +1,52 @@ +--- application-src/amzfs-sendrecv.pl.orig 2009-01-22 02:35:38.000000000 +0100 ++++ application-src/amzfs-sendrecv.pl 2009-01-31 10:37:59.495534563 +0100 +@@ -235,13 +235,48 @@ + } elsif (defined $errmsg) { + $self->print_to_server_and_die($action, $errmsg, $Amanda::Script_App::ERROR); + } else { +- $self->print_to_server_and_die($action, "cannot estimate snapshot '$self->{snapshot}\@$self->{snapshot}': unknown reason", $Amanda::Script_App::ERROR); ++ $self->print_to_server_and_die($action, "cannot estimate snapshot '$self->{snapshot}\@$self->{snapshot}': unknown reason", $Amanda::Script_App::ERROR); + } + } ++ if ($level == 0) { ++ my $compratio = $self->get_compratio(); ++ $msg *= int $compratio; ++ } + + return $msg; + } + ++sub get_compratio ++{ ++ my $self = shift; ++ my $action = shift; ++ ++ my $cmd; ++ $cmd = "$self->{pfexec_cmd} $self->{zfs_path} get -Hp -o value compressratio $self->{filesystem}\@$self->{snapshot}"; ++ debug "running (get-compression): $cmd"; ++ my($wtr, $rdr, $err, $pid); ++ $err = Symbol::gensym; ++ $pid = open3($wtr, $rdr, $err, $cmd); ++ close $wtr; ++ my ($msg) = <$rdr>; ++ my ($errmsg) = <$err>; ++ waitpid $pid, 0; ++ close $rdr; ++ close $err; ++ if ($? != 0) { ++ if (defined $msg && defined $errmsg) { ++ $self->print_to_server_and_die($action, "$msg, $errmsg", $Amanda::Script_App::ERROR); ++ } elsif (defined $msg) { ++ $self->print_to_server_and_die($action, $msg, $Amanda::Script_App::ERROR); ++ } elsif (defined $errmsg) { ++ $self->print_to_server_and_die($action, $errmsg, $Amanda::Script_App::ERROR); ++ } else { ++ $self->print_to_server_and_die($action, "cannot read compression ratio '$self->{snapshot}\@$self->{snapshot}': unknown reason", $Amanda::Script_App::ERROR); ++ } ++ } ++ return $msg ++} ++ + sub command_index_from_output { + } + |