fix: compiler warnings
This commit is contained in:
parent
3ed7f315c8
commit
a36aa3b0c6
@ -1,4 +1,4 @@
|
|||||||
use crate::{Board, CastleRights, ColPiece, Color, Square, BOARD_HEIGHT, BOARD_WIDTH};
|
use crate::{Board, ColPiece, Color, Square, BOARD_HEIGHT, BOARD_WIDTH};
|
||||||
|
|
||||||
pub const START_POSITION: &str = "rnbqkbnr/pppppppp/8/8/8/8/PPPPPPPP/RNBQKBNR w KQkq - 0 1";
|
pub const START_POSITION: &str = "rnbqkbnr/pppppppp/8/8/8/8/PPPPPPPP/RNBQKBNR w KQkq - 0 1";
|
||||||
|
|
||||||
@ -280,8 +280,7 @@ impl ToFen for Board {
|
|||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
mod tests {
|
mod tests {
|
||||||
use super::*;
|
use super::*;
|
||||||
use crate::CastlePlayer;
|
use crate::{CastlePlayer, CastleRights, N_SQUARES};
|
||||||
use crate::N_SQUARES;
|
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_fen_pieces() {
|
fn test_fen_pieces() {
|
||||||
|
29
src/lib.rs
29
src/lib.rs
@ -7,14 +7,13 @@ pub mod fen;
|
|||||||
pub mod movegen;
|
pub mod movegen;
|
||||||
|
|
||||||
use crate::fen::{FromFen, ToFen, START_POSITION};
|
use crate::fen::{FromFen, ToFen, START_POSITION};
|
||||||
use crate::movegen::Move;
|
|
||||||
|
|
||||||
const BOARD_WIDTH: usize = 8;
|
const BOARD_WIDTH: usize = 8;
|
||||||
const BOARD_HEIGHT: usize = 8;
|
const BOARD_HEIGHT: usize = 8;
|
||||||
const N_SQUARES: usize = BOARD_WIDTH * BOARD_HEIGHT;
|
const N_SQUARES: usize = BOARD_WIDTH * BOARD_HEIGHT;
|
||||||
|
|
||||||
#[derive(Debug, Copy, Clone, Default, PartialEq, Eq)]
|
#[derive(Debug, Copy, Clone, Default, PartialEq, Eq)]
|
||||||
enum Color {
|
pub enum Color {
|
||||||
#[default]
|
#[default]
|
||||||
White = 0,
|
White = 0,
|
||||||
Black = 1,
|
Black = 1,
|
||||||
@ -51,11 +50,11 @@ enum Piece {
|
|||||||
}
|
}
|
||||||
const N_PIECES: usize = 6;
|
const N_PIECES: usize = 6;
|
||||||
|
|
||||||
struct PieceErr;
|
pub struct PieceErr;
|
||||||
|
|
||||||
/// Color and piece.
|
/// Color and piece.
|
||||||
#[derive(Debug, Clone, Copy, PartialEq, Eq)]
|
#[derive(Debug, Clone, Copy, PartialEq, Eq)]
|
||||||
struct ColPiece {
|
pub struct ColPiece {
|
||||||
pc: Piece,
|
pc: Piece,
|
||||||
col: Color,
|
col: Color,
|
||||||
}
|
}
|
||||||
@ -114,7 +113,7 @@ impl ColPiece {
|
|||||||
///
|
///
|
||||||
/// A1 is (0, 0) -> 0, A2 is (0, 1) -> 2, and H8 is (7, 7) -> 63.
|
/// A1 is (0, 0) -> 0, A2 is (0, 1) -> 2, and H8 is (7, 7) -> 63.
|
||||||
#[derive(Debug, Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Hash)]
|
#[derive(Debug, Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Hash)]
|
||||||
struct Square(usize);
|
pub struct Square(usize);
|
||||||
|
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
pub enum SquareError {
|
pub enum SquareError {
|
||||||
@ -269,7 +268,7 @@ impl From<Piece> for char {
|
|||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Default, Debug, Clone, Copy, PartialEq, Eq)]
|
#[derive(Default, Debug, Clone, Copy, PartialEq, Eq)]
|
||||||
struct Bitboard(u64);
|
pub struct Bitboard(u64);
|
||||||
|
|
||||||
impl Bitboard {
|
impl Bitboard {
|
||||||
pub fn on_sq(&mut self, idx: Square) {
|
pub fn on_sq(&mut self, idx: Square) {
|
||||||
@ -302,7 +301,7 @@ impl IntoIterator for Bitboard {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
struct BitboardIterator {
|
pub struct BitboardIterator {
|
||||||
remaining: Bitboard,
|
remaining: Bitboard,
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -446,7 +445,7 @@ impl Board {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// Get immutable reference to castling rights.
|
/// Get immutable reference to castling rights.
|
||||||
fn pl_castle(&self, col: Color) -> &CastlePlayer {
|
pub fn pl_castle(&self, col: Color) -> &CastlePlayer {
|
||||||
&self.castle.0[col as usize]
|
&self.castle.0[col as usize]
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -456,12 +455,12 @@ impl Board {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// Get iterator over all squares.
|
/// Get iterator over all squares.
|
||||||
fn squares() -> impl Iterator<Item = Square> {
|
pub fn squares() -> impl Iterator<Item = Square> {
|
||||||
(0..N_SQUARES).map(Square::try_from).map(|x| x.unwrap())
|
(0..N_SQUARES).map(Square::try_from).map(|x| x.unwrap())
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Create a new piece in a location, and pop any existing piece in the destination.
|
/// Create a new piece in a location, and pop any existing piece in the destination.
|
||||||
fn set_piece(&mut self, idx: Square, pc: ColPiece) -> Option<ColPiece> {
|
pub fn set_piece(&mut self, idx: Square, pc: ColPiece) -> Option<ColPiece> {
|
||||||
let dest_pc = self.del_piece(idx);
|
let dest_pc = self.del_piece(idx);
|
||||||
let pl = self.pl_mut(pc.col);
|
let pl = self.pl_mut(pc.col);
|
||||||
pl.board_mut(pc.into()).on_sq(idx);
|
pl.board_mut(pc.into()).on_sq(idx);
|
||||||
@ -470,7 +469,7 @@ impl Board {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// Set the piece (or no piece) in a square, and return ("pop") the existing piece.
|
/// Set the piece (or no piece) in a square, and return ("pop") the existing piece.
|
||||||
fn set_square(&mut self, idx: Square, pc: Option<ColPiece>) -> Option<ColPiece> {
|
pub fn set_square(&mut self, idx: Square, pc: Option<ColPiece>) -> Option<ColPiece> {
|
||||||
match pc {
|
match pc {
|
||||||
Some(pc) => self.set_piece(idx, pc),
|
Some(pc) => self.set_piece(idx, pc),
|
||||||
None => self.del_piece(idx),
|
None => self.del_piece(idx),
|
||||||
@ -478,7 +477,7 @@ impl Board {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// Delete the piece in a location, and return ("pop") that piece.
|
/// Delete the piece in a location, and return ("pop") that piece.
|
||||||
fn del_piece(&mut self, idx: Square) -> Option<ColPiece> {
|
pub fn del_piece(&mut self, idx: Square) -> Option<ColPiece> {
|
||||||
if let Some(pc) = *self.mail.sq_mut(idx) {
|
if let Some(pc) = *self.mail.sq_mut(idx) {
|
||||||
let pl = self.pl_mut(pc.col);
|
let pl = self.pl_mut(pc.col);
|
||||||
pl.board_mut(pc.into()).off_sq(idx);
|
pl.board_mut(pc.into()).off_sq(idx);
|
||||||
@ -500,14 +499,14 @@ impl Board {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// Get the piece at a location.
|
/// Get the piece at a location.
|
||||||
fn get_piece(&self, idx: Square) -> Option<ColPiece> {
|
pub fn get_piece(&self, idx: Square) -> Option<ColPiece> {
|
||||||
*self.mail.sq(idx)
|
*self.mail.sq(idx)
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Mirrors the position so that black and white are switched.
|
/// Mirrors the position so that black and white are switched.
|
||||||
///
|
///
|
||||||
/// Mainly to avoid duplication in tests.
|
/// Mainly to avoid duplication in tests.
|
||||||
fn flip_colors(&self) -> Self {
|
pub fn flip_colors(&self) -> Self {
|
||||||
let mut new_board = Self {
|
let mut new_board = Self {
|
||||||
turn: self.turn.flip(),
|
turn: self.turn.flip(),
|
||||||
half_moves: self.half_moves,
|
half_moves: self.half_moves,
|
||||||
@ -531,7 +530,7 @@ impl Board {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// Is a given player in check?
|
/// Is a given player in check?
|
||||||
fn is_check(&self, pl: Color) -> bool {
|
pub fn is_check(&self, pl: Color) -> bool {
|
||||||
for src in self.pl(pl).board(Piece::King).into_iter() {
|
for src in self.pl(pl).board(Piece::King).into_iter() {
|
||||||
macro_rules! detect_checker {
|
macro_rules! detect_checker {
|
||||||
($dirs: ident, $pc: pat, $keep_going: expr) => {
|
($dirs: ident, $pc: pat, $keep_going: expr) => {
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
//! Move generation.
|
//! Move generation.
|
||||||
|
|
||||||
use crate::fen::{FromFen, ToFen, START_POSITION};
|
use crate::fen::ToFen;
|
||||||
use crate::{
|
use crate::{
|
||||||
Board, CastleRights, ColPiece, Color, Piece, Square, SquareError, BOARD_HEIGHT, BOARD_WIDTH,
|
Board, CastleRights, ColPiece, Color, Piece, Square, SquareError, BOARD_HEIGHT, BOARD_WIDTH,
|
||||||
N_SQUARES,
|
N_SQUARES,
|
||||||
@ -722,14 +722,14 @@ pub fn perft(depth: usize, pos: &mut Board) -> usize {
|
|||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
mod tests {
|
mod tests {
|
||||||
use super::*;
|
use super::*;
|
||||||
use crate::fen::{ToFen, START_POSITION};
|
use crate::fen::{ToFen, START_POSITION, FromFen};
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
/// Ensure that bitboard properly reflects captures.
|
/// Ensure that bitboard properly reflects captures.
|
||||||
fn test_bitboard_capture() {
|
fn test_bitboard_capture() {
|
||||||
let mut pos = Board::from_fen("8/8/8/8/8/8/r7/R7 w - - 0 1").unwrap();
|
let mut pos = Board::from_fen("8/8/8/8/8/8/r7/R7 w - - 0 1").unwrap();
|
||||||
let mv = Move::from_uci_algebraic("a1a2").unwrap();
|
let mv = Move::from_uci_algebraic("a1a2").unwrap();
|
||||||
let anti_move = mv.make(&mut pos);
|
let _anti_move = mv.make(&mut pos);
|
||||||
|
|
||||||
use std::collections::hash_set::HashSet;
|
use std::collections::hash_set::HashSet;
|
||||||
use Piece::*;
|
use Piece::*;
|
||||||
|
Loading…
Reference in New Issue
Block a user