mirror of
https://github.com/OMGeeky/hcsalmon1-Chess-Engine-Test.git
synced 2026-01-19 16:04:42 +01:00
221 lines
7.1 KiB
C#
221 lines
7.1 KiB
C#
using System;
|
|
using static CEngineCopy.Constants;
|
|
using static CEngineCopy.MoveUtils;
|
|
|
|
namespace CEngineCopy
|
|
{
|
|
internal class Debugging
|
|
{
|
|
|
|
public static void PrintAllBitboards()
|
|
{
|
|
for (int i = 0; i < 12; i++)
|
|
{
|
|
PrintBitboard(Board.bitboard_array_global[i]);
|
|
}
|
|
}
|
|
|
|
|
|
public static void PrintBitboard(ulong input)
|
|
{
|
|
if (input == 0)
|
|
{
|
|
Console.WriteLine($" bitboard: {input}");
|
|
return;
|
|
}
|
|
for (int y = 0; y < 8; y++)
|
|
{
|
|
Console.Write(" ");
|
|
for (int x = 0; x < 8; x++)
|
|
{
|
|
int square = (y * 8) + x;
|
|
if ((input & Constants.SQUARE_BBS[square]) != 0)
|
|
{
|
|
Console.Write("X ");
|
|
}
|
|
else
|
|
{
|
|
Console.Write("- ");
|
|
}
|
|
}
|
|
Console.Write("\n");
|
|
}
|
|
|
|
Console.WriteLine($"\nbitboard: {input}\n");
|
|
}
|
|
|
|
|
|
public static void PrintAllDebug(int startingSquare, int targetSquare, int piece, int tag, int captureIndex)
|
|
{
|
|
PrintPiece(piece);
|
|
PrintMoveNoNL(startingSquare, targetSquare, tag);
|
|
Console.WriteLine();
|
|
Console.WriteLine($"capture index: {captureIndex}");
|
|
PrintBoardGlobal();
|
|
}
|
|
|
|
public static void PrintBoardGlobal()
|
|
{
|
|
char[] yCoordinates = { '8', '7', '6', '5', '4', '3', '2', '1' };
|
|
char[] castleChars = { 'K', 'Q', 'k', 'q' };
|
|
|
|
for (int y = 0; y < 8; y++)
|
|
{
|
|
Console.Write($" {yCoordinates[y]} ");
|
|
for (int x = 0; x < 8; x++)
|
|
{
|
|
PrintPiece(y, x);
|
|
}
|
|
Console.Write('\n');
|
|
}
|
|
Console.WriteLine(" A B C D E F G H\n\n");
|
|
if (Board.is_white_global == true)
|
|
{
|
|
Console.WriteLine("Side: White To Play\n");
|
|
}
|
|
else
|
|
{
|
|
Console.WriteLine("Side: Black To Play\n");
|
|
}
|
|
Console.Write("castle: ");
|
|
for (int i = 0; i < 4; i++)
|
|
{
|
|
if (Board.castle_rights_global[i] == true)
|
|
{
|
|
Console.Write(castleChars[i]);
|
|
}
|
|
else
|
|
{
|
|
Console.Write("-");
|
|
}
|
|
}
|
|
Console.Write($"\nEP: ");
|
|
if (Board.ep_global > 63 || Board.ep_global < 0)
|
|
{
|
|
Console.WriteLine(Board.ep_global);
|
|
}
|
|
else
|
|
{
|
|
Console.WriteLine(Constants.SQ_CHAR_X[Board.ep_global]);
|
|
Console.WriteLine(Constants.SQ_CHAR_Y[Board.ep_global]);
|
|
}
|
|
|
|
Console.Write("\n\n");
|
|
}
|
|
|
|
private static void PrintPiece(int y, int x)
|
|
{
|
|
int square = (y * 8) + x;
|
|
bool pieceFound = false;
|
|
|
|
for (int pieceIndex = 0; pieceIndex < 12; pieceIndex++)
|
|
{
|
|
if ((Board.bitboard_array_global[pieceIndex] & Constants.SQUARE_BBS[square]) != 0)
|
|
{
|
|
Console.Write(Constants.PIECE_COLOURS[pieceIndex]);
|
|
Console.Write(Constants.PIECE_CHARS[pieceIndex]);
|
|
Console.Write(' ');
|
|
pieceFound = true;
|
|
break;
|
|
}
|
|
}
|
|
|
|
if (pieceFound == false)
|
|
{
|
|
Console.Write("-- ");
|
|
}
|
|
}
|
|
|
|
public static void PrintMoveNoNL(int starting, int target, int tag)
|
|
{ //starting
|
|
if (OutOfBounds(starting) == true)
|
|
{
|
|
Console.Write(starting);
|
|
}
|
|
else
|
|
{
|
|
Console.Write(SQ_CHAR_X[starting]);
|
|
Console.Write(SQ_CHAR_Y[starting]);
|
|
}
|
|
//target
|
|
if (OutOfBounds(target) == true)
|
|
{
|
|
Console.Write(target);
|
|
}
|
|
else
|
|
{
|
|
Console.Write(SQ_CHAR_X[target]);
|
|
Console.Write(SQ_CHAR_Y[target]);
|
|
}
|
|
if (tag == TAG_B_N_PROMOTION_CAP || tag == TAG_B_N_PROMOTION || tag == TAG_W_N_PROMOTION || tag == TAG_W_N_PROMOTION_CAP)
|
|
{
|
|
Console.Write("n");
|
|
}
|
|
else if (tag == TAG_B_R_PROMOTION_CAP || tag == TAG_B_R_PROMOTION || tag == TAG_W_R_PROMOTION || tag == TAG_W_R_PROMOTION_CAP)
|
|
{
|
|
Console.Write("r");
|
|
}
|
|
else if (tag == TAG_B_B_PROMOTION_CAP || tag == TAG_B_B_PROMOTION || tag == TAG_W_B_PROMOTION || tag == TAG_W_B_PROMOTION_CAP)
|
|
{
|
|
Console.Write("b");
|
|
}
|
|
else if (tag == TAG_B_Q_PROMOTION_CAP || tag == TAG_B_Q_PROMOTION || tag == TAG_W_Q_PROMOTION || tag == TAG_W_Q_PROMOTION_CAP)
|
|
{
|
|
Console.Write("q");
|
|
}
|
|
}
|
|
|
|
public static void PrintMoveNoNL(int[] move)
|
|
{ //starting
|
|
if (OutOfBounds(move[MOVE_STARTING]) == true)
|
|
{
|
|
Console.Write("%d", move[MOVE_STARTING]);
|
|
}
|
|
else
|
|
{
|
|
Console.Write("%c", SQ_CHAR_X[move[MOVE_STARTING]]);
|
|
Console.Write("%c", SQ_CHAR_Y[move[MOVE_STARTING]]);
|
|
}
|
|
//target
|
|
if (OutOfBounds(move[MOVE_TARGET]) == true)
|
|
{
|
|
Console.Write("%d", move[MOVE_TARGET]);
|
|
}
|
|
else
|
|
{
|
|
Console.Write("%c", SQ_CHAR_X[move[MOVE_TARGET]]);
|
|
Console.Write("%c", SQ_CHAR_Y[move[MOVE_TARGET]]);
|
|
}
|
|
int tag = move[MOVE_TAG];
|
|
if (tag == TAG_B_N_PROMOTION_CAP || tag == TAG_B_N_PROMOTION || tag == TAG_W_N_PROMOTION || tag == TAG_W_N_PROMOTION_CAP)
|
|
{
|
|
Console.Write("n");
|
|
}
|
|
else if (tag == TAG_B_R_PROMOTION_CAP || tag == TAG_B_R_PROMOTION || tag == TAG_W_R_PROMOTION || tag == TAG_W_R_PROMOTION_CAP)
|
|
{
|
|
Console.Write("r");
|
|
}
|
|
else if (tag == TAG_B_B_PROMOTION_CAP || tag == TAG_B_B_PROMOTION || tag == TAG_W_B_PROMOTION || tag == TAG_W_B_PROMOTION_CAP)
|
|
{
|
|
Console.Write("b");
|
|
}
|
|
else if (tag == TAG_B_Q_PROMOTION_CAP || tag == TAG_B_Q_PROMOTION || tag == TAG_W_Q_PROMOTION || tag == TAG_W_Q_PROMOTION_CAP)
|
|
{
|
|
Console.Write("q");
|
|
}
|
|
}
|
|
|
|
public static void PrintPiece(int piece)
|
|
{
|
|
Console.Write(Constants.PIECE_COLOURS[piece]);
|
|
Console.Write(Constants.PIECE_CHARS[piece]);
|
|
Console.Write(' ');
|
|
}
|
|
public static void PrintPieceLn(int piece)
|
|
{
|
|
Console.WriteLine(Constants.PIECE_COLOURS[piece]);
|
|
Console.WriteLine(Constants.PIECE_CHARS[piece]);
|
|
}
|
|
}
|
|
}
|