+
+ return if (!defined($pos_calculating));
+
+ #
+ # Check the PVs first. if they're invalid, just wait, as our data
+ # is most likely out of sync. This isn't a very good solution, as
+ # it can frequently miss stuff, but it's good enough for most users.
+ #
+ eval {
+ my $dummy;
+ if (exists($uciinfo{'pv'})) {
+ $dummy = prettyprint_pv($pos_calculating->{'board'},
+ $pos_calculating->{'move_num'},
+ $pos_calculating->{'toplay'},
+ @{$uciinfo{'pv'}});
+ }
+
+ my $mpv = 1;
+ while (exists($uciinfo{'pv' . $mpv})) {
+ $dummy = prettyprint_pv($pos_calculating->{'board'},
+ $pos_calculating->{'move_num'},
+ $pos_calculating->{'toplay'},
+ @{$uciinfo{'pv' . $mpv}});
+ ++$mpv;
+ }
+ };
+ if ($@) {
+ %uciinfo = ();
+ return;
+ }
+
+ my $text = '';
+
+ if (exists($uciid{'name'})) {
+ $text .= "Analysis by $uciid{'name'}:\n\n";
+ } else {
+ $text .= "Analysis:\n\n";
+ }
+
+ return unless (exists($pos_calculating->{'board'}));
+
+ #
+ # Some programs _always_ report MultiPV, even with only one PV.
+ # In this case, we simply use that data as if MultiPV was never
+ # specified.
+ #
+ if (exists($uciinfo{'pv1'}) && !exists($uciinfo{'pv2'})) {
+ for my $key qw(pv score_cp score_mate nodes nps depth seldepth tbhits) {
+ if (exists($uciinfo{$key . '1'}) && !exists($uciinfo{$key})) {
+ $uciinfo{$key} = $uciinfo{$key . '1'};
+ }
+ }
+ }
+
+ my @text_pvs = ();
+ if (exists($uciinfo{'pv1'}) && exists($uciinfo{'pv2'})) {
+ # multi-PV
+ my $mpv = 1;
+ while (exists($uciinfo{'pv' . $mpv})) {
+ $text_pvs[$mpv] = prefix_pv($pos_calculating->{'move_num'}, $pos_calculating->{'toplay'}) .
+ join(' ', prettyprint_pv($pos_calculating->{'board'},
+ $pos_calculating->{'move_num'},
+ $pos_calculating->{'toplay'},
+ @{$uciinfo{'pv' . $mpv}}));
+ ++$mpv;
+ }
+ } else {
+ # single-PV
+ $text_pvs[0] = prefix_pv($pos_calculating->{'move_num'}, $pos_calculating->{'toplay'}) .
+ join(' ', prettyprint_pv($pos_calculating->{'board'},
+ $pos_calculating->{'move_num'},
+ $pos_calculating->{'toplay'},
+ @{$uciinfo{'pv'}}));
+ }