Add possibility to override global formatting definition

This commit is contained in:
Sims24 2017-02-16 13:21:18 +01:00
parent 031a9bae39
commit 9f2776f1cc
1 changed files with 21 additions and 6 deletions

View File

@ -35,18 +35,33 @@ sub custom_metric_output {
my $msg; my $msg;
my $message; my $message;
eval { if (defined($config_data->{filters}) && defined($config_data->{filters}->{formatting})) {
local $SIG{__WARN__} = sub { $message = $_[0]; }; eval {
local $SIG{__DIE__} = sub { $message = $_[0]; }; local $SIG{__WARN__} = sub { $message = $_[0]; };
local $SIG{__DIE__} = sub { $message = $_[0]; };
$msg = sprintf("$config_data->{formatting}->{printf_msg}", eval "$config_data->{formatting}->{printf_var}"); $msg = sprintf("$config_data->{filters}->{formatting}->{printf_msg}", eval "$config_data->{filters}->{formatting}->{printf_var}");
}; };
} elsif (defined($config_data->{selection}->{$self->{result_values}->{instance}}->{formatting})) {
eval {
local $SIG{__WARN__} = sub { $message = $_[0]; };
local $SIG{__DIE__} = sub { $message = $_[0]; };
$msg = sprintf("$config_data->{selection}->{$self->{result_values}->{instance}}->{formatting}->{printf_msg}", eval "$config_data->{selection}->{$self->{result_values}->{instance}}->{formatting}->{printf_var}");
};
} else {
eval {
local $SIG{__WARN__} = sub { $message = $_[0]; };
local $SIG{__DIE__} = sub { $message = $_[0]; };
$msg = sprintf("$config_data->{formatting}->{printf_msg}", eval "$config_data->{formatting}->{printf_var}");
};
}
if (defined($message)) { if (defined($message)) {
$self->{output}->output_add(long_msg => 'printf expression problem: ' . $message); $self->{output}->output_add(long_msg => 'printf expression problem: ' . $message);
$self->{output}->option_exit(); $self->{output}->option_exit();
} }
return $msg; return $msg;
} }
sub custom_metric_calc { sub custom_metric_calc {