X-Git-Url: https://git.sesse.net/?p=stockfish;a=blobdiff_plain;f=src%2Fposition.cpp;h=e6125ec7c2c756816bc098014d132fa04900ae03;hp=ec54da9e9e3161b382120acfaadfe7c9866129fd;hb=9b6b9e67fe767a83837ff4cbf3954a8cf70eee59;hpb=1f97b48a31cd60d71c5fb63541cbf3991a094443 diff --git a/src/position.cpp b/src/position.cpp index ec54da9e..e6125ec7 100644 --- a/src/position.cpp +++ b/src/position.cpp @@ -699,14 +699,30 @@ void Position::update_hidden_checks(Square from, Square to) { set_bit(&moveSquares, to); // Our moving piece could have been a possible pinner or hidden checker behind a dcCandidates? - bool checkerMoved = (st->dcCandidates[us] | st->pinners[them]) && (moveSquares & sliders()); + bool checkerMoved = (st->dcCandidates[us] || bit_is_set(st->pinners[them], from)) && (moveSquares & sliders()); // If we are moving from/to an opponent king attack direction and we was a possible hidden checker // or there exsist some possible hidden checker on that line then recalculate the position // otherwise skip because our dcCandidates and opponent pinned pieces are not changed. if ( (moveSquares & RookPseudoAttacks[ksq]) && (checkerMoved || (rooks_and_queens(us) & RookPseudoAttacks[ksq])) || (moveSquares & BishopPseudoAttacks[ksq]) && (checkerMoved || (bishops_and_queens(us) & BishopPseudoAttacks[ksq]))) - find_hidden_checks(us, Pinned | DcCandidates); + { + // If the move gives direct check and we don't have pinners/dc cadidates + // then we can be sure that we won't have them also after the move if + // we are not moving from a possible king attack direction. + bool outsideChecker = false; + + if ( bit_is_set(st->checkersBB, to) + && !(bit_is_set(RookPseudoAttacks[ksq], from) && (checkerMoved || (rooks_and_queens(us) & RookPseudoAttacks[ksq]))) + && !(bit_is_set(BishopPseudoAttacks[ksq], from) && (checkerMoved || (bishops_and_queens(us) & BishopPseudoAttacks[ksq])))) + outsideChecker = true; + + if (!outsideChecker || st->pinned[them]) + find_hidden_checks(us, Pinned); + + if (!outsideChecker || st->dcCandidates[us] || bit_is_set(st->pinned[them], to)) + find_hidden_checks(us, DcCandidates); + } ksq = king_square(us); @@ -725,16 +741,14 @@ void Position::update_hidden_checks(Square from, Square to) { if ( (moveSquares & RookPseudoAttacks[ksq]) && (checkerCaptured || (rooks_and_queens(them) & RookPseudoAttacks[ksq])) || (moveSquares & BishopPseudoAttacks[ksq]) && (checkerCaptured || (bishops_and_queens(them) & BishopPseudoAttacks[ksq]))) { + find_hidden_checks(them, Pinned); // If we don't have opponent dc candidates and we are moving in the - // attack line then won't be dc candidates also after the move. + // attack line then won't be any dc candidates also after the move. if ( st->dcCandidates[them] - || bit_is_set(RookPseudoAttacks[ksq], from) - || bit_is_set(BishopPseudoAttacks[ksq], from)) - - find_hidden_checks(them, Pinned | DcCandidates); - else - find_hidden_checks(them, Pinned); + || (bit_is_set(RookPseudoAttacks[ksq], from) && (rooks_and_queens(them) & RookPseudoAttacks[ksq])) + || (bit_is_set(BishopPseudoAttacks[ksq], from) && (bishops_and_queens(them) & BishopPseudoAttacks[ksq]))) + find_hidden_checks(them, DcCandidates); } }