From e6c9ce635819957bce641a432b0675c5c033631b Mon Sep 17 00:00:00 2001 From: Marco Costalba Date: Tue, 3 Dec 2013 10:09:17 +0100 Subject: [PATCH] Small improvment to Position::fen() No functional change. --- src/position.cpp | 28 ++++++++++++---------------- src/position.h | 2 +- 2 files changed, 13 insertions(+), 17 deletions(-) diff --git a/src/position.cpp b/src/position.cpp index c4c6389d..d2aeb822 100644 --- a/src/position.cpp +++ b/src/position.cpp @@ -211,7 +211,7 @@ void Position::set(const string& fenStr, bool isChess960, Thread* th) { */ char col, row, token; - size_t p; + size_t idx; Square sq = SQ_A8; std::istringstream ss(fenStr); @@ -227,9 +227,9 @@ void Position::set(const string& fenStr, bool isChess960, Thread* th) { else if (token == '/') sq -= Square(16); - else if ((p = PieceToChar.find(token)) != string::npos) + else if ((idx = PieceToChar.find(token)) != string::npos) { - put_piece(sq, color_of(Piece(p)), type_of(Piece(p))); + put_piece(sq, color_of(Piece(idx)), type_of(Piece(idx))); ++sq; } } @@ -329,25 +329,21 @@ void Position::set_castling_flag(Color c, Square rfrom) { const string Position::fen() const { + int emptyCnt; std::ostringstream ss; for (Rank rank = RANK_8; rank >= RANK_1; --rank) { for (File file = FILE_A; file <= FILE_H; ++file) { - Square sq = file | rank; - - if (empty(sq)) - { - int emptyCnt = 1; - - for ( ; file < FILE_H && empty(++sq); ++file) - ++emptyCnt; + for (emptyCnt = 0; file <= FILE_H && empty(file | rank); ++file) + ++emptyCnt; + if (emptyCnt) ss << emptyCnt; - } - else - ss << PieceToChar[piece_on(sq)]; + + if (file <= FILE_H) + ss << PieceToChar[piece_on(file | rank)]; } if (rank > RANK_1) @@ -368,11 +364,11 @@ const string Position::fen() const { if (can_castle(BLACK_OOO)) ss << (chess960 ? file_to_char(file_of(castling_rook_square(BLACK, QUEEN_SIDE)), true) : 'q'); - if (st->castlingFlags == NO_CASTLING) + if (!can_castle(WHITE) && !can_castle(BLACK)) ss << '-'; ss << (ep_square() == SQ_NONE ? " - " : " " + square_to_string(ep_square()) + " ") - << st->rule50 << " " << 1 + (gamePly - int(sideToMove == BLACK)) / 2; + << st->rule50 << " " << 1 + (gamePly - int(sideToMove == BLACK)) / 2; return ss.str(); } diff --git a/src/position.h b/src/position.h index 903b1b64..64cb349a 100644 --- a/src/position.h +++ b/src/position.h @@ -81,7 +81,7 @@ public: static void init(); // Text input/output - void set(const std::string& fen, bool isChess960, Thread* th); + void set(const std::string& fenStr, bool isChess960, Thread* th); const std::string fen() const; const std::string pretty(Move m = MOVE_NONE) const; -- 2.39.2