X-Git-Url: https://git.sesse.net/?p=remoteglot;a=blobdiff_plain;f=remoteglot.pl;h=52eae900e98dc52aa070d4b5eac3fa8c7436b79e;hp=9439a4bc4d0b063c59b1eb2738cc9cd0c4b987d5;hb=4166f694604b0ee8e7fb47156c6623d036b35457;hpb=f26a218756768fcbbbcd332e56029053e359003c diff --git a/remoteglot.pl b/remoteglot.pl index 9439a4b..52eae90 100755 --- a/remoteglot.pl +++ b/remoteglot.pl @@ -536,6 +536,8 @@ sub prettyprint_pv { } } +my %tbprobe_cache = (); + sub complete_using_tbprobe { my ($pos, $info, $mpv) = @_; @@ -553,10 +555,10 @@ sub complete_using_tbprobe { # Run through the PV until we are at a 6-man position. # TODO: We could in theory only have 5-man data. my @pv = @{$info->{'pv' . $mpv}}; - my $key = join('', @pv); + my $key = $pos->fen() . " " . join('', @pv); my @moves = (); - if (exists($pos->{'tbprobe_cache'}{$key})) { - @moves = $pos->{'tbprobe_cache'}{$key}; + if (exists($tbprobe_cache{$key})) { + @moves = @{$tbprobe_cache{$key}}; } else { if ($mpv ne '') { # Force doing at least one move of the PV. @@ -586,6 +588,8 @@ sub complete_using_tbprobe { ($pos, $uci_move) = $pos->make_pretty_move($move); push @moves, $uci_move; } + + $tbprobe_cache{$key} = \@moves; } $info->{'pv' . $mpv} = \@moves; @@ -1086,7 +1090,7 @@ sub score_digest { if ($score == 0 && $info->{'tablebase'}) { return ['d', undef]; } else { - return ['cp', $score]; + return ['cp', int($score)]; } } }