X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;ds=sidebyside;f=src%2Fmovegen.cpp;h=cc635b84e37160a59cf004fff974d18124397869;hb=01a191936eeb3dc3366554b1423c53da2a1ae56a;hp=09bb95ab03d5d94fc200b7af7f27a5122e07ef27;hpb=a9782b94e640d3a35b597758ff1d5f0e56465666;p=stockfish diff --git a/src/movegen.cpp b/src/movegen.cpp index 09bb95ab..cc635b84 100644 --- a/src/movegen.cpp +++ b/src/movegen.cpp @@ -178,12 +178,12 @@ MoveStack* generate(const Position& pos, MoveStack* mlist) { mlist = generate_piece_moves(pos, mlist, us, target); mlist = generate_piece_moves(pos, mlist, us, target); - if (Type != MV_CAPTURE) + if (Type != MV_CAPTURE && pos.can_castle(us)) { - if (pos.can_castle_kingside(us)) + if (pos.can_castle(us == WHITE ? WHITE_OO : BLACK_OO)) mlist = generate_castle_moves(pos, mlist, us); - if (pos.can_castle_queenside(us)) + if (pos.can_castle(us == WHITE ? WHITE_OOO : BLACK_OOO)) mlist = generate_castle_moves(pos, mlist, us); } @@ -217,7 +217,7 @@ MoveStack* generate(const Position& pos, MoveStack* mlist) while (b) { from = pop_1st_bit(&b); - switch (type_of_piece(pos.piece_on(from))) + switch (piece_type(pos.piece_on(from))) { case PAWN: /* Will be generated togheter with pawns direct checks */ break; case KNIGHT: mlist = generate_discovered_checks(pos, mlist, from); break; @@ -265,9 +265,9 @@ MoveStack* generate(const Position& pos, MoveStack* mlist) { checkersCnt++; checksq = pop_1st_bit(&b); - assert(pos.color_of_piece_on(checksq) == opposite_color(us)); + assert(piece_color(pos.piece_on(checksq)) == opposite_color(us)); - switch (type_of_piece(pos.piece_on(checksq))) + switch (piece_type(pos.piece_on(checksq))) { case BISHOP: sliderAttacks |= BishopPseudoAttacks[checksq]; break; case ROOK: sliderAttacks |= RookPseudoAttacks[checksq]; break; @@ -503,10 +503,11 @@ namespace { Color them = opposite_color(us); Square ksq = pos.king_square(us); + CastleRight f = CastleRight((Side == KING_SIDE ? WHITE_OO : WHITE_OOO) << us); assert(pos.piece_on(ksq) == make_piece(us, KING)); - Square rsq = (Side == KING_SIDE ? pos.initial_kr_square(us) : pos.initial_qr_square(us)); + Square rsq = pos.castle_rook_square(f); Square s1 = relative_square(us, Side == KING_SIDE ? SQ_G1 : SQ_C1); Square s2 = relative_square(us, Side == KING_SIDE ? SQ_F1 : SQ_D1); Square s; @@ -516,12 +517,12 @@ namespace { // It is a bit complicated to correctly handle Chess960 for (s = Min(ksq, s1); s <= Max(ksq, s1); s++) - if ( (s != ksq && s != rsq && pos.square_is_occupied(s)) + if ( (s != ksq && s != rsq && !pos.square_is_empty(s)) ||(pos.attackers_to(s) & pos.pieces_of_color(them))) illegal = true; for (s = Min(rsq, s2); s <= Max(rsq, s2); s++) - if (s != ksq && s != rsq && pos.square_is_occupied(s)) + if (s != ksq && s != rsq && !pos.square_is_empty(s)) illegal = true; if ( Side == QUEEN_SIDE