The code for continuemove is just a series of variable assignments, which by itself doesn't give much hint about how it should be used.
case "continuemove": // Allow multi-part move to be made with mouse/touch
case "redomove": // Allow player to redo illegal move
if ($submit == "Preview")
$submit = "";
$pastmovesfield = ($args[0] == "redomove") ? "" : $moves;
$movelist = $oldmovelist;
$movenum = max($movenum - 1, 0);
if (!$switchsides) {
$side = $turnorder[$movenum % $sidecnt];
}
else
$side = $turnorder[($sidecnt - 1) - ($movenum % $sidecnt)];
break;
So, the main thing to consider is which variables are changing and how they are used. Changing the value of $submit changes which form_* script it includes when it loads the page after submitting a move. With a value of "Preview", it would include form_verify.php for showing a preview of the move and asking the player to confirm it. With an empty value, it will include form_move.php again. If you were playing by yourself in solitaire mode, it would not have to change the script it includes.
$pastmovesfield is for populating a form field that gets used for multi-part moves. So that the moves field works the same as it would for single moves, it starts out empty, and the previously entered moves go in a different form field.
$movelist is a string listing every move in the game on a separate line, sometimes with comments interspersed. $oldmovelist was set to $movelist just before appending the latest move to it. So this sets $movelist to what it was before the partial move that was already made was made. Once the full multi-part move has been made, it will be appended to $movelist as a single string.
$movenum is the number of the latest move. Since it would normally be incremented at the end of a complete move, it is decremented to keep it the same, though it is not allowed to go below zero.
$side indicates the side of the player who can move. This would normally switch to the other player at the end of a turn. But when continuing a move, it should not change to the other player. It gets the value of $side from a list of players whose identifiers in the game are values in the $turnorder array. It does this instead of switching a flag back and forth, because I wanted to add support for multi-player games and games with alternate turn orders, but that project is not complete, because some code in Game Courier just assumes a two-player game with alternating turns.
$switchsides has to do with the orientation of the board. It defaults to 0, which means that the board should be shown from the perspective of the player whose turn it is to move. Setting it to a non-zero value would cause the board to stay in the same position no matter whose turn it is. Since this is only a cosmetic difference, I'm not sure why it should have any bearing on whose side it is. So I'll experiment with whether giving $switchsides a non-zero value will mess up how a multi-move game operates.
The assigned variables mainly affect the form the player gets after completing the first part of a multi-part move, and they have nothing to do with the evaluation of a move, which is what the Post-Move code is supposed to handle. Given the purpose of this command, it should not be executed more than once during a whole series of moves, and it should not be executed for any past moves. In fact, calling it more than once could result in the wrong value for $movenum. So, it makes sense to reserve its use for the Post-Game code. In my code for Extra Move Chess, it is used after calculating the legal moves for the second part of the turn.
The code for continuemove is just a series of variable assignments, which by itself doesn't give much hint about how it should be used.
So, the main thing to consider is which variables are changing and how they are used. Changing the value of $submit changes which form_* script it includes when it loads the page after submitting a move. With a value of "Preview", it would include form_verify.php for showing a preview of the move and asking the player to confirm it. With an empty value, it will include form_move.php again. If you were playing by yourself in solitaire mode, it would not have to change the script it includes.
$pastmovesfield is for populating a form field that gets used for multi-part moves. So that the moves field works the same as it would for single moves, it starts out empty, and the previously entered moves go in a different form field.
$movelist is a string listing every move in the game on a separate line, sometimes with comments interspersed. $oldmovelist was set to $movelist just before appending the latest move to it. So this sets $movelist to what it was before the partial move that was already made was made. Once the full multi-part move has been made, it will be appended to $movelist as a single string.
$movenum is the number of the latest move. Since it would normally be incremented at the end of a complete move, it is decremented to keep it the same, though it is not allowed to go below zero.
$side indicates the side of the player who can move. This would normally switch to the other player at the end of a turn. But when continuing a move, it should not change to the other player. It gets the value of $side from a list of players whose identifiers in the game are values in the $turnorder array. It does this instead of switching a flag back and forth, because I wanted to add support for multi-player games and games with alternate turn orders, but that project is not complete, because some code in Game Courier just assumes a two-player game with alternating turns.
$switchsides has to do with the orientation of the board. It defaults to 0, which means that the board should be shown from the perspective of the player whose turn it is to move. Setting it to a non-zero value would cause the board to stay in the same position no matter whose turn it is. Since this is only a cosmetic difference, I'm not sure why it should have any bearing on whose side it is. So I'll experiment with whether giving $switchsides a non-zero value will mess up how a multi-move game operates.
The assigned variables mainly affect the form the player gets after completing the first part of a multi-part move, and they have nothing to do with the evaluation of a move, which is what the Post-Move code is supposed to handle. Given the purpose of this command, it should not be executed more than once during a whole series of moves, and it should not be executed for any past moves. In fact, calling it more than once could result in the wrong value for $movenum. So, it makes sense to reserve its use for the Post-Game code. In my code for Extra Move Chess, it is used after calculating the legal moves for the second part of the turn.