X-Git-Url: https://git.proxmox.com/?p=pve-common.git;a=blobdiff_plain;f=src%2FPVE%2FCLIFormatter.pm;h=84dbed1e6e2af6fbaf63c2e7d3631247f94bd664;hp=2c10318d3b7c8e9a2e32c0e6e10fd2c366698c4e;hb=c0b8717c443436d724f4e0be9cfce725d8123df0;hpb=a91ee28fe5abd92080260d66078f88d05ff4f4f0 diff --git a/src/PVE/CLIFormatter.pm b/src/PVE/CLIFormatter.pm index 2c10318..84dbed1 100644 --- a/src/PVE/CLIFormatter.pm +++ b/src/PVE/CLIFormatter.pm @@ -2,12 +2,14 @@ package PVE::CLIFormatter; use strict; use warnings; + use I18N::Langinfo; use POSIX qw(strftime); use CPAN::Meta::YAML; # comes with perl-modules use PVE::JSONSchema; use PVE::PTY; + use JSON; use utf8; use Encode; @@ -69,9 +71,6 @@ PVE::JSONSchema::register_renderer( sub render_bytes { my ($value) = @_; - return $value if $value !~ m/^(\d+)$/; - $value = int($1); # untaint for sprintf - my @units = qw(B KiB MiB GiB TiB PiB); my $max_unit = 0; @@ -79,8 +78,8 @@ sub render_bytes { $max_unit = int(log($value)/log(1024)); $value /= 1024**($max_unit); } - - return sprintf "%.2f $units[$max_unit]", $value; + my $unit = $units[$max_unit]; + return sprintf "%.2f $unit", $value; } PVE::JSONSchema::register_renderer('bytes', \&render_bytes); @@ -359,7 +358,7 @@ sub extract_properties_to_print { # takes formatting information from the results property of the call # if $props_to_print is provided, prints only those columns. otherwise # takes all fields of the results property, with a fallback -# to all fields occuring in items of $data. +# to all fields occurring in items of $data. sub print_api_list { my ($data, $result_schema, $props_to_print, $options, $terminal_opts) = @_; @@ -412,8 +411,9 @@ sub print_api_result { my $format = $options->{'output-format'} // 'text'; - if ($result_schema) { + if ($result_schema && defined($result_schema->{type})) { return if $result_schema->{type} eq 'null'; + return if $result_schema->{optional} && !defined($data); } else { my $type = $guess_type->($data); $result_schema = { type => $type };