implemented method collect_moves_single_check in bitboard::movegen used in move generation
This commit is contained in:
@@ -8,6 +8,7 @@ mod kings;
|
||||
use super::board::Board;
|
||||
use super::movebuffer::MoveBuffer;
|
||||
use super::bitmove::BitMove;
|
||||
use super::checkinfo::CheckInfo;
|
||||
use super::utils::*;
|
||||
|
||||
impl Board {
|
||||
@@ -39,6 +40,19 @@ impl Board {
|
||||
self.add_king_moves(buffer, temp_buffer, safe_squares);
|
||||
self.add_king_castles(buffer, safe_squares);
|
||||
|
||||
buffer.append(temp_buffer);
|
||||
temp_buffer.clear();
|
||||
}
|
||||
pub(in super) fn collect_moves_single_check(&self, buffer: &mut MoveBuffer, temp_buffer: &mut MoveBuffer, check_info: &CheckInfo) {
|
||||
let safe_squares = self.get_safe_king_squares();
|
||||
|
||||
self.add_pawn_moves(buffer, temp_buffer, check_info.move_mask);
|
||||
self.add_knight_moves(buffer, temp_buffer, check_info.move_mask);
|
||||
self.add_bishop_moves(buffer, temp_buffer, check_info.move_mask);
|
||||
self.add_rook_moves(buffer, temp_buffer, check_info.move_mask);
|
||||
self.add_queen_moves(buffer, temp_buffer, check_info.move_mask);
|
||||
self.add_king_moves(buffer, temp_buffer, safe_squares);
|
||||
|
||||
buffer.append(temp_buffer);
|
||||
temp_buffer.clear();
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user