chess_validator 0.2.11 → 0.2.16

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (4) hide show
  1. checksums.yaml +4 -4
  2. data/lib/board_logic.rb +13 -15
  3. data/lib/move_logic.rb +4 -3
  4. metadata +1 -1
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 7246b6d061d29511f381b3b152c8b9558a041976aed4b65a2f70b00790b39bfc
4
- data.tar.gz: 8f5f544a578d432a5303185fc95777a4a6c218fd1159021af2a08378e6b19b0b
3
+ metadata.gz: 418ecd1a9c987d472710309ee4b439823aca959f0db13354eaf760e3374d5cc6
4
+ data.tar.gz: 4b8fe686866e3364878b44ef069ad03810692bbfb8a8910c989c569289e05574
5
5
  SHA512:
6
- metadata.gz: 5886da44a02c98e30b802d79072c3d26f5ac81146d58b2a6f0d2cb4f39c032bbd958f7c13288f4b0749efe42574e758f7293c2a4dda7772c809206ce0769315d
7
- data.tar.gz: 52b7d23f1c6ca1d96e68095032f5bde8c431d5da688b25626329969ff2dbd155cb6cd5264e4844c2253610aa6698172d9ef4b1fb0aa3106c94d663249843ee43
6
+ metadata.gz: 4f6ec9b723c3bd3b66dc0af59e4c85c6465601db1c1844137065b66d5eac3d5ff403137dfbb079030223697cda04e08529c3a3adbe05832bae9e72aa57bb839c
7
+ data.tar.gz: 8cd9b541308f86db409b66e8a1b36967af5ac0b081ee536cce34ca6cd928b7810b0eef44f07cfe6832767ddad8da4dfd247ef780d15d0a04bf8a00e599e65512
@@ -17,35 +17,33 @@ module ChessValidator
17
17
  board
18
18
  end
19
19
 
20
- def self.to_fen_notation(board, previous_fen, piece, move)
20
+ def self.to_fen_notation(board, previous_fen, piece, move, captured)
21
21
  notation = handle_position(board)
22
22
  notation += find_turn(previous_fen.active)
23
- notation += handle_castle(previous_fen.castling, piece)
23
+ notation += handle_castle(previous_fen.castling, piece, board)
24
24
  notation += handle_en_passant(piece, move)
25
- notation += handle_half_move_clock(board.size, previous_fen, piece)
25
+ notation += handle_half_move_clock(previous_fen, piece.piece_type, captured)
26
26
  notation += piece.color == 'b' ? previous_fen.fullmove.next : previous_fen.fullmove
27
27
  notation
28
28
  end
29
29
 
30
- def self.handle_half_move_clock(board_size, previous_fen, piece)
31
- if piece.piece_type == 'pawn' || build_board(previous_fen).size > board_size
30
+ def self.handle_half_move_clock(previous_fen, piece_type, captured)
31
+ if piece_type.downcase == 'p' || captured
32
32
  '0 '
33
33
  else
34
34
  previous_fen.halfmove.next + ' '
35
35
  end
36
36
  end
37
37
 
38
- def self.handle_castle(castling, piece)
38
+ def self.handle_castle(castling, piece, board)
39
39
  return castling if castling == '-'
40
- if ['K', 'Q', 'k', 'q'].include?(piece.piece_type)
41
- castling.size == 1 ? '-' : castling.delete(piece.piece_type)
42
- elsif piece.piece_type.downcase == 'r'
43
- castle_side = piece.position[0] == 'a' ? 'q' : 'k'
44
- castle_side = castle_side.capitalize if piece.color == 'w'
45
- castling.size == 1 ? '-' : castling.delete(castle_side)
46
- else
47
- castling
48
- end
40
+ castling.delete!('K') if board[64].nil? || board[64].piece_type != 'R'
41
+ castling.delete!('K') if board[61].nil? || board[61].piece_type != 'K'
42
+ castling.delete!('Q') if board[57].nil? || board[57].piece_type != 'R'
43
+ castling.delete!('k') if board[8].nil? || board[8].piece_type != 'r'
44
+ castling.delete!('k') if board[5].nil? || board[5].piece_type != 'k'
45
+ castling.delete!('q') if board[1].nil? || board[1].piece_type != 'r'
46
+ castling.size == 1 ? '-' : castling
49
47
  end
50
48
 
51
49
  def self.handle_en_passant(piece, move)
@@ -116,7 +116,7 @@ module ChessValidator
116
116
  board = BoardLogic.build_board(fen)
117
117
  new_board = with_next_move(piece, board, move)
118
118
 
119
- BoardLogic.to_fen_notation(new_board, fen, piece, move)
119
+ BoardLogic.to_fen_notation(new_board, fen, piece, move, board[INDEX_KEY[move]])
120
120
  end
121
121
 
122
122
  def castled?(piece, move)
@@ -130,6 +130,7 @@ module ChessValidator
130
130
  def king_will_be_safe?(piece, board, move)
131
131
  new_board = with_next_move(piece, board, move)
132
132
  king, occupied_spaces = find_king_and_spaces(new_board, piece.color)
133
+ return false if king.nil?
133
134
  king_is_safe?(king.color, new_board, king.position, occupied_spaces)
134
135
  end
135
136
 
@@ -161,7 +162,7 @@ module ChessValidator
161
162
  board.values.none? { |piece| [between, move].include?(piece.position) } &&
162
163
  empty_b_square
163
164
  else
164
- valid_destination?(king, board, move) && king_is_safe?(king.color, board, move, occupied_spaces)
165
+ valid_destination?(king, board, move) && king_will_be_safe?(king, board, move)
165
166
  end
166
167
  end
167
168
 
@@ -210,7 +211,7 @@ module ChessValidator
210
211
  def valid_destination?(piece, board, move)
211
212
  target_piece = find_piece(board, move)
212
213
  if target_piece
213
- target_piece.color != piece.color
214
+ target_piece.color != piece.color && target_piece.piece_type.downcase != 'k'
214
215
  else
215
216
  true
216
217
  end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: chess_validator
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.2.11
4
+ version: 0.2.16
5
5
  platform: ruby
6
6
  authors:
7
7
  - Charles Ellison