- // When generating checks consider under-promotion moves (both captures
- // and non captures) only if can give a discovery check. Note that dcp
- // is dc bitboard or pinned bitboard when Type == EVASION.
- Bitboard pp = (Type == CHECK ? pawns & dcp : pawns);
-
- if (Type != EVASION && Type != CAPTURE)
- {
- Bitboard enemyPieces = pos.pieces_of_color(opposite_color(Us));
-
- // Underpromotion captures in the a1-h8 (a8-h1 for black) direction
- b1 = move_pawns<Us, DELTA_NE>(pp) & ~FileABB & enemyPieces & TRank8BB;
- while (b1)
- {
- to = pop_1st_bit(&b1);
- (*mlist++).move = make_promotion_move(to - TDELTA_NE, to, ROOK);
- (*mlist++).move = make_promotion_move(to - TDELTA_NE, to, BISHOP);
- (*mlist++).move = make_promotion_move(to - TDELTA_NE, to, KNIGHT);
- }
-
- // Underpromotion captures in the h1-a8 (h8-a1 for black) direction
- b1 = move_pawns<Us, DELTA_NW>(pp) & ~FileHBB & enemyPieces & TRank8BB;
- while (b1)
- {
- to = pop_1st_bit(&b1);
- (*mlist++).move = make_promotion_move(to - TDELTA_NW, to, ROOK);
- (*mlist++).move = make_promotion_move(to - TDELTA_NW, to, BISHOP);
- (*mlist++).move = make_promotion_move(to - TDELTA_NW, to, KNIGHT);
- }
- }
-
- // Underpromotion pawn pushes. Also queen promotions for evasions and captures.
- b1 = move_pawns<Us, DELTA_N>(pp) & TRank8BB;
- b1 &= (Type == EVASION ? blockSquares : emptySquares);
-
- while (b1)
- {
- to = pop_1st_bit(&b1);
- if (Type == EVASION || Type == CAPTURE)
- (*mlist++).move = make_promotion_move(to - TDELTA_N, to, QUEEN);
-
- if (Type != CAPTURE)
- {
- (*mlist++).move = make_promotion_move(to - TDELTA_N, to, ROOK);
- (*mlist++).move = make_promotion_move(to - TDELTA_N, to, BISHOP);
- (*mlist++).move = make_promotion_move(to - TDELTA_N, to, KNIGHT);
- }
- }