]> git.proxmox.com Git - pve-manager.git/commitdiff
vzdump mail: Refactor text part
authorDominic Jäger <d.jaeger@proxmox.com>
Tue, 17 Nov 2020 10:46:52 +0000 (11:46 +0100)
committerThomas Lamprecht <t.lamprecht@proxmox.com>
Tue, 17 Nov 2020 13:13:11 +0000 (14:13 +0100)
Less lines exeeding the character limit, less nesting, less duplicate code,
more readable sprintf arguments.

Co-authored-by: Thomas Lamprecht <t.lamprecht@proxmox.com>
Signed-off-by: Dominic Jäger <d.jaeger@proxmox.com>
PVE/VZDump.pm

index fa387299aeba5961e6fe501355e759f64a0ead9d..59062d2be711e66d24e092b567b36ce5628a53c0 100644 (file)
@@ -258,24 +258,26 @@ sub sendmail {
 
     # text part
     my $text = $err ? "$err\n\n" : '';
-    $text .= sprintf ("%-10s %-20s %-6s %10s %10s  %s\n", qw(VMID NAME STATUS TIME SIZE FILENAME));
+    my $namelength = 20;
+    $text .= sprintf (
+       "%-10s %-${namelength}s %-6s %10s %10s  %s\n",
+       qw(VMID NAME STATUS TIME SIZE FILENAME)
+    );
     foreach my $task (@$tasklist) {
-       my $vmid = $task->{vmid};
-       if  ($task->{state} eq 'ok') {
-
-           $text .= sprintf ("%-10s %-20s %-6s %10s %10s  %s\n", $vmid,
-                               substr($task->{hostname}, 0, 20),
-                               $task->{state},
-                               format_time($task->{backuptime}),
-                               format_size ($task->{size}),
-                               $task->{target});
-       } else {
-           $text .= sprintf ("%-10s %-20s %-6s %10s %8.2fMB  %s\n", $vmid,
-                               substr($task->{hostname}, 0, 20),
-                               $task->{state},
-                               format_time($task->{backuptime}),
-                               0, '-');
-       }
+       my $name = substr($task->{hostname}, 0, $namelength);
+       my $successful = $task->{state} eq 'ok';
+       my $size = $successful ? format_size ($task->{size}) : 0;
+       my $filename = $successful ? $task->{target} : '-';
+       my $size_fmt = $successful ? "%10s": "%8.2fMB";
+       $text .= sprintf(
+           "%-10s %-${namelength}s %-6s %10s $size_fmt  %s\n",
+           $task->{vmid},
+           $name,
+           $task->{state},
+           format_time($task->{backuptime}),
+           $size,
+           $filename,
+       );
     }
 
     my $text_log_part;