From: Steinar H. Gunderson Date: Wed, 27 Dec 2023 08:24:53 +0000 (+0100) Subject: Lowercase toplay internally, for consistency with FEN. X-Git-Url: https://git.sesse.net/?p=remoteglot;a=commitdiff_plain;h=a2249d895beb04196592e1b529bce35ed79fe210 Lowercase toplay internally, for consistency with FEN. This is for the frontend only; the backend continues with whatever it wants to do. --- diff --git a/www/js/remoteglot.js b/www/js/remoteglot.js index d6659f8..870703c 100644 --- a/www/js/remoteglot.js +++ b/www/js/remoteglot.js @@ -397,12 +397,10 @@ function redraw_arrows() { /** @param {!string} fen * @return {!string} * - * Return whose side it is to play (W or B), given a FEN. - * This is in uppercase due to historical reasons, which we - * should get rid of. + * Return whose side it is to play (w or b), given a FEN. */ function find_toplay(fen) { - return fen.split(' ')[1].toUpperCase(); + return fen.split(' ')[1]; } /** @param {!string} fen @@ -731,13 +729,13 @@ function print_pv(line_num, splicepos, opt_limit, opt_showlast) { if (start_display_move_num > 0) { pv = pv.slice(start_display_move_num); let to_add = start_display_move_num; - if (toplay === 'B') { + if (toplay === 'b') { ++move_num; - toplay = 'W'; + toplay = 'w'; --to_add; } if (to_add % 2 == 1) { - toplay = 'B'; + toplay = 'b'; --to_add; } move_num += to_add / 2; @@ -751,7 +749,7 @@ function print_pv(line_num, splicepos, opt_limit, opt_showlast) { let i = 0; if (opt_limit && opt_showlast && pv.length > opt_limit) { // Truncate the PV at the beginning (instead of at the end). - // We assume here that toplay is 'W'. We also assume that if + // We assume here that toplay is 'w'. We also assume that if // opt_showlast is set, then it is the history, and thus, // the UI should be to expand the history. ret.appendChild(document.createTextNode('(')); @@ -766,7 +764,7 @@ function print_pv(line_num, splicepos, opt_limit, opt_showlast) { ++i; } move_num += i / 2; - } else if (toplay == 'B' && pv.length > 0) { + } else if (toplay == 'b' && pv.length > 0) { ret.appendChild(document.createTextNode(move_num + '. … ')); } for (; i < pv.length; ++i) { @@ -776,10 +774,10 @@ function print_pv(line_num, splicepos, opt_limit, opt_showlast) { in_tb = true; } - if (toplay == 'B' && i == 0) { + if (toplay == 'b' && i == 0) { ++move_num; - toplay = 'W'; - } else if (toplay == 'W') { + toplay = 'w'; + } else if (toplay == 'w') { if (i > opt_limit && !opt_showlast) { if (in_tb) { prefix += ')'; @@ -789,10 +787,10 @@ function print_pv(line_num, splicepos, opt_limit, opt_showlast) { } prefix += ' ' + move_num + '. '; ++move_num; - toplay = 'B'; + toplay = 'b'; } else { prefix += ' '; - toplay = 'W'; + toplay = 'w'; } ret.appendChild(document.createTextNode(prefix)); @@ -884,7 +882,7 @@ function update_refutation_lines() { moves.push(move); } - let invert = (find_toplay(base_fen) === 'B'); + let invert = (find_toplay(base_fen) === 'b'); if (current_display_line && current_display_move % 2 == 0 && !current_display_line_is_history) { invert = !invert; } @@ -1178,18 +1176,18 @@ function update_board() { // Find the previous move. let previous_move_num, previous_toplay; let fen = data['position']['fen']; - if (find_toplay(fen) === 'B') { + if (find_toplay(fen) === 'b') { previous_move_num = find_move_num(fen); - previous_toplay = 'W'; + previous_toplay = 'w'; } else { previous_move_num = find_move_num(fen) - 1; - previous_toplay = 'B'; + previous_toplay = 'b'; } last_move = format_move_with_number( data['position']['last_move'], previous_move_num, - previous_toplay == 'W'); + previous_toplay == 'w'); headline += ' after ' + last_move; } else { last_move = null; @@ -1327,7 +1325,7 @@ function update_board() { hiddenboard.move(data['pv'][i + 1]); // To keep continuity. } - let alt_moves = find_nonstupid_moves(data, 30, toplay === 'B'); + let alt_moves = find_nonstupid_moves(data, 30, toplay === 'b'); for (let i = 1; i < alt_moves.length && i < 3; ++i) { hiddenboard = new Chess(base_fen); let move = patch_move(hiddenboard.move(alt_moves[i])); @@ -1339,7 +1337,7 @@ function update_board() { // See if all semi-reasonable moves have only one possible response. if (data['pv'].length >= 2) { - let nonstupid_moves = find_nonstupid_moves(data, 300, toplay === 'B'); + let nonstupid_moves = find_nonstupid_moves(data, 300, toplay === 'b'); let hiddenboard = new Chess(base_fen); hiddenboard.move(data['pv'][0]); let response = hiddenboard.move(data['pv'][1]); @@ -1400,7 +1398,7 @@ function update_sparkline(data) { if (first_move_num !== undefined) { let fen = data['position']['fen']; let last_move_num = find_move_num(fen) * 2 - 3; - if (find_toplay(fen) === 'B') { + if (find_toplay(fen) === 'b') { ++last_move_num; }