]> git.sesse.net Git - remoteglot/blobdiff - remoteglot.pl
Fix a deadlock in the JSON loading code in serve-analysis.js.
[remoteglot] / remoteglot.pl
index 1b06f05f88c2f29ff65c24ba011817afbd65acec..52eae900e98dc52aa070d4b5eac3fa8c7436b79e 100755 (executable)
@@ -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.
@@ -587,7 +589,7 @@ sub complete_using_tbprobe {
                        push @moves, $uci_move;
                }
 
-               $pos->{'tbprobe_cache'}{$key} = \@moves;
+               $tbprobe_cache{$key} = \@moves;
        }
 
        $info->{'pv' . $mpv} = \@moves;
@@ -1088,7 +1090,7 @@ sub score_digest {
                        if ($score == 0 && $info->{'tablebase'}) {
                                return ['d', undef];
                        } else {
-                               return ['cp', $score];
+                               return ['cp', int($score)];
                        }
                }
        }