From 67ceea26184ab0eede1b43e65f8fd5229a8693a3 Mon Sep 17 00:00:00 2001 From: giantim Date: Tue, 24 Mar 2020 14:06:17 +0900 Subject: [PATCH 01/75] =?UTF-8?q?doc:=20=EC=B2=B4=EC=8A=A4=201=EB=8B=A8?= =?UTF-8?q?=EA=B3=84=20=EA=B8=B0=EB=8A=A5=20=EC=9A=94=EA=B5=AC=20=EC=82=AC?= =?UTF-8?q?=ED=95=AD=20=EC=A0=95=EB=A6=AC?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- README.md | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/README.md b/README.md index 86b3c5f3245..ef5dd275132 100644 --- a/README.md +++ b/README.md @@ -1,2 +1,10 @@ # java-chess 체스 게임 구현을 위한 저장소 + +## 기능 요구 사항 + +1단계 + - [ ] 명령어를 입력 받는다(start, end) + - [ ] (예외) start, end 외의 명령어가 입력된 경우 다시 명령어를 입력 받는다 + - [ ] start 를 입력 시 체스판을 초기화 한다 + - [ ] end 를 입력 시 게임을 종료한다 From eee6977c2b968fc70440d7c531c863fd0d051018 Mon Sep 17 00:00:00 2001 From: giantim Date: Tue, 24 Mar 2020 14:54:59 +0900 Subject: [PATCH 02/75] =?UTF-8?q?feat:=20=EC=9C=84=EC=B9=98=20=EA=B5=AC?= =?UTF-8?q?=ED=98=84?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/main/java/chess/Position.java | 43 +++++++++++++++++++++++++++ src/main/java/chess/Rank.java | 27 +++++++++++++++++ src/test/java/chess/FileTest.java | 15 ++++++++++ src/test/java/chess/PositionTest.java | 15 ++++++++++ src/test/java/chess/RankTest.java | 15 ++++++++++ 5 files changed, 115 insertions(+) create mode 100644 src/main/java/chess/Position.java create mode 100644 src/main/java/chess/Rank.java create mode 100644 src/test/java/chess/FileTest.java create mode 100644 src/test/java/chess/PositionTest.java create mode 100644 src/test/java/chess/RankTest.java diff --git a/src/main/java/chess/Position.java b/src/main/java/chess/Position.java new file mode 100644 index 00000000000..75e0c5505b8 --- /dev/null +++ b/src/main/java/chess/Position.java @@ -0,0 +1,43 @@ +package chess; + +import java.util.ArrayList; +import java.util.List; + +public class Position { + private static List positions; + + private final File file; + private final Rank rank; + + private Position(File file, Rank rank) { + this.file = file; + this.rank = rank; + } + + static { + positions = new ArrayList<>(); + for (File file : File.values()) { + addPosition(file); + } + } + + private static void addPosition(File file) { + for (Rank rank : Rank.values()) { + positions.add(new Position(file, rank)); + } + } + + public static Position of(String position) { + File file = File.of(position.substring(0, 1)); + Rank rank = Rank.of(position.substring(1, 2)); + + return findPosition(file, rank); + } + + private static Position findPosition(File file, Rank rank) { + return positions.stream() + .filter(p -> p.file.equals(file) && p.rank.equals(rank)) + .findFirst() + .orElseThrow(AssertionError::new); + } +} diff --git a/src/main/java/chess/Rank.java b/src/main/java/chess/Rank.java new file mode 100644 index 00000000000..399c99c6938 --- /dev/null +++ b/src/main/java/chess/Rank.java @@ -0,0 +1,27 @@ +package chess; + +import java.util.Arrays; + +public enum Rank { + EIGHT(8), + SEVEN(7), + SIX(6), + FIVE(5), + FOUR(4), + THREE(3), + TWO(2), + ONE(1); + + private int rank; + + Rank(int rank) { + this.rank = rank; + } + + public static Rank of(String rank) { + return Arrays.stream(values()) + .filter(pv -> pv.rank == Integer.parseInt(rank)) + .findFirst() + .orElseThrow(() -> new IllegalArgumentException("잘못된 y 좌표값을 입력하였습니다.")); + } +} diff --git a/src/test/java/chess/FileTest.java b/src/test/java/chess/FileTest.java new file mode 100644 index 00000000000..2b8c66c2929 --- /dev/null +++ b/src/test/java/chess/FileTest.java @@ -0,0 +1,15 @@ +package chess; + +import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; + +class FileTest { + @DisplayName("잘못된 x 좌표값이 들어왔을 때 예외 출력") + @Test + void ofTest() { + Assertions.assertThatThrownBy(() -> { + File.of("i"); + }).isInstanceOf(IllegalArgumentException.class); + } +} \ No newline at end of file diff --git a/src/test/java/chess/PositionTest.java b/src/test/java/chess/PositionTest.java new file mode 100644 index 00000000000..369d0f94814 --- /dev/null +++ b/src/test/java/chess/PositionTest.java @@ -0,0 +1,15 @@ +package chess; + +import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; + +public class PositionTest { + @DisplayName("입력한 값으로 position 변경하는 기능") + @Test + void moveTest() { + Position position = Position.of("b2"); + + Assertions.assertThat(position).isEqualTo(Position.of("b2")); + } +} diff --git a/src/test/java/chess/RankTest.java b/src/test/java/chess/RankTest.java new file mode 100644 index 00000000000..3a6933b9a59 --- /dev/null +++ b/src/test/java/chess/RankTest.java @@ -0,0 +1,15 @@ +package chess; + +import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; + +class RankTest { + @DisplayName("잘못된 y 좌표 입력값에 대해 예외 처리 테스트") + @Test + void ofTest() { + Assertions.assertThatThrownBy(() -> { + Rank.of("9"); + }).isInstanceOf(IllegalArgumentException.class); + } +} \ No newline at end of file From a49d949709325b59bac56eabaff4ba238bea0981 Mon Sep 17 00:00:00 2001 From: giantim Date: Tue, 24 Mar 2020 14:56:16 +0900 Subject: [PATCH 03/75] =?UTF-8?q?feat:=20=EA=B0=80=EB=A1=9C=20=EC=B6=95=20?= =?UTF-8?q?=EA=B5=AC=ED=98=84?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/main/java/chess/File.java | 14 ++++++++++++++ 1 file changed, 14 insertions(+) create mode 100644 src/main/java/chess/File.java diff --git a/src/main/java/chess/File.java b/src/main/java/chess/File.java new file mode 100644 index 00000000000..a8460811fe2 --- /dev/null +++ b/src/main/java/chess/File.java @@ -0,0 +1,14 @@ +package chess; + +import java.util.Arrays; + +public enum File { + A, B, C, D, E, F, G, H; + + public static File of(String file) { + return Arrays.stream(values()) + .filter(ph -> ph.name().equals(file.toUpperCase())) + .findFirst() + .orElseThrow(() -> new IllegalArgumentException("잘못된 x 좌표값을 입력하였습니다.")); + } +} From 16267b56ea1012cbb31ae3c0db3139559c1e0123 Mon Sep 17 00:00:00 2001 From: giantim Date: Wed, 25 Mar 2020 13:43:26 +0900 Subject: [PATCH 04/75] =?UTF-8?q?feat:=20=EB=B3=B4=EB=93=9C=ED=8C=90=20?= =?UTF-8?q?=EC=B4=88=EA=B8=B0=ED=99=94?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/main/java/chess/ChessApplication.java | 10 ++++++ src/main/java/chess/controller/BoardDto.java | 16 ++++++++++ .../chess/controller/ChessController.java | 17 ++++++++++ .../java/chess/controller/PositionDto.java | 16 ++++++++++ src/main/java/chess/domain/board/Board.java | 25 +++++++++++++++ .../chess/domain/board/BoardInitializer.java | 32 +++++++++++++++++++ .../domain/initialize/BishopInitializer.java | 19 +++++++++++ .../domain/initialize/InitializeStrategy.java | 10 ++++++ .../domain/initialize/KingInitializer.java | 17 ++++++++++ .../domain/initialize/KnightInitializer.java | 19 +++++++++++ .../domain/initialize/PawnInitializer.java | 31 ++++++++++++++++++ .../domain/initialize/QueenInitializer.java | 17 ++++++++++ .../domain/initialize/RookInitializer.java | 19 +++++++++++ .../java/chess/domain/piece/PieceType.java | 22 +++++++++++++ .../chess/{ => domain/position}/File.java | 19 +++++++++-- .../chess/{ => domain/position}/Position.java | 22 ++++++++++--- .../chess/{ => domain/position}/Rank.java | 2 +- .../java/chess/view/ConsoleOutputView.java | 24 ++++++++++++++ src/main/java/chess/view/OutputView.java | 8 +++++ .../chess/{ => domain/position}/FileTest.java | 2 +- .../{ => domain/position}/PositionTest.java | 2 +- .../chess/{ => domain/position}/RankTest.java | 2 +- 22 files changed, 339 insertions(+), 12 deletions(-) create mode 100644 src/main/java/chess/ChessApplication.java create mode 100644 src/main/java/chess/controller/BoardDto.java create mode 100644 src/main/java/chess/controller/ChessController.java create mode 100644 src/main/java/chess/controller/PositionDto.java create mode 100644 src/main/java/chess/domain/board/Board.java create mode 100644 src/main/java/chess/domain/board/BoardInitializer.java create mode 100644 src/main/java/chess/domain/initialize/BishopInitializer.java create mode 100644 src/main/java/chess/domain/initialize/InitializeStrategy.java create mode 100644 src/main/java/chess/domain/initialize/KingInitializer.java create mode 100644 src/main/java/chess/domain/initialize/KnightInitializer.java create mode 100644 src/main/java/chess/domain/initialize/PawnInitializer.java create mode 100644 src/main/java/chess/domain/initialize/QueenInitializer.java create mode 100644 src/main/java/chess/domain/initialize/RookInitializer.java create mode 100644 src/main/java/chess/domain/piece/PieceType.java rename src/main/java/chess/{ => domain/position}/File.java (50%) rename src/main/java/chess/{ => domain/position}/Position.java (70%) rename src/main/java/chess/{ => domain/position}/Rank.java (94%) create mode 100644 src/main/java/chess/view/ConsoleOutputView.java create mode 100644 src/main/java/chess/view/OutputView.java rename src/test/java/chess/{ => domain/position}/FileTest.java (92%) rename src/test/java/chess/{ => domain/position}/PositionTest.java (92%) rename src/test/java/chess/{ => domain/position}/RankTest.java (92%) diff --git a/src/main/java/chess/ChessApplication.java b/src/main/java/chess/ChessApplication.java new file mode 100644 index 00000000000..f70d30b2b5f --- /dev/null +++ b/src/main/java/chess/ChessApplication.java @@ -0,0 +1,10 @@ +package chess; + +import chess.controller.ChessController; + +public class ChessApplication { + + public static void main(String[] args) { + ChessController.run(); + } +} \ No newline at end of file diff --git a/src/main/java/chess/controller/BoardDto.java b/src/main/java/chess/controller/BoardDto.java new file mode 100644 index 00000000000..e8b0aa88b43 --- /dev/null +++ b/src/main/java/chess/controller/BoardDto.java @@ -0,0 +1,16 @@ +package chess.controller; + +import java.util.Map; + +public class BoardDto { + + private Map board; + + public BoardDto(Map board) { + this.board = board; + } + + public Map get() { + return board; + } +} diff --git a/src/main/java/chess/controller/ChessController.java b/src/main/java/chess/controller/ChessController.java new file mode 100644 index 00000000000..4dd09542914 --- /dev/null +++ b/src/main/java/chess/controller/ChessController.java @@ -0,0 +1,17 @@ +package chess.controller; + +import chess.domain.board.Board; +import chess.domain.position.Position; +import chess.view.ConsoleOutputView; +import chess.view.OutputView; + +public class ChessController { + private static OutputView outputView = new ConsoleOutputView(); + + public static void run() { + Board board = new Board(); + BoardDto boardDto = new BoardDto(board.get()); + PositionDto positionDto = new PositionDto(Position.getPositions()); + outputView.printBoard(positionDto.getPositions(), boardDto.get()); + } +} diff --git a/src/main/java/chess/controller/PositionDto.java b/src/main/java/chess/controller/PositionDto.java new file mode 100644 index 00000000000..8af6b20c9a3 --- /dev/null +++ b/src/main/java/chess/controller/PositionDto.java @@ -0,0 +1,16 @@ +package chess.controller; + +import java.util.List; + +public class PositionDto { + + private final List positions; + + public PositionDto(List positions) { + this.positions = positions; + } + + public List getPositions() { + return positions; + } +} diff --git a/src/main/java/chess/domain/board/Board.java b/src/main/java/chess/domain/board/Board.java new file mode 100644 index 00000000000..b49da019fdd --- /dev/null +++ b/src/main/java/chess/domain/board/Board.java @@ -0,0 +1,25 @@ +package chess.domain.board; + +import chess.domain.piece.PieceType; +import chess.domain.position.Position; + +import java.util.HashMap; +import java.util.LinkedHashMap; +import java.util.Map; +import java.util.stream.Collectors; + +public class Board { + private Map board; + + public Board() { + this.board = BoardInitializer.initializeAll(); + } + + public Map get() { + return board.entrySet() + .stream() + .collect(Collectors.toMap(entry -> entry.getKey().toString(), + entry -> entry.getValue().getName(), + (e1, e2) -> e1, LinkedHashMap::new)); + } +} diff --git a/src/main/java/chess/domain/board/BoardInitializer.java b/src/main/java/chess/domain/board/BoardInitializer.java new file mode 100644 index 00000000000..976240c07a3 --- /dev/null +++ b/src/main/java/chess/domain/board/BoardInitializer.java @@ -0,0 +1,32 @@ +package chess.domain.board; + +import chess.domain.initialize.*; +import chess.domain.piece.PieceType; +import chess.domain.position.Position; + +import java.util.*; + +public class BoardInitializer { + private static final List INITIALIZER; + + static { + INITIALIZER = new ArrayList<>(Arrays.asList( + new KingInitializer(), + new QueenInitializer(), + new RookInitializer(), + new KnightInitializer(), + new BishopInitializer(), + new PawnInitializer() + )); + } + + public static Map initializeAll() { + Map board = new HashMap<>(); + + for (InitializeStrategy strategy : INITIALIZER) { + board.putAll(strategy.initialize()); + } + + return board; + } +} diff --git a/src/main/java/chess/domain/initialize/BishopInitializer.java b/src/main/java/chess/domain/initialize/BishopInitializer.java new file mode 100644 index 00000000000..43dfa72531b --- /dev/null +++ b/src/main/java/chess/domain/initialize/BishopInitializer.java @@ -0,0 +1,19 @@ +package chess.domain.initialize; + +import chess.domain.piece.PieceType; +import chess.domain.position.Position; + +import java.util.*; + +public final class BishopInitializer implements InitializeStrategy { + @Override + public Map initialize() { + Map piece = new HashMap<>(); + piece.put(Position.of("c8"), PieceType.BISHOP); + piece.put(Position.of("c1"), PieceType.BISHOP); + piece.put(Position.of("f8"), PieceType.BISHOP); + piece.put(Position.of("f1"), PieceType.BISHOP); + + return Collections.unmodifiableMap(piece); + } +} \ No newline at end of file diff --git a/src/main/java/chess/domain/initialize/InitializeStrategy.java b/src/main/java/chess/domain/initialize/InitializeStrategy.java new file mode 100644 index 00000000000..038e1d2abe4 --- /dev/null +++ b/src/main/java/chess/domain/initialize/InitializeStrategy.java @@ -0,0 +1,10 @@ +package chess.domain.initialize; + +import chess.domain.piece.PieceType; +import chess.domain.position.Position; + +import java.util.Map; + +public interface InitializeStrategy { + Map initialize(); +} diff --git a/src/main/java/chess/domain/initialize/KingInitializer.java b/src/main/java/chess/domain/initialize/KingInitializer.java new file mode 100644 index 00000000000..c19217f1ba1 --- /dev/null +++ b/src/main/java/chess/domain/initialize/KingInitializer.java @@ -0,0 +1,17 @@ +package chess.domain.initialize; + +import chess.domain.piece.PieceType; +import chess.domain.position.Position; + +import java.util.*; + +public final class KingInitializer implements InitializeStrategy { + @Override + public Map initialize() { + Map piece = new HashMap<>(); + piece.put(Position.of("e8"), PieceType.KING); + piece.put(Position.of("e1"), PieceType.KING); + + return Collections.unmodifiableMap(piece); + } +} diff --git a/src/main/java/chess/domain/initialize/KnightInitializer.java b/src/main/java/chess/domain/initialize/KnightInitializer.java new file mode 100644 index 00000000000..bdbd3521439 --- /dev/null +++ b/src/main/java/chess/domain/initialize/KnightInitializer.java @@ -0,0 +1,19 @@ +package chess.domain.initialize; + +import chess.domain.piece.PieceType; +import chess.domain.position.Position; + +import java.util.*; + +public final class KnightInitializer implements InitializeStrategy { + @Override + public Map initialize() { + Map piece = new HashMap<>(); + piece.put(Position.of("b8"), PieceType.KNIGHT); + piece.put(Position.of("b1"), PieceType.KNIGHT); + piece.put(Position.of("g8"), PieceType.KNIGHT); + piece.put(Position.of("g1"), PieceType.KNIGHT); + + return Collections.unmodifiableMap(piece); + } +} \ No newline at end of file diff --git a/src/main/java/chess/domain/initialize/PawnInitializer.java b/src/main/java/chess/domain/initialize/PawnInitializer.java new file mode 100644 index 00000000000..1147aa8b3e7 --- /dev/null +++ b/src/main/java/chess/domain/initialize/PawnInitializer.java @@ -0,0 +1,31 @@ +package chess.domain.initialize; + +import chess.domain.piece.PieceType; +import chess.domain.position.Position; + +import java.util.*; + +public final class PawnInitializer implements InitializeStrategy { + @Override + public Map initialize() { + Map piece = new HashMap<>(); + piece.put(Position.of("a7"), PieceType.PAWN); + piece.put(Position.of("b7"), PieceType.PAWN); + piece.put(Position.of("c7"), PieceType.PAWN); + piece.put(Position.of("d7"), PieceType.PAWN); + piece.put(Position.of("e7"), PieceType.PAWN); + piece.put(Position.of("f7"), PieceType.PAWN); + piece.put(Position.of("g7"), PieceType.PAWN); + piece.put(Position.of("h7"), PieceType.PAWN); + piece.put(Position.of("a2"), PieceType.PAWN); + piece.put(Position.of("b2"), PieceType.PAWN); + piece.put(Position.of("c2"), PieceType.PAWN); + piece.put(Position.of("d2"), PieceType.PAWN); + piece.put(Position.of("e2"), PieceType.PAWN); + piece.put(Position.of("f2"), PieceType.PAWN); + piece.put(Position.of("g2"), PieceType.PAWN); + piece.put(Position.of("h2"), PieceType.PAWN); + + return Collections.unmodifiableMap(piece); + } +} diff --git a/src/main/java/chess/domain/initialize/QueenInitializer.java b/src/main/java/chess/domain/initialize/QueenInitializer.java new file mode 100644 index 00000000000..f19f1064278 --- /dev/null +++ b/src/main/java/chess/domain/initialize/QueenInitializer.java @@ -0,0 +1,17 @@ +package chess.domain.initialize; + +import chess.domain.piece.PieceType; +import chess.domain.position.Position; + +import java.util.*; + +public final class QueenInitializer implements InitializeStrategy { + @Override + public Map initialize() { + Map piece = new HashMap<>(); + piece.put(Position.of("d8"), PieceType.QUEEN); + piece.put(Position.of("d1"), PieceType.QUEEN); + + return Collections.unmodifiableMap(piece); + } +} \ No newline at end of file diff --git a/src/main/java/chess/domain/initialize/RookInitializer.java b/src/main/java/chess/domain/initialize/RookInitializer.java new file mode 100644 index 00000000000..5be7f5240b0 --- /dev/null +++ b/src/main/java/chess/domain/initialize/RookInitializer.java @@ -0,0 +1,19 @@ +package chess.domain.initialize; + +import chess.domain.piece.PieceType; +import chess.domain.position.Position; + +import java.util.*; + +public final class RookInitializer implements InitializeStrategy { + @Override + public Map initialize() { + Map piece = new HashMap<>(); + piece.put(Position.of("a8"), PieceType.ROOK); + piece.put(Position.of("a1"), PieceType.ROOK); + piece.put(Position.of("h8"), PieceType.ROOK); + piece.put(Position.of("h1"), PieceType.ROOK); + + return Collections.unmodifiableMap(piece); + } +} \ No newline at end of file diff --git a/src/main/java/chess/domain/piece/PieceType.java b/src/main/java/chess/domain/piece/PieceType.java new file mode 100644 index 00000000000..5186eec729d --- /dev/null +++ b/src/main/java/chess/domain/piece/PieceType.java @@ -0,0 +1,22 @@ +package chess.domain.piece; + +public enum PieceType { + KING("k", 0), + QUEEN("q", 9), + ROOK("r", 5), + BISHOP("b", 3), + KNIGHT("n", 2.5), + PAWN("p", 1); + + private String name; + private double score; + + PieceType(String name, double score) { + this.name = name; + this.score = score; + } + + public String getName() { + return name; + } +} diff --git a/src/main/java/chess/File.java b/src/main/java/chess/domain/position/File.java similarity index 50% rename from src/main/java/chess/File.java rename to src/main/java/chess/domain/position/File.java index a8460811fe2..81ff817ee66 100644 --- a/src/main/java/chess/File.java +++ b/src/main/java/chess/domain/position/File.java @@ -1,13 +1,26 @@ -package chess; +package chess.domain.position; import java.util.Arrays; public enum File { - A, B, C, D, E, F, G, H; + A("a"), + B("b"), + C("c"), + D("d"), + E("e"), + F("f"), + G("g"), + H("h"); + + private String name; + + File(String name) { + this.name = name; + } public static File of(String file) { return Arrays.stream(values()) - .filter(ph -> ph.name().equals(file.toUpperCase())) + .filter(ph -> ph.name.equals(file.toLowerCase())) .findFirst() .orElseThrow(() -> new IllegalArgumentException("잘못된 x 좌표값을 입력하였습니다.")); } diff --git a/src/main/java/chess/Position.java b/src/main/java/chess/domain/position/Position.java similarity index 70% rename from src/main/java/chess/Position.java rename to src/main/java/chess/domain/position/Position.java index 75e0c5505b8..292ef06fed4 100644 --- a/src/main/java/chess/Position.java +++ b/src/main/java/chess/domain/position/Position.java @@ -1,7 +1,8 @@ -package chess; +package chess.domain.position; import java.util.ArrayList; import java.util.List; +import java.util.stream.Collectors; public class Position { private static List positions; @@ -16,13 +17,13 @@ private Position(File file, Rank rank) { static { positions = new ArrayList<>(); - for (File file : File.values()) { - addPosition(file); + for (Rank rank : Rank.values()) { + addPosition(rank); } } - private static void addPosition(File file) { - for (Rank rank : Rank.values()) { + private static void addPosition(Rank rank) { + for (File file : File.values()) { positions.add(new Position(file, rank)); } } @@ -40,4 +41,15 @@ private static Position findPosition(File file, Rank rank) { .findFirst() .orElseThrow(AssertionError::new); } + + public static List getPositions() { + return positions.stream() + .map(Position::toString) + .collect(Collectors.toList()); + } + + @Override + public String toString() { + return file.name() + rank.name(); + } } diff --git a/src/main/java/chess/Rank.java b/src/main/java/chess/domain/position/Rank.java similarity index 94% rename from src/main/java/chess/Rank.java rename to src/main/java/chess/domain/position/Rank.java index 399c99c6938..7b56f82e412 100644 --- a/src/main/java/chess/Rank.java +++ b/src/main/java/chess/domain/position/Rank.java @@ -1,4 +1,4 @@ -package chess; +package chess.domain.position; import java.util.Arrays; diff --git a/src/main/java/chess/view/ConsoleOutputView.java b/src/main/java/chess/view/ConsoleOutputView.java new file mode 100644 index 00000000000..9ed1c865145 --- /dev/null +++ b/src/main/java/chess/view/ConsoleOutputView.java @@ -0,0 +1,24 @@ +package chess.view; + +import java.util.List; +import java.util.Map; + +public class ConsoleOutputView implements OutputView { + @Override + public void printBoard(List positions, Map board) { + for (int i = 1; i <= positions.size(); i++) { + String piece = board.get(positions.get(i - 1)); + System.out.print(printPiece(piece)); + if (i % 8 == 0) { + System.out.println(); + } + } + } + + private String printPiece(String piece) { + if (piece == null) { + return "."; + } + return piece; + } +} diff --git a/src/main/java/chess/view/OutputView.java b/src/main/java/chess/view/OutputView.java new file mode 100644 index 00000000000..578a232713f --- /dev/null +++ b/src/main/java/chess/view/OutputView.java @@ -0,0 +1,8 @@ +package chess.view; + +import java.util.List; +import java.util.Map; + +public interface OutputView { + void printBoard(List positions, Map board); +} diff --git a/src/test/java/chess/FileTest.java b/src/test/java/chess/domain/position/FileTest.java similarity index 92% rename from src/test/java/chess/FileTest.java rename to src/test/java/chess/domain/position/FileTest.java index 2b8c66c2929..d5892185db6 100644 --- a/src/test/java/chess/FileTest.java +++ b/src/test/java/chess/domain/position/FileTest.java @@ -1,4 +1,4 @@ -package chess; +package chess.domain.position; import org.assertj.core.api.Assertions; import org.junit.jupiter.api.DisplayName; diff --git a/src/test/java/chess/PositionTest.java b/src/test/java/chess/domain/position/PositionTest.java similarity index 92% rename from src/test/java/chess/PositionTest.java rename to src/test/java/chess/domain/position/PositionTest.java index 369d0f94814..890c88097cf 100644 --- a/src/test/java/chess/PositionTest.java +++ b/src/test/java/chess/domain/position/PositionTest.java @@ -1,4 +1,4 @@ -package chess; +package chess.domain.position; import org.assertj.core.api.Assertions; import org.junit.jupiter.api.DisplayName; diff --git a/src/test/java/chess/RankTest.java b/src/test/java/chess/domain/position/RankTest.java similarity index 92% rename from src/test/java/chess/RankTest.java rename to src/test/java/chess/domain/position/RankTest.java index 3a6933b9a59..485e04d7753 100644 --- a/src/test/java/chess/RankTest.java +++ b/src/test/java/chess/domain/position/RankTest.java @@ -1,4 +1,4 @@ -package chess; +package chess.domain.position; import org.assertj.core.api.Assertions; import org.junit.jupiter.api.DisplayName; From 9d82c7269ce1d19ef3f2da5b8ca349d5be8183e3 Mon Sep 17 00:00:00 2001 From: giantim Date: Wed, 25 Mar 2020 15:06:14 +0900 Subject: [PATCH 05/75] =?UTF-8?q?feat:=20=EC=B2=B4=EC=8A=A4=20=EA=B2=8C?= =?UTF-8?q?=EC=9E=84=EC=9D=84=20=EC=8B=9C=EC=9E=91=ED=95=98=EB=8A=94=20?= =?UTF-8?q?=EB=AA=85=EB=A0=B9=EC=96=B4=20=EC=9E=85=EB=A0=A5=20refactor:=20?= =?UTF-8?q?final=20=ED=82=A4=EC=9B=8C=EB=93=9C=20=EC=B6=94=EA=B0=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/main/java/chess/controller/BoardDto.java | 16 ------- .../chess/controller/ChessController.java | 15 ++++++- .../java/chess/controller/dto/BoardDto.java | 16 +++++++ .../controller/{ => dto}/PositionDto.java | 8 ++-- src/main/java/chess/domain/board/Board.java | 13 +++--- .../chess/domain/board/BoardInitializer.java | 8 ++-- .../domain/initialize/BishopInitializer.java | 20 +++++---- .../domain/initialize/InitializeStrategy.java | 4 +- .../domain/initialize/KingInitializer.java | 16 ++++--- .../domain/initialize/KnightInitializer.java | 20 +++++---- .../domain/initialize/PawnInitializer.java | 45 ++++++++++--------- .../domain/initialize/QueenInitializer.java | 16 ++++--- .../domain/initialize/RookInitializer.java | 20 +++++---- src/main/java/chess/domain/piece/Piece.java | 15 +++++++ .../java/chess/domain/piece/PieceType.java | 12 ++--- src/main/java/chess/domain/piece/Team.java | 18 ++++++++ src/main/java/chess/domain/position/File.java | 2 +- .../java/chess/domain/position/Position.java | 8 ++-- src/main/java/chess/domain/position/Rank.java | 2 +- .../java/chess/view/ConsoleInputView.java | 36 +++++++++++++++ .../java/chess/view/ConsoleOutputView.java | 17 ++++--- src/main/java/chess/view/InputView.java | 5 +++ 22 files changed, 226 insertions(+), 106 deletions(-) delete mode 100644 src/main/java/chess/controller/BoardDto.java create mode 100644 src/main/java/chess/controller/dto/BoardDto.java rename src/main/java/chess/controller/{ => dto}/PositionDto.java (52%) create mode 100644 src/main/java/chess/domain/piece/Piece.java create mode 100644 src/main/java/chess/domain/piece/Team.java create mode 100644 src/main/java/chess/view/ConsoleInputView.java create mode 100644 src/main/java/chess/view/InputView.java diff --git a/src/main/java/chess/controller/BoardDto.java b/src/main/java/chess/controller/BoardDto.java deleted file mode 100644 index e8b0aa88b43..00000000000 --- a/src/main/java/chess/controller/BoardDto.java +++ /dev/null @@ -1,16 +0,0 @@ -package chess.controller; - -import java.util.Map; - -public class BoardDto { - - private Map board; - - public BoardDto(Map board) { - this.board = board; - } - - public Map get() { - return board; - } -} diff --git a/src/main/java/chess/controller/ChessController.java b/src/main/java/chess/controller/ChessController.java index 4dd09542914..d75a0b61b39 100644 --- a/src/main/java/chess/controller/ChessController.java +++ b/src/main/java/chess/controller/ChessController.java @@ -1,16 +1,27 @@ package chess.controller; +import chess.controller.dto.BoardDto; +import chess.controller.dto.PositionDto; import chess.domain.board.Board; import chess.domain.position.Position; +import chess.view.ConsoleInputView; import chess.view.ConsoleOutputView; +import chess.view.InputView; import chess.view.OutputView; public class ChessController { + private static InputView inputView = new ConsoleInputView(); private static OutputView outputView = new ConsoleOutputView(); public static void run() { - Board board = new Board(); - BoardDto boardDto = new BoardDto(board.get()); + if (inputView.askChessRun()) { + Board board = new Board(); + printInitialize(board); + } + } + + private static void printInitialize(Board board) { + BoardDto boardDto = new BoardDto(board.parse()); PositionDto positionDto = new PositionDto(Position.getPositions()); outputView.printBoard(positionDto.getPositions(), boardDto.get()); } diff --git a/src/main/java/chess/controller/dto/BoardDto.java b/src/main/java/chess/controller/dto/BoardDto.java new file mode 100644 index 00000000000..cbc17ea78b5 --- /dev/null +++ b/src/main/java/chess/controller/dto/BoardDto.java @@ -0,0 +1,16 @@ +package chess.controller.dto; + +import java.util.Collections; +import java.util.Map; + +public class BoardDto { + private final Map board; + + public BoardDto(final Map board) { + this.board = board; + } + + public Map get() { + return Collections.unmodifiableMap(this.board); + } +} diff --git a/src/main/java/chess/controller/PositionDto.java b/src/main/java/chess/controller/dto/PositionDto.java similarity index 52% rename from src/main/java/chess/controller/PositionDto.java rename to src/main/java/chess/controller/dto/PositionDto.java index 8af6b20c9a3..db5875990fe 100644 --- a/src/main/java/chess/controller/PositionDto.java +++ b/src/main/java/chess/controller/dto/PositionDto.java @@ -1,16 +1,16 @@ -package chess.controller; +package chess.controller.dto; +import java.util.Collections; import java.util.List; public class PositionDto { - private final List positions; - public PositionDto(List positions) { + public PositionDto(final List positions) { this.positions = positions; } public List getPositions() { - return positions; + return Collections.unmodifiableList(positions); } } diff --git a/src/main/java/chess/domain/board/Board.java b/src/main/java/chess/domain/board/Board.java index b49da019fdd..df7d71e2bf1 100644 --- a/src/main/java/chess/domain/board/Board.java +++ b/src/main/java/chess/domain/board/Board.java @@ -1,25 +1,26 @@ package chess.domain.board; -import chess.domain.piece.PieceType; +import chess.domain.piece.Piece; import chess.domain.position.Position; -import java.util.HashMap; +import java.util.Collections; import java.util.LinkedHashMap; import java.util.Map; import java.util.stream.Collectors; public class Board { - private Map board; + private final Map board; public Board() { this.board = BoardInitializer.initializeAll(); } - public Map get() { - return board.entrySet() + public Map parse() { + Map parseResult = board.entrySet() .stream() .collect(Collectors.toMap(entry -> entry.getKey().toString(), - entry -> entry.getValue().getName(), + entry -> entry.getValue().toSymbol(), (e1, e2) -> e1, LinkedHashMap::new)); + return Collections.unmodifiableMap(parseResult); } } diff --git a/src/main/java/chess/domain/board/BoardInitializer.java b/src/main/java/chess/domain/board/BoardInitializer.java index 976240c07a3..573184ac6fd 100644 --- a/src/main/java/chess/domain/board/BoardInitializer.java +++ b/src/main/java/chess/domain/board/BoardInitializer.java @@ -1,7 +1,7 @@ package chess.domain.board; import chess.domain.initialize.*; -import chess.domain.piece.PieceType; +import chess.domain.piece.Piece; import chess.domain.position.Position; import java.util.*; @@ -20,13 +20,13 @@ public class BoardInitializer { )); } - public static Map initializeAll() { - Map board = new HashMap<>(); + public static Map initializeAll() { + Map board = new HashMap<>(); for (InitializeStrategy strategy : INITIALIZER) { board.putAll(strategy.initialize()); } - return board; + return Collections.unmodifiableMap(board); } } diff --git a/src/main/java/chess/domain/initialize/BishopInitializer.java b/src/main/java/chess/domain/initialize/BishopInitializer.java index 43dfa72531b..da628c0905d 100644 --- a/src/main/java/chess/domain/initialize/BishopInitializer.java +++ b/src/main/java/chess/domain/initialize/BishopInitializer.java @@ -1,19 +1,23 @@ package chess.domain.initialize; +import chess.domain.piece.Piece; import chess.domain.piece.PieceType; +import chess.domain.piece.Team; import chess.domain.position.Position; -import java.util.*; +import java.util.Collections; +import java.util.HashMap; +import java.util.Map; public final class BishopInitializer implements InitializeStrategy { @Override - public Map initialize() { - Map piece = new HashMap<>(); - piece.put(Position.of("c8"), PieceType.BISHOP); - piece.put(Position.of("c1"), PieceType.BISHOP); - piece.put(Position.of("f8"), PieceType.BISHOP); - piece.put(Position.of("f1"), PieceType.BISHOP); + public Map initialize() { + Map pieces = new HashMap<>(); + pieces.put(Position.of("c8"), new Piece(PieceType.BISHOP, Team.BLACK)); + pieces.put(Position.of("c1"), new Piece(PieceType.BISHOP, Team.WHITE)); + pieces.put(Position.of("f8"), new Piece(PieceType.BISHOP, Team.BLACK)); + pieces.put(Position.of("f1"), new Piece(PieceType.BISHOP, Team.WHITE)); - return Collections.unmodifiableMap(piece); + return Collections.unmodifiableMap(pieces); } } \ No newline at end of file diff --git a/src/main/java/chess/domain/initialize/InitializeStrategy.java b/src/main/java/chess/domain/initialize/InitializeStrategy.java index 038e1d2abe4..47fc1403522 100644 --- a/src/main/java/chess/domain/initialize/InitializeStrategy.java +++ b/src/main/java/chess/domain/initialize/InitializeStrategy.java @@ -1,10 +1,10 @@ package chess.domain.initialize; -import chess.domain.piece.PieceType; +import chess.domain.piece.Piece; import chess.domain.position.Position; import java.util.Map; public interface InitializeStrategy { - Map initialize(); + Map initialize(); } diff --git a/src/main/java/chess/domain/initialize/KingInitializer.java b/src/main/java/chess/domain/initialize/KingInitializer.java index c19217f1ba1..9ce672ddc12 100644 --- a/src/main/java/chess/domain/initialize/KingInitializer.java +++ b/src/main/java/chess/domain/initialize/KingInitializer.java @@ -1,17 +1,21 @@ package chess.domain.initialize; +import chess.domain.piece.Piece; import chess.domain.piece.PieceType; +import chess.domain.piece.Team; import chess.domain.position.Position; -import java.util.*; +import java.util.Collections; +import java.util.HashMap; +import java.util.Map; public final class KingInitializer implements InitializeStrategy { @Override - public Map initialize() { - Map piece = new HashMap<>(); - piece.put(Position.of("e8"), PieceType.KING); - piece.put(Position.of("e1"), PieceType.KING); + public Map initialize() { + Map pieces = new HashMap<>(); + pieces.put(Position.of("e8"), new Piece(PieceType.KING, Team.BLACK)); + pieces.put(Position.of("e1"), new Piece(PieceType.KING, Team.WHITE)); - return Collections.unmodifiableMap(piece); + return Collections.unmodifiableMap(pieces); } } diff --git a/src/main/java/chess/domain/initialize/KnightInitializer.java b/src/main/java/chess/domain/initialize/KnightInitializer.java index bdbd3521439..a8f3edfd4fb 100644 --- a/src/main/java/chess/domain/initialize/KnightInitializer.java +++ b/src/main/java/chess/domain/initialize/KnightInitializer.java @@ -1,19 +1,23 @@ package chess.domain.initialize; +import chess.domain.piece.Piece; import chess.domain.piece.PieceType; +import chess.domain.piece.Team; import chess.domain.position.Position; -import java.util.*; +import java.util.Collections; +import java.util.HashMap; +import java.util.Map; public final class KnightInitializer implements InitializeStrategy { @Override - public Map initialize() { - Map piece = new HashMap<>(); - piece.put(Position.of("b8"), PieceType.KNIGHT); - piece.put(Position.of("b1"), PieceType.KNIGHT); - piece.put(Position.of("g8"), PieceType.KNIGHT); - piece.put(Position.of("g1"), PieceType.KNIGHT); + public Map initialize() { + Map pieces = new HashMap<>(); + pieces.put(Position.of("b8"), new Piece(PieceType.KNIGHT, Team.BLACK)); + pieces.put(Position.of("b1"), new Piece(PieceType.KNIGHT, Team.WHITE)); + pieces.put(Position.of("g8"), new Piece(PieceType.KNIGHT, Team.BLACK)); + pieces.put(Position.of("g1"), new Piece(PieceType.KNIGHT, Team.WHITE)); - return Collections.unmodifiableMap(piece); + return Collections.unmodifiableMap(pieces); } } \ No newline at end of file diff --git a/src/main/java/chess/domain/initialize/PawnInitializer.java b/src/main/java/chess/domain/initialize/PawnInitializer.java index 1147aa8b3e7..ced1279ba67 100644 --- a/src/main/java/chess/domain/initialize/PawnInitializer.java +++ b/src/main/java/chess/domain/initialize/PawnInitializer.java @@ -1,31 +1,36 @@ package chess.domain.initialize; +import chess.domain.piece.Piece; import chess.domain.piece.PieceType; +import chess.domain.piece.Team; import chess.domain.position.Position; -import java.util.*; +import java.util.Collections; +import java.util.HashMap; +import java.util.Map; public final class PawnInitializer implements InitializeStrategy { @Override - public Map initialize() { - Map piece = new HashMap<>(); - piece.put(Position.of("a7"), PieceType.PAWN); - piece.put(Position.of("b7"), PieceType.PAWN); - piece.put(Position.of("c7"), PieceType.PAWN); - piece.put(Position.of("d7"), PieceType.PAWN); - piece.put(Position.of("e7"), PieceType.PAWN); - piece.put(Position.of("f7"), PieceType.PAWN); - piece.put(Position.of("g7"), PieceType.PAWN); - piece.put(Position.of("h7"), PieceType.PAWN); - piece.put(Position.of("a2"), PieceType.PAWN); - piece.put(Position.of("b2"), PieceType.PAWN); - piece.put(Position.of("c2"), PieceType.PAWN); - piece.put(Position.of("d2"), PieceType.PAWN); - piece.put(Position.of("e2"), PieceType.PAWN); - piece.put(Position.of("f2"), PieceType.PAWN); - piece.put(Position.of("g2"), PieceType.PAWN); - piece.put(Position.of("h2"), PieceType.PAWN); + public Map initialize() { + Map pieces = new HashMap<>(); + pieces.put(Position.of("a7"), new Piece(PieceType.PAWN, Team.BLACK)); + pieces.put(Position.of("b7"), new Piece(PieceType.PAWN, Team.BLACK)); + pieces.put(Position.of("c7"), new Piece(PieceType.PAWN, Team.BLACK)); + pieces.put(Position.of("d7"), new Piece(PieceType.PAWN, Team.BLACK)); + pieces.put(Position.of("e7"), new Piece(PieceType.PAWN, Team.BLACK)); + pieces.put(Position.of("f7"), new Piece(PieceType.PAWN, Team.BLACK)); + pieces.put(Position.of("g7"), new Piece(PieceType.PAWN, Team.BLACK)); + pieces.put(Position.of("h7"), new Piece(PieceType.PAWN, Team.BLACK)); - return Collections.unmodifiableMap(piece); + pieces.put(Position.of("a2"), new Piece(PieceType.PAWN, Team.WHITE)); + pieces.put(Position.of("b2"), new Piece(PieceType.PAWN, Team.WHITE)); + pieces.put(Position.of("c2"), new Piece(PieceType.PAWN, Team.WHITE)); + pieces.put(Position.of("d2"), new Piece(PieceType.PAWN, Team.WHITE)); + pieces.put(Position.of("e2"), new Piece(PieceType.PAWN, Team.WHITE)); + pieces.put(Position.of("f2"), new Piece(PieceType.PAWN, Team.WHITE)); + pieces.put(Position.of("g2"), new Piece(PieceType.PAWN, Team.WHITE)); + pieces.put(Position.of("h2"), new Piece(PieceType.PAWN, Team.WHITE)); + + return Collections.unmodifiableMap(pieces); } } diff --git a/src/main/java/chess/domain/initialize/QueenInitializer.java b/src/main/java/chess/domain/initialize/QueenInitializer.java index f19f1064278..507f401250c 100644 --- a/src/main/java/chess/domain/initialize/QueenInitializer.java +++ b/src/main/java/chess/domain/initialize/QueenInitializer.java @@ -1,17 +1,21 @@ package chess.domain.initialize; +import chess.domain.piece.Piece; import chess.domain.piece.PieceType; +import chess.domain.piece.Team; import chess.domain.position.Position; -import java.util.*; +import java.util.Collections; +import java.util.HashMap; +import java.util.Map; public final class QueenInitializer implements InitializeStrategy { @Override - public Map initialize() { - Map piece = new HashMap<>(); - piece.put(Position.of("d8"), PieceType.QUEEN); - piece.put(Position.of("d1"), PieceType.QUEEN); + public Map initialize() { + Map pieces = new HashMap<>(); + pieces.put(Position.of("d8"), new Piece(PieceType.QUEEN, Team.BLACK)); + pieces.put(Position.of("d1"), new Piece(PieceType.QUEEN, Team.WHITE)); - return Collections.unmodifiableMap(piece); + return Collections.unmodifiableMap(pieces); } } \ No newline at end of file diff --git a/src/main/java/chess/domain/initialize/RookInitializer.java b/src/main/java/chess/domain/initialize/RookInitializer.java index 5be7f5240b0..47fd77a442e 100644 --- a/src/main/java/chess/domain/initialize/RookInitializer.java +++ b/src/main/java/chess/domain/initialize/RookInitializer.java @@ -1,19 +1,23 @@ package chess.domain.initialize; +import chess.domain.piece.Piece; import chess.domain.piece.PieceType; +import chess.domain.piece.Team; import chess.domain.position.Position; -import java.util.*; +import java.util.Collections; +import java.util.HashMap; +import java.util.Map; public final class RookInitializer implements InitializeStrategy { @Override - public Map initialize() { - Map piece = new HashMap<>(); - piece.put(Position.of("a8"), PieceType.ROOK); - piece.put(Position.of("a1"), PieceType.ROOK); - piece.put(Position.of("h8"), PieceType.ROOK); - piece.put(Position.of("h1"), PieceType.ROOK); + public Map initialize() { + Map pieces = new HashMap<>(); + pieces.put(Position.of("a8"), new Piece(PieceType.ROOK, Team.BLACK)); + pieces.put(Position.of("a1"), new Piece(PieceType.ROOK, Team.WHITE)); + pieces.put(Position.of("h8"), new Piece(PieceType.ROOK, Team.BLACK)); + pieces.put(Position.of("h1"), new Piece(PieceType.ROOK, Team.WHITE)); - return Collections.unmodifiableMap(piece); + return Collections.unmodifiableMap(pieces); } } \ No newline at end of file diff --git a/src/main/java/chess/domain/piece/Piece.java b/src/main/java/chess/domain/piece/Piece.java new file mode 100644 index 00000000000..68b661d453e --- /dev/null +++ b/src/main/java/chess/domain/piece/Piece.java @@ -0,0 +1,15 @@ +package chess.domain.piece; + +public class Piece { + private final PieceType pieceType; + private final Team team; + + public Piece(final PieceType pieceType, final Team team) { + this.pieceType = pieceType; + this.team = team; + } + + public String toSymbol() { + return this.team.convert(this.pieceType.getSymbol()); + } +} diff --git a/src/main/java/chess/domain/piece/PieceType.java b/src/main/java/chess/domain/piece/PieceType.java index 5186eec729d..cfe6e8a92cb 100644 --- a/src/main/java/chess/domain/piece/PieceType.java +++ b/src/main/java/chess/domain/piece/PieceType.java @@ -8,15 +8,15 @@ public enum PieceType { KNIGHT("n", 2.5), PAWN("p", 1); - private String name; - private double score; + private final String symbol; + private final double score; - PieceType(String name, double score) { - this.name = name; + PieceType(String symbol, double score) { + this.symbol = symbol; this.score = score; } - public String getName() { - return name; + public String getSymbol() { + return symbol; } } diff --git a/src/main/java/chess/domain/piece/Team.java b/src/main/java/chess/domain/piece/Team.java new file mode 100644 index 00000000000..ec97b6aa539 --- /dev/null +++ b/src/main/java/chess/domain/piece/Team.java @@ -0,0 +1,18 @@ +package chess.domain.piece; + +import java.util.function.Function; + +public enum Team { + BLACK(String::toUpperCase), + WHITE(String::toLowerCase); + + private final Function expression; + + Team(Function expression) { + this.expression = expression; + } + + public String convert(final String name) { + return this.expression.apply(name); + } +} diff --git a/src/main/java/chess/domain/position/File.java b/src/main/java/chess/domain/position/File.java index 81ff817ee66..d4212488217 100644 --- a/src/main/java/chess/domain/position/File.java +++ b/src/main/java/chess/domain/position/File.java @@ -12,7 +12,7 @@ public enum File { G("g"), H("h"); - private String name; + private final String name; File(String name) { this.name = name; diff --git a/src/main/java/chess/domain/position/Position.java b/src/main/java/chess/domain/position/Position.java index 292ef06fed4..0f51e44f09e 100644 --- a/src/main/java/chess/domain/position/Position.java +++ b/src/main/java/chess/domain/position/Position.java @@ -1,6 +1,7 @@ package chess.domain.position; import java.util.ArrayList; +import java.util.Collections; import java.util.List; import java.util.stream.Collectors; @@ -10,7 +11,7 @@ public class Position { private final File file; private final Rank rank; - private Position(File file, Rank rank) { + private Position(final File file, final Rank rank) { this.file = file; this.rank = rank; } @@ -28,7 +29,7 @@ private static void addPosition(Rank rank) { } } - public static Position of(String position) { + public static Position of(final String position) { File file = File.of(position.substring(0, 1)); Rank rank = Rank.of(position.substring(1, 2)); @@ -43,9 +44,10 @@ private static Position findPosition(File file, Rank rank) { } public static List getPositions() { - return positions.stream() + List parseResult = positions.stream() .map(Position::toString) .collect(Collectors.toList()); + return Collections.unmodifiableList(parseResult); } @Override diff --git a/src/main/java/chess/domain/position/Rank.java b/src/main/java/chess/domain/position/Rank.java index 7b56f82e412..6d0c3c582eb 100644 --- a/src/main/java/chess/domain/position/Rank.java +++ b/src/main/java/chess/domain/position/Rank.java @@ -12,7 +12,7 @@ public enum Rank { TWO(2), ONE(1); - private int rank; + private final int rank; Rank(int rank) { this.rank = rank; diff --git a/src/main/java/chess/view/ConsoleInputView.java b/src/main/java/chess/view/ConsoleInputView.java new file mode 100644 index 00000000000..3daac277af9 --- /dev/null +++ b/src/main/java/chess/view/ConsoleInputView.java @@ -0,0 +1,36 @@ +package chess.view; + +import java.util.Scanner; + +public class ConsoleInputView implements InputView { + private static final Scanner SCANNER = new Scanner(System.in); + private static final String START_COMMAND = "start"; + private static final String END_COMMAND = "end"; + + @Override + public boolean askChessRun() { + try { + System.out.println("체스 게임을 시작합니다."); + System.out.println("게임 시작은 start, 종료는 end 명령어를 입력하세요."); + String input = SCANNER.nextLine(); + validateCommand(input); + return runFlag(input); + } catch (IllegalArgumentException e) { + System.out.println(e.getMessage()); + return askChessRun(); + } + } + + private void validateCommand(String input) { + if (!input.equals(START_COMMAND) && !input.equals(END_COMMAND)) { + throw new IllegalArgumentException("start 또는 end 를 입력해주세요."); + } + } + + private boolean runFlag(String input) { + if (input.equals(START_COMMAND)) { + return true; + } + return false; + } +} diff --git a/src/main/java/chess/view/ConsoleOutputView.java b/src/main/java/chess/view/ConsoleOutputView.java index 9ed1c865145..d9208378aae 100644 --- a/src/main/java/chess/view/ConsoleOutputView.java +++ b/src/main/java/chess/view/ConsoleOutputView.java @@ -4,20 +4,27 @@ import java.util.Map; public class ConsoleOutputView implements OutputView { + private static final String EMPTY_SQUARE = "."; + private static final int MAX_BOARD_SIZE = 8; + @Override - public void printBoard(List positions, Map board) { + public void printBoard(final List positions, final Map board) { for (int i = 1; i <= positions.size(); i++) { String piece = board.get(positions.get(i - 1)); System.out.print(printPiece(piece)); - if (i % 8 == 0) { - System.out.println(); - } + checkNewLine(i); + } + } + + private void checkNewLine(final int i) { + if (i % MAX_BOARD_SIZE == 0) { + System.out.println(); } } private String printPiece(String piece) { if (piece == null) { - return "."; + return EMPTY_SQUARE; } return piece; } diff --git a/src/main/java/chess/view/InputView.java b/src/main/java/chess/view/InputView.java new file mode 100644 index 00000000000..9581c3801f1 --- /dev/null +++ b/src/main/java/chess/view/InputView.java @@ -0,0 +1,5 @@ +package chess.view; + +public interface InputView { + boolean askChessRun(); +} From 3dcf3f958311282188df05e32fdbac3f09a224b9 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=EA=B9=80=EC=98=88=EB=B9=88?= Date: Wed, 25 Mar 2020 19:25:08 +0900 Subject: [PATCH 06/75] =?UTF-8?q?feat:=20=EC=9D=B4=EB=8F=99=20=EC=A0=84?= =?UTF-8?q?=EB=9E=B5=20=EA=B5=AC=ED=98=84?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../chess/domain/move/BishopMoveStrategy.java | 18 +++++++++++++ .../chess/domain/move/KingMoveStrategy.java | 18 +++++++++++++ .../chess/domain/move/KnightMoveStrategy.java | 17 +++++++++++++ .../java/chess/domain/move/MoveStrategy.java | 13 ++++++++++ .../chess/domain/move/PawnMoveStrategy.java | 18 +++++++++++++ .../chess/domain/move/QueenMoveStrategy.java | 12 +++++++++ .../chess/domain/move/RookMoveStrategy.java | 17 +++++++++++++ .../java/chess/domain/piece/PieceType.java | 20 +++++++++------ src/main/java/chess/domain/position/File.java | 24 +++++++++--------- .../java/chess/domain/position/Position.java | 25 +++++++++++++++++++ src/main/java/chess/domain/position/Rank.java | 8 +++--- 11 files changed, 166 insertions(+), 24 deletions(-) create mode 100644 src/main/java/chess/domain/move/BishopMoveStrategy.java create mode 100644 src/main/java/chess/domain/move/KingMoveStrategy.java create mode 100644 src/main/java/chess/domain/move/KnightMoveStrategy.java create mode 100644 src/main/java/chess/domain/move/MoveStrategy.java create mode 100644 src/main/java/chess/domain/move/PawnMoveStrategy.java create mode 100644 src/main/java/chess/domain/move/QueenMoveStrategy.java create mode 100644 src/main/java/chess/domain/move/RookMoveStrategy.java diff --git a/src/main/java/chess/domain/move/BishopMoveStrategy.java b/src/main/java/chess/domain/move/BishopMoveStrategy.java new file mode 100644 index 00000000000..bbf8b3b7ab8 --- /dev/null +++ b/src/main/java/chess/domain/move/BishopMoveStrategy.java @@ -0,0 +1,18 @@ +package chess.domain.move; + +import chess.domain.position.Position; + +public class BishopMoveStrategy extends MoveStrategy { + + @Override + public boolean movable(Position source, Position target) { + if (isSamePosition(source, target)) { + return false; + } + + int fileGap = Math.abs(source.calculateFileGap(target)); + int rankGap = Math.abs(source.calculateRankGap(target)); + + return fileGap == rankGap; + } +} diff --git a/src/main/java/chess/domain/move/KingMoveStrategy.java b/src/main/java/chess/domain/move/KingMoveStrategy.java new file mode 100644 index 00000000000..789b5f53f73 --- /dev/null +++ b/src/main/java/chess/domain/move/KingMoveStrategy.java @@ -0,0 +1,18 @@ +package chess.domain.move; + +import chess.domain.position.Position; + +public class KingMoveStrategy extends MoveStrategy { + + @Override + public boolean movable(Position source, Position target) { + if (isSamePosition(source, target)) { + return false; + } + + int fileGap = Math.abs(source.calculateFileGap(target)); + int rankGap = Math.abs(source.calculateRankGap(target)); + + return fileGap <= 1 && rankGap <= 1; + } +} diff --git a/src/main/java/chess/domain/move/KnightMoveStrategy.java b/src/main/java/chess/domain/move/KnightMoveStrategy.java new file mode 100644 index 00000000000..b1814787293 --- /dev/null +++ b/src/main/java/chess/domain/move/KnightMoveStrategy.java @@ -0,0 +1,17 @@ +package chess.domain.move; + +import chess.domain.position.Position; + +public class KnightMoveStrategy extends MoveStrategy { + @Override + public boolean movable(Position source, Position target) { + if (isSamePosition(source, target)) { + return false; + } + + int fileGap = Math.abs(source.calculateFileGap(target)); + int rankGap = Math.abs(source.calculateRankGap(target)); + + return fileGap <= 1 && rankGap <= 1; + } +} \ No newline at end of file diff --git a/src/main/java/chess/domain/move/MoveStrategy.java b/src/main/java/chess/domain/move/MoveStrategy.java new file mode 100644 index 00000000000..3f741626568 --- /dev/null +++ b/src/main/java/chess/domain/move/MoveStrategy.java @@ -0,0 +1,13 @@ +package chess.domain.move; + +import chess.domain.position.Position; + +public abstract class MoveStrategy { + + protected abstract boolean movable(Position source, Position target); + + protected boolean isSamePosition(Position source, Position target) { + return source.equals(target); + } + +} diff --git a/src/main/java/chess/domain/move/PawnMoveStrategy.java b/src/main/java/chess/domain/move/PawnMoveStrategy.java new file mode 100644 index 00000000000..673eec2c9a0 --- /dev/null +++ b/src/main/java/chess/domain/move/PawnMoveStrategy.java @@ -0,0 +1,18 @@ +package chess.domain.move; + +import chess.domain.position.Position; + +public class PawnMoveStrategy extends MoveStrategy { + + @Override + public boolean movable(Position source, Position target) { + if (isSamePosition(source, target)) { + return false; + } + + int fileGap = Math.abs(source.calculateFileGap(target)); + int rankGap = Math.abs(source.calculateRankGap(target)); + + return fileGap <= 1 && rankGap <= 1; + } +} \ No newline at end of file diff --git a/src/main/java/chess/domain/move/QueenMoveStrategy.java b/src/main/java/chess/domain/move/QueenMoveStrategy.java new file mode 100644 index 00000000000..f03231668bc --- /dev/null +++ b/src/main/java/chess/domain/move/QueenMoveStrategy.java @@ -0,0 +1,12 @@ +package chess.domain.move; + +import chess.domain.position.Position; + +public class QueenMoveStrategy extends MoveStrategy { + + @Override + public boolean movable(Position source, Position target) { + return new RookMoveStrategy().movable(source, target) + && new BishopMoveStrategy().movable(source, target); + } +} \ No newline at end of file diff --git a/src/main/java/chess/domain/move/RookMoveStrategy.java b/src/main/java/chess/domain/move/RookMoveStrategy.java new file mode 100644 index 00000000000..151bd9117aa --- /dev/null +++ b/src/main/java/chess/domain/move/RookMoveStrategy.java @@ -0,0 +1,17 @@ +package chess.domain.move; + +import chess.domain.position.Position; + +public class RookMoveStrategy extends MoveStrategy { + @Override + public boolean movable(Position source, Position target) { + if (isSamePosition(source, target)) { + return false; + } + + int fileGap = Math.abs(source.calculateFileGap(target)); + int rankGap = Math.abs(source.calculateRankGap(target)); + + return fileGap == 0 && rankGap > 0; + } +} diff --git a/src/main/java/chess/domain/piece/PieceType.java b/src/main/java/chess/domain/piece/PieceType.java index cfe6e8a92cb..414db71cb5c 100644 --- a/src/main/java/chess/domain/piece/PieceType.java +++ b/src/main/java/chess/domain/piece/PieceType.java @@ -1,22 +1,26 @@ package chess.domain.piece; +import chess.domain.move.*; + public enum PieceType { - KING("k", 0), - QUEEN("q", 9), - ROOK("r", 5), - BISHOP("b", 3), - KNIGHT("n", 2.5), - PAWN("p", 1); + KING("k", 0, new KingMoveStrategy()), + QUEEN("q", 9, new QueenMoveStrategy()), + ROOK("r", 5, new RookMoveStrategy()), + BISHOP("b", 3, new BishopMoveStrategy()), + KNIGHT("n", 2.5, new KnightMoveStrategy()), + PAWN("p", 1, new PawnMoveStrategy()); private final String symbol; private final double score; + private final MoveStrategy moveStrategy; - PieceType(String symbol, double score) { + PieceType(String symbol, double score, MoveStrategy moveStrategy) { this.symbol = symbol; this.score = score; + this.moveStrategy = moveStrategy; } public String getSymbol() { return symbol; } -} +} \ No newline at end of file diff --git a/src/main/java/chess/domain/position/File.java b/src/main/java/chess/domain/position/File.java index d4212488217..2646ac73daa 100644 --- a/src/main/java/chess/domain/position/File.java +++ b/src/main/java/chess/domain/position/File.java @@ -3,24 +3,24 @@ import java.util.Arrays; public enum File { - A("a"), - B("b"), - C("c"), - D("d"), - E("e"), - F("f"), - G("g"), - H("h"); + A('a'), + B('b'), + C('c'), + D('d'), + E('e'), + F('f'), + G('g'), + H('h'); - private final String name; + private final char symbol; - File(String name) { - this.name = name; + File(char symbol) { + this.symbol = symbol; } public static File of(String file) { return Arrays.stream(values()) - .filter(ph -> ph.name.equals(file.toLowerCase())) + .filter(ph -> ph.symbol == file.toLowerCase().charAt(0)) .findFirst() .orElseThrow(() -> new IllegalArgumentException("잘못된 x 좌표값을 입력하였습니다.")); } diff --git a/src/main/java/chess/domain/position/Position.java b/src/main/java/chess/domain/position/Position.java index 0f51e44f09e..b9695fa9826 100644 --- a/src/main/java/chess/domain/position/Position.java +++ b/src/main/java/chess/domain/position/Position.java @@ -3,6 +3,7 @@ import java.util.ArrayList; import java.util.Collections; import java.util.List; +import java.util.Objects; import java.util.stream.Collectors; public class Position { @@ -50,8 +51,32 @@ public static List getPositions() { return Collections.unmodifiableList(parseResult); } + public int calculateFileGap(Position target) { + int fileGap = this.file.compareTo(target.file); + return fileGap; + } + + public int calculateRankGap(Position target) { + int rankGap = this.rank.compareTo(target.rank); + return rankGap; + } + @Override public String toString() { return file.name() + rank.name(); } + + @Override + public boolean equals(Object o) { + if (this == o) return true; + if (o == null || getClass() != o.getClass()) return false; + Position position = (Position) o; + return file == position.file && + rank == position.rank; + } + + @Override + public int hashCode() { + return Objects.hash(file, rank); + } } diff --git a/src/main/java/chess/domain/position/Rank.java b/src/main/java/chess/domain/position/Rank.java index 6d0c3c582eb..e006e8c7f5c 100644 --- a/src/main/java/chess/domain/position/Rank.java +++ b/src/main/java/chess/domain/position/Rank.java @@ -12,15 +12,15 @@ public enum Rank { TWO(2), ONE(1); - private final int rank; + private final int symbol; - Rank(int rank) { - this.rank = rank; + Rank(int symbol) { + this.symbol = symbol; } public static Rank of(String rank) { return Arrays.stream(values()) - .filter(pv -> pv.rank == Integer.parseInt(rank)) + .filter(pv -> pv.symbol == Integer.parseInt(rank)) .findFirst() .orElseThrow(() -> new IllegalArgumentException("잘못된 y 좌표값을 입력하였습니다.")); } From b0392f37e70d7fe5f9334809aa5dfe2e6dffe7cd Mon Sep 17 00:00:00 2001 From: giantim Date: Wed, 25 Mar 2020 20:30:13 +0900 Subject: [PATCH 07/75] =?UTF-8?q?feat:=20=ED=8F=B0=EC=9D=98=20=EC=9D=B4?= =?UTF-8?q?=EB=8F=99=20=EC=A0=84=EB=9E=B5=EA=B3=BC=20=ED=8C=80=EB=B3=84=20?= =?UTF-8?q?=EC=9D=B4=EB=8F=99=20=EC=A0=84=EB=9E=B5?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../chess/controller/ChessController.java | 5 ++++ src/main/java/chess/domain/board/Board.java | 20 ++++++++++++++++ .../chess/domain/board/BoardInitializer.java | 2 +- .../chess/domain/move/KnightMoveStrategy.java | 2 +- .../java/chess/domain/move/MoveStrategy.java | 3 +-- .../domain/move/MoveStrategyFactory.java | 10 ++++++++ .../chess/domain/move/PawnMoveStrategy.java | 5 ++++ src/main/java/chess/domain/piece/Piece.java | 10 ++++++++ .../java/chess/domain/piece/PieceType.java | 5 ++++ src/main/java/chess/domain/piece/Team.java | 7 ++++++ .../java/chess/view/ConsoleInputView.java | 24 +++++++++++++++++-- src/main/java/chess/view/InputView.java | 1 + 12 files changed, 88 insertions(+), 6 deletions(-) create mode 100644 src/main/java/chess/domain/move/MoveStrategyFactory.java diff --git a/src/main/java/chess/controller/ChessController.java b/src/main/java/chess/controller/ChessController.java index d75a0b61b39..7e112174b34 100644 --- a/src/main/java/chess/controller/ChessController.java +++ b/src/main/java/chess/controller/ChessController.java @@ -17,6 +17,11 @@ public static void run() { if (inputView.askChessRun()) { Board board = new Board(); printInitialize(board); + String[] moveSource = inputView.askMove().split(" "); + String sourcePosition = moveSource[1]; + String targetPosition = moveSource[2]; + board.updateBoard(sourcePosition, targetPosition); + printInitialize(board); } } diff --git a/src/main/java/chess/domain/board/Board.java b/src/main/java/chess/domain/board/Board.java index df7d71e2bf1..4cbf79a936b 100644 --- a/src/main/java/chess/domain/board/Board.java +++ b/src/main/java/chess/domain/board/Board.java @@ -1,6 +1,7 @@ package chess.domain.board; import chess.domain.piece.Piece; +import chess.domain.piece.Team; import chess.domain.position.Position; import java.util.Collections; @@ -11,8 +12,11 @@ public class Board { private final Map board; + private Team team; + public Board() { this.board = BoardInitializer.initializeAll(); + this.team = Team.WHITE; } public Map parse() { @@ -23,4 +27,20 @@ public Map parse() { (e1, e2) -> e1, LinkedHashMap::new)); return Collections.unmodifiableMap(parseResult); } + + public void updateBoard(String source, String target) { + Position sourcePosition = Position.of(source); + Position targetPosition = Position.of(target); + Piece movedPiece = this.board.get(sourcePosition); + if (!movedPiece.move(sourcePosition, targetPosition)) { + throw new IllegalArgumentException("이동할 수 없는 곳입니다."); + } + this.board.put(targetPosition, movedPiece); + this.board.remove(sourcePosition); + changeTurn(); + } + + private void changeTurn() { + this.team = Team.changeTurn(this.team); + } } diff --git a/src/main/java/chess/domain/board/BoardInitializer.java b/src/main/java/chess/domain/board/BoardInitializer.java index 573184ac6fd..614699b0424 100644 --- a/src/main/java/chess/domain/board/BoardInitializer.java +++ b/src/main/java/chess/domain/board/BoardInitializer.java @@ -27,6 +27,6 @@ public static Map initializeAll() { board.putAll(strategy.initialize()); } - return Collections.unmodifiableMap(board); + return board; } } diff --git a/src/main/java/chess/domain/move/KnightMoveStrategy.java b/src/main/java/chess/domain/move/KnightMoveStrategy.java index b1814787293..bd607700b67 100644 --- a/src/main/java/chess/domain/move/KnightMoveStrategy.java +++ b/src/main/java/chess/domain/move/KnightMoveStrategy.java @@ -12,6 +12,6 @@ public boolean movable(Position source, Position target) { int fileGap = Math.abs(source.calculateFileGap(target)); int rankGap = Math.abs(source.calculateRankGap(target)); - return fileGap <= 1 && rankGap <= 1; + return (fileGap == 2 && rankGap == 1) || (fileGap == 1 && rankGap == 2); } } \ No newline at end of file diff --git a/src/main/java/chess/domain/move/MoveStrategy.java b/src/main/java/chess/domain/move/MoveStrategy.java index 3f741626568..2296bb1963b 100644 --- a/src/main/java/chess/domain/move/MoveStrategy.java +++ b/src/main/java/chess/domain/move/MoveStrategy.java @@ -4,10 +4,9 @@ public abstract class MoveStrategy { - protected abstract boolean movable(Position source, Position target); - protected boolean isSamePosition(Position source, Position target) { return source.equals(target); } + public abstract boolean movable(Position source, Position target); } diff --git a/src/main/java/chess/domain/move/MoveStrategyFactory.java b/src/main/java/chess/domain/move/MoveStrategyFactory.java new file mode 100644 index 00000000000..0ca7e3ff23f --- /dev/null +++ b/src/main/java/chess/domain/move/MoveStrategyFactory.java @@ -0,0 +1,10 @@ +package chess.domain.move; + +import chess.domain.piece.PieceType; +import chess.domain.piece.Team; + +public class MoveStrategyFactory { +// public static MoveStrategy create(PieceType pieceType, Team team) { +// +// } +} diff --git a/src/main/java/chess/domain/move/PawnMoveStrategy.java b/src/main/java/chess/domain/move/PawnMoveStrategy.java index 673eec2c9a0..f1423e1b14d 100644 --- a/src/main/java/chess/domain/move/PawnMoveStrategy.java +++ b/src/main/java/chess/domain/move/PawnMoveStrategy.java @@ -1,8 +1,13 @@ package chess.domain.move; +import chess.domain.piece.Team; import chess.domain.position.Position; public class PawnMoveStrategy extends MoveStrategy { + private static final int WHITE_POSITION = 2; + private static final int BLACK_POSITION = 7; + + private Team team; @Override public boolean movable(Position source, Position target) { diff --git a/src/main/java/chess/domain/piece/Piece.java b/src/main/java/chess/domain/piece/Piece.java index 68b661d453e..39c5bae1b38 100644 --- a/src/main/java/chess/domain/piece/Piece.java +++ b/src/main/java/chess/domain/piece/Piece.java @@ -1,15 +1,25 @@ package chess.domain.piece; +import chess.domain.move.MoveStrategy; +import chess.domain.move.MoveStrategyFactory; +import chess.domain.position.Position; + public class Piece { private final PieceType pieceType; private final Team team; +// private final MoveStrategy moveStrategy; public Piece(final PieceType pieceType, final Team team) { this.pieceType = pieceType; this.team = team; +// this.moveStrategy = MoveStrategyFactory.create(pieceType, team); } public String toSymbol() { return this.team.convert(this.pieceType.getSymbol()); } + + public boolean move(Position source, Position target) { + return this.pieceType.move(source, target); + } } diff --git a/src/main/java/chess/domain/piece/PieceType.java b/src/main/java/chess/domain/piece/PieceType.java index 414db71cb5c..3d63b5401a4 100644 --- a/src/main/java/chess/domain/piece/PieceType.java +++ b/src/main/java/chess/domain/piece/PieceType.java @@ -1,6 +1,7 @@ package chess.domain.piece; import chess.domain.move.*; +import chess.domain.position.Position; public enum PieceType { KING("k", 0, new KingMoveStrategy()), @@ -23,4 +24,8 @@ public enum PieceType { public String getSymbol() { return symbol; } + + public boolean move(Position source, Position target) { + return this.moveStrategy.movable(source, target); + } } \ No newline at end of file diff --git a/src/main/java/chess/domain/piece/Team.java b/src/main/java/chess/domain/piece/Team.java index ec97b6aa539..ace859b507f 100644 --- a/src/main/java/chess/domain/piece/Team.java +++ b/src/main/java/chess/domain/piece/Team.java @@ -12,6 +12,13 @@ public enum Team { this.expression = expression; } + public static Team changeTurn(Team team) { + if (team == BLACK) { + return WHITE; + } + return BLACK; + } + public String convert(final String name) { return this.expression.apply(name); } diff --git a/src/main/java/chess/view/ConsoleInputView.java b/src/main/java/chess/view/ConsoleInputView.java index 3daac277af9..3dc45472fba 100644 --- a/src/main/java/chess/view/ConsoleInputView.java +++ b/src/main/java/chess/view/ConsoleInputView.java @@ -9,9 +9,11 @@ public class ConsoleInputView implements InputView { @Override public boolean askChessRun() { + System.out.println("> 체스 게임을 시작합니다."); + System.out.println("> 게임 시작 : start"); + System.out.println("> 게임 종료 : end"); + System.out.println("> 게임 이동 : move source위치 target위치 - 예. move b2 b3"); try { - System.out.println("체스 게임을 시작합니다."); - System.out.println("게임 시작은 start, 종료는 end 명령어를 입력하세요."); String input = SCANNER.nextLine(); validateCommand(input); return runFlag(input); @@ -33,4 +35,22 @@ private boolean runFlag(String input) { } return false; } + + @Override + public String askMove() { + try { + String input = SCANNER.nextLine(); + validateMove(input); + return input; + } catch (IllegalArgumentException e) { + System.out.println(e.getMessage()); + return askMove(); + } + } + + private static void validateMove(String input) { + if (!input.contains("move")) { + throw new IllegalArgumentException("잘못된 명령어를 입력하였습니다."); + } + } } diff --git a/src/main/java/chess/view/InputView.java b/src/main/java/chess/view/InputView.java index 9581c3801f1..6d6ef517950 100644 --- a/src/main/java/chess/view/InputView.java +++ b/src/main/java/chess/view/InputView.java @@ -2,4 +2,5 @@ public interface InputView { boolean askChessRun(); + String askMove(); } From 08ab69b8478ce71a067465c41f186d0822592161 Mon Sep 17 00:00:00 2001 From: giantim Date: Thu, 26 Mar 2020 15:19:47 +0900 Subject: [PATCH 08/75] =?UTF-8?q?feat:=20=EB=A7=90=20=EC=9D=B4=EB=8F=99=20?= =?UTF-8?q?=EC=8B=9C=20=EC=9E=A5=EC=95=A0=EB=AC=BC=20=ED=83=90=EC=83=89=20?= =?UTF-8?q?=20=20=20=20-=20=EA=B2=8C=EC=9E=84=EC=9D=84=20=EC=A7=84?= =?UTF-8?q?=ED=96=89=ED=95=98=EB=8A=94=20ChessRunner=20=ED=81=B4=EB=9E=98?= =?UTF-8?q?=EC=8A=A4=20=EA=B5=AC=ED=98=84?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../chess/controller/ChessController.java | 9 ++-- src/main/java/chess/domain/ChessRunner.java | 43 +++++++++++++++++++ src/main/java/chess/domain/board/Board.java | 24 ++++------- .../chess/domain/move/BishopMoveStrategy.java | 7 ++- .../chess/domain/move/KingMoveStrategy.java | 4 +- .../chess/domain/move/KnightMoveStrategy.java | 3 +- .../java/chess/domain/move/MoveStrategy.java | 28 +++++++++++- .../domain/move/MoveStrategyFactory.java | 10 ----- .../java/chess/domain/move/PathFinder.java | 39 +++++++++++++++++ .../chess/domain/move/PawnMoveStrategy.java | 38 +++++++++++++--- .../chess/domain/move/QueenMoveStrategy.java | 7 +-- .../chess/domain/move/RookMoveStrategy.java | 8 +++- .../move/direction/DirectionStrategy.java | 9 ++++ .../domain/move/direction/DownStrategy.java | 18 ++++++++ .../domain/move/direction/UpStrategy.java | 18 ++++++++ src/main/java/chess/domain/piece/Piece.java | 15 +++++-- .../java/chess/domain/piece/PieceType.java | 5 ++- src/main/java/chess/domain/piece/Team.java | 8 ++++ src/main/java/chess/domain/position/File.java | 13 +++++- .../java/chess/domain/position/Position.java | 18 ++++++++ src/main/java/chess/domain/position/Rank.java | 11 +++++ 21 files changed, 283 insertions(+), 52 deletions(-) create mode 100644 src/main/java/chess/domain/ChessRunner.java delete mode 100644 src/main/java/chess/domain/move/MoveStrategyFactory.java create mode 100644 src/main/java/chess/domain/move/PathFinder.java create mode 100644 src/main/java/chess/domain/move/direction/DirectionStrategy.java create mode 100644 src/main/java/chess/domain/move/direction/DownStrategy.java create mode 100644 src/main/java/chess/domain/move/direction/UpStrategy.java diff --git a/src/main/java/chess/controller/ChessController.java b/src/main/java/chess/controller/ChessController.java index 7e112174b34..6590998b01b 100644 --- a/src/main/java/chess/controller/ChessController.java +++ b/src/main/java/chess/controller/ChessController.java @@ -2,6 +2,7 @@ import chess.controller.dto.BoardDto; import chess.controller.dto.PositionDto; +import chess.domain.ChessRunner; import chess.domain.board.Board; import chess.domain.position.Position; import chess.view.ConsoleInputView; @@ -15,13 +16,13 @@ public class ChessController { public static void run() { if (inputView.askChessRun()) { - Board board = new Board(); - printInitialize(board); + ChessRunner chessRunner = new ChessRunner(); + printInitialize(chessRunner.getBoard()); String[] moveSource = inputView.askMove().split(" "); String sourcePosition = moveSource[1]; String targetPosition = moveSource[2]; - board.updateBoard(sourcePosition, targetPosition); - printInitialize(board); + chessRunner.update(sourcePosition, targetPosition); + printInitialize(chessRunner.getBoard()); } } diff --git a/src/main/java/chess/domain/ChessRunner.java b/src/main/java/chess/domain/ChessRunner.java new file mode 100644 index 00000000000..ef332ef0b00 --- /dev/null +++ b/src/main/java/chess/domain/ChessRunner.java @@ -0,0 +1,43 @@ +package chess.domain; + +import chess.domain.board.Board; +import chess.domain.piece.Piece; +import chess.domain.piece.Team; +import chess.domain.position.Position; + +public class ChessRunner { + private Board board; + private Team currentTeam; + + public ChessRunner() { + this.board = new Board(); + this.currentTeam = Team.WHITE; + } + + public void update(String source, String target) { + Position sourcePosition = Position.of(source); + Position targetPosition = Position.of(target); + Piece selectedPiece = this.board.getPiece(sourcePosition); + + if (!(currentTeam.isEnemy(selectedPiece.getTeam()))) { + throw new IllegalArgumentException("현재 차례가 아닙니다."); + } + + if (!(selectedPiece.move(sourcePosition, targetPosition, board))) { + throw new IllegalArgumentException("이동할 수 없는 곳입니다."); + } + + this.board.updateBoard(sourcePosition, targetPosition, selectedPiece); + + changeTurn(); + + } + + private void changeTurn() { + this.currentTeam = Team.changeTurn(this.currentTeam); + } + + public Board getBoard() { + return this.board; + } +} diff --git a/src/main/java/chess/domain/board/Board.java b/src/main/java/chess/domain/board/Board.java index 4cbf79a936b..e98ce9021fc 100644 --- a/src/main/java/chess/domain/board/Board.java +++ b/src/main/java/chess/domain/board/Board.java @@ -12,11 +12,8 @@ public class Board { private final Map board; - private Team team; - public Board() { this.board = BoardInitializer.initializeAll(); - this.team = Team.WHITE; } public Map parse() { @@ -28,19 +25,16 @@ public Map parse() { return Collections.unmodifiableMap(parseResult); } - public void updateBoard(String source, String target) { - Position sourcePosition = Position.of(source); - Position targetPosition = Position.of(target); - Piece movedPiece = this.board.get(sourcePosition); - if (!movedPiece.move(sourcePosition, targetPosition)) { - throw new IllegalArgumentException("이동할 수 없는 곳입니다."); - } - this.board.put(targetPosition, movedPiece); + public void updateBoard(Position sourcePosition, Position targetPosition, Piece selectedPiece) { + this.board.put(targetPosition, selectedPiece); this.board.remove(sourcePosition); - changeTurn(); } - private void changeTurn() { - this.team = Team.changeTurn(this.team); + public boolean isEmpty(final Position position) { + return this.board.containsKey(position); + } + + public Piece getPiece(final Position position) { + return this.board.get(position); } -} +} \ No newline at end of file diff --git a/src/main/java/chess/domain/move/BishopMoveStrategy.java b/src/main/java/chess/domain/move/BishopMoveStrategy.java index bbf8b3b7ab8..f63996a5f23 100644 --- a/src/main/java/chess/domain/move/BishopMoveStrategy.java +++ b/src/main/java/chess/domain/move/BishopMoveStrategy.java @@ -1,11 +1,12 @@ package chess.domain.move; +import chess.domain.board.Board; import chess.domain.position.Position; public class BishopMoveStrategy extends MoveStrategy { @Override - public boolean movable(Position source, Position target) { + public boolean movable(Position source, Position target, Board board) { if (isSamePosition(source, target)) { return false; } @@ -13,6 +14,8 @@ public boolean movable(Position source, Position target) { int fileGap = Math.abs(source.calculateFileGap(target)); int rankGap = Math.abs(source.calculateRankGap(target)); - return fileGap == rankGap; + return fileGap == rankGap + && checkObstacle(source, target, board) + && checkTarget(source, target, board); } } diff --git a/src/main/java/chess/domain/move/KingMoveStrategy.java b/src/main/java/chess/domain/move/KingMoveStrategy.java index 789b5f53f73..fda5384ee5b 100644 --- a/src/main/java/chess/domain/move/KingMoveStrategy.java +++ b/src/main/java/chess/domain/move/KingMoveStrategy.java @@ -1,11 +1,13 @@ package chess.domain.move; +import chess.domain.board.Board; +import chess.domain.piece.Piece; import chess.domain.position.Position; public class KingMoveStrategy extends MoveStrategy { @Override - public boolean movable(Position source, Position target) { + public boolean movable(Position source, Position target, Board board) { if (isSamePosition(source, target)) { return false; } diff --git a/src/main/java/chess/domain/move/KnightMoveStrategy.java b/src/main/java/chess/domain/move/KnightMoveStrategy.java index bd607700b67..fb917dbfadf 100644 --- a/src/main/java/chess/domain/move/KnightMoveStrategy.java +++ b/src/main/java/chess/domain/move/KnightMoveStrategy.java @@ -1,10 +1,11 @@ package chess.domain.move; +import chess.domain.board.Board; import chess.domain.position.Position; public class KnightMoveStrategy extends MoveStrategy { @Override - public boolean movable(Position source, Position target) { + public boolean movable(Position source, Position target, Board board) { if (isSamePosition(source, target)) { return false; } diff --git a/src/main/java/chess/domain/move/MoveStrategy.java b/src/main/java/chess/domain/move/MoveStrategy.java index 2296bb1963b..77524596c9e 100644 --- a/src/main/java/chess/domain/move/MoveStrategy.java +++ b/src/main/java/chess/domain/move/MoveStrategy.java @@ -1,12 +1,38 @@ package chess.domain.move; +import chess.domain.board.Board; +import chess.domain.move.direction.DirectionStrategy; +import chess.domain.piece.Piece; import chess.domain.position.Position; +import java.util.List; + public abstract class MoveStrategy { protected boolean isSamePosition(Position source, Position target) { return source.equals(target); } - public abstract boolean movable(Position source, Position target); + public abstract boolean movable(Position source, Position target, Board board); + + protected boolean checkObstacle(Position source, Position target, Board board) { + DirectionStrategy directionStrategy= PathFinder.find(source, target); + List path = directionStrategy.find(source, target); + + for (Position position : path) { + if (!board.isEmpty(position)) { + return false; + } + } + return true; + } + + protected boolean checkTarget(Position source, Position target, Board board) { + Piece sourcePiece = board.getPiece(source); + if (board.isEmpty(target)) { + return true; + } + Piece targetPiece = board.getPiece(target); + return sourcePiece.isEnemy(targetPiece); + } } diff --git a/src/main/java/chess/domain/move/MoveStrategyFactory.java b/src/main/java/chess/domain/move/MoveStrategyFactory.java deleted file mode 100644 index 0ca7e3ff23f..00000000000 --- a/src/main/java/chess/domain/move/MoveStrategyFactory.java +++ /dev/null @@ -1,10 +0,0 @@ -package chess.domain.move; - -import chess.domain.piece.PieceType; -import chess.domain.piece.Team; - -public class MoveStrategyFactory { -// public static MoveStrategy create(PieceType pieceType, Team team) { -// -// } -} diff --git a/src/main/java/chess/domain/move/PathFinder.java b/src/main/java/chess/domain/move/PathFinder.java new file mode 100644 index 00000000000..0c9c4358fdc --- /dev/null +++ b/src/main/java/chess/domain/move/PathFinder.java @@ -0,0 +1,39 @@ +package chess.domain.move; + +import chess.domain.move.direction.DirectionStrategy; +import chess.domain.move.direction.DownStrategy; +import chess.domain.move.direction.UpStrategy; +import chess.domain.position.Position; + +public class PathFinder { + public static DirectionStrategy find(Position source, Position target) { + int fileGap = target.calculateFileGap(source); + int rankGap = target.calculateRankGap(source); + + if (fileGap == 0 && rankGap > 0) { + return new UpStrategy(); + } + if (fileGap == 0 && rankGap < 0) { + return new DownStrategy(); + } + if (fileGap > 0 && rankGap == 0) { + + } + if (fileGap < 0 && rankGap == 0) { + + } + if (fileGap > 0 && rankGap > 0) { + + } + if (fileGap > 0 && rankGap < 0) { + + } + if (fileGap < 0 && rankGap > 0) { + + } + if (fileGap < 0 && rankGap < 0) { + + } + return null; + } +} diff --git a/src/main/java/chess/domain/move/PawnMoveStrategy.java b/src/main/java/chess/domain/move/PawnMoveStrategy.java index f1423e1b14d..58981836295 100644 --- a/src/main/java/chess/domain/move/PawnMoveStrategy.java +++ b/src/main/java/chess/domain/move/PawnMoveStrategy.java @@ -1,5 +1,7 @@ package chess.domain.move; +import chess.domain.board.Board; +import chess.domain.piece.Piece; import chess.domain.piece.Team; import chess.domain.position.Position; @@ -7,17 +9,41 @@ public class PawnMoveStrategy extends MoveStrategy { private static final int WHITE_POSITION = 2; private static final int BLACK_POSITION = 7; - private Team team; - @Override - public boolean movable(Position source, Position target) { + public boolean movable(Position source, Position target, Board board) { if (isSamePosition(source, target)) { return false; } - int fileGap = Math.abs(source.calculateFileGap(target)); - int rankGap = Math.abs(source.calculateRankGap(target)); + int fileGap = source.calculateFileGap(target); + int rankGap = source.calculateRankGap(target); + + Piece sourcePiece = board.getPiece(source); + Piece targetPiece = board.getPiece(target); + Team pawnTeam = sourcePiece.getTeam(); - return fileGap <= 1 && rankGap <= 1; + if (pawnTeam.isWhite()) { + if (fileGap == 0 && rankGap == -1) { + return board.isEmpty(target); + } + if (fileGap == 0 && rankGap == -2) { + return source.getRank() == WHITE_POSITION; + } + if (Math.abs(fileGap) == 1 && rankGap == -1) { + return !board.isEmpty(target) && sourcePiece.isEnemy(targetPiece); + } + } + if (!pawnTeam.isWhite()) { + if (fileGap == 0 && rankGap == 1) { + return board.isEmpty(target); + } + if (fileGap == 0 && rankGap == 2) { + return source.getRank() == BLACK_POSITION; + } + if (Math.abs(fileGap) == 1 && rankGap == 1) { + return !board.isEmpty(target) && sourcePiece.isEnemy(targetPiece); + } + } + return false; } } \ No newline at end of file diff --git a/src/main/java/chess/domain/move/QueenMoveStrategy.java b/src/main/java/chess/domain/move/QueenMoveStrategy.java index f03231668bc..55442763d21 100644 --- a/src/main/java/chess/domain/move/QueenMoveStrategy.java +++ b/src/main/java/chess/domain/move/QueenMoveStrategy.java @@ -1,12 +1,13 @@ package chess.domain.move; +import chess.domain.board.Board; import chess.domain.position.Position; public class QueenMoveStrategy extends MoveStrategy { @Override - public boolean movable(Position source, Position target) { - return new RookMoveStrategy().movable(source, target) - && new BishopMoveStrategy().movable(source, target); + public boolean movable(Position source, Position target, Board board) { + return new RookMoveStrategy().movable(source, target, board) + && new BishopMoveStrategy().movable(source, target, board); } } \ No newline at end of file diff --git a/src/main/java/chess/domain/move/RookMoveStrategy.java b/src/main/java/chess/domain/move/RookMoveStrategy.java index 151bd9117aa..87e435b5735 100644 --- a/src/main/java/chess/domain/move/RookMoveStrategy.java +++ b/src/main/java/chess/domain/move/RookMoveStrategy.java @@ -1,10 +1,14 @@ package chess.domain.move; +import chess.domain.board.Board; +import chess.domain.move.direction.DirectionStrategy; import chess.domain.position.Position; +import java.util.List; + public class RookMoveStrategy extends MoveStrategy { @Override - public boolean movable(Position source, Position target) { + public boolean movable(Position source, Position target, Board board) { if (isSamePosition(source, target)) { return false; } @@ -12,6 +16,6 @@ public boolean movable(Position source, Position target) { int fileGap = Math.abs(source.calculateFileGap(target)); int rankGap = Math.abs(source.calculateRankGap(target)); - return fileGap == 0 && rankGap > 0; + return fileGap == 0 && rankGap > 0 && checkObstacle(source, target, board); } } diff --git a/src/main/java/chess/domain/move/direction/DirectionStrategy.java b/src/main/java/chess/domain/move/direction/DirectionStrategy.java new file mode 100644 index 00000000000..298b0eeed25 --- /dev/null +++ b/src/main/java/chess/domain/move/direction/DirectionStrategy.java @@ -0,0 +1,9 @@ +package chess.domain.move.direction; + +import chess.domain.position.Position; + +import java.util.List; + +public interface DirectionStrategy { + List find(Position source, Position target); +} \ No newline at end of file diff --git a/src/main/java/chess/domain/move/direction/DownStrategy.java b/src/main/java/chess/domain/move/direction/DownStrategy.java new file mode 100644 index 00000000000..6ce3899e91a --- /dev/null +++ b/src/main/java/chess/domain/move/direction/DownStrategy.java @@ -0,0 +1,18 @@ +package chess.domain.move.direction; + +import chess.domain.position.Position; + +import java.util.ArrayList; +import java.util.List; + +public class DownStrategy implements DirectionStrategy { + @Override + public List find(Position source, Position target) { + List path = new ArrayList<>(); + + for (int i = target.getRank() + 1; i < source.getRank(); i++) { + path.add(Position.of(source.getFile(), i)); + } + return path; + } +} \ No newline at end of file diff --git a/src/main/java/chess/domain/move/direction/UpStrategy.java b/src/main/java/chess/domain/move/direction/UpStrategy.java new file mode 100644 index 00000000000..3fd2319d9e8 --- /dev/null +++ b/src/main/java/chess/domain/move/direction/UpStrategy.java @@ -0,0 +1,18 @@ +package chess.domain.move.direction; + +import chess.domain.position.Position; + +import java.util.ArrayList; +import java.util.List; + +public class UpStrategy implements DirectionStrategy { + @Override + public List find(Position source, Position target) { + List path = new ArrayList<>(); + + for (int i = target.getRank() - 1; i > source.getRank(); i--) { + path.add(Position.of(source.getFile(), i)); + } + return path; + } +} \ No newline at end of file diff --git a/src/main/java/chess/domain/piece/Piece.java b/src/main/java/chess/domain/piece/Piece.java index 39c5bae1b38..5286a31b705 100644 --- a/src/main/java/chess/domain/piece/Piece.java +++ b/src/main/java/chess/domain/piece/Piece.java @@ -1,7 +1,6 @@ package chess.domain.piece; -import chess.domain.move.MoveStrategy; -import chess.domain.move.MoveStrategyFactory; +import chess.domain.board.Board; import chess.domain.position.Position; public class Piece { @@ -19,7 +18,15 @@ public String toSymbol() { return this.team.convert(this.pieceType.getSymbol()); } - public boolean move(Position source, Position target) { - return this.pieceType.move(source, target); + public boolean move(Position source, Position target, Board board) { + return this.pieceType.move(source, target, board); + } + + public boolean isEnemy(Piece targetPiece) { + return this.team.isEnemy(targetPiece.getTeam()); + } + + public Team getTeam() { + return this.team; } } diff --git a/src/main/java/chess/domain/piece/PieceType.java b/src/main/java/chess/domain/piece/PieceType.java index 3d63b5401a4..f3e742e3247 100644 --- a/src/main/java/chess/domain/piece/PieceType.java +++ b/src/main/java/chess/domain/piece/PieceType.java @@ -1,5 +1,6 @@ package chess.domain.piece; +import chess.domain.board.Board; import chess.domain.move.*; import chess.domain.position.Position; @@ -25,7 +26,7 @@ public String getSymbol() { return symbol; } - public boolean move(Position source, Position target) { - return this.moveStrategy.movable(source, target); + public boolean move(Position source, Position target, Board board) { + return this.moveStrategy.movable(source, target, board); } } \ No newline at end of file diff --git a/src/main/java/chess/domain/piece/Team.java b/src/main/java/chess/domain/piece/Team.java index ace859b507f..bd6eae9ddb3 100644 --- a/src/main/java/chess/domain/piece/Team.java +++ b/src/main/java/chess/domain/piece/Team.java @@ -22,4 +22,12 @@ public static Team changeTurn(Team team) { public String convert(final String name) { return this.expression.apply(name); } + + public boolean isEnemy(Team team) { + return this != team; + } + + public boolean isWhite() { + return this == WHITE; + } } diff --git a/src/main/java/chess/domain/position/File.java b/src/main/java/chess/domain/position/File.java index 2646ac73daa..0a856960b02 100644 --- a/src/main/java/chess/domain/position/File.java +++ b/src/main/java/chess/domain/position/File.java @@ -20,8 +20,19 @@ public enum File { public static File of(String file) { return Arrays.stream(values()) - .filter(ph -> ph.symbol == file.toLowerCase().charAt(0)) + .filter(f -> f.symbol == file.toLowerCase().charAt(0)) .findFirst() .orElseThrow(() -> new IllegalArgumentException("잘못된 x 좌표값을 입력하였습니다.")); } + + public static File of(int file) { + return Arrays.stream(values()) + .filter(f -> f.symbol == (char) file) + .findFirst() + .orElseThrow(() -> new IllegalArgumentException("잘못된 x 좌표값을 입력하였습니다.")); + } + + public int getSymbol() { + return this.symbol; + } } diff --git a/src/main/java/chess/domain/position/Position.java b/src/main/java/chess/domain/position/Position.java index b9695fa9826..29520ae3f02 100644 --- a/src/main/java/chess/domain/position/Position.java +++ b/src/main/java/chess/domain/position/Position.java @@ -44,6 +44,16 @@ private static Position findPosition(File file, Rank rank) { .orElseThrow(AssertionError::new); } + public static Position of(final File file, final Rank rank) { + return findPosition(file, rank); + } + + public static Position of(final int fileSymbol, final int rankSymbol) { + + + return findPosition(File.of(fileSymbol), Rank.of(rankSymbol)); + } + public static List getPositions() { List parseResult = positions.stream() .map(Position::toString) @@ -61,6 +71,14 @@ public int calculateRankGap(Position target) { return rankGap; } + public int getFile() { + return this.file.getSymbol(); + } + + public int getRank() { + return this.rank.getSymbol(); + } + @Override public String toString() { return file.name() + rank.name(); diff --git a/src/main/java/chess/domain/position/Rank.java b/src/main/java/chess/domain/position/Rank.java index e006e8c7f5c..c1cbd0e889c 100644 --- a/src/main/java/chess/domain/position/Rank.java +++ b/src/main/java/chess/domain/position/Rank.java @@ -24,4 +24,15 @@ public static Rank of(String rank) { .findFirst() .orElseThrow(() -> new IllegalArgumentException("잘못된 y 좌표값을 입력하였습니다.")); } + + public static Rank of(int rank) { + return Arrays.stream(values()) + .filter(f -> f.symbol == rank) + .findFirst() + .orElseThrow(() -> new IllegalArgumentException("잘못된 x 좌표값을 입력하였습니다.")); + } + + public int getSymbol() { + return this.symbol; + } } From 1d69dbfee24fc619b419d4d894d7792fcb755b6b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=EA=B9=80=EC=98=88=EB=B9=88?= Date: Thu, 26 Mar 2020 15:53:57 +0900 Subject: [PATCH 09/75] =?UTF-8?q?feat:=20=EB=B0=A9=ED=96=A5=20=EC=A0=84?= =?UTF-8?q?=EB=9E=B5=20=EA=B5=AC=ED=98=84?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/main/java/chess/domain/ChessRunner.java | 2 +- .../chess/domain/move/BishopMoveStrategy.java | 2 +- .../chess/domain/move/KingMoveStrategy.java | 3 ++- .../chess/domain/move/KnightMoveStrategy.java | 3 ++- .../java/chess/domain/move/PathFinder.java | 18 ++++++------- .../chess/domain/move/QueenMoveStrategy.java | 2 +- .../chess/domain/move/RookMoveStrategy.java | 4 ++- .../move/direction/LeftDownStrategy.java | 20 ++++++++++++++ .../domain/move/direction/LeftStrategy.java | 18 +++++++++++++ .../domain/move/direction/LeftUpStrategy.java | 20 ++++++++++++++ .../move/direction/RightDownStrategy.java | 20 ++++++++++++++ .../domain/move/direction/RightStrategy.java | 18 +++++++++++++ .../move/direction/RightUpStrategy.java | 20 ++++++++++++++ src/main/java/chess/domain/piece/Piece.java | 2 -- src/main/java/chess/domain/position/File.java | 26 ++++++++++++------- .../java/chess/domain/position/Position.java | 4 +-- src/main/java/chess/view/InputView.java | 2 ++ 17 files changed, 153 insertions(+), 31 deletions(-) create mode 100644 src/main/java/chess/domain/move/direction/LeftDownStrategy.java create mode 100644 src/main/java/chess/domain/move/direction/LeftStrategy.java create mode 100644 src/main/java/chess/domain/move/direction/LeftUpStrategy.java create mode 100644 src/main/java/chess/domain/move/direction/RightDownStrategy.java create mode 100644 src/main/java/chess/domain/move/direction/RightStrategy.java create mode 100644 src/main/java/chess/domain/move/direction/RightUpStrategy.java diff --git a/src/main/java/chess/domain/ChessRunner.java b/src/main/java/chess/domain/ChessRunner.java index ef332ef0b00..478814ed72b 100644 --- a/src/main/java/chess/domain/ChessRunner.java +++ b/src/main/java/chess/domain/ChessRunner.java @@ -19,7 +19,7 @@ public void update(String source, String target) { Position targetPosition = Position.of(target); Piece selectedPiece = this.board.getPiece(sourcePosition); - if (!(currentTeam.isEnemy(selectedPiece.getTeam()))) { + if ((currentTeam.isEnemy(selectedPiece.getTeam()))) { throw new IllegalArgumentException("현재 차례가 아닙니다."); } diff --git a/src/main/java/chess/domain/move/BishopMoveStrategy.java b/src/main/java/chess/domain/move/BishopMoveStrategy.java index f63996a5f23..131b5e079da 100644 --- a/src/main/java/chess/domain/move/BishopMoveStrategy.java +++ b/src/main/java/chess/domain/move/BishopMoveStrategy.java @@ -14,7 +14,7 @@ public boolean movable(Position source, Position target, Board board) { int fileGap = Math.abs(source.calculateFileGap(target)); int rankGap = Math.abs(source.calculateRankGap(target)); - return fileGap == rankGap + return (fileGap == rankGap) && checkObstacle(source, target, board) && checkTarget(source, target, board); } diff --git a/src/main/java/chess/domain/move/KingMoveStrategy.java b/src/main/java/chess/domain/move/KingMoveStrategy.java index fda5384ee5b..bc816329df6 100644 --- a/src/main/java/chess/domain/move/KingMoveStrategy.java +++ b/src/main/java/chess/domain/move/KingMoveStrategy.java @@ -15,6 +15,7 @@ public boolean movable(Position source, Position target, Board board) { int fileGap = Math.abs(source.calculateFileGap(target)); int rankGap = Math.abs(source.calculateRankGap(target)); - return fileGap <= 1 && rankGap <= 1; + return (fileGap <= 1 && rankGap <= 1) + && checkTarget(source, target, board); } } diff --git a/src/main/java/chess/domain/move/KnightMoveStrategy.java b/src/main/java/chess/domain/move/KnightMoveStrategy.java index fb917dbfadf..484d2e3ae2d 100644 --- a/src/main/java/chess/domain/move/KnightMoveStrategy.java +++ b/src/main/java/chess/domain/move/KnightMoveStrategy.java @@ -13,6 +13,7 @@ public boolean movable(Position source, Position target, Board board) { int fileGap = Math.abs(source.calculateFileGap(target)); int rankGap = Math.abs(source.calculateRankGap(target)); - return (fileGap == 2 && rankGap == 1) || (fileGap == 1 && rankGap == 2); + return (fileGap == 2 && rankGap == 1) || (fileGap == 1 && rankGap == 2) + && checkTarget(source, target, board); } } \ No newline at end of file diff --git a/src/main/java/chess/domain/move/PathFinder.java b/src/main/java/chess/domain/move/PathFinder.java index 0c9c4358fdc..043af998b1e 100644 --- a/src/main/java/chess/domain/move/PathFinder.java +++ b/src/main/java/chess/domain/move/PathFinder.java @@ -1,8 +1,6 @@ package chess.domain.move; -import chess.domain.move.direction.DirectionStrategy; -import chess.domain.move.direction.DownStrategy; -import chess.domain.move.direction.UpStrategy; +import chess.domain.move.direction.*; import chess.domain.position.Position; public class PathFinder { @@ -17,23 +15,23 @@ public static DirectionStrategy find(Position source, Position target) { return new DownStrategy(); } if (fileGap > 0 && rankGap == 0) { - + return new RightStrategy(); } if (fileGap < 0 && rankGap == 0) { - + return new LeftStrategy(); } if (fileGap > 0 && rankGap > 0) { - + return new RightUpStrategy(); } if (fileGap > 0 && rankGap < 0) { - + return new RightDownStrategy(); } if (fileGap < 0 && rankGap > 0) { - + return new LeftUpStrategy(); } if (fileGap < 0 && rankGap < 0) { - + return new LeftDownStrategy(); } - return null; + throw new AssertionError(); } } diff --git a/src/main/java/chess/domain/move/QueenMoveStrategy.java b/src/main/java/chess/domain/move/QueenMoveStrategy.java index 55442763d21..3cb9525322b 100644 --- a/src/main/java/chess/domain/move/QueenMoveStrategy.java +++ b/src/main/java/chess/domain/move/QueenMoveStrategy.java @@ -8,6 +8,6 @@ public class QueenMoveStrategy extends MoveStrategy { @Override public boolean movable(Position source, Position target, Board board) { return new RookMoveStrategy().movable(source, target, board) - && new BishopMoveStrategy().movable(source, target, board); + || new BishopMoveStrategy().movable(source, target, board); } } \ No newline at end of file diff --git a/src/main/java/chess/domain/move/RookMoveStrategy.java b/src/main/java/chess/domain/move/RookMoveStrategy.java index 87e435b5735..d9db390d72d 100644 --- a/src/main/java/chess/domain/move/RookMoveStrategy.java +++ b/src/main/java/chess/domain/move/RookMoveStrategy.java @@ -16,6 +16,8 @@ public boolean movable(Position source, Position target, Board board) { int fileGap = Math.abs(source.calculateFileGap(target)); int rankGap = Math.abs(source.calculateRankGap(target)); - return fileGap == 0 && rankGap > 0 && checkObstacle(source, target, board); + return (fileGap == 0 && rankGap > 0) + && checkObstacle(source, target, board) + && checkTarget(source, target, board); } } diff --git a/src/main/java/chess/domain/move/direction/LeftDownStrategy.java b/src/main/java/chess/domain/move/direction/LeftDownStrategy.java new file mode 100644 index 00000000000..29dd121a889 --- /dev/null +++ b/src/main/java/chess/domain/move/direction/LeftDownStrategy.java @@ -0,0 +1,20 @@ +package chess.domain.move.direction; + +import chess.domain.position.Position; + +import java.util.ArrayList; +import java.util.List; + +public class LeftDownStrategy implements DirectionStrategy { + + @Override + public List find(Position source, Position target) { + List path = new ArrayList<>(); + + for (int i = target.getFile() + 1 ; i < source.getFile() ; i++) { + path.add(Position.of(i, target.getRank() - (target.getFile() - i))); + } + + return path; + } +} diff --git a/src/main/java/chess/domain/move/direction/LeftStrategy.java b/src/main/java/chess/domain/move/direction/LeftStrategy.java new file mode 100644 index 00000000000..8189c9a41b9 --- /dev/null +++ b/src/main/java/chess/domain/move/direction/LeftStrategy.java @@ -0,0 +1,18 @@ +package chess.domain.move.direction; + +import chess.domain.position.Position; + +import java.util.ArrayList; +import java.util.List; + +public class LeftStrategy implements DirectionStrategy { + @Override + public List find(Position source, Position target) { + List path = new ArrayList<>(); + + for (int i = target.getFile() + 1; i < source.getFile(); i++) { + path.add(Position.of(i, source.getRank())); + } + return path; + } +} \ No newline at end of file diff --git a/src/main/java/chess/domain/move/direction/LeftUpStrategy.java b/src/main/java/chess/domain/move/direction/LeftUpStrategy.java new file mode 100644 index 00000000000..30e0511bbd5 --- /dev/null +++ b/src/main/java/chess/domain/move/direction/LeftUpStrategy.java @@ -0,0 +1,20 @@ +package chess.domain.move.direction; + +import chess.domain.position.File; +import chess.domain.position.Position; + +import java.util.ArrayList; +import java.util.List; + +public class LeftUpStrategy implements DirectionStrategy { + @Override + public List find(Position source, Position target) { + List path = new ArrayList<>(); + + for (int i = target.getFile() + 1 ; i < source.getFile() ; i++) { + path.add(Position.of(i, target.getRank() + (target.getFile() - i))); + } + + return path; + } +} \ No newline at end of file diff --git a/src/main/java/chess/domain/move/direction/RightDownStrategy.java b/src/main/java/chess/domain/move/direction/RightDownStrategy.java new file mode 100644 index 00000000000..abde87be180 --- /dev/null +++ b/src/main/java/chess/domain/move/direction/RightDownStrategy.java @@ -0,0 +1,20 @@ +package chess.domain.move.direction; + +import chess.domain.position.Position; + +import java.util.ArrayList; +import java.util.List; + +public class RightDownStrategy implements DirectionStrategy { + + @Override + public List find(Position source, Position target) { + List path = new ArrayList<>(); + + for (int i = target.getFile() - 1 ; i > source.getFile() ; i--) { + path.add(Position.of(i, target.getRank() - (target.getFile() - i))); + } + + return path; + } +} diff --git a/src/main/java/chess/domain/move/direction/RightStrategy.java b/src/main/java/chess/domain/move/direction/RightStrategy.java new file mode 100644 index 00000000000..f07bdf3360b --- /dev/null +++ b/src/main/java/chess/domain/move/direction/RightStrategy.java @@ -0,0 +1,18 @@ +package chess.domain.move.direction; + +import chess.domain.position.Position; + +import java.util.ArrayList; +import java.util.List; + +public class RightStrategy implements DirectionStrategy { + @Override + public List find(Position source, Position target) { + List path = new ArrayList<>(); + + for (int i = target.getFile() - 1; i > source.getFile(); i--) { + path.add(Position.of(i, source.getRank())); + } + return path; + } +} \ No newline at end of file diff --git a/src/main/java/chess/domain/move/direction/RightUpStrategy.java b/src/main/java/chess/domain/move/direction/RightUpStrategy.java new file mode 100644 index 00000000000..bd2c6afcd4f --- /dev/null +++ b/src/main/java/chess/domain/move/direction/RightUpStrategy.java @@ -0,0 +1,20 @@ +package chess.domain.move.direction; + +import chess.domain.position.Position; + +import java.util.ArrayList; +import java.util.List; + +public class RightUpStrategy implements DirectionStrategy { + + @Override + public List find(Position source, Position target) { + List path = new ArrayList<>(); + + for (int i = target.getFile() - 1 ; i > source.getFile() ; i--) { + path.add(Position.of(i, target.getRank() - (target.getFile() - i))); + } + + return path; + } +} diff --git a/src/main/java/chess/domain/piece/Piece.java b/src/main/java/chess/domain/piece/Piece.java index 5286a31b705..672aecf7216 100644 --- a/src/main/java/chess/domain/piece/Piece.java +++ b/src/main/java/chess/domain/piece/Piece.java @@ -6,12 +6,10 @@ public class Piece { private final PieceType pieceType; private final Team team; -// private final MoveStrategy moveStrategy; public Piece(final PieceType pieceType, final Team team) { this.pieceType = pieceType; this.team = team; -// this.moveStrategy = MoveStrategyFactory.create(pieceType, team); } public String toSymbol() { diff --git a/src/main/java/chess/domain/position/File.java b/src/main/java/chess/domain/position/File.java index 0a856960b02..51666ff95e8 100644 --- a/src/main/java/chess/domain/position/File.java +++ b/src/main/java/chess/domain/position/File.java @@ -3,19 +3,21 @@ import java.util.Arrays; public enum File { - A('a'), - B('b'), - C('c'), - D('d'), - E('e'), - F('f'), - G('g'), - H('h'); + A('a', 1), + B('b', 2), + C('c', 3), + D('d', 4), + E('e', 5), + F('f', 6), + G('g', 7), + H('h', 8); private final char symbol; + private final int number; - File(char symbol) { + File(char symbol, int number) { this.symbol = symbol; + this.number = number; } public static File of(String file) { @@ -27,11 +29,15 @@ public static File of(String file) { public static File of(int file) { return Arrays.stream(values()) - .filter(f -> f.symbol == (char) file) + .filter(f -> f.number == file) .findFirst() .orElseThrow(() -> new IllegalArgumentException("잘못된 x 좌표값을 입력하였습니다.")); } + public int getNumber() { + return number; + } + public int getSymbol() { return this.symbol; } diff --git a/src/main/java/chess/domain/position/Position.java b/src/main/java/chess/domain/position/Position.java index 29520ae3f02..8ca674b00fa 100644 --- a/src/main/java/chess/domain/position/Position.java +++ b/src/main/java/chess/domain/position/Position.java @@ -49,8 +49,6 @@ public static Position of(final File file, final Rank rank) { } public static Position of(final int fileSymbol, final int rankSymbol) { - - return findPosition(File.of(fileSymbol), Rank.of(rankSymbol)); } @@ -72,7 +70,7 @@ public int calculateRankGap(Position target) { } public int getFile() { - return this.file.getSymbol(); + return this.file.getNumber(); } public int getRank() { diff --git a/src/main/java/chess/view/InputView.java b/src/main/java/chess/view/InputView.java index 6d6ef517950..108539edd2a 100644 --- a/src/main/java/chess/view/InputView.java +++ b/src/main/java/chess/view/InputView.java @@ -1,6 +1,8 @@ package chess.view; public interface InputView { + boolean askChessRun(); + String askMove(); } From c6fd4f6dc2bc927b873ab53c6d530a91897bb67a Mon Sep 17 00:00:00 2001 From: giantim Date: Thu, 26 Mar 2020 16:26:21 +0900 Subject: [PATCH 10/75] =?UTF-8?q?feat:=202=EB=8B=A8=EA=B3=84=20=EA=B5=AC?= =?UTF-8?q?=ED=98=84?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/main/java/chess/ChessApplication.java | 2 +- .../chess/controller/ChessController.java | 32 ++++++++++++++----- src/main/java/chess/domain/board/Board.java | 3 +- .../chess/domain/move/KingMoveStrategy.java | 1 - .../java/chess/domain/move/MoveStrategy.java | 2 +- .../chess/domain/move/RookMoveStrategy.java | 5 +-- .../move/direction/LeftDownStrategy.java | 2 +- .../domain/move/direction/LeftUpStrategy.java | 3 +- .../move/direction/RightDownStrategy.java | 2 +- .../move/direction/RightUpStrategy.java | 2 +- .../domain/move/direction/UpStrategy.java | 4 +-- .../java/chess/domain/position/Position.java | 3 +- src/main/java/chess/domain/position/Rank.java | 5 +++ 13 files changed, 40 insertions(+), 26 deletions(-) diff --git a/src/main/java/chess/ChessApplication.java b/src/main/java/chess/ChessApplication.java index f70d30b2b5f..ac637cc3938 100644 --- a/src/main/java/chess/ChessApplication.java +++ b/src/main/java/chess/ChessApplication.java @@ -5,6 +5,6 @@ public class ChessApplication { public static void main(String[] args) { - ChessController.run(); + ChessController.start(); } } \ No newline at end of file diff --git a/src/main/java/chess/controller/ChessController.java b/src/main/java/chess/controller/ChessController.java index 6590998b01b..6bc65e1e79e 100644 --- a/src/main/java/chess/controller/ChessController.java +++ b/src/main/java/chess/controller/ChessController.java @@ -14,15 +14,31 @@ public class ChessController { private static InputView inputView = new ConsoleInputView(); private static OutputView outputView = new ConsoleOutputView(); - public static void run() { + public static void start() { if (inputView.askChessRun()) { - ChessRunner chessRunner = new ChessRunner(); - printInitialize(chessRunner.getBoard()); - String[] moveSource = inputView.askMove().split(" "); - String sourcePosition = moveSource[1]; - String targetPosition = moveSource[2]; - chessRunner.update(sourcePosition, targetPosition); - printInitialize(chessRunner.getBoard()); + run(); + } + } + + + public static void run() { + ChessRunner chessRunner = new ChessRunner(); + printInitialize(chessRunner.getBoard()); + boolean moveFlag = true; + + while (moveFlag) { + try { + String[] moveSource = inputView.askMove().split(" "); + if (moveSource[0].toUpperCase() == "END") { + break; + } + String sourcePosition = moveSource[1]; + String targetPosition = moveSource[2]; + chessRunner.update(sourcePosition, targetPosition); + printInitialize(chessRunner.getBoard()); + } catch (IllegalArgumentException e) { + System.out.println(e.getMessage()); + } } } diff --git a/src/main/java/chess/domain/board/Board.java b/src/main/java/chess/domain/board/Board.java index e98ce9021fc..1df9825a933 100644 --- a/src/main/java/chess/domain/board/Board.java +++ b/src/main/java/chess/domain/board/Board.java @@ -1,7 +1,6 @@ package chess.domain.board; import chess.domain.piece.Piece; -import chess.domain.piece.Team; import chess.domain.position.Position; import java.util.Collections; @@ -31,7 +30,7 @@ public void updateBoard(Position sourcePosition, Position targetPosition, Piece } public boolean isEmpty(final Position position) { - return this.board.containsKey(position); + return !this.board.containsKey(position); } public Piece getPiece(final Position position) { diff --git a/src/main/java/chess/domain/move/KingMoveStrategy.java b/src/main/java/chess/domain/move/KingMoveStrategy.java index bc816329df6..c4e9a086426 100644 --- a/src/main/java/chess/domain/move/KingMoveStrategy.java +++ b/src/main/java/chess/domain/move/KingMoveStrategy.java @@ -1,7 +1,6 @@ package chess.domain.move; import chess.domain.board.Board; -import chess.domain.piece.Piece; import chess.domain.position.Position; public class KingMoveStrategy extends MoveStrategy { diff --git a/src/main/java/chess/domain/move/MoveStrategy.java b/src/main/java/chess/domain/move/MoveStrategy.java index 77524596c9e..bb43e5055c3 100644 --- a/src/main/java/chess/domain/move/MoveStrategy.java +++ b/src/main/java/chess/domain/move/MoveStrategy.java @@ -16,7 +16,7 @@ protected boolean isSamePosition(Position source, Position target) { public abstract boolean movable(Position source, Position target, Board board); protected boolean checkObstacle(Position source, Position target, Board board) { - DirectionStrategy directionStrategy= PathFinder.find(source, target); + DirectionStrategy directionStrategy = PathFinder.find(source, target); List path = directionStrategy.find(source, target); for (Position position : path) { diff --git a/src/main/java/chess/domain/move/RookMoveStrategy.java b/src/main/java/chess/domain/move/RookMoveStrategy.java index d9db390d72d..67ce216c581 100644 --- a/src/main/java/chess/domain/move/RookMoveStrategy.java +++ b/src/main/java/chess/domain/move/RookMoveStrategy.java @@ -1,11 +1,8 @@ package chess.domain.move; import chess.domain.board.Board; -import chess.domain.move.direction.DirectionStrategy; import chess.domain.position.Position; -import java.util.List; - public class RookMoveStrategy extends MoveStrategy { @Override public boolean movable(Position source, Position target, Board board) { @@ -16,7 +13,7 @@ public boolean movable(Position source, Position target, Board board) { int fileGap = Math.abs(source.calculateFileGap(target)); int rankGap = Math.abs(source.calculateRankGap(target)); - return (fileGap == 0 && rankGap > 0) + return ((fileGap > 0 && rankGap == 0) || (fileGap == 0 && rankGap > 0)) && checkObstacle(source, target, board) && checkTarget(source, target, board); } diff --git a/src/main/java/chess/domain/move/direction/LeftDownStrategy.java b/src/main/java/chess/domain/move/direction/LeftDownStrategy.java index 29dd121a889..a2950d3d9b3 100644 --- a/src/main/java/chess/domain/move/direction/LeftDownStrategy.java +++ b/src/main/java/chess/domain/move/direction/LeftDownStrategy.java @@ -11,7 +11,7 @@ public class LeftDownStrategy implements DirectionStrategy { public List find(Position source, Position target) { List path = new ArrayList<>(); - for (int i = target.getFile() + 1 ; i < source.getFile() ; i++) { + for (int i = target.getFile() + 1; i < source.getFile(); i++) { path.add(Position.of(i, target.getRank() - (target.getFile() - i))); } diff --git a/src/main/java/chess/domain/move/direction/LeftUpStrategy.java b/src/main/java/chess/domain/move/direction/LeftUpStrategy.java index 30e0511bbd5..f2a8719eaa3 100644 --- a/src/main/java/chess/domain/move/direction/LeftUpStrategy.java +++ b/src/main/java/chess/domain/move/direction/LeftUpStrategy.java @@ -1,6 +1,5 @@ package chess.domain.move.direction; -import chess.domain.position.File; import chess.domain.position.Position; import java.util.ArrayList; @@ -11,7 +10,7 @@ public class LeftUpStrategy implements DirectionStrategy { public List find(Position source, Position target) { List path = new ArrayList<>(); - for (int i = target.getFile() + 1 ; i < source.getFile() ; i++) { + for (int i = target.getFile() + 1; i < source.getFile(); i++) { path.add(Position.of(i, target.getRank() + (target.getFile() - i))); } diff --git a/src/main/java/chess/domain/move/direction/RightDownStrategy.java b/src/main/java/chess/domain/move/direction/RightDownStrategy.java index abde87be180..ce28c51645f 100644 --- a/src/main/java/chess/domain/move/direction/RightDownStrategy.java +++ b/src/main/java/chess/domain/move/direction/RightDownStrategy.java @@ -11,7 +11,7 @@ public class RightDownStrategy implements DirectionStrategy { public List find(Position source, Position target) { List path = new ArrayList<>(); - for (int i = target.getFile() - 1 ; i > source.getFile() ; i--) { + for (int i = target.getFile() - 1; i > source.getFile(); i--) { path.add(Position.of(i, target.getRank() - (target.getFile() - i))); } diff --git a/src/main/java/chess/domain/move/direction/RightUpStrategy.java b/src/main/java/chess/domain/move/direction/RightUpStrategy.java index bd2c6afcd4f..b19bd61bd58 100644 --- a/src/main/java/chess/domain/move/direction/RightUpStrategy.java +++ b/src/main/java/chess/domain/move/direction/RightUpStrategy.java @@ -11,7 +11,7 @@ public class RightUpStrategy implements DirectionStrategy { public List find(Position source, Position target) { List path = new ArrayList<>(); - for (int i = target.getFile() - 1 ; i > source.getFile() ; i--) { + for (int i = target.getFile() - 1; i > source.getFile(); i--) { path.add(Position.of(i, target.getRank() - (target.getFile() - i))); } diff --git a/src/main/java/chess/domain/move/direction/UpStrategy.java b/src/main/java/chess/domain/move/direction/UpStrategy.java index 3fd2319d9e8..1bcf3de6da6 100644 --- a/src/main/java/chess/domain/move/direction/UpStrategy.java +++ b/src/main/java/chess/domain/move/direction/UpStrategy.java @@ -11,8 +11,8 @@ public List find(Position source, Position target) { List path = new ArrayList<>(); for (int i = target.getRank() - 1; i > source.getRank(); i--) { - path.add(Position.of(source.getFile(), i)); - } + path.add(Position.of(source.getFile(), i)); + } return path; } } \ No newline at end of file diff --git a/src/main/java/chess/domain/position/Position.java b/src/main/java/chess/domain/position/Position.java index 8ca674b00fa..ac8a76b63e4 100644 --- a/src/main/java/chess/domain/position/Position.java +++ b/src/main/java/chess/domain/position/Position.java @@ -65,8 +65,7 @@ public int calculateFileGap(Position target) { } public int calculateRankGap(Position target) { - int rankGap = this.rank.compareTo(target.rank); - return rankGap; + return this.rank.getDifference(target.rank); } public int getFile() { diff --git a/src/main/java/chess/domain/position/Rank.java b/src/main/java/chess/domain/position/Rank.java index c1cbd0e889c..86f966f7544 100644 --- a/src/main/java/chess/domain/position/Rank.java +++ b/src/main/java/chess/domain/position/Rank.java @@ -35,4 +35,9 @@ public static Rank of(int rank) { public int getSymbol() { return this.symbol; } + + + public int getDifference(Rank rank) { + return this.symbol - rank.symbol; + } } From b757656f3fc887817f142625fad305c50b8e176d Mon Sep 17 00:00:00 2001 From: giantim Date: Thu, 26 Mar 2020 16:46:54 +0900 Subject: [PATCH 11/75] =?UTF-8?q?feat:=20=EC=99=95=EC=9D=B4=20=EC=A3=BD?= =?UTF-8?q?=EC=97=88=EC=9D=84=20=EB=95=8C=20=EC=8A=B9=EB=A6=AC=ED=95=9C=20?= =?UTF-8?q?=ED=8C=80=20=EC=B6=9C=EB=A0=A5?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../chess/controller/ChessController.java | 9 +++++++ src/main/java/chess/domain/ChessRunner.java | 4 +++ src/main/java/chess/domain/board/Board.java | 25 +++++++++++++++++++ src/main/java/chess/domain/piece/Piece.java | 8 ++++++ .../java/chess/domain/piece/PieceType.java | 4 +++ .../java/chess/view/ConsoleOutputView.java | 7 ++++++ src/main/java/chess/view/OutputView.java | 4 +++ 7 files changed, 61 insertions(+) diff --git a/src/main/java/chess/controller/ChessController.java b/src/main/java/chess/controller/ChessController.java index 6bc65e1e79e..7ae66f09a21 100644 --- a/src/main/java/chess/controller/ChessController.java +++ b/src/main/java/chess/controller/ChessController.java @@ -36,12 +36,21 @@ public static void run() { String targetPosition = moveSource[2]; chessRunner.update(sourcePosition, targetPosition); printInitialize(chessRunner.getBoard()); + if (checkWinner(chessRunner)) continue; + } catch (IllegalArgumentException e) { System.out.println(e.getMessage()); } } } + private static boolean checkWinner(ChessRunner chessRunner) { + if (chessRunner.checkWinner() != null) { + outputView.printWinner(chessRunner.checkWinner()); + } + return true; + } + private static void printInitialize(Board board) { BoardDto boardDto = new BoardDto(board.parse()); PositionDto positionDto = new PositionDto(Position.getPositions()); diff --git a/src/main/java/chess/domain/ChessRunner.java b/src/main/java/chess/domain/ChessRunner.java index 478814ed72b..b1f462e2d01 100644 --- a/src/main/java/chess/domain/ChessRunner.java +++ b/src/main/java/chess/domain/ChessRunner.java @@ -37,6 +37,10 @@ private void changeTurn() { this.currentTeam = Team.changeTurn(this.currentTeam); } + public Team checkWinner() { + return this.board.checkWinner(); + } + public Board getBoard() { return this.board; } diff --git a/src/main/java/chess/domain/board/Board.java b/src/main/java/chess/domain/board/Board.java index 1df9825a933..d2983e520b6 100644 --- a/src/main/java/chess/domain/board/Board.java +++ b/src/main/java/chess/domain/board/Board.java @@ -1,6 +1,7 @@ package chess.domain.board; import chess.domain.piece.Piece; +import chess.domain.piece.Team; import chess.domain.position.Position; import java.util.Collections; @@ -29,6 +30,30 @@ public void updateBoard(Position sourcePosition, Position targetPosition, Piece this.board.remove(sourcePosition); } + public Team checkWinner() { + if (checkWhiteKing() && !checkBlackKing()) { + return Team.WHITE; + } + if (!checkWhiteKing() && checkBlackKing()) { + return Team.BLACK; + } + return null; + } + + private boolean checkWhiteKing() { + for (Piece piece : board.values()) { + if (piece.isWhiteKing()) return true; + } + return false; + } + + private boolean checkBlackKing() { + for (Piece piece : board.values()) { + if (piece.isBlackKing()) return true; + } + return false; + } + public boolean isEmpty(final Position position) { return !this.board.containsKey(position); } diff --git a/src/main/java/chess/domain/piece/Piece.java b/src/main/java/chess/domain/piece/Piece.java index 672aecf7216..7ca77251f52 100644 --- a/src/main/java/chess/domain/piece/Piece.java +++ b/src/main/java/chess/domain/piece/Piece.java @@ -27,4 +27,12 @@ public boolean isEnemy(Piece targetPiece) { public Team getTeam() { return this.team; } + + public boolean isWhiteKing() { + return this.pieceType.isKing() && this.team.isWhite(); + } + + public boolean isBlackKing() { + return this.pieceType.isKing() && !this.team.isWhite(); + } } diff --git a/src/main/java/chess/domain/piece/PieceType.java b/src/main/java/chess/domain/piece/PieceType.java index f3e742e3247..89814cbccb3 100644 --- a/src/main/java/chess/domain/piece/PieceType.java +++ b/src/main/java/chess/domain/piece/PieceType.java @@ -29,4 +29,8 @@ public String getSymbol() { public boolean move(Position source, Position target, Board board) { return this.moveStrategy.movable(source, target, board); } + + public boolean isKing() { + return this == KING; + } } \ No newline at end of file diff --git a/src/main/java/chess/view/ConsoleOutputView.java b/src/main/java/chess/view/ConsoleOutputView.java index d9208378aae..641b002edec 100644 --- a/src/main/java/chess/view/ConsoleOutputView.java +++ b/src/main/java/chess/view/ConsoleOutputView.java @@ -1,5 +1,7 @@ package chess.view; +import chess.domain.piece.Team; + import java.util.List; import java.util.Map; @@ -28,4 +30,9 @@ private String printPiece(String piece) { } return piece; } + + @Override + public void printWinner(Team team) { + System.out.println(String.format("%s 팀이 이겼습니다.", team.name())); + } } diff --git a/src/main/java/chess/view/OutputView.java b/src/main/java/chess/view/OutputView.java index 578a232713f..1678ba6d52e 100644 --- a/src/main/java/chess/view/OutputView.java +++ b/src/main/java/chess/view/OutputView.java @@ -1,8 +1,12 @@ package chess.view; +import chess.domain.piece.Team; + import java.util.List; import java.util.Map; public interface OutputView { void printBoard(List positions, Map board); + + void printWinner(Team team); } From 202d59045ef399e62f01b367328de301fab4fbe4 Mon Sep 17 00:00:00 2001 From: giantim Date: Thu, 26 Mar 2020 16:47:44 +0900 Subject: [PATCH 12/75] =?UTF-8?q?feat:=20=EC=99=95=EC=9D=B4=20=EC=A3=BD?= =?UTF-8?q?=EC=97=88=EC=9D=84=20=EB=95=8C=20=EA=B2=8C=EC=9E=84=20=EC=A2=85?= =?UTF-8?q?=EB=A3=8C?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/main/java/chess/controller/ChessController.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/main/java/chess/controller/ChessController.java b/src/main/java/chess/controller/ChessController.java index 7ae66f09a21..b5922ae1d82 100644 --- a/src/main/java/chess/controller/ChessController.java +++ b/src/main/java/chess/controller/ChessController.java @@ -36,7 +36,7 @@ public static void run() { String targetPosition = moveSource[2]; chessRunner.update(sourcePosition, targetPosition); printInitialize(chessRunner.getBoard()); - if (checkWinner(chessRunner)) continue; + if (!checkWinner(chessRunner)) break; } catch (IllegalArgumentException e) { System.out.println(e.getMessage()); From 622ee0a626f2d50e27bb42e6b500bc56584279dd Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=EA=B9=80=EC=98=88=EB=B9=88?= Date: Thu, 26 Mar 2020 17:16:44 +0900 Subject: [PATCH 13/75] =?UTF-8?q?feat:=20status=20=EB=AA=85=EB=A0=B9?= =?UTF-8?q?=EC=96=B4=20=EC=9E=85=EB=A0=A5=20=EC=8B=9C=20=EC=A0=90=EC=88=98?= =?UTF-8?q?=20=EA=B3=84=EC=82=B0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/main/java/chess/controller/ChessController.java | 9 ++++++--- src/main/java/chess/domain/ChessRunner.java | 11 ++++++++--- src/main/java/chess/domain/board/Board.java | 10 ++++++++++ src/main/java/chess/domain/piece/Piece.java | 12 ++++++++---- src/main/java/chess/domain/piece/PieceType.java | 4 ++++ src/main/java/chess/view/ConsoleInputView.java | 6 +++--- src/main/java/chess/view/ConsoleOutputView.java | 5 +++++ src/main/java/chess/view/InputView.java | 2 +- src/main/java/chess/view/OutputView.java | 2 ++ 9 files changed, 47 insertions(+), 14 deletions(-) diff --git a/src/main/java/chess/controller/ChessController.java b/src/main/java/chess/controller/ChessController.java index b5922ae1d82..888d6e8da30 100644 --- a/src/main/java/chess/controller/ChessController.java +++ b/src/main/java/chess/controller/ChessController.java @@ -20,7 +20,6 @@ public static void start() { } } - public static void run() { ChessRunner chessRunner = new ChessRunner(); printInitialize(chessRunner.getBoard()); @@ -28,10 +27,14 @@ public static void run() { while (moveFlag) { try { - String[] moveSource = inputView.askMove().split(" "); - if (moveSource[0].toUpperCase() == "END") { + String[] moveSource = inputView.askMoveOrStatus().split(" "); + if (moveSource[0].toUpperCase().equals("END")) { break; } + if (moveSource[0].toUpperCase().equals("STATUS")) { + outputView.printStatus(chessRunner.calculateScore(), chessRunner.getCurrentTeam()); + continue; + } String sourcePosition = moveSource[1]; String targetPosition = moveSource[2]; chessRunner.update(sourcePosition, targetPosition); diff --git a/src/main/java/chess/domain/ChessRunner.java b/src/main/java/chess/domain/ChessRunner.java index b1f462e2d01..73c1d1f6ee9 100644 --- a/src/main/java/chess/domain/ChessRunner.java +++ b/src/main/java/chess/domain/ChessRunner.java @@ -26,11 +26,8 @@ public void update(String source, String target) { if (!(selectedPiece.move(sourcePosition, targetPosition, board))) { throw new IllegalArgumentException("이동할 수 없는 곳입니다."); } - this.board.updateBoard(sourcePosition, targetPosition, selectedPiece); - changeTurn(); - } private void changeTurn() { @@ -41,6 +38,14 @@ public Team checkWinner() { return this.board.checkWinner(); } + public double calculateScore() { + return board.calculateScore(currentTeam); + } + + public Team getCurrentTeam() { + return currentTeam; + } + public Board getBoard() { return this.board; } diff --git a/src/main/java/chess/domain/board/Board.java b/src/main/java/chess/domain/board/Board.java index d2983e520b6..13f0666a432 100644 --- a/src/main/java/chess/domain/board/Board.java +++ b/src/main/java/chess/domain/board/Board.java @@ -61,4 +61,14 @@ public boolean isEmpty(final Position position) { public Piece getPiece(final Position position) { return this.board.get(position); } + + public double calculateScore(Team team) { + double score = 0; + for (Piece piece : board.values()) { + if (piece.getTeam() == team) { + score += piece.getScore(); + } + } + return score; + } } \ No newline at end of file diff --git a/src/main/java/chess/domain/piece/Piece.java b/src/main/java/chess/domain/piece/Piece.java index 7ca77251f52..ade246fb0e3 100644 --- a/src/main/java/chess/domain/piece/Piece.java +++ b/src/main/java/chess/domain/piece/Piece.java @@ -24,10 +24,6 @@ public boolean isEnemy(Piece targetPiece) { return this.team.isEnemy(targetPiece.getTeam()); } - public Team getTeam() { - return this.team; - } - public boolean isWhiteKing() { return this.pieceType.isKing() && this.team.isWhite(); } @@ -35,4 +31,12 @@ public boolean isWhiteKing() { public boolean isBlackKing() { return this.pieceType.isKing() && !this.team.isWhite(); } + + public Team getTeam() { + return this.team; + } + + public double getScore() { + return this.pieceType.getScore(); + } } diff --git a/src/main/java/chess/domain/piece/PieceType.java b/src/main/java/chess/domain/piece/PieceType.java index 89814cbccb3..8bf41e1ada4 100644 --- a/src/main/java/chess/domain/piece/PieceType.java +++ b/src/main/java/chess/domain/piece/PieceType.java @@ -33,4 +33,8 @@ public boolean move(Position source, Position target, Board board) { public boolean isKing() { return this == KING; } + + public double getScore() { + return score; + } } \ No newline at end of file diff --git a/src/main/java/chess/view/ConsoleInputView.java b/src/main/java/chess/view/ConsoleInputView.java index 3dc45472fba..83347cc5bd3 100644 --- a/src/main/java/chess/view/ConsoleInputView.java +++ b/src/main/java/chess/view/ConsoleInputView.java @@ -37,19 +37,19 @@ private boolean runFlag(String input) { } @Override - public String askMove() { + public String askMoveOrStatus() { try { String input = SCANNER.nextLine(); validateMove(input); return input; } catch (IllegalArgumentException e) { System.out.println(e.getMessage()); - return askMove(); + return askMoveOrStatus(); } } private static void validateMove(String input) { - if (!input.contains("move")) { + if (!input.contains("move") && !input.equals("status") && !input.equals("end")) { throw new IllegalArgumentException("잘못된 명령어를 입력하였습니다."); } } diff --git a/src/main/java/chess/view/ConsoleOutputView.java b/src/main/java/chess/view/ConsoleOutputView.java index 641b002edec..b6326a5d503 100644 --- a/src/main/java/chess/view/ConsoleOutputView.java +++ b/src/main/java/chess/view/ConsoleOutputView.java @@ -35,4 +35,9 @@ private String printPiece(String piece) { public void printWinner(Team team) { System.out.println(String.format("%s 팀이 이겼습니다.", team.name())); } + + @Override + public void printStatus(double calculateScore, Team team) { + System.out.println(String.format("%s 팀의 점수는 %.1f 점입니다.", team.name(), calculateScore)); + } } diff --git a/src/main/java/chess/view/InputView.java b/src/main/java/chess/view/InputView.java index 108539edd2a..01c2fb9df8f 100644 --- a/src/main/java/chess/view/InputView.java +++ b/src/main/java/chess/view/InputView.java @@ -4,5 +4,5 @@ public interface InputView { boolean askChessRun(); - String askMove(); + String askMoveOrStatus(); } diff --git a/src/main/java/chess/view/OutputView.java b/src/main/java/chess/view/OutputView.java index 1678ba6d52e..99cf6959ee1 100644 --- a/src/main/java/chess/view/OutputView.java +++ b/src/main/java/chess/view/OutputView.java @@ -9,4 +9,6 @@ public interface OutputView { void printBoard(List positions, Map board); void printWinner(Team team); + + void printStatus(double calculateScore, Team team); } From 6a947619329fdeec0cb45cce56c47037f8a58ca2 Mon Sep 17 00:00:00 2001 From: giantim Date: Thu, 26 Mar 2020 17:35:55 +0900 Subject: [PATCH 14/75] =?UTF-8?q?feat:=203=EB=8B=A8=EA=B3=84=20=EA=B8=B0?= =?UTF-8?q?=EB=8A=A5=20=EA=B5=AC=ED=98=84?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/main/java/chess/domain/board/Board.java | 12 ++++++++++++ src/main/java/chess/domain/piece/Piece.java | 8 ++++++++ src/main/java/chess/domain/piece/PieceType.java | 4 ++++ 3 files changed, 24 insertions(+) diff --git a/src/main/java/chess/domain/board/Board.java b/src/main/java/chess/domain/board/Board.java index 13f0666a432..39ebb6c7b8a 100644 --- a/src/main/java/chess/domain/board/Board.java +++ b/src/main/java/chess/domain/board/Board.java @@ -2,10 +2,12 @@ import chess.domain.piece.Piece; import chess.domain.piece.Team; +import chess.domain.position.File; import chess.domain.position.Position; import java.util.Collections; import java.util.LinkedHashMap; +import java.util.List; import java.util.Map; import java.util.stream.Collectors; @@ -69,6 +71,16 @@ public double calculateScore(Team team) { score += piece.getScore(); } } + + for (File file : File.values()) { + List> sameFile = this.board.entrySet().stream() + .filter(entry -> File.of(entry.getKey().getFile()).equals(file)) + .filter(entry -> entry.getValue().isPawn() && !entry.getValue().isEnemy(team)) + .collect(Collectors.toList()); + if (sameFile.size() > 1) { + score -= sameFile.size() * 0.5; + } + } return score; } } \ No newline at end of file diff --git a/src/main/java/chess/domain/piece/Piece.java b/src/main/java/chess/domain/piece/Piece.java index ade246fb0e3..46befc3474c 100644 --- a/src/main/java/chess/domain/piece/Piece.java +++ b/src/main/java/chess/domain/piece/Piece.java @@ -24,6 +24,10 @@ public boolean isEnemy(Piece targetPiece) { return this.team.isEnemy(targetPiece.getTeam()); } + public boolean isEnemy(Team team) { + return this.team.isEnemy(team); + } + public boolean isWhiteKing() { return this.pieceType.isKing() && this.team.isWhite(); } @@ -39,4 +43,8 @@ public Team getTeam() { public double getScore() { return this.pieceType.getScore(); } + + public boolean isPawn() { + return this.pieceType.isPawn(); + } } diff --git a/src/main/java/chess/domain/piece/PieceType.java b/src/main/java/chess/domain/piece/PieceType.java index 8bf41e1ada4..c9594930798 100644 --- a/src/main/java/chess/domain/piece/PieceType.java +++ b/src/main/java/chess/domain/piece/PieceType.java @@ -37,4 +37,8 @@ public boolean isKing() { public double getScore() { return score; } + + public boolean isPawn() { + return this == PAWN; + } } \ No newline at end of file From fdc9cfa1a295936c35765e47f5941879eb938a78 Mon Sep 17 00:00:00 2001 From: giantim Date: Thu, 26 Mar 2020 17:40:07 +0900 Subject: [PATCH 15/75] =?UTF-8?q?doc:=20README=20=EC=97=85=EB=8D=B0?= =?UTF-8?q?=EC=9D=B4=ED=8A=B8?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- README.md | 19 +++++++++++++++---- 1 file changed, 15 insertions(+), 4 deletions(-) diff --git a/README.md b/README.md index ef5dd275132..0c1464ff026 100644 --- a/README.md +++ b/README.md @@ -4,7 +4,18 @@ ## 기능 요구 사항 1단계 - - [ ] 명령어를 입력 받는다(start, end) - - [ ] (예외) start, end 외의 명령어가 입력된 경우 다시 명령어를 입력 받는다 - - [ ] start 를 입력 시 체스판을 초기화 한다 - - [ ] end 를 입력 시 게임을 종료한다 + - [x] 명령어를 입력 받는다(start, end) + - [x] (예외) start, end 외의 명령어가 입력된 경우 다시 명령어를 입력 받는다 + - [x] start 를 입력 시 체스판을 초기화 한다 + - [x] end 를 입력 시 게임을 종료한다 + + 2단계 + - [x] 체스 말 규칙에 따라 말을 이동한다 + - [x] 폰은 시작 위치에서 2칸 이동이 가능하고 시작 위치가 아닐 때 대각선의 적을 잡을 수 있다 + - [x] `move source위치 target위치` 명령어로 말을 움직인다 + + 3단계 + - [x] 왕을 잡으면 게임이 종료된다 + - [x] `status` 명령어를 입력하면 현재 남아있는 말의 점수를 구할 수 있다 + - [x] 한 번에 한 쪽의 점수만 계산한다 + - [x] 같은 세로줄에 같은 색의 폰이 있는 경우 1점이 아닌 0.5점을 준다 From fb4d0af351e33e203c6a5583892c1b62c9b6cf06 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=EA=B9=80=EC=98=88=EB=B9=88?= Date: Thu, 26 Mar 2020 20:36:06 +0900 Subject: [PATCH 16/75] =?UTF-8?q?refactor:=20=EC=84=B8=EB=B6=80=20?= =?UTF-8?q?=EB=84=A4=EC=9D=B4=EB=B0=8D=20=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../chess/controller/ChessController.java | 17 ++++++++------- .../chess/controller/dto/PositionDto.java | 2 +- src/main/java/chess/domain/ChessRunner.java | 18 +++++++++------- src/main/java/chess/domain/board/Board.java | 21 ++++++++++++------- ...der.java => DirectionStrategyFactory.java} | 2 +- .../java/chess/domain/move/MoveStrategy.java | 6 +++--- src/main/java/chess/domain/piece/Piece.java | 18 ++++++++-------- .../java/chess/domain/piece/PieceType.java | 14 ++++++------- src/main/java/chess/domain/piece/Team.java | 8 +++---- src/main/java/chess/domain/position/File.java | 4 ---- src/main/java/chess/domain/position/Rank.java | 3 +-- .../java/chess/view/ConsoleInputView.java | 9 +++----- 12 files changed, 64 insertions(+), 58 deletions(-) rename src/main/java/chess/domain/move/{PathFinder.java => DirectionStrategyFactory.java} (96%) diff --git a/src/main/java/chess/controller/ChessController.java b/src/main/java/chess/controller/ChessController.java index 888d6e8da30..7488488f82d 100644 --- a/src/main/java/chess/controller/ChessController.java +++ b/src/main/java/chess/controller/ChessController.java @@ -4,6 +4,7 @@ import chess.controller.dto.PositionDto; import chess.domain.ChessRunner; import chess.domain.board.Board; +import chess.domain.piece.Team; import chess.domain.position.Position; import chess.view.ConsoleInputView; import chess.view.ConsoleOutputView; @@ -22,7 +23,7 @@ public static void start() { public static void run() { ChessRunner chessRunner = new ChessRunner(); - printInitialize(chessRunner.getBoard()); + printBoard(chessRunner.getBoard()); boolean moveFlag = true; while (moveFlag) { @@ -38,8 +39,8 @@ public static void run() { String sourcePosition = moveSource[1]; String targetPosition = moveSource[2]; chessRunner.update(sourcePosition, targetPosition); - printInitialize(chessRunner.getBoard()); - if (!checkWinner(chessRunner)) break; + printBoard(chessRunner.getBoard()); + if (!findWinner(chessRunner)) break; } catch (IllegalArgumentException e) { System.out.println(e.getMessage()); @@ -47,14 +48,16 @@ public static void run() { } } - private static boolean checkWinner(ChessRunner chessRunner) { - if (chessRunner.checkWinner() != null) { - outputView.printWinner(chessRunner.checkWinner()); + private static boolean findWinner(ChessRunner chessRunner) { + Team winner = chessRunner.findWinner(); + if (winner != null) { + outputView.printWinner(winner); + return false; } return true; } - private static void printInitialize(Board board) { + private static void printBoard(Board board) { BoardDto boardDto = new BoardDto(board.parse()); PositionDto positionDto = new PositionDto(Position.getPositions()); outputView.printBoard(positionDto.getPositions(), boardDto.get()); diff --git a/src/main/java/chess/controller/dto/PositionDto.java b/src/main/java/chess/controller/dto/PositionDto.java index db5875990fe..4083a2f2444 100644 --- a/src/main/java/chess/controller/dto/PositionDto.java +++ b/src/main/java/chess/controller/dto/PositionDto.java @@ -13,4 +13,4 @@ public PositionDto(final List positions) { public List getPositions() { return Collections.unmodifiableList(positions); } -} +} \ No newline at end of file diff --git a/src/main/java/chess/domain/ChessRunner.java b/src/main/java/chess/domain/ChessRunner.java index 73c1d1f6ee9..9adfae4119f 100644 --- a/src/main/java/chess/domain/ChessRunner.java +++ b/src/main/java/chess/domain/ChessRunner.java @@ -19,22 +19,26 @@ public void update(String source, String target) { Position targetPosition = Position.of(target); Piece selectedPiece = this.board.getPiece(sourcePosition); - if ((currentTeam.isEnemy(selectedPiece.getTeam()))) { + if ((currentTeam.isSameTeamWith(selectedPiece.getTeam()))) { throw new IllegalArgumentException("현재 차례가 아닙니다."); } - if (!(selectedPiece.move(sourcePosition, targetPosition, board))) { + if (!(selectedPiece.movable(sourcePosition, targetPosition, board))) { throw new IllegalArgumentException("이동할 수 없는 곳입니다."); } - this.board.updateBoard(sourcePosition, targetPosition, selectedPiece); - changeTurn(); + updateBoard(sourcePosition, targetPosition); + changeTeam(); } - private void changeTurn() { - this.currentTeam = Team.changeTurn(this.currentTeam); + private void updateBoard(Position sourcePosition, Position targetPosition) { + this.board.updateBoard(sourcePosition, targetPosition); } - public Team checkWinner() { + private void changeTeam() { + this.currentTeam = Team.changeTeam(this.currentTeam); + } + + public Team findWinner() { return this.board.checkWinner(); } diff --git a/src/main/java/chess/domain/board/Board.java b/src/main/java/chess/domain/board/Board.java index 39ebb6c7b8a..0c5c21b5034 100644 --- a/src/main/java/chess/domain/board/Board.java +++ b/src/main/java/chess/domain/board/Board.java @@ -27,7 +27,8 @@ public Map parse() { return Collections.unmodifiableMap(parseResult); } - public void updateBoard(Position sourcePosition, Position targetPosition, Piece selectedPiece) { + public void updateBoard(Position sourcePosition, Position targetPosition) { + Piece selectedPiece = this.board.get(sourcePosition); this.board.put(targetPosition, selectedPiece); this.board.remove(sourcePosition); } @@ -65,18 +66,24 @@ public Piece getPiece(final Position position) { } public double calculateScore(Team team) { - double score = 0; - for (Piece piece : board.values()) { - if (piece.getTeam() == team) { - score += piece.getScore(); - } - } + double totalScore = calculateTotalScore(team); + return calculatePawnScore(team, totalScore); + } + private double calculateTotalScore(Team team) { + return board.values().stream() + .filter(piece -> team.isSameTeamWith(piece.getTeam())) + .mapToDouble(Piece::getScore) + .sum(); + } + + private double calculatePawnScore(Team team, double score) { for (File file : File.values()) { List> sameFile = this.board.entrySet().stream() .filter(entry -> File.of(entry.getKey().getFile()).equals(file)) .filter(entry -> entry.getValue().isPawn() && !entry.getValue().isEnemy(team)) .collect(Collectors.toList()); + if (sameFile.size() > 1) { score -= sameFile.size() * 0.5; } diff --git a/src/main/java/chess/domain/move/PathFinder.java b/src/main/java/chess/domain/move/DirectionStrategyFactory.java similarity index 96% rename from src/main/java/chess/domain/move/PathFinder.java rename to src/main/java/chess/domain/move/DirectionStrategyFactory.java index 043af998b1e..ecd1202b79e 100644 --- a/src/main/java/chess/domain/move/PathFinder.java +++ b/src/main/java/chess/domain/move/DirectionStrategyFactory.java @@ -3,7 +3,7 @@ import chess.domain.move.direction.*; import chess.domain.position.Position; -public class PathFinder { +public class DirectionStrategyFactory { public static DirectionStrategy find(Position source, Position target) { int fileGap = target.calculateFileGap(source); int rankGap = target.calculateRankGap(source); diff --git a/src/main/java/chess/domain/move/MoveStrategy.java b/src/main/java/chess/domain/move/MoveStrategy.java index bb43e5055c3..f345d60fc2a 100644 --- a/src/main/java/chess/domain/move/MoveStrategy.java +++ b/src/main/java/chess/domain/move/MoveStrategy.java @@ -13,10 +13,8 @@ protected boolean isSamePosition(Position source, Position target) { return source.equals(target); } - public abstract boolean movable(Position source, Position target, Board board); - protected boolean checkObstacle(Position source, Position target, Board board) { - DirectionStrategy directionStrategy = PathFinder.find(source, target); + DirectionStrategy directionStrategy = DirectionStrategyFactory.find(source, target); List path = directionStrategy.find(source, target); for (Position position : path) { @@ -35,4 +33,6 @@ protected boolean checkTarget(Position source, Position target, Board board) { Piece targetPiece = board.getPiece(target); return sourcePiece.isEnemy(targetPiece); } + + public abstract boolean movable(Position source, Position target, Board board); } diff --git a/src/main/java/chess/domain/piece/Piece.java b/src/main/java/chess/domain/piece/Piece.java index 46befc3474c..72b62745474 100644 --- a/src/main/java/chess/domain/piece/Piece.java +++ b/src/main/java/chess/domain/piece/Piece.java @@ -13,19 +13,19 @@ public Piece(final PieceType pieceType, final Team team) { } public String toSymbol() { - return this.team.convert(this.pieceType.getSymbol()); + return this.team.symbolize(this.pieceType.getSymbol()); } - public boolean move(Position source, Position target, Board board) { - return this.pieceType.move(source, target, board); + public boolean movable(Position source, Position target, Board board) { + return this.pieceType.movable(source, target, board); } public boolean isEnemy(Piece targetPiece) { - return this.team.isEnemy(targetPiece.getTeam()); + return !this.team.isSameTeamWith(targetPiece.getTeam()); } public boolean isEnemy(Team team) { - return this.team.isEnemy(team); + return !this.team.isSameTeamWith(team); } public boolean isWhiteKing() { @@ -36,6 +36,10 @@ public boolean isBlackKing() { return this.pieceType.isKing() && !this.team.isWhite(); } + public boolean isPawn() { + return this.pieceType.isPawn(); + } + public Team getTeam() { return this.team; } @@ -43,8 +47,4 @@ public Team getTeam() { public double getScore() { return this.pieceType.getScore(); } - - public boolean isPawn() { - return this.pieceType.isPawn(); - } } diff --git a/src/main/java/chess/domain/piece/PieceType.java b/src/main/java/chess/domain/piece/PieceType.java index c9594930798..e503bf706f3 100644 --- a/src/main/java/chess/domain/piece/PieceType.java +++ b/src/main/java/chess/domain/piece/PieceType.java @@ -22,11 +22,7 @@ public enum PieceType { this.moveStrategy = moveStrategy; } - public String getSymbol() { - return symbol; - } - - public boolean move(Position source, Position target, Board board) { + public boolean movable(Position source, Position target, Board board) { return this.moveStrategy.movable(source, target, board); } @@ -34,11 +30,15 @@ public boolean isKing() { return this == KING; } + public boolean isPawn() { + return this == PAWN; + } + public double getScore() { return score; } - public boolean isPawn() { - return this == PAWN; + public String getSymbol() { + return symbol; } } \ No newline at end of file diff --git a/src/main/java/chess/domain/piece/Team.java b/src/main/java/chess/domain/piece/Team.java index bd6eae9ddb3..8b7d025abe0 100644 --- a/src/main/java/chess/domain/piece/Team.java +++ b/src/main/java/chess/domain/piece/Team.java @@ -12,19 +12,19 @@ public enum Team { this.expression = expression; } - public static Team changeTurn(Team team) { + public static Team changeTeam(Team team) { if (team == BLACK) { return WHITE; } return BLACK; } - public String convert(final String name) { + public String symbolize(final String name) { return this.expression.apply(name); } - public boolean isEnemy(Team team) { - return this != team; + public boolean isSameTeamWith(Team team) { + return this == team; } public boolean isWhite() { diff --git a/src/main/java/chess/domain/position/File.java b/src/main/java/chess/domain/position/File.java index 51666ff95e8..29f6ad3747a 100644 --- a/src/main/java/chess/domain/position/File.java +++ b/src/main/java/chess/domain/position/File.java @@ -37,8 +37,4 @@ public static File of(int file) { public int getNumber() { return number; } - - public int getSymbol() { - return this.symbol; - } } diff --git a/src/main/java/chess/domain/position/Rank.java b/src/main/java/chess/domain/position/Rank.java index 86f966f7544..f1034ef6464 100644 --- a/src/main/java/chess/domain/position/Rank.java +++ b/src/main/java/chess/domain/position/Rank.java @@ -29,14 +29,13 @@ public static Rank of(int rank) { return Arrays.stream(values()) .filter(f -> f.symbol == rank) .findFirst() - .orElseThrow(() -> new IllegalArgumentException("잘못된 x 좌표값을 입력하였습니다.")); + .orElseThrow(() -> new IllegalArgumentException("잘못된 y 좌표값을 입력하였습니다.")); } public int getSymbol() { return this.symbol; } - public int getDifference(Rank rank) { return this.symbol - rank.symbol; } diff --git a/src/main/java/chess/view/ConsoleInputView.java b/src/main/java/chess/view/ConsoleInputView.java index 83347cc5bd3..89b07e3f2a4 100644 --- a/src/main/java/chess/view/ConsoleInputView.java +++ b/src/main/java/chess/view/ConsoleInputView.java @@ -15,7 +15,7 @@ public boolean askChessRun() { System.out.println("> 게임 이동 : move source위치 target위치 - 예. move b2 b3"); try { String input = SCANNER.nextLine(); - validateCommand(input); + validateRunCommand(input); return runFlag(input); } catch (IllegalArgumentException e) { System.out.println(e.getMessage()); @@ -23,17 +23,14 @@ public boolean askChessRun() { } } - private void validateCommand(String input) { + private void validateRunCommand(String input) { if (!input.equals(START_COMMAND) && !input.equals(END_COMMAND)) { throw new IllegalArgumentException("start 또는 end 를 입력해주세요."); } } private boolean runFlag(String input) { - if (input.equals(START_COMMAND)) { - return true; - } - return false; + return input.equals(START_COMMAND); } @Override From 236e0661ce39abb6427cd97a80411db897fc9d44 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=EA=B9=80=EC=98=88=EB=B9=88?= Date: Fri, 27 Mar 2020 13:40:54 +0900 Subject: [PATCH 17/75] =?UTF-8?q?refactor:=20=EB=B0=A9=ED=96=A5=20?= =?UTF-8?q?=EC=A0=84=EB=9E=B5=20=EC=83=9D=EC=84=B1=20=EB=B6=84=EA=B8=B0?= =?UTF-8?q?=EB=AC=B8=20=EC=82=AD=EC=A0=9C?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/main/java/chess/domain/ChessRunner.java | 2 +- .../chess/domain/board/BoardInitializer.java | 2 +- .../domain/move/DirectionStrategyFactory.java | 37 ------------------- .../java/chess/domain/piece/PieceType.java | 2 +- .../initialize/BishopInitializer.java | 2 +- .../initialize/InitializeStrategy.java | 2 +- .../initialize/KingInitializer.java | 2 +- .../initialize/KnightInitializer.java | 2 +- .../initialize/PawnInitializer.java | 2 +- .../initialize/QueenInitializer.java | 2 +- .../initialize/RookInitializer.java | 2 +- .../move/BishopMoveStrategy.java | 2 +- .../{ => strategy}/move/KingMoveStrategy.java | 2 +- .../move/KnightMoveStrategy.java | 2 +- .../{ => strategy}/move/MoveStrategy.java | 15 +++----- .../{ => strategy}/move/PawnMoveStrategy.java | 2 +- .../move/QueenMoveStrategy.java | 2 +- .../{ => strategy}/move/RookMoveStrategy.java | 2 +- .../strategy/move/direction/Direction.java | 36 ++++++++++++++++++ .../move/direction/DirectionStrategy.java | 2 +- .../move/direction/DownStrategy.java | 2 +- .../move/direction/LeftDownStrategy.java | 2 +- .../move/direction/LeftStrategy.java | 2 +- .../move/direction/LeftUpStrategy.java | 2 +- .../move/direction/RightDownStrategy.java | 2 +- .../move/direction/RightStrategy.java | 2 +- .../move/direction/RightUpStrategy.java | 2 +- .../move/direction/UpStrategy.java | 2 +- 28 files changed, 67 insertions(+), 71 deletions(-) delete mode 100644 src/main/java/chess/domain/move/DirectionStrategyFactory.java rename src/main/java/chess/domain/{ => strategy}/initialize/BishopInitializer.java (94%) rename src/main/java/chess/domain/{ => strategy}/initialize/InitializeStrategy.java (80%) rename src/main/java/chess/domain/{ => strategy}/initialize/KingInitializer.java (93%) rename src/main/java/chess/domain/{ => strategy}/initialize/KnightInitializer.java (94%) rename src/main/java/chess/domain/{ => strategy}/initialize/PawnInitializer.java (97%) rename src/main/java/chess/domain/{ => strategy}/initialize/QueenInitializer.java (93%) rename src/main/java/chess/domain/{ => strategy}/initialize/RookInitializer.java (94%) rename src/main/java/chess/domain/{ => strategy}/move/BishopMoveStrategy.java (94%) rename src/main/java/chess/domain/{ => strategy}/move/KingMoveStrategy.java (93%) rename src/main/java/chess/domain/{ => strategy}/move/KnightMoveStrategy.java (94%) rename src/main/java/chess/domain/{ => strategy}/move/MoveStrategy.java (71%) rename src/main/java/chess/domain/{ => strategy}/move/PawnMoveStrategy.java (97%) rename src/main/java/chess/domain/{ => strategy}/move/QueenMoveStrategy.java (91%) rename src/main/java/chess/domain/{ => strategy}/move/RookMoveStrategy.java (94%) create mode 100644 src/main/java/chess/domain/strategy/move/direction/Direction.java rename src/main/java/chess/domain/{ => strategy}/move/direction/DirectionStrategy.java (77%) rename src/main/java/chess/domain/{ => strategy}/move/direction/DownStrategy.java (90%) rename src/main/java/chess/domain/{ => strategy}/move/direction/LeftDownStrategy.java (91%) rename src/main/java/chess/domain/{ => strategy}/move/direction/LeftStrategy.java (90%) rename src/main/java/chess/domain/{ => strategy}/move/direction/LeftUpStrategy.java (91%) rename src/main/java/chess/domain/{ => strategy}/move/direction/RightDownStrategy.java (91%) rename src/main/java/chess/domain/{ => strategy}/move/direction/RightStrategy.java (90%) rename src/main/java/chess/domain/{ => strategy}/move/direction/RightUpStrategy.java (91%) rename src/main/java/chess/domain/{ => strategy}/move/direction/UpStrategy.java (90%) diff --git a/src/main/java/chess/domain/ChessRunner.java b/src/main/java/chess/domain/ChessRunner.java index 9adfae4119f..3a8845d409d 100644 --- a/src/main/java/chess/domain/ChessRunner.java +++ b/src/main/java/chess/domain/ChessRunner.java @@ -19,7 +19,7 @@ public void update(String source, String target) { Position targetPosition = Position.of(target); Piece selectedPiece = this.board.getPiece(sourcePosition); - if ((currentTeam.isSameTeamWith(selectedPiece.getTeam()))) { + if (!(currentTeam.isSameTeamWith(selectedPiece.getTeam()))) { throw new IllegalArgumentException("현재 차례가 아닙니다."); } diff --git a/src/main/java/chess/domain/board/BoardInitializer.java b/src/main/java/chess/domain/board/BoardInitializer.java index 614699b0424..e9a2a83ccb2 100644 --- a/src/main/java/chess/domain/board/BoardInitializer.java +++ b/src/main/java/chess/domain/board/BoardInitializer.java @@ -1,6 +1,6 @@ package chess.domain.board; -import chess.domain.initialize.*; +import chess.domain.strategy.initialize.*; import chess.domain.piece.Piece; import chess.domain.position.Position; diff --git a/src/main/java/chess/domain/move/DirectionStrategyFactory.java b/src/main/java/chess/domain/move/DirectionStrategyFactory.java deleted file mode 100644 index ecd1202b79e..00000000000 --- a/src/main/java/chess/domain/move/DirectionStrategyFactory.java +++ /dev/null @@ -1,37 +0,0 @@ -package chess.domain.move; - -import chess.domain.move.direction.*; -import chess.domain.position.Position; - -public class DirectionStrategyFactory { - public static DirectionStrategy find(Position source, Position target) { - int fileGap = target.calculateFileGap(source); - int rankGap = target.calculateRankGap(source); - - if (fileGap == 0 && rankGap > 0) { - return new UpStrategy(); - } - if (fileGap == 0 && rankGap < 0) { - return new DownStrategy(); - } - if (fileGap > 0 && rankGap == 0) { - return new RightStrategy(); - } - if (fileGap < 0 && rankGap == 0) { - return new LeftStrategy(); - } - if (fileGap > 0 && rankGap > 0) { - return new RightUpStrategy(); - } - if (fileGap > 0 && rankGap < 0) { - return new RightDownStrategy(); - } - if (fileGap < 0 && rankGap > 0) { - return new LeftUpStrategy(); - } - if (fileGap < 0 && rankGap < 0) { - return new LeftDownStrategy(); - } - throw new AssertionError(); - } -} diff --git a/src/main/java/chess/domain/piece/PieceType.java b/src/main/java/chess/domain/piece/PieceType.java index e503bf706f3..02df3964bd4 100644 --- a/src/main/java/chess/domain/piece/PieceType.java +++ b/src/main/java/chess/domain/piece/PieceType.java @@ -1,7 +1,7 @@ package chess.domain.piece; import chess.domain.board.Board; -import chess.domain.move.*; +import chess.domain.strategy.move.*; import chess.domain.position.Position; public enum PieceType { diff --git a/src/main/java/chess/domain/initialize/BishopInitializer.java b/src/main/java/chess/domain/strategy/initialize/BishopInitializer.java similarity index 94% rename from src/main/java/chess/domain/initialize/BishopInitializer.java rename to src/main/java/chess/domain/strategy/initialize/BishopInitializer.java index da628c0905d..aa96685bbe1 100644 --- a/src/main/java/chess/domain/initialize/BishopInitializer.java +++ b/src/main/java/chess/domain/strategy/initialize/BishopInitializer.java @@ -1,4 +1,4 @@ -package chess.domain.initialize; +package chess.domain.strategy.initialize; import chess.domain.piece.Piece; import chess.domain.piece.PieceType; diff --git a/src/main/java/chess/domain/initialize/InitializeStrategy.java b/src/main/java/chess/domain/strategy/initialize/InitializeStrategy.java similarity index 80% rename from src/main/java/chess/domain/initialize/InitializeStrategy.java rename to src/main/java/chess/domain/strategy/initialize/InitializeStrategy.java index 47fc1403522..18ae42a7b9d 100644 --- a/src/main/java/chess/domain/initialize/InitializeStrategy.java +++ b/src/main/java/chess/domain/strategy/initialize/InitializeStrategy.java @@ -1,4 +1,4 @@ -package chess.domain.initialize; +package chess.domain.strategy.initialize; import chess.domain.piece.Piece; import chess.domain.position.Position; diff --git a/src/main/java/chess/domain/initialize/KingInitializer.java b/src/main/java/chess/domain/strategy/initialize/KingInitializer.java similarity index 93% rename from src/main/java/chess/domain/initialize/KingInitializer.java rename to src/main/java/chess/domain/strategy/initialize/KingInitializer.java index 9ce672ddc12..31346c488f2 100644 --- a/src/main/java/chess/domain/initialize/KingInitializer.java +++ b/src/main/java/chess/domain/strategy/initialize/KingInitializer.java @@ -1,4 +1,4 @@ -package chess.domain.initialize; +package chess.domain.strategy.initialize; import chess.domain.piece.Piece; import chess.domain.piece.PieceType; diff --git a/src/main/java/chess/domain/initialize/KnightInitializer.java b/src/main/java/chess/domain/strategy/initialize/KnightInitializer.java similarity index 94% rename from src/main/java/chess/domain/initialize/KnightInitializer.java rename to src/main/java/chess/domain/strategy/initialize/KnightInitializer.java index a8f3edfd4fb..610e7e8864c 100644 --- a/src/main/java/chess/domain/initialize/KnightInitializer.java +++ b/src/main/java/chess/domain/strategy/initialize/KnightInitializer.java @@ -1,4 +1,4 @@ -package chess.domain.initialize; +package chess.domain.strategy.initialize; import chess.domain.piece.Piece; import chess.domain.piece.PieceType; diff --git a/src/main/java/chess/domain/initialize/PawnInitializer.java b/src/main/java/chess/domain/strategy/initialize/PawnInitializer.java similarity index 97% rename from src/main/java/chess/domain/initialize/PawnInitializer.java rename to src/main/java/chess/domain/strategy/initialize/PawnInitializer.java index ced1279ba67..fae533df5d9 100644 --- a/src/main/java/chess/domain/initialize/PawnInitializer.java +++ b/src/main/java/chess/domain/strategy/initialize/PawnInitializer.java @@ -1,4 +1,4 @@ -package chess.domain.initialize; +package chess.domain.strategy.initialize; import chess.domain.piece.Piece; import chess.domain.piece.PieceType; diff --git a/src/main/java/chess/domain/initialize/QueenInitializer.java b/src/main/java/chess/domain/strategy/initialize/QueenInitializer.java similarity index 93% rename from src/main/java/chess/domain/initialize/QueenInitializer.java rename to src/main/java/chess/domain/strategy/initialize/QueenInitializer.java index 507f401250c..d13feded160 100644 --- a/src/main/java/chess/domain/initialize/QueenInitializer.java +++ b/src/main/java/chess/domain/strategy/initialize/QueenInitializer.java @@ -1,4 +1,4 @@ -package chess.domain.initialize; +package chess.domain.strategy.initialize; import chess.domain.piece.Piece; import chess.domain.piece.PieceType; diff --git a/src/main/java/chess/domain/initialize/RookInitializer.java b/src/main/java/chess/domain/strategy/initialize/RookInitializer.java similarity index 94% rename from src/main/java/chess/domain/initialize/RookInitializer.java rename to src/main/java/chess/domain/strategy/initialize/RookInitializer.java index 47fd77a442e..c1409b0f6c0 100644 --- a/src/main/java/chess/domain/initialize/RookInitializer.java +++ b/src/main/java/chess/domain/strategy/initialize/RookInitializer.java @@ -1,4 +1,4 @@ -package chess.domain.initialize; +package chess.domain.strategy.initialize; import chess.domain.piece.Piece; import chess.domain.piece.PieceType; diff --git a/src/main/java/chess/domain/move/BishopMoveStrategy.java b/src/main/java/chess/domain/strategy/move/BishopMoveStrategy.java similarity index 94% rename from src/main/java/chess/domain/move/BishopMoveStrategy.java rename to src/main/java/chess/domain/strategy/move/BishopMoveStrategy.java index 131b5e079da..60fc5310997 100644 --- a/src/main/java/chess/domain/move/BishopMoveStrategy.java +++ b/src/main/java/chess/domain/strategy/move/BishopMoveStrategy.java @@ -1,4 +1,4 @@ -package chess.domain.move; +package chess.domain.strategy.move; import chess.domain.board.Board; import chess.domain.position.Position; diff --git a/src/main/java/chess/domain/move/KingMoveStrategy.java b/src/main/java/chess/domain/strategy/move/KingMoveStrategy.java similarity index 93% rename from src/main/java/chess/domain/move/KingMoveStrategy.java rename to src/main/java/chess/domain/strategy/move/KingMoveStrategy.java index c4e9a086426..86893b86e6b 100644 --- a/src/main/java/chess/domain/move/KingMoveStrategy.java +++ b/src/main/java/chess/domain/strategy/move/KingMoveStrategy.java @@ -1,4 +1,4 @@ -package chess.domain.move; +package chess.domain.strategy.move; import chess.domain.board.Board; import chess.domain.position.Position; diff --git a/src/main/java/chess/domain/move/KnightMoveStrategy.java b/src/main/java/chess/domain/strategy/move/KnightMoveStrategy.java similarity index 94% rename from src/main/java/chess/domain/move/KnightMoveStrategy.java rename to src/main/java/chess/domain/strategy/move/KnightMoveStrategy.java index 484d2e3ae2d..6a7582c9bbb 100644 --- a/src/main/java/chess/domain/move/KnightMoveStrategy.java +++ b/src/main/java/chess/domain/strategy/move/KnightMoveStrategy.java @@ -1,4 +1,4 @@ -package chess.domain.move; +package chess.domain.strategy.move; import chess.domain.board.Board; import chess.domain.position.Position; diff --git a/src/main/java/chess/domain/move/MoveStrategy.java b/src/main/java/chess/domain/strategy/move/MoveStrategy.java similarity index 71% rename from src/main/java/chess/domain/move/MoveStrategy.java rename to src/main/java/chess/domain/strategy/move/MoveStrategy.java index f345d60fc2a..d7beb3201b5 100644 --- a/src/main/java/chess/domain/move/MoveStrategy.java +++ b/src/main/java/chess/domain/strategy/move/MoveStrategy.java @@ -1,7 +1,8 @@ -package chess.domain.move; +package chess.domain.strategy.move; import chess.domain.board.Board; -import chess.domain.move.direction.DirectionStrategy; +import chess.domain.strategy.move.direction.Direction; +import chess.domain.strategy.move.direction.DirectionStrategy; import chess.domain.piece.Piece; import chess.domain.position.Position; @@ -14,15 +15,11 @@ protected boolean isSamePosition(Position source, Position target) { } protected boolean checkObstacle(Position source, Position target, Board board) { - DirectionStrategy directionStrategy = DirectionStrategyFactory.find(source, target); + DirectionStrategy directionStrategy = Direction.find(source, target); List path = directionStrategy.find(source, target); - for (Position position : path) { - if (!board.isEmpty(position)) { - return false; - } - } - return true; + return path.stream() + .anyMatch(position -> !board.isEmpty(position)); } protected boolean checkTarget(Position source, Position target, Board board) { diff --git a/src/main/java/chess/domain/move/PawnMoveStrategy.java b/src/main/java/chess/domain/strategy/move/PawnMoveStrategy.java similarity index 97% rename from src/main/java/chess/domain/move/PawnMoveStrategy.java rename to src/main/java/chess/domain/strategy/move/PawnMoveStrategy.java index 58981836295..ab116760b22 100644 --- a/src/main/java/chess/domain/move/PawnMoveStrategy.java +++ b/src/main/java/chess/domain/strategy/move/PawnMoveStrategy.java @@ -1,4 +1,4 @@ -package chess.domain.move; +package chess.domain.strategy.move; import chess.domain.board.Board; import chess.domain.piece.Piece; diff --git a/src/main/java/chess/domain/move/QueenMoveStrategy.java b/src/main/java/chess/domain/strategy/move/QueenMoveStrategy.java similarity index 91% rename from src/main/java/chess/domain/move/QueenMoveStrategy.java rename to src/main/java/chess/domain/strategy/move/QueenMoveStrategy.java index 3cb9525322b..4a8f9dbbd6f 100644 --- a/src/main/java/chess/domain/move/QueenMoveStrategy.java +++ b/src/main/java/chess/domain/strategy/move/QueenMoveStrategy.java @@ -1,4 +1,4 @@ -package chess.domain.move; +package chess.domain.strategy.move; import chess.domain.board.Board; import chess.domain.position.Position; diff --git a/src/main/java/chess/domain/move/RookMoveStrategy.java b/src/main/java/chess/domain/strategy/move/RookMoveStrategy.java similarity index 94% rename from src/main/java/chess/domain/move/RookMoveStrategy.java rename to src/main/java/chess/domain/strategy/move/RookMoveStrategy.java index 67ce216c581..6b46d56f9a0 100644 --- a/src/main/java/chess/domain/move/RookMoveStrategy.java +++ b/src/main/java/chess/domain/strategy/move/RookMoveStrategy.java @@ -1,4 +1,4 @@ -package chess.domain.move; +package chess.domain.strategy.move; import chess.domain.board.Board; import chess.domain.position.Position; diff --git a/src/main/java/chess/domain/strategy/move/direction/Direction.java b/src/main/java/chess/domain/strategy/move/direction/Direction.java new file mode 100644 index 00000000000..0b16d539acf --- /dev/null +++ b/src/main/java/chess/domain/strategy/move/direction/Direction.java @@ -0,0 +1,36 @@ +package chess.domain.strategy.move.direction; + +import chess.domain.position.Position; + +import java.util.Arrays; +import java.util.function.BiPredicate; + +public enum Direction { + UP(new UpStrategy(), (fileGap, rankGap) -> fileGap == 0 && rankGap > 0), + DOWN(new DownStrategy(), (fileGap, rankGap) -> fileGap == 0 && rankGap < 0), + LEFT(new LeftStrategy(), (fileGap, rankGap) -> fileGap < 0 && rankGap == 0), + RIGHT(new RightStrategy(), (fileGap, rankGap) -> fileGap > 0 && rankGap == 0), + LEFT_UP(new LeftUpStrategy(), (fileGap, rankGap) -> fileGap < 0 && rankGap > 0), + LEFT_DOWN(new LeftDownStrategy(), (fileGap, rankGap) -> fileGap < 0 && rankGap < 0), + RIGHT_UP(new RightUpStrategy(), (fileGap, rankGap) -> fileGap > 0 && rankGap > 0), + RIGHT_DOWN(new RightDownStrategy(), (fileGap, rankGap) -> fileGap > 0 && rankGap < 0); + + private DirectionStrategy directionStrategy; + private BiPredicate condition; + + Direction(DirectionStrategy directionStrategy, BiPredicate condition) { + this.directionStrategy = directionStrategy; + this.condition = condition; + } + + public static DirectionStrategy find(Position source, Position target) { + int fileGap = target.calculateFileGap(source); + int rankGap = target.calculateRankGap(source); + + return Arrays.stream(values()) + .filter(direction -> direction.condition.test(fileGap, rankGap)) + .findFirst() + .map(direction -> direction.directionStrategy) + .orElseThrow(AssertionError::new); + } +} \ No newline at end of file diff --git a/src/main/java/chess/domain/move/direction/DirectionStrategy.java b/src/main/java/chess/domain/strategy/move/direction/DirectionStrategy.java similarity index 77% rename from src/main/java/chess/domain/move/direction/DirectionStrategy.java rename to src/main/java/chess/domain/strategy/move/direction/DirectionStrategy.java index 298b0eeed25..3b7594e165c 100644 --- a/src/main/java/chess/domain/move/direction/DirectionStrategy.java +++ b/src/main/java/chess/domain/strategy/move/direction/DirectionStrategy.java @@ -1,4 +1,4 @@ -package chess.domain.move.direction; +package chess.domain.strategy.move.direction; import chess.domain.position.Position; diff --git a/src/main/java/chess/domain/move/direction/DownStrategy.java b/src/main/java/chess/domain/strategy/move/direction/DownStrategy.java similarity index 90% rename from src/main/java/chess/domain/move/direction/DownStrategy.java rename to src/main/java/chess/domain/strategy/move/direction/DownStrategy.java index 6ce3899e91a..ce41d8129e8 100644 --- a/src/main/java/chess/domain/move/direction/DownStrategy.java +++ b/src/main/java/chess/domain/strategy/move/direction/DownStrategy.java @@ -1,4 +1,4 @@ -package chess.domain.move.direction; +package chess.domain.strategy.move.direction; import chess.domain.position.Position; diff --git a/src/main/java/chess/domain/move/direction/LeftDownStrategy.java b/src/main/java/chess/domain/strategy/move/direction/LeftDownStrategy.java similarity index 91% rename from src/main/java/chess/domain/move/direction/LeftDownStrategy.java rename to src/main/java/chess/domain/strategy/move/direction/LeftDownStrategy.java index a2950d3d9b3..009cafb531b 100644 --- a/src/main/java/chess/domain/move/direction/LeftDownStrategy.java +++ b/src/main/java/chess/domain/strategy/move/direction/LeftDownStrategy.java @@ -1,4 +1,4 @@ -package chess.domain.move.direction; +package chess.domain.strategy.move.direction; import chess.domain.position.Position; diff --git a/src/main/java/chess/domain/move/direction/LeftStrategy.java b/src/main/java/chess/domain/strategy/move/direction/LeftStrategy.java similarity index 90% rename from src/main/java/chess/domain/move/direction/LeftStrategy.java rename to src/main/java/chess/domain/strategy/move/direction/LeftStrategy.java index 8189c9a41b9..1e160c1d7e1 100644 --- a/src/main/java/chess/domain/move/direction/LeftStrategy.java +++ b/src/main/java/chess/domain/strategy/move/direction/LeftStrategy.java @@ -1,4 +1,4 @@ -package chess.domain.move.direction; +package chess.domain.strategy.move.direction; import chess.domain.position.Position; diff --git a/src/main/java/chess/domain/move/direction/LeftUpStrategy.java b/src/main/java/chess/domain/strategy/move/direction/LeftUpStrategy.java similarity index 91% rename from src/main/java/chess/domain/move/direction/LeftUpStrategy.java rename to src/main/java/chess/domain/strategy/move/direction/LeftUpStrategy.java index f2a8719eaa3..78d922aac0a 100644 --- a/src/main/java/chess/domain/move/direction/LeftUpStrategy.java +++ b/src/main/java/chess/domain/strategy/move/direction/LeftUpStrategy.java @@ -1,4 +1,4 @@ -package chess.domain.move.direction; +package chess.domain.strategy.move.direction; import chess.domain.position.Position; diff --git a/src/main/java/chess/domain/move/direction/RightDownStrategy.java b/src/main/java/chess/domain/strategy/move/direction/RightDownStrategy.java similarity index 91% rename from src/main/java/chess/domain/move/direction/RightDownStrategy.java rename to src/main/java/chess/domain/strategy/move/direction/RightDownStrategy.java index ce28c51645f..c34489a93db 100644 --- a/src/main/java/chess/domain/move/direction/RightDownStrategy.java +++ b/src/main/java/chess/domain/strategy/move/direction/RightDownStrategy.java @@ -1,4 +1,4 @@ -package chess.domain.move.direction; +package chess.domain.strategy.move.direction; import chess.domain.position.Position; diff --git a/src/main/java/chess/domain/move/direction/RightStrategy.java b/src/main/java/chess/domain/strategy/move/direction/RightStrategy.java similarity index 90% rename from src/main/java/chess/domain/move/direction/RightStrategy.java rename to src/main/java/chess/domain/strategy/move/direction/RightStrategy.java index f07bdf3360b..674c19beb5f 100644 --- a/src/main/java/chess/domain/move/direction/RightStrategy.java +++ b/src/main/java/chess/domain/strategy/move/direction/RightStrategy.java @@ -1,4 +1,4 @@ -package chess.domain.move.direction; +package chess.domain.strategy.move.direction; import chess.domain.position.Position; diff --git a/src/main/java/chess/domain/move/direction/RightUpStrategy.java b/src/main/java/chess/domain/strategy/move/direction/RightUpStrategy.java similarity index 91% rename from src/main/java/chess/domain/move/direction/RightUpStrategy.java rename to src/main/java/chess/domain/strategy/move/direction/RightUpStrategy.java index b19bd61bd58..27c9d5396d0 100644 --- a/src/main/java/chess/domain/move/direction/RightUpStrategy.java +++ b/src/main/java/chess/domain/strategy/move/direction/RightUpStrategy.java @@ -1,4 +1,4 @@ -package chess.domain.move.direction; +package chess.domain.strategy.move.direction; import chess.domain.position.Position; diff --git a/src/main/java/chess/domain/move/direction/UpStrategy.java b/src/main/java/chess/domain/strategy/move/direction/UpStrategy.java similarity index 90% rename from src/main/java/chess/domain/move/direction/UpStrategy.java rename to src/main/java/chess/domain/strategy/move/direction/UpStrategy.java index 1bcf3de6da6..ee128dbae6e 100644 --- a/src/main/java/chess/domain/move/direction/UpStrategy.java +++ b/src/main/java/chess/domain/strategy/move/direction/UpStrategy.java @@ -1,4 +1,4 @@ -package chess.domain.move.direction; +package chess.domain.strategy.move.direction; import chess.domain.position.Position; From bf61f63031d9a644c9560a8480f3264a65797b19 Mon Sep 17 00:00:00 2001 From: giantim Date: Fri, 27 Mar 2020 14:30:57 +0900 Subject: [PATCH 18/75] =?UTF-8?q?refactor:=20=ED=85=8C=EC=8A=A4=ED=8A=B8?= =?UTF-8?q?=20=EC=BD=94=EB=93=9C=20=EB=94=94=EB=A0=89=ED=86=A0=EB=A6=AC=20?= =?UTF-8?q?=EC=B6=94=EA=B0=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../domain/strategy/move/BishopMoveStrategyTest.java | 12 ++++++++++++ .../strategy/move/direction/DirectionTest.java | 12 ++++++++++++ 2 files changed, 24 insertions(+) create mode 100644 src/test/java/chess/domain/strategy/move/BishopMoveStrategyTest.java create mode 100644 src/test/java/chess/domain/strategy/move/direction/DirectionTest.java diff --git a/src/test/java/chess/domain/strategy/move/BishopMoveStrategyTest.java b/src/test/java/chess/domain/strategy/move/BishopMoveStrategyTest.java new file mode 100644 index 00000000000..2985b56b07d --- /dev/null +++ b/src/test/java/chess/domain/strategy/move/BishopMoveStrategyTest.java @@ -0,0 +1,12 @@ +package chess.domain.strategy.move; + +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; + +public class BishopMoveStrategyTest { + @DisplayName("비숍의 우 상단 대각 이동") + @Test + void rightUpTest() { + + } +} diff --git a/src/test/java/chess/domain/strategy/move/direction/DirectionTest.java b/src/test/java/chess/domain/strategy/move/direction/DirectionTest.java new file mode 100644 index 00000000000..778ade7f67a --- /dev/null +++ b/src/test/java/chess/domain/strategy/move/direction/DirectionTest.java @@ -0,0 +1,12 @@ +package chess.domain.strategy.move.direction; + +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; + +public class DirectionTest { + @DisplayName("조건에 맞는 방향 반환") + @Test + void findTest() { + + } +} From 9d29cfd67a4cd03155e70af099f24ce62b37b034 Mon Sep 17 00:00:00 2001 From: giantim Date: Fri, 27 Mar 2020 18:50:55 +0900 Subject: [PATCH 19/75] =?UTF-8?q?refactor:=20=ED=85=8C=EC=8A=A4=ED=8A=B8?= =?UTF-8?q?=20=EC=BD=94=EB=93=9C=20=EC=B6=94=EA=B0=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/main/java/chess/domain/board/Board.java | 6 +- .../chess/domain/board/BoardInitializer.java | 2 +- .../java/chess/domain/piece/PieceType.java | 2 +- .../domain/strategy/move/MoveStrategy.java | 9 +- .../strategy/move/direction/Direction.java | 9 +- .../move/direction/DirectionStrategy.java | 2 +- .../strategy/move/direction/DownStrategy.java | 2 +- .../move/direction/LeftDownStrategy.java | 6 +- .../strategy/move/direction/LeftStrategy.java | 2 +- .../move/direction/LeftUpStrategy.java | 2 +- .../move/direction/RightDownStrategy.java | 4 +- .../move/direction/RightStrategy.java | 2 +- .../move/direction/RightUpStrategy.java | 2 +- .../strategy/move/direction/UpStrategy.java | 2 +- .../java/chess/domain/ChessRunnerTest.java | 32 +++++ .../java/chess/domain/board/BoardTest.java | 107 +++++++++++++++++ .../java/chess/domain/piece/PieceTest.java | 52 ++++++++ .../java/chess/domain/piece/TeamTest.java | 17 +++ .../strategy/move/BishopMoveStrategyTest.java | 65 ++++++++++ .../strategy/move/KingMoveStrategyTest.java | 64 ++++++++++ .../strategy/move/KnightMoveStrategyTest.java | 64 ++++++++++ .../strategy/move/PawnMoveStrategyTest.java | 107 +++++++++++++++++ .../strategy/move/QueenMoveStrategyTest.java | 113 ++++++++++++++++++ .../strategy/move/RookMoveStrategyTest.java | 77 ++++++++++++ .../move/direction/DirectionTest.java | 67 ++++++++++- 25 files changed, 793 insertions(+), 24 deletions(-) create mode 100644 src/test/java/chess/domain/ChessRunnerTest.java create mode 100644 src/test/java/chess/domain/board/BoardTest.java create mode 100644 src/test/java/chess/domain/piece/PieceTest.java create mode 100644 src/test/java/chess/domain/piece/TeamTest.java create mode 100644 src/test/java/chess/domain/strategy/move/KingMoveStrategyTest.java create mode 100644 src/test/java/chess/domain/strategy/move/KnightMoveStrategyTest.java create mode 100644 src/test/java/chess/domain/strategy/move/PawnMoveStrategyTest.java create mode 100644 src/test/java/chess/domain/strategy/move/QueenMoveStrategyTest.java create mode 100644 src/test/java/chess/domain/strategy/move/RookMoveStrategyTest.java diff --git a/src/main/java/chess/domain/board/Board.java b/src/main/java/chess/domain/board/Board.java index 0c5c21b5034..c685bab6c97 100644 --- a/src/main/java/chess/domain/board/Board.java +++ b/src/main/java/chess/domain/board/Board.java @@ -15,7 +15,11 @@ public class Board { private final Map board; public Board() { - this.board = BoardInitializer.initializeAll(); + this(BoardInitializer.initializeAll()); + } + + public Board(Map board) { + this.board = board; } public Map parse() { diff --git a/src/main/java/chess/domain/board/BoardInitializer.java b/src/main/java/chess/domain/board/BoardInitializer.java index e9a2a83ccb2..057eb7137b0 100644 --- a/src/main/java/chess/domain/board/BoardInitializer.java +++ b/src/main/java/chess/domain/board/BoardInitializer.java @@ -1,8 +1,8 @@ package chess.domain.board; -import chess.domain.strategy.initialize.*; import chess.domain.piece.Piece; import chess.domain.position.Position; +import chess.domain.strategy.initialize.*; import java.util.*; diff --git a/src/main/java/chess/domain/piece/PieceType.java b/src/main/java/chess/domain/piece/PieceType.java index 02df3964bd4..f14a48d6022 100644 --- a/src/main/java/chess/domain/piece/PieceType.java +++ b/src/main/java/chess/domain/piece/PieceType.java @@ -1,8 +1,8 @@ package chess.domain.piece; import chess.domain.board.Board; -import chess.domain.strategy.move.*; import chess.domain.position.Position; +import chess.domain.strategy.move.*; public enum PieceType { KING("k", 0, new KingMoveStrategy()), diff --git a/src/main/java/chess/domain/strategy/move/MoveStrategy.java b/src/main/java/chess/domain/strategy/move/MoveStrategy.java index d7beb3201b5..27ea9af6e81 100644 --- a/src/main/java/chess/domain/strategy/move/MoveStrategy.java +++ b/src/main/java/chess/domain/strategy/move/MoveStrategy.java @@ -1,10 +1,9 @@ package chess.domain.strategy.move; import chess.domain.board.Board; -import chess.domain.strategy.move.direction.Direction; -import chess.domain.strategy.move.direction.DirectionStrategy; import chess.domain.piece.Piece; import chess.domain.position.Position; +import chess.domain.strategy.move.direction.Direction; import java.util.List; @@ -15,11 +14,11 @@ protected boolean isSamePosition(Position source, Position target) { } protected boolean checkObstacle(Position source, Position target, Board board) { - DirectionStrategy directionStrategy = Direction.find(source, target); - List path = directionStrategy.find(source, target); + Direction direction = Direction.findDirection(source, target); + List path = direction.findPath(source, target); return path.stream() - .anyMatch(position -> !board.isEmpty(position)); + .allMatch(board::isEmpty); } protected boolean checkTarget(Position source, Position target, Board board) { diff --git a/src/main/java/chess/domain/strategy/move/direction/Direction.java b/src/main/java/chess/domain/strategy/move/direction/Direction.java index 0b16d539acf..48301427d30 100644 --- a/src/main/java/chess/domain/strategy/move/direction/Direction.java +++ b/src/main/java/chess/domain/strategy/move/direction/Direction.java @@ -3,6 +3,7 @@ import chess.domain.position.Position; import java.util.Arrays; +import java.util.List; import java.util.function.BiPredicate; public enum Direction { @@ -23,14 +24,16 @@ public enum Direction { this.condition = condition; } - public static DirectionStrategy find(Position source, Position target) { + public static Direction findDirection(Position source, Position target) { int fileGap = target.calculateFileGap(source); int rankGap = target.calculateRankGap(source); - return Arrays.stream(values()) .filter(direction -> direction.condition.test(fileGap, rankGap)) .findFirst() - .map(direction -> direction.directionStrategy) .orElseThrow(AssertionError::new); } + + public List findPath(Position source, Position target) { + return this.directionStrategy.findPath(source, target); + } } \ No newline at end of file diff --git a/src/main/java/chess/domain/strategy/move/direction/DirectionStrategy.java b/src/main/java/chess/domain/strategy/move/direction/DirectionStrategy.java index 3b7594e165c..d9d3f558288 100644 --- a/src/main/java/chess/domain/strategy/move/direction/DirectionStrategy.java +++ b/src/main/java/chess/domain/strategy/move/direction/DirectionStrategy.java @@ -5,5 +5,5 @@ import java.util.List; public interface DirectionStrategy { - List find(Position source, Position target); + List findPath(Position source, Position target); } \ No newline at end of file diff --git a/src/main/java/chess/domain/strategy/move/direction/DownStrategy.java b/src/main/java/chess/domain/strategy/move/direction/DownStrategy.java index ce41d8129e8..d7d62a77070 100644 --- a/src/main/java/chess/domain/strategy/move/direction/DownStrategy.java +++ b/src/main/java/chess/domain/strategy/move/direction/DownStrategy.java @@ -7,7 +7,7 @@ public class DownStrategy implements DirectionStrategy { @Override - public List find(Position source, Position target) { + public List findPath(Position source, Position target) { List path = new ArrayList<>(); for (int i = target.getRank() + 1; i < source.getRank(); i++) { diff --git a/src/main/java/chess/domain/strategy/move/direction/LeftDownStrategy.java b/src/main/java/chess/domain/strategy/move/direction/LeftDownStrategy.java index 009cafb531b..f6aecaba9d9 100644 --- a/src/main/java/chess/domain/strategy/move/direction/LeftDownStrategy.java +++ b/src/main/java/chess/domain/strategy/move/direction/LeftDownStrategy.java @@ -8,13 +8,17 @@ public class LeftDownStrategy implements DirectionStrategy { @Override - public List find(Position source, Position target) { + public List findPath(Position source, Position target) { List path = new ArrayList<>(); for (int i = target.getFile() + 1; i < source.getFile(); i++) { path.add(Position.of(i, target.getRank() - (target.getFile() - i))); } +// List path2 = IntStream.range(target.getFile() + 1, source.getFile()) +// .mapToObj(index -> Position.of(index, target.getRank() - (target.getFile() - index))) +// .collect(Collectors.toList()); + return path; } } diff --git a/src/main/java/chess/domain/strategy/move/direction/LeftStrategy.java b/src/main/java/chess/domain/strategy/move/direction/LeftStrategy.java index 1e160c1d7e1..53fed6f5394 100644 --- a/src/main/java/chess/domain/strategy/move/direction/LeftStrategy.java +++ b/src/main/java/chess/domain/strategy/move/direction/LeftStrategy.java @@ -7,7 +7,7 @@ public class LeftStrategy implements DirectionStrategy { @Override - public List find(Position source, Position target) { + public List findPath(Position source, Position target) { List path = new ArrayList<>(); for (int i = target.getFile() + 1; i < source.getFile(); i++) { diff --git a/src/main/java/chess/domain/strategy/move/direction/LeftUpStrategy.java b/src/main/java/chess/domain/strategy/move/direction/LeftUpStrategy.java index 78d922aac0a..20842f29f74 100644 --- a/src/main/java/chess/domain/strategy/move/direction/LeftUpStrategy.java +++ b/src/main/java/chess/domain/strategy/move/direction/LeftUpStrategy.java @@ -7,7 +7,7 @@ public class LeftUpStrategy implements DirectionStrategy { @Override - public List find(Position source, Position target) { + public List findPath(Position source, Position target) { List path = new ArrayList<>(); for (int i = target.getFile() + 1; i < source.getFile(); i++) { diff --git a/src/main/java/chess/domain/strategy/move/direction/RightDownStrategy.java b/src/main/java/chess/domain/strategy/move/direction/RightDownStrategy.java index c34489a93db..d5919f032e8 100644 --- a/src/main/java/chess/domain/strategy/move/direction/RightDownStrategy.java +++ b/src/main/java/chess/domain/strategy/move/direction/RightDownStrategy.java @@ -8,11 +8,11 @@ public class RightDownStrategy implements DirectionStrategy { @Override - public List find(Position source, Position target) { + public List findPath(Position source, Position target) { List path = new ArrayList<>(); for (int i = target.getFile() - 1; i > source.getFile(); i--) { - path.add(Position.of(i, target.getRank() - (target.getFile() - i))); + path.add(Position.of(i, target.getRank() + (target.getFile() - i))); } return path; diff --git a/src/main/java/chess/domain/strategy/move/direction/RightStrategy.java b/src/main/java/chess/domain/strategy/move/direction/RightStrategy.java index 674c19beb5f..2ce164b797c 100644 --- a/src/main/java/chess/domain/strategy/move/direction/RightStrategy.java +++ b/src/main/java/chess/domain/strategy/move/direction/RightStrategy.java @@ -7,7 +7,7 @@ public class RightStrategy implements DirectionStrategy { @Override - public List find(Position source, Position target) { + public List findPath(Position source, Position target) { List path = new ArrayList<>(); for (int i = target.getFile() - 1; i > source.getFile(); i--) { diff --git a/src/main/java/chess/domain/strategy/move/direction/RightUpStrategy.java b/src/main/java/chess/domain/strategy/move/direction/RightUpStrategy.java index 27c9d5396d0..ce7a9472f12 100644 --- a/src/main/java/chess/domain/strategy/move/direction/RightUpStrategy.java +++ b/src/main/java/chess/domain/strategy/move/direction/RightUpStrategy.java @@ -8,7 +8,7 @@ public class RightUpStrategy implements DirectionStrategy { @Override - public List find(Position source, Position target) { + public List findPath(Position source, Position target) { List path = new ArrayList<>(); for (int i = target.getFile() - 1; i > source.getFile(); i--) { diff --git a/src/main/java/chess/domain/strategy/move/direction/UpStrategy.java b/src/main/java/chess/domain/strategy/move/direction/UpStrategy.java index ee128dbae6e..9728fdc2e8f 100644 --- a/src/main/java/chess/domain/strategy/move/direction/UpStrategy.java +++ b/src/main/java/chess/domain/strategy/move/direction/UpStrategy.java @@ -7,7 +7,7 @@ public class UpStrategy implements DirectionStrategy { @Override - public List find(Position source, Position target) { + public List findPath(Position source, Position target) { List path = new ArrayList<>(); for (int i = target.getRank() - 1; i > source.getRank(); i--) { diff --git a/src/test/java/chess/domain/ChessRunnerTest.java b/src/test/java/chess/domain/ChessRunnerTest.java new file mode 100644 index 00000000000..093fd56c2b9 --- /dev/null +++ b/src/test/java/chess/domain/ChessRunnerTest.java @@ -0,0 +1,32 @@ +package chess.domain; + +import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; + +import static org.assertj.core.api.Assertions.assertThatThrownBy; + +class ChessRunnerTest { + ChessRunner chessRunner; + + @BeforeEach + void setUp() { + chessRunner = new ChessRunner(); + } + + @DisplayName("현재 순서가 아닐 때 에러 메시지 출력") + @Test + void validateCurrentTeam() { + assertThatThrownBy(() -> chessRunner.update("a7", "a5")) //블랙 팀 폰 이동 + .isInstanceOf(IllegalArgumentException.class) + .hasMessage("현재 차례가 아닙니다."); + } + + @DisplayName("이동할 수 없는 곳일 때 에러 메시지 출력") + @Test + void validateMovable() { + assertThatThrownBy(() -> chessRunner.update("a1", "a2")) //화이트 팀 룩 이동 + .isInstanceOf(IllegalArgumentException.class) + .hasMessage("이동할 수 없는 곳입니다."); + } +} \ No newline at end of file diff --git a/src/test/java/chess/domain/board/BoardTest.java b/src/test/java/chess/domain/board/BoardTest.java new file mode 100644 index 00000000000..9a0e11c066b --- /dev/null +++ b/src/test/java/chess/domain/board/BoardTest.java @@ -0,0 +1,107 @@ +package chess.domain.board; + +import chess.domain.piece.Piece; +import chess.domain.piece.PieceType; +import chess.domain.piece.Team; +import chess.domain.position.Position; +import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; + +import java.util.HashMap; +import java.util.Map; + +public class BoardTest { + @DisplayName("빈 칸으로 말 이동") + @Test + void updateAtEmptyBoard() { + Board board = new Board(); + Position source = Position.of("a2"); + Position target = Position.of("a3"); + board.updateBoard(source, target); + + Assertions.assertThat(board.getPiece(source)).isNull(); + Assertions.assertThat(board.getPiece(target)).isNotNull(); + Assertions.assertThat(board.getPiece(target)).isInstanceOf(Piece.class); + } + + @DisplayName("상대 편으로 말 이동") + @Test + void updateAtEnemy() { + Piece rook = new Piece(PieceType.ROOK, Team.WHITE); + Piece pawn = new Piece(PieceType.PAWN, Team.BLACK); + Map entry = new HashMap<>(); + Position source = Position.of("a2"); + Position target = Position.of("a3"); + entry.put(source, rook); + entry.put(target, pawn); + Board board = new Board(entry); + board.updateBoard(source, target); + + Assertions.assertThat(board.getPiece(source)).isNull(); + Assertions.assertThat(board.getPiece(target)).isNotNull(); + Assertions.assertThat(board.getPiece(target)).isInstanceOf(Piece.class); + } + + @DisplayName("승자 팀을 판단") + @Test + void checkWinnerTest() { + Map whiteKing = new HashMap<>(); + whiteKing.put(Position.of("a3"), new Piece(PieceType.KING, Team.WHITE)); + Board whiteWinBoard = new Board(whiteKing); + + Map blackKing = new HashMap<>(); + blackKing.put(Position.of("b4"), new Piece(PieceType.KING, Team.BLACK)); + Board blackWinBoard = new Board(blackKing); + + Map bothKing = new HashMap<>(); + bothKing.put(Position.of("a5"), new Piece(PieceType.KING, Team.BLACK)); + bothKing.put(Position.of("b7"), new Piece(PieceType.KING, Team.WHITE)); + Board drawBoard = new Board(bothKing); + + Assertions.assertThat(whiteWinBoard.checkWinner()).isEqualTo(Team.WHITE); + Assertions.assertThat(blackWinBoard.checkWinner()).isEqualTo(Team.BLACK); + Assertions.assertThat(drawBoard.checkWinner()).isNull(); + } + + @DisplayName("지정한 칸이 비어있는지 판단") + @Test + void isEmptyTest() { + Position nonEmptyTarget = Position.of("a2"); + Position emptyTarget = Position.of("a3"); + Board board = new Board(); + + Assertions.assertThat(board.isEmpty(nonEmptyTarget)).isFalse(); + Assertions.assertThat(board.isEmpty(emptyTarget)).isTrue(); + } + + @DisplayName("지정한 칸의 체스 말 반환") + @Test + void getPieceTest() { + Board board = new Board(); + + Assertions.assertThat(board.getPiece(Position.of("a2"))).isInstanceOf(Piece.class); + Assertions.assertThat(board.getPiece(Position.of("a3"))).isNull(); + } + + @DisplayName("같은 세로줄에 폰이 없을 때 점수 계산") + @Test + void calculateScoreWithoutSameFilePawnTest() { + Board board = new Board(); + + Assertions.assertThat(board.calculateScore(Team.WHITE)).isEqualTo(38d); + Assertions.assertThat(board.calculateScore(Team.BLACK)).isEqualTo(38d); + } + + @DisplayName("같은 세로줄에 폰이 있을 때 점수 계산") + @Test + void calculateScoreWithSameFilePawn() { + Map sameFilePawn = new HashMap<>(); + sameFilePawn.put(Position.of("a3"), new Piece(PieceType.PAWN, Team.WHITE)); + sameFilePawn.put(Position.of("a4"), new Piece(PieceType.PAWN, Team.WHITE)); + sameFilePawn.put(Position.of("a5"), new Piece(PieceType.PAWN, Team.WHITE)); + Board board = new Board(sameFilePawn); + + Assertions.assertThat(board.calculateScore(Team.WHITE)).isEqualTo(1.5d); + } +} diff --git a/src/test/java/chess/domain/piece/PieceTest.java b/src/test/java/chess/domain/piece/PieceTest.java new file mode 100644 index 00000000000..088f7bc1eab --- /dev/null +++ b/src/test/java/chess/domain/piece/PieceTest.java @@ -0,0 +1,52 @@ +package chess.domain.piece; + +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; + +import static org.assertj.core.api.Assertions.assertThat; + +class PieceTest { + @DisplayName("팀 별 대소문자로 출력") + @Test + void toSymbol() { + Piece whitePiece = new Piece(PieceType.BISHOP, Team.WHITE); + Piece blackPiece = new Piece(PieceType.BISHOP, Team.BLACK); + assertThat(whitePiece.toSymbol()).isEqualTo("b"); + assertThat(blackPiece.toSymbol()).isEqualTo("B"); + } + + @DisplayName("피스의 팀 구분") + @Test + void isEnemy() { + Piece whitePiece = new Piece(PieceType.KNIGHT, Team.WHITE); + Piece blackPiece = new Piece(PieceType.KNIGHT, Team.BLACK); + assertThat(whitePiece.isEnemy(blackPiece)).isTrue(); + } + + @DisplayName("피스가 흰 팀의 킹인지 테스트") + @Test + void isWhiteKing() { + Piece whiteKing = new Piece(PieceType.KING, Team.WHITE); + Piece blackBishop = new Piece(PieceType.BISHOP, Team.BLACK); + assertThat(whiteKing.isWhiteKing()).isTrue(); + assertThat(blackBishop.isWhiteKing()).isFalse(); + } + + @DisplayName("피스가 검은 팀의 킹인지 테스트") + @Test + void isBlackKing() { + Piece blackKing = new Piece(PieceType.KING, Team.BLACK); + Piece whiteBishop = new Piece(PieceType.BISHOP, Team.WHITE); + assertThat(blackKing.isBlackKing()).isTrue(); + assertThat(whiteBishop.isBlackKing()).isFalse(); + } + + @DisplayName("피스가 폰인지 테스트") + @Test + void isPawn() { + Piece whitePawn = new Piece(PieceType.PAWN, Team.WHITE); + Piece blackQueen = new Piece(PieceType.QUEEN, Team.BLACK); + assertThat(whitePawn.isPawn()).isTrue(); + assertThat(blackQueen.isPawn()).isFalse(); + } +} \ No newline at end of file diff --git a/src/test/java/chess/domain/piece/TeamTest.java b/src/test/java/chess/domain/piece/TeamTest.java new file mode 100644 index 00000000000..6578588c4a4 --- /dev/null +++ b/src/test/java/chess/domain/piece/TeamTest.java @@ -0,0 +1,17 @@ +package chess.domain.piece; + +import chess.domain.ChessRunner; +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; + +import static org.assertj.core.api.Assertions.assertThat; + +class TeamTest { + @DisplayName("팀 순서 변경 테스트") + @Test + void changeTeam() { + ChessRunner chessRunner = new ChessRunner(); + Team nextTeam = Team.changeTeam(chessRunner.getCurrentTeam()); + assertThat(nextTeam.isSameTeamWith(Team.BLACK)).isTrue(); + } +} \ No newline at end of file diff --git a/src/test/java/chess/domain/strategy/move/BishopMoveStrategyTest.java b/src/test/java/chess/domain/strategy/move/BishopMoveStrategyTest.java index 2985b56b07d..6bdeb3df2ca 100644 --- a/src/test/java/chess/domain/strategy/move/BishopMoveStrategyTest.java +++ b/src/test/java/chess/domain/strategy/move/BishopMoveStrategyTest.java @@ -1,12 +1,77 @@ package chess.domain.strategy.move; +import chess.domain.board.Board; +import chess.domain.piece.Piece; +import chess.domain.piece.PieceType; +import chess.domain.piece.Team; +import chess.domain.position.Position; +import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.DisplayName; import org.junit.jupiter.api.Test; +import java.util.HashMap; +import java.util.Map; + public class BishopMoveStrategyTest { + private MoveStrategy bishopStrategy; + private Board board; + + @BeforeEach + private void setUp() { + bishopStrategy = new BishopMoveStrategy(); + Map emptyBoard = new HashMap<>(); + board = new Board(emptyBoard); + } + @DisplayName("비숍의 우 상단 대각 이동") @Test void rightUpTest() { + Position source = Position.of("a1"); + Position target = Position.of("e5"); + + Assertions.assertThat(bishopStrategy.movable(source, target, board)).isTrue(); + } + + @DisplayName("비숍의 우 하단 대각 이동") + @Test + void rightDownTest() { + Position source = Position.of("a7"); + Position target = Position.of("e3"); + + Assertions.assertThat(bishopStrategy.movable(source, target, board)).isTrue(); + } + + @DisplayName("비숍의 좌 상단 대각 이동") + @Test + void leftUpTest() { + Position source = Position.of("g1"); + Position target = Position.of("c5"); + + Assertions.assertThat(bishopStrategy.movable(source, target, board)).isTrue(); + } + + @DisplayName("비숍의 좌 하단 대각 이동") + @Test + void leftDownTest() { + Position source = Position.of("g7"); + Position target = Position.of("c3"); + + Assertions.assertThat(bishopStrategy.movable(source, target, board)).isTrue(); + } + + @DisplayName("타겟 위치에 적이 있을 때 이동") + @Test + void moveWhenEnemyTest() { + Piece bishop = new Piece(PieceType.BISHOP, Team.BLACK); + Piece enemy = new Piece(PieceType.PAWN, Team.WHITE); + Position source = Position.of("a1"); + Position target = Position.of("e5"); + Map enemyEntry = new HashMap<>(); + enemyEntry.put(source, bishop); + enemyEntry.put(target, enemy); + Board enemyBoard = new Board(enemyEntry); + Assertions.assertThat(bishopStrategy.movable(source, target, enemyBoard)).isTrue(); } } diff --git a/src/test/java/chess/domain/strategy/move/KingMoveStrategyTest.java b/src/test/java/chess/domain/strategy/move/KingMoveStrategyTest.java new file mode 100644 index 00000000000..0f54b0d7e69 --- /dev/null +++ b/src/test/java/chess/domain/strategy/move/KingMoveStrategyTest.java @@ -0,0 +1,64 @@ +package chess.domain.strategy.move; + +import chess.domain.board.Board; +import chess.domain.piece.Piece; +import chess.domain.piece.PieceType; +import chess.domain.piece.Team; +import chess.domain.position.Position; +import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; + +import java.util.HashMap; +import java.util.Map; + +public class KingMoveStrategyTest { + private MoveStrategy kingStrategy; + + @BeforeEach + private void setUp() { + kingStrategy = new KingMoveStrategy(); + } + + @DisplayName("킹의 이동 가능 위치에 대해 이동 테스트") + @Test + void moveTest() { + Map emptyBoard = new HashMap<>(); + Board board = new Board(emptyBoard); + Position source = Position.of("d4"); + + Position up = Position.of("d5"); + Position down = Position.of("d3"); + Position left = Position.of("c4"); + Position right = Position.of("e4"); + Position rightUp = Position.of("e5"); + Position rightDown = Position.of("e3"); + Position leftUp = Position.of("c5"); + Position leftDown = Position.of("c3"); + + Assertions.assertThat(kingStrategy.movable(source, up, board)).isTrue(); + Assertions.assertThat(kingStrategy.movable(source, down, board)).isTrue(); + Assertions.assertThat(kingStrategy.movable(source, left, board)).isTrue(); + Assertions.assertThat(kingStrategy.movable(source, right, board)).isTrue(); + Assertions.assertThat(kingStrategy.movable(source, rightUp, board)).isTrue(); + Assertions.assertThat(kingStrategy.movable(source, rightDown, board)).isTrue(); + Assertions.assertThat(kingStrategy.movable(source, leftUp, board)).isTrue(); + Assertions.assertThat(kingStrategy.movable(source, leftDown, board)).isTrue(); + } + + @DisplayName("타겟 위치에 적이 있을 때 이동") + @Test + void moveWhenEnemyTest() { + Piece king = new Piece(PieceType.KING, Team.BLACK); + Piece enemy = new Piece(PieceType.PAWN, Team.WHITE); + Position source = Position.of("d4"); + Position target = Position.of("e5"); + Map enemyEntry = new HashMap<>(); + enemyEntry.put(source, king); + enemyEntry.put(target, enemy); + Board enemyBoard = new Board(enemyEntry); + + Assertions.assertThat(kingStrategy.movable(source, target, enemyBoard)).isTrue(); + } +} diff --git a/src/test/java/chess/domain/strategy/move/KnightMoveStrategyTest.java b/src/test/java/chess/domain/strategy/move/KnightMoveStrategyTest.java new file mode 100644 index 00000000000..84bcf4d3aa8 --- /dev/null +++ b/src/test/java/chess/domain/strategy/move/KnightMoveStrategyTest.java @@ -0,0 +1,64 @@ +package chess.domain.strategy.move; + +import chess.domain.board.Board; +import chess.domain.piece.Piece; +import chess.domain.piece.PieceType; +import chess.domain.piece.Team; +import chess.domain.position.Position; +import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; + +import java.util.HashMap; +import java.util.Map; + +public class KnightMoveStrategyTest { + private MoveStrategy knightStrategy; + + @BeforeEach + private void setUp() { + knightStrategy = new KnightMoveStrategy(); + } + + @DisplayName("나이트의 이동 가능 위치에 이동") + @Test + void moveTest() { + Position source = Position.of("d4"); + Map emptyBoard = new HashMap<>(); + Board board = new Board(emptyBoard); + + Position upLeft = Position.of("c6"); + Position upRight = Position.of("e6"); + Position downLeft = Position.of("c2"); + Position downRight = Position.of("e2"); + Position leftUp = Position.of("b5"); + Position leftDown = Position.of("b3"); + Position rightUp = Position.of("f5"); + Position rightDown = Position.of("f3"); + + Assertions.assertThat(knightStrategy.movable(source, upLeft, board)).isTrue(); + Assertions.assertThat(knightStrategy.movable(source, upRight, board)).isTrue(); + Assertions.assertThat(knightStrategy.movable(source, downLeft, board)).isTrue(); + Assertions.assertThat(knightStrategy.movable(source, downRight, board)).isTrue(); + Assertions.assertThat(knightStrategy.movable(source, leftUp, board)).isTrue(); + Assertions.assertThat(knightStrategy.movable(source, leftDown, board)).isTrue(); + Assertions.assertThat(knightStrategy.movable(source, rightUp, board)).isTrue(); + Assertions.assertThat(knightStrategy.movable(source, rightDown, board)).isTrue(); + } + + @DisplayName("타겟 위치에 적이 있을 때 이동") + @Test + void moveWhenEnemyTest() { + Piece knight = new Piece(PieceType.KING, Team.BLACK); + Piece enemy = new Piece(PieceType.PAWN, Team.WHITE); + Position source = Position.of("d4"); + Position target = Position.of("e6"); + Map enemyEntry = new HashMap<>(); + enemyEntry.put(source, knight); + enemyEntry.put(target, enemy); + Board enemyBoard = new Board(enemyEntry); + + Assertions.assertThat(knightStrategy.movable(source, target, enemyBoard)).isTrue(); + } +} diff --git a/src/test/java/chess/domain/strategy/move/PawnMoveStrategyTest.java b/src/test/java/chess/domain/strategy/move/PawnMoveStrategyTest.java new file mode 100644 index 00000000000..41e2d60050c --- /dev/null +++ b/src/test/java/chess/domain/strategy/move/PawnMoveStrategyTest.java @@ -0,0 +1,107 @@ +package chess.domain.strategy.move; + +import chess.domain.board.Board; +import chess.domain.piece.Piece; +import chess.domain.piece.PieceType; +import chess.domain.piece.Team; +import chess.domain.position.Position; +import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; + +import java.util.HashMap; +import java.util.Map; + +public class PawnMoveStrategyTest { + private MoveStrategy pawnStrategy; + + @BeforeEach + private void setUp() { + pawnStrategy = new PawnMoveStrategy(); +// Piece whitePawn = new Piece(PieceType.PAWN, Team.WHITE); +// Piece blackPawn = new Piece(PieceType.PAWN, Team.BLACK); +// Position whiteSource = Position.of("d4"); +// Position blackSource = Position.of("d3"); +// Map entry = new HashMap<>(); +// entry.put(whiteSource, whitePawn); +// entry.put(blackSource, blackPawn); +// board = new Board(entry); + } + + @DisplayName("폰이 시작 위치일 때 1칸 또는 2칸 이동") + @Test + void moveAtInitialPosition() { + Piece whitePawn = new Piece(PieceType.PAWN, Team.WHITE); + Piece blackPawn = new Piece(PieceType.PAWN, Team.BLACK); + Position whiteInitial = Position.of("a2"); + Position blackInitial = Position.of("a7"); + Map emptyBoard = new HashMap<>(); + emptyBoard.put(whiteInitial, whitePawn); + emptyBoard.put(blackInitial, blackPawn); + Board board = new Board(emptyBoard); + + Position whiteOne = Position.of("a3"); + Position whiteTwo = Position.of("a4"); + Position blackOne = Position.of("a6"); + Position blackTwo = Position.of("a5"); + + Assertions.assertThat(pawnStrategy.movable(whiteInitial, whiteOne, board)).isTrue(); + Assertions.assertThat(pawnStrategy.movable(whiteInitial, whiteTwo, board)).isTrue(); + Assertions.assertThat(pawnStrategy.movable(blackInitial, blackOne, board)).isTrue(); + Assertions.assertThat(pawnStrategy.movable(blackInitial, blackTwo, board)).isTrue(); + } + + @DisplayName("폰이 시작 위치가 아닐 때 1칸 전진") + @Test + void moveAtNoneInitialPosition() { + Piece whitePawn = new Piece(PieceType.PAWN, Team.WHITE); + Piece blackPawn = new Piece(PieceType.PAWN, Team.BLACK); + Position whiteSource = Position.of("a3"); + Position blackSource = Position.of("a6"); + Map emptyBoard = new HashMap<>(); + emptyBoard.put(whiteSource, whitePawn); + emptyBoard.put(blackSource, blackPawn); + Board board = new Board(emptyBoard); + + Position upTarget = Position.of("a4"); + Position downTarget = Position.of("a5"); + + Assertions.assertThat(pawnStrategy.movable(whiteSource, upTarget, board)).isTrue(); + Assertions.assertThat(pawnStrategy.movable(blackSource, downTarget, board)).isTrue(); + } + + @DisplayName("폰이 시작 위치가 아닐 때 대각선의 적을 공격 가능") + @Test + void moveDiagonalTest() { + Piece whitePawn = new Piece(PieceType.PAWN, Team.WHITE); + Piece whiteLeftEnemy = new Piece(PieceType.PAWN, Team.BLACK); + Piece whiteRightEnemy = new Piece(PieceType.PAWN, Team.BLACK); + + Piece blackPawn = new Piece(PieceType.PAWN, Team.BLACK); + Piece blackLeftEnemy = new Piece(PieceType.PAWN, Team.WHITE); + Piece blackRightEnemy = new Piece(PieceType.PAWN, Team.WHITE); + + Position whiteSource = Position.of("d3"); + Position whiteDiagonalLeft = Position.of("c4"); + Position whiteDiagonalRight = Position.of("e4"); + + Position blackSource = Position.of("d6"); + Position blackDiagonalLeft = Position.of("c5"); + Position blackDiagonalRight = Position.of("e5"); + + Map entry = new HashMap<>(); + entry.put(whiteSource, whitePawn); + entry.put(whiteDiagonalLeft, whiteLeftEnemy); + entry.put(whiteDiagonalRight, whiteRightEnemy); + entry.put(blackSource, blackPawn); + entry.put(blackDiagonalLeft, blackLeftEnemy); + entry.put(blackDiagonalRight, blackRightEnemy); + Board board = new Board(entry); + + Assertions.assertThat(pawnStrategy.movable(whiteSource, whiteDiagonalLeft, board)).isTrue(); + Assertions.assertThat(pawnStrategy.movable(whiteSource, whiteDiagonalRight, board)).isTrue(); + Assertions.assertThat(pawnStrategy.movable(blackSource, blackDiagonalLeft, board)).isTrue(); + Assertions.assertThat(pawnStrategy.movable(blackSource, blackDiagonalRight, board)).isTrue(); + } +} diff --git a/src/test/java/chess/domain/strategy/move/QueenMoveStrategyTest.java b/src/test/java/chess/domain/strategy/move/QueenMoveStrategyTest.java new file mode 100644 index 00000000000..e1cc32da9fd --- /dev/null +++ b/src/test/java/chess/domain/strategy/move/QueenMoveStrategyTest.java @@ -0,0 +1,113 @@ +package chess.domain.strategy.move; + +import chess.domain.board.Board; +import chess.domain.piece.Piece; +import chess.domain.piece.PieceType; +import chess.domain.piece.Team; +import chess.domain.position.Position; +import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; + +import java.util.HashMap; +import java.util.Map; + +public class QueenMoveStrategyTest { + private MoveStrategy queenStrategy; + private Board board; + + @BeforeEach + private void setUp() { + queenStrategy = new QueenMoveStrategy(); + Map emptyBoard = new HashMap<>(); + board = new Board(emptyBoard); + } + + @DisplayName("퀸의 우 상단 대각 이동") + @Test + void rightUpTest() { + Position source = Position.of("a1"); + Position target = Position.of("e5"); + + Assertions.assertThat(queenStrategy.movable(source, target, board)).isTrue(); + } + + @DisplayName("퀸의 우 하단 대각 이동") + @Test + void rightDownTest() { + Position source = Position.of("a7"); + Position target = Position.of("e3"); + + Assertions.assertThat(queenStrategy.movable(source, target, board)).isTrue(); + } + + @DisplayName("퀸의 좌 상단 대각 이동") + @Test + void leftUpTest() { + Position source = Position.of("g1"); + Position target = Position.of("c5"); + + Assertions.assertThat(queenStrategy.movable(source, target, board)).isTrue(); + } + + @DisplayName("퀸의 좌 하단 대각 이동") + @Test + void leftDownTest() { + Position source = Position.of("g7"); + Position target = Position.of("c3"); + + Assertions.assertThat(queenStrategy.movable(source, target, board)).isTrue(); + } + + @DisplayName("퀸의 상단 직진 이동") + @Test + void upTest() { + Position source = Position.of("a1"); + Position target = Position.of("a6"); + + Assertions.assertThat(queenStrategy.movable(source, target, board)).isTrue(); + } + + @DisplayName("퀸의 하단 직진 이동") + @Test + void downTest() { + Position source = Position.of("a6"); + Position target = Position.of("a1"); + + Assertions.assertThat(queenStrategy.movable(source, target, board)).isTrue(); + } + + @DisplayName("퀸의 우측 직진 이동") + @Test + void rightTest() { + Position source = Position.of("a1"); + Position target = Position.of("g1"); + + Assertions.assertThat(queenStrategy.movable(source, target, board)).isTrue(); + } + + @DisplayName("퀸의 좌측 직진 이동") + @Test + void leftTest() { + Position source = Position.of("g1"); + Position target = Position.of("a1"); + + Assertions.assertThat(queenStrategy.movable(source, target, board)).isTrue(); + } + + @DisplayName("타겟 위치에 적이 있을 때 이동") + @Test + void moveWhenEnemyTest() { + Piece queen = new Piece(PieceType.QUEEN, Team.BLACK); + Piece enemy = new Piece(PieceType.PAWN, Team.WHITE); + Position source = Position.of("a1"); + Position target = Position.of("a6"); + Map enemyEntry = new HashMap<>(); + enemyEntry.put(source, queen); + enemyEntry.put(target, enemy); + Board enemyBoard = new Board(enemyEntry); + + Assertions.assertThat(queenStrategy.movable(source, target, enemyBoard)).isTrue(); + } +} diff --git a/src/test/java/chess/domain/strategy/move/RookMoveStrategyTest.java b/src/test/java/chess/domain/strategy/move/RookMoveStrategyTest.java new file mode 100644 index 00000000000..bf977aa2c90 --- /dev/null +++ b/src/test/java/chess/domain/strategy/move/RookMoveStrategyTest.java @@ -0,0 +1,77 @@ +package chess.domain.strategy.move; + +import chess.domain.board.Board; +import chess.domain.piece.Piece; +import chess.domain.piece.PieceType; +import chess.domain.piece.Team; +import chess.domain.position.Position; +import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; + +import java.util.HashMap; +import java.util.Map; + +public class RookMoveStrategyTest { + private MoveStrategy rookStrategy; + private Board board; + + @BeforeEach + private void setUp() { + rookStrategy = new RookMoveStrategy(); + Map emptyBoard = new HashMap<>(); + board = new Board(emptyBoard); + } + + @DisplayName("룩의 상단 직진 이동") + @Test + void upTest() { + Position source = Position.of("a1"); + Position target = Position.of("a6"); + + Assertions.assertThat(rookStrategy.movable(source, target, board)).isTrue(); + } + + @DisplayName("룩의 하단 직진 이동") + @Test + void downTest() { + Position source = Position.of("a6"); + Position target = Position.of("a1"); + + Assertions.assertThat(rookStrategy.movable(source, target, board)).isTrue(); + } + + @DisplayName("룩의 우측 직진 이동") + @Test + void rightTest() { + Position source = Position.of("a1"); + Position target = Position.of("g1"); + + Assertions.assertThat(rookStrategy.movable(source, target, board)).isTrue(); + } + + @DisplayName("룩의 좌측 직진 이동") + @Test + void leftTest() { + Position source = Position.of("g1"); + Position target = Position.of("a1"); + + Assertions.assertThat(rookStrategy.movable(source, target, board)).isTrue(); + } + + @DisplayName("타겟 위치에 적이 있을 때 이동 테스트") + @Test + void moveWhenEnemyTest() { + Piece rook = new Piece(PieceType.ROOK, Team.BLACK); + Piece enemy = new Piece(PieceType.PAWN, Team.WHITE); + Position source = Position.of("a1"); + Position target = Position.of("a6"); + Map enemyEntry = new HashMap<>(); + enemyEntry.put(source, rook); + enemyEntry.put(target, enemy); + Board enemyBoard = new Board(enemyEntry); + + Assertions.assertThat(rookStrategy.movable(source, target, enemyBoard)).isTrue(); + } +} diff --git a/src/test/java/chess/domain/strategy/move/direction/DirectionTest.java b/src/test/java/chess/domain/strategy/move/direction/DirectionTest.java index 778ade7f67a..6e099801ded 100644 --- a/src/test/java/chess/domain/strategy/move/direction/DirectionTest.java +++ b/src/test/java/chess/domain/strategy/move/direction/DirectionTest.java @@ -1,12 +1,73 @@ package chess.domain.strategy.move.direction; +import chess.domain.position.Position; import org.junit.jupiter.api.DisplayName; import org.junit.jupiter.api.Test; +import static org.assertj.core.api.Assertions.assertThat; + public class DirectionTest { - @DisplayName("조건에 맞는 방향 반환") + @DisplayName("위 방향 이동") + @Test + void checkUpStrategy() { + Position source = Position.of("a1"); + Position target = Position.of("a8"); + assertThat(Direction.findDirection(source, target)).isEqualTo(Direction.UP); + } + + @DisplayName("아래 방향 이동") @Test - void findTest() { + void checkDownStrategy() { + Position source = Position.of("a8"); + Position target = Position.of("a1"); + assertThat(Direction.findDirection(source, target)).isEqualTo(Direction.DOWN); + } + + @DisplayName("왼쪽 방향 이동") + @Test + void checkLeftStrategy() { + Position source = Position.of("e5"); + Position target = Position.of("b5"); + assertThat(Direction.findDirection(source, target)).isEqualTo(Direction.LEFT); + } + + @DisplayName("오른쪽 방향 이동") + @Test + void checkRightStrategy() { + Position source = Position.of("b5"); + Position target = Position.of("e5"); + assertThat(Direction.findDirection(source, target)).isEqualTo(Direction.RIGHT); + } + @DisplayName("왼쪽 위 방향 이동") + @Test + void checkLeftUpStrategy() { + Position source = Position.of("e1"); + Position target = Position.of("c3"); + assertThat(Direction.findDirection(source, target)).isEqualTo(Direction.LEFT_UP); + } + + @DisplayName("왼쪽 아래 방향 이동") + @Test + void checkLeftDownStrategy() { + Position source = Position.of("h8"); + Position target = Position.of("a1"); + assertThat(Direction.findDirection(source, target)).isEqualTo(Direction.LEFT_DOWN); + } + + @DisplayName("오른쪽 위 방향 이동") + @Test + void checkRightUpStrategy() { + Position source = Position.of("a1"); + Position target = Position.of("h8"); + assertThat(Direction.findDirection(source, target)).isEqualTo(Direction.RIGHT_UP); + } + + @DisplayName("오른쪽 아래 방향 이동") + @Test + void checkRightDownStrategy() { + Position source = Position.of("a8"); + Position target = Position.of("e1"); + assertThat(Direction.findDirection(source, target)).isEqualTo(Direction.RIGHT_DOWN); } -} +} \ No newline at end of file From db9009f88f07f7890120dabdfaeb3d504761dbc5 Mon Sep 17 00:00:00 2001 From: giantim Date: Sat, 28 Mar 2020 12:07:33 +0900 Subject: [PATCH 20/75] =?UTF-8?q?refactor:=20=EB=B3=80=EA=B2=BD=EB=90=98?= =?UTF-8?q?=EB=A9=B4=20=EC=95=88=EB=90=98=EB=8A=94=20=EB=A7=A4=EA=B0=9C=20?= =?UTF-8?q?=EB=B3=80=EC=88=98,=20=ED=81=B4=EB=9E=98=EC=8A=A4=EC=97=90=20fi?= =?UTF-8?q?nal=20=ED=82=A4=EC=9B=8C=EB=93=9C=20=EC=B6=94=EA=B0=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../chess/controller/ChessController.java | 4 +-- src/main/java/chess/domain/board/Board.java | 30 +++++++++---------- src/main/java/chess/domain/piece/Piece.java | 6 ++-- .../java/chess/domain/piece/PieceType.java | 2 +- src/main/java/chess/domain/piece/Team.java | 4 +-- src/main/java/chess/domain/position/File.java | 4 +-- .../java/chess/domain/position/Position.java | 7 ++--- src/main/java/chess/domain/position/Rank.java | 12 ++++---- .../strategy/move/BishopMoveStrategy.java | 5 ++-- .../strategy/move/KingMoveStrategy.java | 5 ++-- .../strategy/move/KnightMoveStrategy.java | 4 +-- .../domain/strategy/move/MoveStrategy.java | 9 +++--- .../strategy/move/PawnMoveStrategy.java | 4 +-- .../strategy/move/QueenMoveStrategy.java | 5 ++-- .../strategy/move/RookMoveStrategy.java | 4 +-- .../strategy/move/direction/Direction.java | 9 +++--- .../strategy/move/direction/DownStrategy.java | 4 +-- .../move/direction/LeftDownStrategy.java | 4 +-- .../strategy/move/direction/LeftStrategy.java | 4 +-- .../move/direction/LeftUpStrategy.java | 4 +-- .../move/direction/RightDownStrategy.java | 4 +-- .../move/direction/RightStrategy.java | 4 +-- .../move/direction/RightUpStrategy.java | 4 +-- .../strategy/move/direction/UpStrategy.java | 4 +-- 24 files changed, 71 insertions(+), 75 deletions(-) diff --git a/src/main/java/chess/controller/ChessController.java b/src/main/java/chess/controller/ChessController.java index 7488488f82d..fdf6c94e972 100644 --- a/src/main/java/chess/controller/ChessController.java +++ b/src/main/java/chess/controller/ChessController.java @@ -48,7 +48,7 @@ public static void run() { } } - private static boolean findWinner(ChessRunner chessRunner) { + private static boolean findWinner(final ChessRunner chessRunner) { Team winner = chessRunner.findWinner(); if (winner != null) { outputView.printWinner(winner); @@ -57,7 +57,7 @@ private static boolean findWinner(ChessRunner chessRunner) { return true; } - private static void printBoard(Board board) { + private static void printBoard(final Board board) { BoardDto boardDto = new BoardDto(board.parse()); PositionDto positionDto = new PositionDto(Position.getPositions()); outputView.printBoard(positionDto.getPositions(), boardDto.get()); diff --git a/src/main/java/chess/domain/board/Board.java b/src/main/java/chess/domain/board/Board.java index c685bab6c97..d42f958b544 100644 --- a/src/main/java/chess/domain/board/Board.java +++ b/src/main/java/chess/domain/board/Board.java @@ -12,13 +12,16 @@ import java.util.stream.Collectors; public class Board { + private static final int PAWN_ON_SAME_FILE = 1; + private static final double PAWN_SCORE_STRATEGY = 0.5; + private final Map board; public Board() { this(BoardInitializer.initializeAll()); } - public Board(Map board) { + public Board(final Map board) { this.board = board; } @@ -28,10 +31,11 @@ public Map parse() { .collect(Collectors.toMap(entry -> entry.getKey().toString(), entry -> entry.getValue().toSymbol(), (e1, e2) -> e1, LinkedHashMap::new)); + return Collections.unmodifiableMap(parseResult); } - public void updateBoard(Position sourcePosition, Position targetPosition) { + public void updateBoard(final Position sourcePosition, final Position targetPosition) { Piece selectedPiece = this.board.get(sourcePosition); this.board.put(targetPosition, selectedPiece); this.board.remove(sourcePosition); @@ -48,17 +52,13 @@ public Team checkWinner() { } private boolean checkWhiteKing() { - for (Piece piece : board.values()) { - if (piece.isWhiteKing()) return true; - } - return false; + return this.board.values().stream() + .anyMatch(Piece::isWhiteKing); } private boolean checkBlackKing() { - for (Piece piece : board.values()) { - if (piece.isBlackKing()) return true; - } - return false; + return this.board.values().stream() + .anyMatch(Piece::isBlackKing); } public boolean isEmpty(final Position position) { @@ -69,27 +69,27 @@ public Piece getPiece(final Position position) { return this.board.get(position); } - public double calculateScore(Team team) { + public double calculateScore(final Team team) { double totalScore = calculateTotalScore(team); return calculatePawnScore(team, totalScore); } - private double calculateTotalScore(Team team) { + private double calculateTotalScore(final Team team) { return board.values().stream() .filter(piece -> team.isSameTeamWith(piece.getTeam())) .mapToDouble(Piece::getScore) .sum(); } - private double calculatePawnScore(Team team, double score) { + private double calculatePawnScore(final Team team, double score) { for (File file : File.values()) { List> sameFile = this.board.entrySet().stream() .filter(entry -> File.of(entry.getKey().getFile()).equals(file)) .filter(entry -> entry.getValue().isPawn() && !entry.getValue().isEnemy(team)) .collect(Collectors.toList()); - if (sameFile.size() > 1) { - score -= sameFile.size() * 0.5; + if (sameFile.size() > PAWN_ON_SAME_FILE) { + score -= sameFile.size() * PAWN_SCORE_STRATEGY; } } return score; diff --git a/src/main/java/chess/domain/piece/Piece.java b/src/main/java/chess/domain/piece/Piece.java index 72b62745474..5169eb6c99c 100644 --- a/src/main/java/chess/domain/piece/Piece.java +++ b/src/main/java/chess/domain/piece/Piece.java @@ -16,15 +16,15 @@ public String toSymbol() { return this.team.symbolize(this.pieceType.getSymbol()); } - public boolean movable(Position source, Position target, Board board) { + public boolean movable(final Position source, final Position target, final Board board) { return this.pieceType.movable(source, target, board); } - public boolean isEnemy(Piece targetPiece) { + public boolean isEnemy(final Piece targetPiece) { return !this.team.isSameTeamWith(targetPiece.getTeam()); } - public boolean isEnemy(Team team) { + public boolean isEnemy(final Team team) { return !this.team.isSameTeamWith(team); } diff --git a/src/main/java/chess/domain/piece/PieceType.java b/src/main/java/chess/domain/piece/PieceType.java index f14a48d6022..f50f5efc873 100644 --- a/src/main/java/chess/domain/piece/PieceType.java +++ b/src/main/java/chess/domain/piece/PieceType.java @@ -22,7 +22,7 @@ public enum PieceType { this.moveStrategy = moveStrategy; } - public boolean movable(Position source, Position target, Board board) { + public boolean movable(final Position source, final Position target, final Board board) { return this.moveStrategy.movable(source, target, board); } diff --git a/src/main/java/chess/domain/piece/Team.java b/src/main/java/chess/domain/piece/Team.java index 8b7d025abe0..6ae03e8124d 100644 --- a/src/main/java/chess/domain/piece/Team.java +++ b/src/main/java/chess/domain/piece/Team.java @@ -12,7 +12,7 @@ public enum Team { this.expression = expression; } - public static Team changeTeam(Team team) { + public static Team changeTeam(final Team team) { if (team == BLACK) { return WHITE; } @@ -23,7 +23,7 @@ public String symbolize(final String name) { return this.expression.apply(name); } - public boolean isSameTeamWith(Team team) { + public boolean isSameTeamWith(final Team team) { return this == team; } diff --git a/src/main/java/chess/domain/position/File.java b/src/main/java/chess/domain/position/File.java index 29f6ad3747a..bb03d1216d0 100644 --- a/src/main/java/chess/domain/position/File.java +++ b/src/main/java/chess/domain/position/File.java @@ -20,14 +20,14 @@ public enum File { this.number = number; } - public static File of(String file) { + public static File of(final String file) { return Arrays.stream(values()) .filter(f -> f.symbol == file.toLowerCase().charAt(0)) .findFirst() .orElseThrow(() -> new IllegalArgumentException("잘못된 x 좌표값을 입력하였습니다.")); } - public static File of(int file) { + public static File of(final int file) { return Arrays.stream(values()) .filter(f -> f.number == file) .findFirst() diff --git a/src/main/java/chess/domain/position/Position.java b/src/main/java/chess/domain/position/Position.java index ac8a76b63e4..4ba4ddb7fd5 100644 --- a/src/main/java/chess/domain/position/Position.java +++ b/src/main/java/chess/domain/position/Position.java @@ -59,12 +59,11 @@ public static List getPositions() { return Collections.unmodifiableList(parseResult); } - public int calculateFileGap(Position target) { - int fileGap = this.file.compareTo(target.file); - return fileGap; + public int calculateFileGap(final Position target) { + return this.file.compareTo(target.file); } - public int calculateRankGap(Position target) { + public int calculateRankGap(final Position target) { return this.rank.getDifference(target.rank); } diff --git a/src/main/java/chess/domain/position/Rank.java b/src/main/java/chess/domain/position/Rank.java index f1034ef6464..002a9c69536 100644 --- a/src/main/java/chess/domain/position/Rank.java +++ b/src/main/java/chess/domain/position/Rank.java @@ -18,25 +18,25 @@ public enum Rank { this.symbol = symbol; } - public static Rank of(String rank) { + public static Rank of(final String rank) { return Arrays.stream(values()) .filter(pv -> pv.symbol == Integer.parseInt(rank)) .findFirst() .orElseThrow(() -> new IllegalArgumentException("잘못된 y 좌표값을 입력하였습니다.")); } - public static Rank of(int rank) { + public static Rank of(final int rank) { return Arrays.stream(values()) .filter(f -> f.symbol == rank) .findFirst() .orElseThrow(() -> new IllegalArgumentException("잘못된 y 좌표값을 입력하였습니다.")); } - public int getSymbol() { - return this.symbol; + public int getDifference(final Rank rank) { + return this.symbol - rank.symbol; } - public int getDifference(Rank rank) { - return this.symbol - rank.symbol; + public int getSymbol() { + return this.symbol; } } diff --git a/src/main/java/chess/domain/strategy/move/BishopMoveStrategy.java b/src/main/java/chess/domain/strategy/move/BishopMoveStrategy.java index 60fc5310997..2d6b99cda57 100644 --- a/src/main/java/chess/domain/strategy/move/BishopMoveStrategy.java +++ b/src/main/java/chess/domain/strategy/move/BishopMoveStrategy.java @@ -3,10 +3,9 @@ import chess.domain.board.Board; import chess.domain.position.Position; -public class BishopMoveStrategy extends MoveStrategy { - +public final class BishopMoveStrategy extends MoveStrategy { @Override - public boolean movable(Position source, Position target, Board board) { + public boolean movable(final Position source, final Position target, final Board board) { if (isSamePosition(source, target)) { return false; } diff --git a/src/main/java/chess/domain/strategy/move/KingMoveStrategy.java b/src/main/java/chess/domain/strategy/move/KingMoveStrategy.java index 86893b86e6b..1b7c157e9e1 100644 --- a/src/main/java/chess/domain/strategy/move/KingMoveStrategy.java +++ b/src/main/java/chess/domain/strategy/move/KingMoveStrategy.java @@ -3,10 +3,9 @@ import chess.domain.board.Board; import chess.domain.position.Position; -public class KingMoveStrategy extends MoveStrategy { - +public final class KingMoveStrategy extends MoveStrategy { @Override - public boolean movable(Position source, Position target, Board board) { + public boolean movable(final Position source, final Position target, final Board board) { if (isSamePosition(source, target)) { return false; } diff --git a/src/main/java/chess/domain/strategy/move/KnightMoveStrategy.java b/src/main/java/chess/domain/strategy/move/KnightMoveStrategy.java index 6a7582c9bbb..7a2e2676256 100644 --- a/src/main/java/chess/domain/strategy/move/KnightMoveStrategy.java +++ b/src/main/java/chess/domain/strategy/move/KnightMoveStrategy.java @@ -3,9 +3,9 @@ import chess.domain.board.Board; import chess.domain.position.Position; -public class KnightMoveStrategy extends MoveStrategy { +public final class KnightMoveStrategy extends MoveStrategy { @Override - public boolean movable(Position source, Position target, Board board) { + public boolean movable(final Position source, final Position target, final Board board) { if (isSamePosition(source, target)) { return false; } diff --git a/src/main/java/chess/domain/strategy/move/MoveStrategy.java b/src/main/java/chess/domain/strategy/move/MoveStrategy.java index 27ea9af6e81..5b6395ce053 100644 --- a/src/main/java/chess/domain/strategy/move/MoveStrategy.java +++ b/src/main/java/chess/domain/strategy/move/MoveStrategy.java @@ -8,12 +8,11 @@ import java.util.List; public abstract class MoveStrategy { - - protected boolean isSamePosition(Position source, Position target) { + protected boolean isSamePosition(final Position source, final Position target) { return source.equals(target); } - protected boolean checkObstacle(Position source, Position target, Board board) { + protected boolean checkObstacle(final Position source, final Position target, final Board board) { Direction direction = Direction.findDirection(source, target); List path = direction.findPath(source, target); @@ -21,7 +20,7 @@ protected boolean checkObstacle(Position source, Position target, Board board) { .allMatch(board::isEmpty); } - protected boolean checkTarget(Position source, Position target, Board board) { + protected boolean checkTarget(final Position source, final Position target, final Board board) { Piece sourcePiece = board.getPiece(source); if (board.isEmpty(target)) { return true; @@ -30,5 +29,5 @@ protected boolean checkTarget(Position source, Position target, Board board) { return sourcePiece.isEnemy(targetPiece); } - public abstract boolean movable(Position source, Position target, Board board); + public abstract boolean movable(final Position source, final Position target, final Board board); } diff --git a/src/main/java/chess/domain/strategy/move/PawnMoveStrategy.java b/src/main/java/chess/domain/strategy/move/PawnMoveStrategy.java index ab116760b22..51152f41ea2 100644 --- a/src/main/java/chess/domain/strategy/move/PawnMoveStrategy.java +++ b/src/main/java/chess/domain/strategy/move/PawnMoveStrategy.java @@ -5,12 +5,12 @@ import chess.domain.piece.Team; import chess.domain.position.Position; -public class PawnMoveStrategy extends MoveStrategy { +public final class PawnMoveStrategy extends MoveStrategy { private static final int WHITE_POSITION = 2; private static final int BLACK_POSITION = 7; @Override - public boolean movable(Position source, Position target, Board board) { + public boolean movable(final Position source, final Position target, final Board board) { if (isSamePosition(source, target)) { return false; } diff --git a/src/main/java/chess/domain/strategy/move/QueenMoveStrategy.java b/src/main/java/chess/domain/strategy/move/QueenMoveStrategy.java index 4a8f9dbbd6f..06b05f8db8b 100644 --- a/src/main/java/chess/domain/strategy/move/QueenMoveStrategy.java +++ b/src/main/java/chess/domain/strategy/move/QueenMoveStrategy.java @@ -3,10 +3,9 @@ import chess.domain.board.Board; import chess.domain.position.Position; -public class QueenMoveStrategy extends MoveStrategy { - +public final class QueenMoveStrategy extends MoveStrategy { @Override - public boolean movable(Position source, Position target, Board board) { + public boolean movable(final Position source, final Position target, final Board board) { return new RookMoveStrategy().movable(source, target, board) || new BishopMoveStrategy().movable(source, target, board); } diff --git a/src/main/java/chess/domain/strategy/move/RookMoveStrategy.java b/src/main/java/chess/domain/strategy/move/RookMoveStrategy.java index 6b46d56f9a0..91f0bc112c3 100644 --- a/src/main/java/chess/domain/strategy/move/RookMoveStrategy.java +++ b/src/main/java/chess/domain/strategy/move/RookMoveStrategy.java @@ -3,9 +3,9 @@ import chess.domain.board.Board; import chess.domain.position.Position; -public class RookMoveStrategy extends MoveStrategy { +public final class RookMoveStrategy extends MoveStrategy { @Override - public boolean movable(Position source, Position target, Board board) { + public boolean movable(final Position source, final Position target, final Board board) { if (isSamePosition(source, target)) { return false; } diff --git a/src/main/java/chess/domain/strategy/move/direction/Direction.java b/src/main/java/chess/domain/strategy/move/direction/Direction.java index 48301427d30..857ad66d9a7 100644 --- a/src/main/java/chess/domain/strategy/move/direction/Direction.java +++ b/src/main/java/chess/domain/strategy/move/direction/Direction.java @@ -16,24 +16,25 @@ public enum Direction { RIGHT_UP(new RightUpStrategy(), (fileGap, rankGap) -> fileGap > 0 && rankGap > 0), RIGHT_DOWN(new RightDownStrategy(), (fileGap, rankGap) -> fileGap > 0 && rankGap < 0); - private DirectionStrategy directionStrategy; - private BiPredicate condition; + private final DirectionStrategy directionStrategy; + private final BiPredicate condition; Direction(DirectionStrategy directionStrategy, BiPredicate condition) { this.directionStrategy = directionStrategy; this.condition = condition; } - public static Direction findDirection(Position source, Position target) { + public static Direction findDirection(final Position source, final Position target) { int fileGap = target.calculateFileGap(source); int rankGap = target.calculateRankGap(source); + return Arrays.stream(values()) .filter(direction -> direction.condition.test(fileGap, rankGap)) .findFirst() .orElseThrow(AssertionError::new); } - public List findPath(Position source, Position target) { + public List findPath(final Position source, final Position target) { return this.directionStrategy.findPath(source, target); } } \ No newline at end of file diff --git a/src/main/java/chess/domain/strategy/move/direction/DownStrategy.java b/src/main/java/chess/domain/strategy/move/direction/DownStrategy.java index d7d62a77070..182db434310 100644 --- a/src/main/java/chess/domain/strategy/move/direction/DownStrategy.java +++ b/src/main/java/chess/domain/strategy/move/direction/DownStrategy.java @@ -5,9 +5,9 @@ import java.util.ArrayList; import java.util.List; -public class DownStrategy implements DirectionStrategy { +public final class DownStrategy implements DirectionStrategy { @Override - public List findPath(Position source, Position target) { + public List findPath(final Position source, final Position target) { List path = new ArrayList<>(); for (int i = target.getRank() + 1; i < source.getRank(); i++) { diff --git a/src/main/java/chess/domain/strategy/move/direction/LeftDownStrategy.java b/src/main/java/chess/domain/strategy/move/direction/LeftDownStrategy.java index f6aecaba9d9..0c882279e8d 100644 --- a/src/main/java/chess/domain/strategy/move/direction/LeftDownStrategy.java +++ b/src/main/java/chess/domain/strategy/move/direction/LeftDownStrategy.java @@ -5,10 +5,10 @@ import java.util.ArrayList; import java.util.List; -public class LeftDownStrategy implements DirectionStrategy { +public final class LeftDownStrategy implements DirectionStrategy { @Override - public List findPath(Position source, Position target) { + public List findPath(final Position source, final Position target) { List path = new ArrayList<>(); for (int i = target.getFile() + 1; i < source.getFile(); i++) { diff --git a/src/main/java/chess/domain/strategy/move/direction/LeftStrategy.java b/src/main/java/chess/domain/strategy/move/direction/LeftStrategy.java index 53fed6f5394..b5a6caa750b 100644 --- a/src/main/java/chess/domain/strategy/move/direction/LeftStrategy.java +++ b/src/main/java/chess/domain/strategy/move/direction/LeftStrategy.java @@ -5,9 +5,9 @@ import java.util.ArrayList; import java.util.List; -public class LeftStrategy implements DirectionStrategy { +public final class LeftStrategy implements DirectionStrategy { @Override - public List findPath(Position source, Position target) { + public List findPath(final Position source, final Position target) { List path = new ArrayList<>(); for (int i = target.getFile() + 1; i < source.getFile(); i++) { diff --git a/src/main/java/chess/domain/strategy/move/direction/LeftUpStrategy.java b/src/main/java/chess/domain/strategy/move/direction/LeftUpStrategy.java index 20842f29f74..d3313f7e5a9 100644 --- a/src/main/java/chess/domain/strategy/move/direction/LeftUpStrategy.java +++ b/src/main/java/chess/domain/strategy/move/direction/LeftUpStrategy.java @@ -5,9 +5,9 @@ import java.util.ArrayList; import java.util.List; -public class LeftUpStrategy implements DirectionStrategy { +public final class LeftUpStrategy implements DirectionStrategy { @Override - public List findPath(Position source, Position target) { + public List findPath(final Position source, final Position target) { List path = new ArrayList<>(); for (int i = target.getFile() + 1; i < source.getFile(); i++) { diff --git a/src/main/java/chess/domain/strategy/move/direction/RightDownStrategy.java b/src/main/java/chess/domain/strategy/move/direction/RightDownStrategy.java index d5919f032e8..5551b9af7ff 100644 --- a/src/main/java/chess/domain/strategy/move/direction/RightDownStrategy.java +++ b/src/main/java/chess/domain/strategy/move/direction/RightDownStrategy.java @@ -5,10 +5,10 @@ import java.util.ArrayList; import java.util.List; -public class RightDownStrategy implements DirectionStrategy { +public final class RightDownStrategy implements DirectionStrategy { @Override - public List findPath(Position source, Position target) { + public List findPath(final Position source, final Position target) { List path = new ArrayList<>(); for (int i = target.getFile() - 1; i > source.getFile(); i--) { diff --git a/src/main/java/chess/domain/strategy/move/direction/RightStrategy.java b/src/main/java/chess/domain/strategy/move/direction/RightStrategy.java index 2ce164b797c..4dc81307ff7 100644 --- a/src/main/java/chess/domain/strategy/move/direction/RightStrategy.java +++ b/src/main/java/chess/domain/strategy/move/direction/RightStrategy.java @@ -5,9 +5,9 @@ import java.util.ArrayList; import java.util.List; -public class RightStrategy implements DirectionStrategy { +public final class RightStrategy implements DirectionStrategy { @Override - public List findPath(Position source, Position target) { + public List findPath(final Position source, final Position target) { List path = new ArrayList<>(); for (int i = target.getFile() - 1; i > source.getFile(); i--) { diff --git a/src/main/java/chess/domain/strategy/move/direction/RightUpStrategy.java b/src/main/java/chess/domain/strategy/move/direction/RightUpStrategy.java index ce7a9472f12..c518116fe6c 100644 --- a/src/main/java/chess/domain/strategy/move/direction/RightUpStrategy.java +++ b/src/main/java/chess/domain/strategy/move/direction/RightUpStrategy.java @@ -5,10 +5,10 @@ import java.util.ArrayList; import java.util.List; -public class RightUpStrategy implements DirectionStrategy { +public final class RightUpStrategy implements DirectionStrategy { @Override - public List findPath(Position source, Position target) { + public List findPath(final Position source, final Position target) { List path = new ArrayList<>(); for (int i = target.getFile() - 1; i > source.getFile(); i--) { diff --git a/src/main/java/chess/domain/strategy/move/direction/UpStrategy.java b/src/main/java/chess/domain/strategy/move/direction/UpStrategy.java index 9728fdc2e8f..a4afb7f27b5 100644 --- a/src/main/java/chess/domain/strategy/move/direction/UpStrategy.java +++ b/src/main/java/chess/domain/strategy/move/direction/UpStrategy.java @@ -5,9 +5,9 @@ import java.util.ArrayList; import java.util.List; -public class UpStrategy implements DirectionStrategy { +public final class UpStrategy implements DirectionStrategy { @Override - public List findPath(Position source, Position target) { + public List findPath(final Position source, final Position target) { List path = new ArrayList<>(); for (int i = target.getRank() - 1; i > source.getRank(); i--) { From fd4d688ecce35c708b3dc6fef22c29c0cf296014 Mon Sep 17 00:00:00 2001 From: giantim Date: Sat, 28 Mar 2020 15:08:51 +0900 Subject: [PATCH 21/75] =?UTF-8?q?refactor:=20=EC=BB=A8=ED=8A=B8=EB=A1=A4?= =?UTF-8?q?=EB=9F=AC=EC=9D=98=20=EC=8B=A4=ED=96=89=20=EB=A9=94=EC=84=9C?= =?UTF-8?q?=EB=93=9C=EB=A5=BC=20=EB=AA=85=EB=A0=B9=EC=96=B4=20=EB=B3=84?= =?UTF-8?q?=EB=A1=9C=20=EB=B6=84=EB=A6=AC?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../chess/controller/ChessController.java | 81 +++++++++++++------ src/main/java/chess/controller/Command.java | 27 +++++++ .../java/chess/view/ConsoleInputView.java | 40 +-------- .../java/chess/view/ConsoleOutputView.java | 9 ++- src/main/java/chess/view/InputView.java | 6 +- src/main/java/chess/view/OutputView.java | 4 +- 6 files changed, 96 insertions(+), 71 deletions(-) create mode 100644 src/main/java/chess/controller/Command.java diff --git a/src/main/java/chess/controller/ChessController.java b/src/main/java/chess/controller/ChessController.java index fdf6c94e972..81c2c1da8e5 100644 --- a/src/main/java/chess/controller/ChessController.java +++ b/src/main/java/chess/controller/ChessController.java @@ -12,39 +12,65 @@ import chess.view.OutputView; public class ChessController { + private static final String DELIMITER = " "; + private static final int SOURCE_INDEX = 1; + private static final int TARGET_INDEX = 2; + private static InputView inputView = new ConsoleInputView(); private static OutputView outputView = new ConsoleOutputView(); public static void start() { - if (inputView.askChessRun()) { - run(); + try { + Command command = Command.of(inputView.askChessRun()); + run(command); + } catch (IllegalArgumentException e) { + System.out.println(e.getMessage()); + start(); } } - public static void run() { - ChessRunner chessRunner = new ChessRunner(); - printBoard(chessRunner.getBoard()); - boolean moveFlag = true; + private static void run(Command command) { + if (command.isStart()) { + ChessRunner chessRunner = new ChessRunner(); + printBoard(chessRunner.getBoard()); + runChess(chessRunner); + } + } + + public static void runChess(ChessRunner chessRunner) { + try { + String input = inputView.askGameCommand(); + Command command = Command.of(input); + + runByCommand(chessRunner, input, command); + } catch (IllegalArgumentException e) { + System.out.println(e.getMessage()); + runChess(chessRunner); + } + } - while (moveFlag) { - try { - String[] moveSource = inputView.askMoveOrStatus().split(" "); - if (moveSource[0].toUpperCase().equals("END")) { - break; - } - if (moveSource[0].toUpperCase().equals("STATUS")) { - outputView.printStatus(chessRunner.calculateScore(), chessRunner.getCurrentTeam()); - continue; - } - String sourcePosition = moveSource[1]; - String targetPosition = moveSource[2]; - chessRunner.update(sourcePosition, targetPosition); - printBoard(chessRunner.getBoard()); - if (!findWinner(chessRunner)) break; + private static void runByCommand(ChessRunner chessRunner, String input, Command command) { + switch (command) { + case MOVE: + runMove(chessRunner, input); + break; + case STATUS: + runStatus(chessRunner); + break; + case END: + default: + break; + } + } - } catch (IllegalArgumentException e) { - System.out.println(e.getMessage()); - } + private static void runMove(ChessRunner chessRunner, String input) { + String[] commands = input.split(DELIMITER); + String source = commands[SOURCE_INDEX]; + String target = commands[TARGET_INDEX]; + chessRunner.update(source, target); + printBoard(chessRunner.getBoard()); + if (findWinner(chessRunner)) { + runChess(chessRunner); } } @@ -57,6 +83,13 @@ private static boolean findWinner(final ChessRunner chessRunner) { return true; } + private static void runStatus(ChessRunner chessRunner) { + double score = chessRunner.calculateScore(); + outputView.printStatus(score, chessRunner.getCurrentTeam()); + printBoard(chessRunner.getBoard()); + runChess(chessRunner); + } + private static void printBoard(final Board board) { BoardDto boardDto = new BoardDto(board.parse()); PositionDto positionDto = new PositionDto(Position.getPositions()); diff --git a/src/main/java/chess/controller/Command.java b/src/main/java/chess/controller/Command.java new file mode 100644 index 00000000000..b8585d45382 --- /dev/null +++ b/src/main/java/chess/controller/Command.java @@ -0,0 +1,27 @@ +package chess.controller; + +import java.util.Arrays; + +public enum Command { + START("start"), + MOVE("move"), + STATUS("status"), + END("end"); + + private String command; + + Command(String command) { + this.command = command; + } + + public static Command of(final String command) { + return Arrays.stream(values()) + .filter(c -> command.contains(c.command)) + .findFirst() + .orElseThrow(() -> new IllegalArgumentException("잘못된 명령어를 입력하였습니다.")); + } + + public boolean isStart() { + return this == START; + } +} diff --git a/src/main/java/chess/view/ConsoleInputView.java b/src/main/java/chess/view/ConsoleInputView.java index 89b07e3f2a4..caf9c36fe07 100644 --- a/src/main/java/chess/view/ConsoleInputView.java +++ b/src/main/java/chess/view/ConsoleInputView.java @@ -4,50 +4,18 @@ public class ConsoleInputView implements InputView { private static final Scanner SCANNER = new Scanner(System.in); - private static final String START_COMMAND = "start"; - private static final String END_COMMAND = "end"; @Override - public boolean askChessRun() { + public String askChessRun() { System.out.println("> 체스 게임을 시작합니다."); System.out.println("> 게임 시작 : start"); System.out.println("> 게임 종료 : end"); System.out.println("> 게임 이동 : move source위치 target위치 - 예. move b2 b3"); - try { - String input = SCANNER.nextLine(); - validateRunCommand(input); - return runFlag(input); - } catch (IllegalArgumentException e) { - System.out.println(e.getMessage()); - return askChessRun(); - } - } - - private void validateRunCommand(String input) { - if (!input.equals(START_COMMAND) && !input.equals(END_COMMAND)) { - throw new IllegalArgumentException("start 또는 end 를 입력해주세요."); - } - } - - private boolean runFlag(String input) { - return input.equals(START_COMMAND); + return askGameCommand(); } @Override - public String askMoveOrStatus() { - try { - String input = SCANNER.nextLine(); - validateMove(input); - return input; - } catch (IllegalArgumentException e) { - System.out.println(e.getMessage()); - return askMoveOrStatus(); - } - } - - private static void validateMove(String input) { - if (!input.contains("move") && !input.equals("status") && !input.equals("end")) { - throw new IllegalArgumentException("잘못된 명령어를 입력하였습니다."); - } + public String askGameCommand() { + return SCANNER.nextLine(); } } diff --git a/src/main/java/chess/view/ConsoleOutputView.java b/src/main/java/chess/view/ConsoleOutputView.java index b6326a5d503..b0cc85985cd 100644 --- a/src/main/java/chess/view/ConsoleOutputView.java +++ b/src/main/java/chess/view/ConsoleOutputView.java @@ -16,6 +16,7 @@ public void printBoard(final List positions, final Map b System.out.print(printPiece(piece)); checkNewLine(i); } + System.out.println(); } private void checkNewLine(final int i) { @@ -32,12 +33,12 @@ private String printPiece(String piece) { } @Override - public void printWinner(Team team) { - System.out.println(String.format("%s 팀이 이겼습니다.", team.name())); + public void printStatus(double calculateScore, Team team) { + System.out.println(String.format("%s 팀의 점수는 %.1f 점입니다.", team.name(), calculateScore)); } @Override - public void printStatus(double calculateScore, Team team) { - System.out.println(String.format("%s 팀의 점수는 %.1f 점입니다.", team.name(), calculateScore)); + public void printWinner(Team team) { + System.out.println(String.format("%s 팀이 이겼습니다.", team.name())); } } diff --git a/src/main/java/chess/view/InputView.java b/src/main/java/chess/view/InputView.java index 01c2fb9df8f..adb656d5da3 100644 --- a/src/main/java/chess/view/InputView.java +++ b/src/main/java/chess/view/InputView.java @@ -1,8 +1,6 @@ package chess.view; public interface InputView { - - boolean askChessRun(); - - String askMoveOrStatus(); + String askChessRun(); + String askGameCommand(); } diff --git a/src/main/java/chess/view/OutputView.java b/src/main/java/chess/view/OutputView.java index 99cf6959ee1..1399b824401 100644 --- a/src/main/java/chess/view/OutputView.java +++ b/src/main/java/chess/view/OutputView.java @@ -7,8 +7,6 @@ public interface OutputView { void printBoard(List positions, Map board); - - void printWinner(Team team); - void printStatus(double calculateScore, Team team); + void printWinner(Team team); } From 6f154645366819aff1624a71bbf0966a1d3bec99 Mon Sep 17 00:00:00 2001 From: giantim Date: Sat, 28 Mar 2020 15:39:38 +0900 Subject: [PATCH 22/75] =?UTF-8?q?refactor:=20DirectionStrategy=20=EC=9D=98?= =?UTF-8?q?=20=EA=B5=AC=ED=98=84=20=ED=81=B4=EB=9E=98=EC=8A=A4=EB=93=A4?= =?UTF-8?q?=EC=9D=98=20=ED=85=8C=EC=8A=A4=ED=8A=B8=20=EC=BD=94=EB=93=9C=20?= =?UTF-8?q?=EC=B6=94=EA=B0=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../strategy/move/direction/DownStrategy.java | 12 +++++---- .../move/direction/LeftDownStrategy.java | 17 +++++------- .../strategy/move/direction/LeftStrategy.java | 12 +++++---- .../move/direction/LeftUpStrategy.java | 15 ++++++----- .../move/direction/RightDownStrategy.java | 13 ++++----- .../move/direction/RightStrategy.java | 12 +++++---- .../move/direction/RightUpStrategy.java | 13 ++++----- .../strategy/move/direction/UpStrategy.java | 12 +++++---- .../move/direction/DownStrategyTest.java | 26 ++++++++++++++++++ .../move/direction/LeftDownStrategyTest.java | 26 ++++++++++++++++++ .../move/direction/LeftStrategyTest.java | 27 +++++++++++++++++++ .../move/direction/LeftUpStrategyTest.java | 26 ++++++++++++++++++ .../move/direction/RightDownStrategyTest.java | 26 ++++++++++++++++++ .../move/direction/RightStrategyTest.java | 26 ++++++++++++++++++ .../move/direction/RightUpStrategyTest.java | 26 ++++++++++++++++++ .../move/direction/UpStrategyTest.java | 26 ++++++++++++++++++ 16 files changed, 266 insertions(+), 49 deletions(-) create mode 100644 src/test/java/chess/domain/strategy/move/direction/DownStrategyTest.java create mode 100644 src/test/java/chess/domain/strategy/move/direction/LeftDownStrategyTest.java create mode 100644 src/test/java/chess/domain/strategy/move/direction/LeftStrategyTest.java create mode 100644 src/test/java/chess/domain/strategy/move/direction/LeftUpStrategyTest.java create mode 100644 src/test/java/chess/domain/strategy/move/direction/RightDownStrategyTest.java create mode 100644 src/test/java/chess/domain/strategy/move/direction/RightStrategyTest.java create mode 100644 src/test/java/chess/domain/strategy/move/direction/RightUpStrategyTest.java create mode 100644 src/test/java/chess/domain/strategy/move/direction/UpStrategyTest.java diff --git a/src/main/java/chess/domain/strategy/move/direction/DownStrategy.java b/src/main/java/chess/domain/strategy/move/direction/DownStrategy.java index 182db434310..9d0cae3a260 100644 --- a/src/main/java/chess/domain/strategy/move/direction/DownStrategy.java +++ b/src/main/java/chess/domain/strategy/move/direction/DownStrategy.java @@ -3,16 +3,18 @@ import chess.domain.position.Position; import java.util.ArrayList; +import java.util.Collections; import java.util.List; +import java.util.stream.Collectors; +import java.util.stream.IntStream; public final class DownStrategy implements DirectionStrategy { @Override public List findPath(final Position source, final Position target) { - List path = new ArrayList<>(); + List path = IntStream.range(target.getRank() + 1, source.getRank()) + .mapToObj(index -> Position.of(source.getFile(), index)) + .collect(Collectors.toList()); - for (int i = target.getRank() + 1; i < source.getRank(); i++) { - path.add(Position.of(source.getFile(), i)); - } - return path; + return Collections.unmodifiableList(path); } } \ No newline at end of file diff --git a/src/main/java/chess/domain/strategy/move/direction/LeftDownStrategy.java b/src/main/java/chess/domain/strategy/move/direction/LeftDownStrategy.java index 0c882279e8d..0b2927ebcfb 100644 --- a/src/main/java/chess/domain/strategy/move/direction/LeftDownStrategy.java +++ b/src/main/java/chess/domain/strategy/move/direction/LeftDownStrategy.java @@ -3,22 +3,19 @@ import chess.domain.position.Position; import java.util.ArrayList; +import java.util.Collections; import java.util.List; +import java.util.stream.Collectors; +import java.util.stream.IntStream; public final class LeftDownStrategy implements DirectionStrategy { @Override public List findPath(final Position source, final Position target) { - List path = new ArrayList<>(); + List path = IntStream.range(target.getFile() + 1, source.getFile()) + .mapToObj(index -> Position.of(index, target.getRank() - (target.getFile() - index))) + .collect(Collectors.toList()); - for (int i = target.getFile() + 1; i < source.getFile(); i++) { - path.add(Position.of(i, target.getRank() - (target.getFile() - i))); - } - -// List path2 = IntStream.range(target.getFile() + 1, source.getFile()) -// .mapToObj(index -> Position.of(index, target.getRank() - (target.getFile() - index))) -// .collect(Collectors.toList()); - - return path; + return Collections.unmodifiableList(path); } } diff --git a/src/main/java/chess/domain/strategy/move/direction/LeftStrategy.java b/src/main/java/chess/domain/strategy/move/direction/LeftStrategy.java index b5a6caa750b..e95cbff9e82 100644 --- a/src/main/java/chess/domain/strategy/move/direction/LeftStrategy.java +++ b/src/main/java/chess/domain/strategy/move/direction/LeftStrategy.java @@ -3,16 +3,18 @@ import chess.domain.position.Position; import java.util.ArrayList; +import java.util.Collections; import java.util.List; +import java.util.stream.Collectors; +import java.util.stream.IntStream; public final class LeftStrategy implements DirectionStrategy { @Override public List findPath(final Position source, final Position target) { - List path = new ArrayList<>(); + List path = IntStream.range(target.getFile() + 1, source.getFile()) + .mapToObj(index -> Position.of(index, source.getRank())) + .collect(Collectors.toList()); - for (int i = target.getFile() + 1; i < source.getFile(); i++) { - path.add(Position.of(i, source.getRank())); - } - return path; + return Collections.unmodifiableList(path); } } \ No newline at end of file diff --git a/src/main/java/chess/domain/strategy/move/direction/LeftUpStrategy.java b/src/main/java/chess/domain/strategy/move/direction/LeftUpStrategy.java index d3313f7e5a9..03400dc3e29 100644 --- a/src/main/java/chess/domain/strategy/move/direction/LeftUpStrategy.java +++ b/src/main/java/chess/domain/strategy/move/direction/LeftUpStrategy.java @@ -3,17 +3,18 @@ import chess.domain.position.Position; import java.util.ArrayList; +import java.util.Collections; import java.util.List; +import java.util.stream.Collectors; +import java.util.stream.IntStream; public final class LeftUpStrategy implements DirectionStrategy { @Override public List findPath(final Position source, final Position target) { - List path = new ArrayList<>(); - - for (int i = target.getFile() + 1; i < source.getFile(); i++) { - path.add(Position.of(i, target.getRank() + (target.getFile() - i))); - } - - return path; + List path = IntStream.range(target.getFile() + 1, source.getFile()) + .mapToObj(index -> Position.of(index, target.getRank() + (target.getFile() - index))) + .collect(Collectors.toList()); + + return Collections.unmodifiableList(path); } } \ No newline at end of file diff --git a/src/main/java/chess/domain/strategy/move/direction/RightDownStrategy.java b/src/main/java/chess/domain/strategy/move/direction/RightDownStrategy.java index 5551b9af7ff..9a304efcfaa 100644 --- a/src/main/java/chess/domain/strategy/move/direction/RightDownStrategy.java +++ b/src/main/java/chess/domain/strategy/move/direction/RightDownStrategy.java @@ -3,18 +3,19 @@ import chess.domain.position.Position; import java.util.ArrayList; +import java.util.Collections; import java.util.List; +import java.util.stream.Collectors; +import java.util.stream.IntStream; public final class RightDownStrategy implements DirectionStrategy { @Override public List findPath(final Position source, final Position target) { - List path = new ArrayList<>(); + List path = IntStream.rangeClosed(source.getFile() + 1, target.getFile() -1) + .mapToObj(index -> Position.of(index, target.getRank() + (target.getFile() - index))) + .collect(Collectors.toList()); - for (int i = target.getFile() - 1; i > source.getFile(); i--) { - path.add(Position.of(i, target.getRank() + (target.getFile() - i))); - } - - return path; + return Collections.unmodifiableList(path); } } diff --git a/src/main/java/chess/domain/strategy/move/direction/RightStrategy.java b/src/main/java/chess/domain/strategy/move/direction/RightStrategy.java index 4dc81307ff7..112de22e38f 100644 --- a/src/main/java/chess/domain/strategy/move/direction/RightStrategy.java +++ b/src/main/java/chess/domain/strategy/move/direction/RightStrategy.java @@ -3,16 +3,18 @@ import chess.domain.position.Position; import java.util.ArrayList; +import java.util.Collections; import java.util.List; +import java.util.stream.Collectors; +import java.util.stream.IntStream; public final class RightStrategy implements DirectionStrategy { @Override public List findPath(final Position source, final Position target) { - List path = new ArrayList<>(); + List path = IntStream.rangeClosed(source.getFile() + 1, target.getFile() - 1) + .mapToObj(index -> Position.of(index, source.getRank())) + .collect(Collectors.toList()); - for (int i = target.getFile() - 1; i > source.getFile(); i--) { - path.add(Position.of(i, source.getRank())); - } - return path; + return Collections.unmodifiableList(path); } } \ No newline at end of file diff --git a/src/main/java/chess/domain/strategy/move/direction/RightUpStrategy.java b/src/main/java/chess/domain/strategy/move/direction/RightUpStrategy.java index c518116fe6c..ffadef2983d 100644 --- a/src/main/java/chess/domain/strategy/move/direction/RightUpStrategy.java +++ b/src/main/java/chess/domain/strategy/move/direction/RightUpStrategy.java @@ -3,18 +3,19 @@ import chess.domain.position.Position; import java.util.ArrayList; +import java.util.Collections; import java.util.List; +import java.util.stream.Collectors; +import java.util.stream.IntStream; public final class RightUpStrategy implements DirectionStrategy { @Override public List findPath(final Position source, final Position target) { - List path = new ArrayList<>(); + List path = IntStream.rangeClosed(source.getFile() + 1, target.getFile() - 1) + .mapToObj(index -> Position.of(index, target.getRank() - (target.getFile() - index))) + .collect(Collectors.toList()); - for (int i = target.getFile() - 1; i > source.getFile(); i--) { - path.add(Position.of(i, target.getRank() - (target.getFile() - i))); - } - - return path; + return Collections.unmodifiableList(path); } } diff --git a/src/main/java/chess/domain/strategy/move/direction/UpStrategy.java b/src/main/java/chess/domain/strategy/move/direction/UpStrategy.java index a4afb7f27b5..8c7e704a4a8 100644 --- a/src/main/java/chess/domain/strategy/move/direction/UpStrategy.java +++ b/src/main/java/chess/domain/strategy/move/direction/UpStrategy.java @@ -3,16 +3,18 @@ import chess.domain.position.Position; import java.util.ArrayList; +import java.util.Collections; import java.util.List; +import java.util.stream.Collectors; +import java.util.stream.IntStream; public final class UpStrategy implements DirectionStrategy { @Override public List findPath(final Position source, final Position target) { - List path = new ArrayList<>(); + List path = IntStream.rangeClosed(source.getRank() + 1, target.getRank() - 1) + .mapToObj(index -> Position.of(source.getFile(), index)) + .collect(Collectors.toList()); - for (int i = target.getRank() - 1; i > source.getRank(); i--) { - path.add(Position.of(source.getFile(), i)); - } - return path; + return Collections.unmodifiableList(path); } } \ No newline at end of file diff --git a/src/test/java/chess/domain/strategy/move/direction/DownStrategyTest.java b/src/test/java/chess/domain/strategy/move/direction/DownStrategyTest.java new file mode 100644 index 00000000000..60eea0efeb5 --- /dev/null +++ b/src/test/java/chess/domain/strategy/move/direction/DownStrategyTest.java @@ -0,0 +1,26 @@ +package chess.domain.strategy.move.direction; + +import chess.domain.position.Position; +import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; + +import java.util.List; + +public class DownStrategyTest { + @DisplayName("하단 이동 시 경로 구하기") + @Test + void findPathTest() { + DirectionStrategy directionStrategy = new DownStrategy(); + Position source = Position.of("a7"); + Position target = Position.of("a2"); + List path = directionStrategy.findPath(source, target); + + Assertions.assertThat(path).containsExactly( + Position.of("a3"), + Position.of("a4"), + Position.of("a5"), + Position.of("a6") + ); + } +} diff --git a/src/test/java/chess/domain/strategy/move/direction/LeftDownStrategyTest.java b/src/test/java/chess/domain/strategy/move/direction/LeftDownStrategyTest.java new file mode 100644 index 00000000000..7b0ccb44a14 --- /dev/null +++ b/src/test/java/chess/domain/strategy/move/direction/LeftDownStrategyTest.java @@ -0,0 +1,26 @@ +package chess.domain.strategy.move.direction; + +import chess.domain.position.Position; +import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; + +import java.util.List; + +public class LeftDownStrategyTest { + @DisplayName("좌측 하단 이동 시 경로 구하기") + @Test + void findPathTest() { + DirectionStrategy directionStrategy = new LeftDownStrategy(); + Position source = Position.of("g7"); + Position target = Position.of("b2"); + List path = directionStrategy.findPath(source, target); + + Assertions.assertThat(path).containsExactly( + Position.of("c3"), + Position.of("d4"), + Position.of("e5"), + Position.of("f6") + ); + } +} diff --git a/src/test/java/chess/domain/strategy/move/direction/LeftStrategyTest.java b/src/test/java/chess/domain/strategy/move/direction/LeftStrategyTest.java new file mode 100644 index 00000000000..8b27066e7f4 --- /dev/null +++ b/src/test/java/chess/domain/strategy/move/direction/LeftStrategyTest.java @@ -0,0 +1,27 @@ +package chess.domain.strategy.move.direction; + +import chess.domain.position.Position; +import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; + +import java.util.List; + +public class LeftStrategyTest { + @DisplayName("좌측 이동 시 경로 구하기") + @Test + void findPathTest() { + DirectionStrategy directionStrategy = new LeftStrategy(); + Position source = Position.of("g2"); + Position target = Position.of("a2"); + List path = directionStrategy.findPath(source, target); + + Assertions.assertThat(path).containsExactly( + Position.of("b2"), + Position.of("c2"), + Position.of("d2"), + Position.of("e2"), + Position.of("f2") + ); + } +} diff --git a/src/test/java/chess/domain/strategy/move/direction/LeftUpStrategyTest.java b/src/test/java/chess/domain/strategy/move/direction/LeftUpStrategyTest.java new file mode 100644 index 00000000000..8d3582c09c1 --- /dev/null +++ b/src/test/java/chess/domain/strategy/move/direction/LeftUpStrategyTest.java @@ -0,0 +1,26 @@ +package chess.domain.strategy.move.direction; + +import chess.domain.position.Position; +import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; + +import java.util.List; + +public class LeftUpStrategyTest { + @DisplayName("좌측 상단 이동 시 경로 구하기") + @Test + void findPathTest() { + DirectionStrategy directionStrategy = new LeftUpStrategy(); + Position source = Position.of("g2"); + Position target = Position.of("b7"); + List path = directionStrategy.findPath(source, target); + + Assertions.assertThat(path).containsExactly( + Position.of("c6"), + Position.of("d5"), + Position.of("e4"), + Position.of("f3") + ); + } +} diff --git a/src/test/java/chess/domain/strategy/move/direction/RightDownStrategyTest.java b/src/test/java/chess/domain/strategy/move/direction/RightDownStrategyTest.java new file mode 100644 index 00000000000..196e8560276 --- /dev/null +++ b/src/test/java/chess/domain/strategy/move/direction/RightDownStrategyTest.java @@ -0,0 +1,26 @@ +package chess.domain.strategy.move.direction; + +import chess.domain.position.Position; +import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; + +import java.util.List; + +public class RightDownStrategyTest { + @DisplayName("우측 하단 이동 시 경로 구하기") + @Test + void findPathTest() { + DirectionStrategy directionStrategy = new RightDownStrategy(); + Position source = Position.of("b7"); + Position target = Position.of("g2"); + List path = directionStrategy.findPath(source, target); + + Assertions.assertThat(path).containsExactly( + Position.of("c6"), + Position.of("d5"), + Position.of("e4"), + Position.of("f3") + ); + } +} diff --git a/src/test/java/chess/domain/strategy/move/direction/RightStrategyTest.java b/src/test/java/chess/domain/strategy/move/direction/RightStrategyTest.java new file mode 100644 index 00000000000..0487ca15540 --- /dev/null +++ b/src/test/java/chess/domain/strategy/move/direction/RightStrategyTest.java @@ -0,0 +1,26 @@ +package chess.domain.strategy.move.direction; + +import chess.domain.position.Position; +import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; + +import java.util.List; + +public class RightStrategyTest { + @DisplayName("우측 이동 시 경로 구하기") + @Test + void findPathTest() { + DirectionStrategy directionStrategy = new RightStrategy(); + Position source = Position.of("b2"); + Position target = Position.of("g2"); + List path = directionStrategy.findPath(source, target); + + Assertions.assertThat(path).containsExactly( + Position.of("c2"), + Position.of("d2"), + Position.of("e2"), + Position.of("f2") + ); + } +} diff --git a/src/test/java/chess/domain/strategy/move/direction/RightUpStrategyTest.java b/src/test/java/chess/domain/strategy/move/direction/RightUpStrategyTest.java new file mode 100644 index 00000000000..c4903e7303a --- /dev/null +++ b/src/test/java/chess/domain/strategy/move/direction/RightUpStrategyTest.java @@ -0,0 +1,26 @@ +package chess.domain.strategy.move.direction; + +import chess.domain.position.Position; +import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; + +import java.util.List; + +public class RightUpStrategyTest { + @DisplayName("우측 상단 이동 시 경로 구하기") + @Test + void findPathTest() { + DirectionStrategy directionStrategy = new RightUpStrategy(); + Position source = Position.of("b2"); + Position target = Position.of("g7"); + List path = directionStrategy.findPath(source, target); + + Assertions.assertThat(path).containsExactly( + Position.of("c3"), + Position.of("d4"), + Position.of("e5"), + Position.of("f6") + ); + } +} diff --git a/src/test/java/chess/domain/strategy/move/direction/UpStrategyTest.java b/src/test/java/chess/domain/strategy/move/direction/UpStrategyTest.java new file mode 100644 index 00000000000..8acb305c8c1 --- /dev/null +++ b/src/test/java/chess/domain/strategy/move/direction/UpStrategyTest.java @@ -0,0 +1,26 @@ +package chess.domain.strategy.move.direction; + +import chess.domain.position.Position; +import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; + +import java.util.List; + +public class UpStrategyTest { + @DisplayName("상단 이동 시 경로 구하기") + @Test + void findPathTest() { + DirectionStrategy directionStrategy = new UpStrategy(); + Position source = Position.of("b2"); + Position target = Position.of("b7"); + List path = directionStrategy.findPath(source, target); + + Assertions.assertThat(path).containsExactly( + Position.of("b3"), + Position.of("b4"), + Position.of("b5"), + Position.of("b6") + ); + } +} From 31e70aec16a68c720b9d484135914d18afea8329 Mon Sep 17 00:00:00 2001 From: giantim Date: Tue, 31 Mar 2020 00:46:02 +0900 Subject: [PATCH 23/75] =?UTF-8?q?refactor:=20=EC=BB=A8=ED=8A=B8=EB=A1=A4?= =?UTF-8?q?=EB=9F=AC=20=EC=B6=94=EC=83=81=ED=99=94?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../chess/controller/ChessController.java | 11 ++++++++ src/main/java/chess/controller/Command.java | 22 +++++++++++----- .../java/chess/controller/EndController.java | 14 +++++++++++ .../java/chess/controller/GameController.java | 25 +++++++++++++++++++ .../java/chess/controller/MoveController.java | 22 ++++++++++++++++ .../chess/controller/StartController.java | 14 +++++++++++ .../chess/controller/StatusController.java | 16 ++++++++++++ 7 files changed, 118 insertions(+), 6 deletions(-) create mode 100644 src/main/java/chess/controller/EndController.java create mode 100644 src/main/java/chess/controller/GameController.java create mode 100644 src/main/java/chess/controller/MoveController.java create mode 100644 src/main/java/chess/controller/StartController.java create mode 100644 src/main/java/chess/controller/StatusController.java diff --git a/src/main/java/chess/controller/ChessController.java b/src/main/java/chess/controller/ChessController.java index 81c2c1da8e5..484f4244bfe 100644 --- a/src/main/java/chess/controller/ChessController.java +++ b/src/main/java/chess/controller/ChessController.java @@ -29,6 +29,17 @@ public static void start() { } } + public static void run2(ChessRunner chessRunner) { + Command command; + + do { + String commands = inputView.askGameCommand(); + command = Command.of(commands); + GameController gameController = command.getGameController(); + gameController.execute(chessRunner, commands); + } while (!command.isEnd() && findWinner(chessRunner)); + } + private static void run(Command command) { if (command.isStart()) { ChessRunner chessRunner = new ChessRunner(); diff --git a/src/main/java/chess/controller/Command.java b/src/main/java/chess/controller/Command.java index b8585d45382..c140263d451 100644 --- a/src/main/java/chess/controller/Command.java +++ b/src/main/java/chess/controller/Command.java @@ -3,15 +3,17 @@ import java.util.Arrays; public enum Command { - START("start"), - MOVE("move"), - STATUS("status"), - END("end"); + START("start", new StartController()), + MOVE("move", new MoveController()), + STATUS("status", new StatusController()), + END("end", new EndController()); - private String command; + private final String command; + private final GameController gameController; - Command(String command) { + Command(String command, GameController gameController) { this.command = command; + this.gameController = gameController; } public static Command of(final String command) { @@ -24,4 +26,12 @@ public static Command of(final String command) { public boolean isStart() { return this == START; } + + public GameController getGameController() { + return this.gameController; + } + + public boolean isEnd() { + return this == END; + } } diff --git a/src/main/java/chess/controller/EndController.java b/src/main/java/chess/controller/EndController.java new file mode 100644 index 00000000000..5447a5811c3 --- /dev/null +++ b/src/main/java/chess/controller/EndController.java @@ -0,0 +1,14 @@ +package chess.controller; + +import chess.domain.ChessRunner; + +public class EndController extends GameController { + public EndController() { + super(); + } + + @Override + public void execute(ChessRunner chessRunner, String input) { + return; + } +} diff --git a/src/main/java/chess/controller/GameController.java b/src/main/java/chess/controller/GameController.java new file mode 100644 index 00000000000..1bab9902963 --- /dev/null +++ b/src/main/java/chess/controller/GameController.java @@ -0,0 +1,25 @@ +package chess.controller; + +import chess.controller.dto.BoardDto; +import chess.controller.dto.PositionDto; +import chess.domain.ChessRunner; +import chess.domain.board.Board; +import chess.domain.position.Position; +import chess.view.ConsoleOutputView; +import chess.view.OutputView; + +public abstract class GameController { + protected final OutputView outputView; + + public GameController() { + this.outputView = new ConsoleOutputView(); + } + + protected void printBoard(final Board board) { + BoardDto boardDto = new BoardDto(board.parse()); + PositionDto positionDto = new PositionDto(Position.getPositions()); + this.outputView.printBoard(positionDto.getPositions(), boardDto.get()); + } + + public abstract void execute(ChessRunner chessRunner, String input); +} diff --git a/src/main/java/chess/controller/MoveController.java b/src/main/java/chess/controller/MoveController.java new file mode 100644 index 00000000000..6613c3b2e70 --- /dev/null +++ b/src/main/java/chess/controller/MoveController.java @@ -0,0 +1,22 @@ +package chess.controller; + +import chess.domain.ChessRunner; + +public class MoveController extends GameController { + private static final String DELIMITER = " "; + private static final int SOURCE_INDEX = 1; + private static final int TARGET_INDEX = 2; + + public MoveController() { + super(); + } + + @Override + public void execute(ChessRunner chessRunner, String input) { + String[] commands = input.split(DELIMITER); + String source = commands[SOURCE_INDEX]; + String target = commands[TARGET_INDEX]; + chessRunner.update(source, target); + printBoard(chessRunner.getBoard()); + } +} diff --git a/src/main/java/chess/controller/StartController.java b/src/main/java/chess/controller/StartController.java new file mode 100644 index 00000000000..78edcede867 --- /dev/null +++ b/src/main/java/chess/controller/StartController.java @@ -0,0 +1,14 @@ +package chess.controller; + +import chess.domain.ChessRunner; + +public class StartController extends GameController { + public StartController() { + super(); + } + + @Override + public void execute(ChessRunner chessRunner, String input) { + chessRunner = new ChessRunner(); + } +} diff --git a/src/main/java/chess/controller/StatusController.java b/src/main/java/chess/controller/StatusController.java new file mode 100644 index 00000000000..76c3613c5cb --- /dev/null +++ b/src/main/java/chess/controller/StatusController.java @@ -0,0 +1,16 @@ +package chess.controller; + +import chess.domain.ChessRunner; + +public class StatusController extends GameController { + public StatusController() { + super(); + } + + @Override + public void execute(ChessRunner chessRunner, String input) { + double score = chessRunner.calculateScore(); + outputView.printStatus(score, chessRunner.getCurrentTeam()); + printBoard(chessRunner.getBoard()); + } +} From a1f14315d2d643ae97b497a6ca3fe8faf1d4f003 Mon Sep 17 00:00:00 2001 From: giantim Date: Tue, 31 Mar 2020 16:18:59 +0900 Subject: [PATCH 24/75] =?UTF-8?q?refactor:=20=EC=BB=A8=ED=8A=B8=EB=A1=A4?= =?UTF-8?q?=EB=9F=AC=20=EC=B6=94=EC=83=81=ED=99=94(2)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../chess/controller/ChessController.java | 86 +++---------------- .../chess/controller/StartController.java | 2 +- .../java/chess/view/ConsoleInputView.java | 2 +- 3 files changed, 15 insertions(+), 75 deletions(-) diff --git a/src/main/java/chess/controller/ChessController.java b/src/main/java/chess/controller/ChessController.java index 484f4244bfe..984701bc7a4 100644 --- a/src/main/java/chess/controller/ChessController.java +++ b/src/main/java/chess/controller/ChessController.java @@ -1,87 +1,40 @@ package chess.controller; -import chess.controller.dto.BoardDto; -import chess.controller.dto.PositionDto; import chess.domain.ChessRunner; -import chess.domain.board.Board; import chess.domain.piece.Team; -import chess.domain.position.Position; import chess.view.ConsoleInputView; import chess.view.ConsoleOutputView; import chess.view.InputView; import chess.view.OutputView; +import org.apache.commons.lang3.StringUtils; public class ChessController { - private static final String DELIMITER = " "; - private static final int SOURCE_INDEX = 1; - private static final int TARGET_INDEX = 2; - private static InputView inputView = new ConsoleInputView(); private static OutputView outputView = new ConsoleOutputView(); public static void start() { try { - Command command = Command.of(inputView.askChessRun()); - run(command); + runChessGame(); } catch (IllegalArgumentException e) { System.out.println(e.getMessage()); start(); } } - public static void run2(ChessRunner chessRunner) { - Command command; - - do { - String commands = inputView.askGameCommand(); - command = Command.of(commands); - GameController gameController = command.getGameController(); - gameController.execute(chessRunner, commands); - } while (!command.isEnd() && findWinner(chessRunner)); - } + public static void runChessGame() { + Command command = Command.of(inputView.askChessRun()); - private static void run(Command command) { if (command.isStart()) { ChessRunner chessRunner = new ChessRunner(); - printBoard(chessRunner.getBoard()); - runChess(chessRunner); - } - } - - public static void runChess(ChessRunner chessRunner) { - try { - String input = inputView.askGameCommand(); - Command command = Command.of(input); - - runByCommand(chessRunner, input, command); - } catch (IllegalArgumentException e) { - System.out.println(e.getMessage()); - runChess(chessRunner); - } - } - - private static void runByCommand(ChessRunner chessRunner, String input, Command command) { - switch (command) { - case MOVE: - runMove(chessRunner, input); - break; - case STATUS: - runStatus(chessRunner); - break; - case END: - default: - break; - } - } - - private static void runMove(ChessRunner chessRunner, String input) { - String[] commands = input.split(DELIMITER); - String source = commands[SOURCE_INDEX]; - String target = commands[TARGET_INDEX]; - chessRunner.update(source, target); - printBoard(chessRunner.getBoard()); - if (findWinner(chessRunner)) { - runChess(chessRunner); + GameController startController = command.getGameController(); + startController.execute(chessRunner, StringUtils.EMPTY); + + do { + String commands = inputView.askGameCommand(); + command = Command.of(commands); + GameController gameController = command.getGameController(); + gameController.execute(chessRunner, commands); + } while (!command.isEnd() && findWinner(chessRunner)); } } @@ -93,17 +46,4 @@ private static boolean findWinner(final ChessRunner chessRunner) { } return true; } - - private static void runStatus(ChessRunner chessRunner) { - double score = chessRunner.calculateScore(); - outputView.printStatus(score, chessRunner.getCurrentTeam()); - printBoard(chessRunner.getBoard()); - runChess(chessRunner); - } - - private static void printBoard(final Board board) { - BoardDto boardDto = new BoardDto(board.parse()); - PositionDto positionDto = new PositionDto(Position.getPositions()); - outputView.printBoard(positionDto.getPositions(), boardDto.get()); - } } diff --git a/src/main/java/chess/controller/StartController.java b/src/main/java/chess/controller/StartController.java index 78edcede867..7ce8debfbac 100644 --- a/src/main/java/chess/controller/StartController.java +++ b/src/main/java/chess/controller/StartController.java @@ -9,6 +9,6 @@ public StartController() { @Override public void execute(ChessRunner chessRunner, String input) { - chessRunner = new ChessRunner(); + printBoard(chessRunner.getBoard()); } } diff --git a/src/main/java/chess/view/ConsoleInputView.java b/src/main/java/chess/view/ConsoleInputView.java index caf9c36fe07..0649abe99fb 100644 --- a/src/main/java/chess/view/ConsoleInputView.java +++ b/src/main/java/chess/view/ConsoleInputView.java @@ -11,7 +11,7 @@ public String askChessRun() { System.out.println("> 게임 시작 : start"); System.out.println("> 게임 종료 : end"); System.out.println("> 게임 이동 : move source위치 target위치 - 예. move b2 b3"); - return askGameCommand(); + return SCANNER.nextLine(); } @Override From 7bd04ff7338587c6ff1587566afad39046df58de Mon Sep 17 00:00:00 2001 From: giantim Date: Tue, 31 Mar 2020 22:28:10 +0900 Subject: [PATCH 25/75] =?UTF-8?q?refactor:=201=EC=B0=A8=20=EC=88=98?= =?UTF-8?q?=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../chess/controller/ChessController.java | 89 +++----------- .../java/chess/controller/MoveController.java | 5 + .../chess/controller/StartController.java | 2 +- .../chess/controller/StatusController.java | 4 +- src/main/java/chess/domain/ChessRunner.java | 64 ++++++++-- src/main/java/chess/domain/board/Board.java | 72 +++++------ .../java/chess/domain/board/BoardScore.java | 26 ++++ src/main/java/chess/domain/piece/Bishop.java | 17 +++ src/main/java/chess/domain/piece/King.java | 21 ++++ src/main/java/chess/domain/piece/Knight.java | 23 ++++ .../java/chess/domain/piece/MoveStrategy.java | 7 ++ src/main/java/chess/domain/piece/Pawn.java | 51 ++++++++ src/main/java/chess/domain/piece/Piece.java | 21 ++-- .../java/chess/domain/piece/PieceType.java | 24 ++-- src/main/java/chess/domain/piece/Queen.java | 15 +++ src/main/java/chess/domain/piece/Rook.java | 22 ++++ src/main/java/chess/domain/piece/Team.java | 4 +- .../{move => }/direction/Direction.java | 2 +- .../direction/DirectionStrategy.java | 2 +- .../{move => }/direction/DownStrategy.java | 3 +- .../direction/LeftDownStrategy.java | 3 +- .../{move => }/direction/LeftStrategy.java | 3 +- .../{move => }/direction/LeftUpStrategy.java | 5 +- .../direction/RightDownStrategy.java | 5 +- .../{move => }/direction/RightStrategy.java | 3 +- .../{move => }/direction/RightUpStrategy.java | 3 +- .../{move => }/direction/UpStrategy.java | 3 +- .../initialize/BishopInitializer.java | 9 +- .../strategy/initialize/KingInitializer.java | 5 +- .../initialize/KnightInitializer.java | 9 +- .../strategy/initialize/PawnInitializer.java | 33 ++--- .../strategy/initialize/QueenInitializer.java | 5 +- .../strategy/initialize/RookInitializer.java | 9 +- .../strategy/move/BishopMoveStrategy.java | 20 ---- .../strategy/move/KingMoveStrategy.java | 19 --- .../strategy/move/KnightMoveStrategy.java | 19 --- .../domain/strategy/move/MoveStrategy.java | 33 ----- .../strategy/move/PawnMoveStrategy.java | 49 -------- .../strategy/move/QueenMoveStrategy.java | 12 -- .../strategy/move/RookMoveStrategy.java | 20 ---- .../java/chess/view/ConsoleInputView.java | 2 +- src/main/java/chess/view/InputView.java | 1 + src/main/java/chess/view/OutputView.java | 2 + .../java/chess/domain/ChessRunnerTest.java | 30 ++++- .../java/chess/domain/board/BoardTest.java | 41 ++++--- .../java/chess/domain/piece/PieceTest.java | 20 ++-- .../java/chess/domain/piece/TeamTest.java | 15 ++- .../{move => }/direction/DirectionTest.java | 2 +- .../direction/DownStrategyTest.java | 2 +- .../direction/LeftDownStrategyTest.java | 2 +- .../direction/LeftStrategyTest.java | 2 +- .../direction/LeftUpStrategyTest.java | 2 +- .../direction/RightDownStrategyTest.java | 2 +- .../direction/RightStrategyTest.java | 2 +- .../direction/RightUpStrategyTest.java | 2 +- .../{move => }/direction/UpStrategyTest.java | 2 +- .../strategy/move/BishopMoveStrategyTest.java | 77 ------------ .../strategy/move/KingMoveStrategyTest.java | 64 ---------- .../strategy/move/KnightMoveStrategyTest.java | 64 ---------- .../strategy/move/PawnMoveStrategyTest.java | 107 ----------------- .../strategy/move/QueenMoveStrategyTest.java | 113 ------------------ .../strategy/move/RookMoveStrategyTest.java | 77 ------------ 62 files changed, 443 insertions(+), 929 deletions(-) create mode 100644 src/main/java/chess/domain/board/BoardScore.java create mode 100644 src/main/java/chess/domain/piece/Bishop.java create mode 100644 src/main/java/chess/domain/piece/King.java create mode 100644 src/main/java/chess/domain/piece/Knight.java create mode 100644 src/main/java/chess/domain/piece/MoveStrategy.java create mode 100644 src/main/java/chess/domain/piece/Pawn.java create mode 100644 src/main/java/chess/domain/piece/Queen.java create mode 100644 src/main/java/chess/domain/piece/Rook.java rename src/main/java/chess/domain/strategy/{move => }/direction/Direction.java (97%) rename src/main/java/chess/domain/strategy/{move => }/direction/DirectionStrategy.java (78%) rename src/main/java/chess/domain/strategy/{move => }/direction/DownStrategy.java (88%) rename src/main/java/chess/domain/strategy/{move => }/direction/LeftDownStrategy.java (89%) rename src/main/java/chess/domain/strategy/{move => }/direction/LeftStrategy.java (88%) rename src/main/java/chess/domain/strategy/{move => }/direction/LeftUpStrategy.java (88%) rename src/main/java/chess/domain/strategy/{move => }/direction/RightDownStrategy.java (85%) rename src/main/java/chess/domain/strategy/{move => }/direction/RightStrategy.java (89%) rename src/main/java/chess/domain/strategy/{move => }/direction/RightUpStrategy.java (89%) rename src/main/java/chess/domain/strategy/{move => }/direction/UpStrategy.java (89%) delete mode 100644 src/main/java/chess/domain/strategy/move/BishopMoveStrategy.java delete mode 100644 src/main/java/chess/domain/strategy/move/KingMoveStrategy.java delete mode 100644 src/main/java/chess/domain/strategy/move/KnightMoveStrategy.java delete mode 100644 src/main/java/chess/domain/strategy/move/MoveStrategy.java delete mode 100644 src/main/java/chess/domain/strategy/move/PawnMoveStrategy.java delete mode 100644 src/main/java/chess/domain/strategy/move/QueenMoveStrategy.java delete mode 100644 src/main/java/chess/domain/strategy/move/RookMoveStrategy.java rename src/test/java/chess/domain/strategy/{move => }/direction/DirectionTest.java (98%) rename src/test/java/chess/domain/strategy/{move => }/direction/DownStrategyTest.java (94%) rename src/test/java/chess/domain/strategy/{move => }/direction/LeftDownStrategyTest.java (94%) rename src/test/java/chess/domain/strategy/{move => }/direction/LeftStrategyTest.java (94%) rename src/test/java/chess/domain/strategy/{move => }/direction/LeftUpStrategyTest.java (94%) rename src/test/java/chess/domain/strategy/{move => }/direction/RightDownStrategyTest.java (94%) rename src/test/java/chess/domain/strategy/{move => }/direction/RightStrategyTest.java (94%) rename src/test/java/chess/domain/strategy/{move => }/direction/RightUpStrategyTest.java (94%) rename src/test/java/chess/domain/strategy/{move => }/direction/UpStrategyTest.java (94%) delete mode 100644 src/test/java/chess/domain/strategy/move/BishopMoveStrategyTest.java delete mode 100644 src/test/java/chess/domain/strategy/move/KingMoveStrategyTest.java delete mode 100644 src/test/java/chess/domain/strategy/move/KnightMoveStrategyTest.java delete mode 100644 src/test/java/chess/domain/strategy/move/PawnMoveStrategyTest.java delete mode 100644 src/test/java/chess/domain/strategy/move/QueenMoveStrategyTest.java delete mode 100644 src/test/java/chess/domain/strategy/move/RookMoveStrategyTest.java diff --git a/src/main/java/chess/controller/ChessController.java b/src/main/java/chess/controller/ChessController.java index 484f4244bfe..0c45cd5ad61 100644 --- a/src/main/java/chess/controller/ChessController.java +++ b/src/main/java/chess/controller/ChessController.java @@ -1,88 +1,44 @@ package chess.controller; -import chess.controller.dto.BoardDto; -import chess.controller.dto.PositionDto; import chess.domain.ChessRunner; -import chess.domain.board.Board; import chess.domain.piece.Team; -import chess.domain.position.Position; import chess.view.ConsoleInputView; import chess.view.ConsoleOutputView; import chess.view.InputView; import chess.view.OutputView; +import org.apache.commons.lang3.StringUtils; public class ChessController { - private static final String DELIMITER = " "; - private static final int SOURCE_INDEX = 1; - private static final int TARGET_INDEX = 2; - private static InputView inputView = new ConsoleInputView(); private static OutputView outputView = new ConsoleOutputView(); public static void start() { - try { - Command command = Command.of(inputView.askChessRun()); - run(command); - } catch (IllegalArgumentException e) { - System.out.println(e.getMessage()); - start(); + Command command = Command.of(inputView.askChessRun()); + if (command.isStart()) { + ChessRunner chessRunner = new ChessRunner(); + GameController gameController = command.getGameController(); + gameController.execute(chessRunner, StringUtils.EMPTY); + + runChessGame(command, chessRunner); } } - public static void run2(ChessRunner chessRunner) { - Command command; - + private static void runChessGame(Command command, ChessRunner chessRunner) { do { - String commands = inputView.askGameCommand(); - command = Command.of(commands); - GameController gameController = command.getGameController(); - gameController.execute(chessRunner, commands); + command = validateExecute(command, chessRunner); } while (!command.isEnd() && findWinner(chessRunner)); } - private static void run(Command command) { - if (command.isStart()) { - ChessRunner chessRunner = new ChessRunner(); - printBoard(chessRunner.getBoard()); - runChess(chessRunner); - } - } - - public static void runChess(ChessRunner chessRunner) { + private static Command validateExecute(Command command, ChessRunner chessRunner) { try { - String input = inputView.askGameCommand(); - Command command = Command.of(input); - - runByCommand(chessRunner, input, command); + String commands = inputView.askGameCommand(); + command = Command.of(commands); + GameController gameController = command.getGameController(); + gameController.execute(chessRunner, commands); } catch (IllegalArgumentException e) { System.out.println(e.getMessage()); - runChess(chessRunner); - } - } - - private static void runByCommand(ChessRunner chessRunner, String input, Command command) { - switch (command) { - case MOVE: - runMove(chessRunner, input); - break; - case STATUS: - runStatus(chessRunner); - break; - case END: - default: - break; - } - } - - private static void runMove(ChessRunner chessRunner, String input) { - String[] commands = input.split(DELIMITER); - String source = commands[SOURCE_INDEX]; - String target = commands[TARGET_INDEX]; - chessRunner.update(source, target); - printBoard(chessRunner.getBoard()); - if (findWinner(chessRunner)) { - runChess(chessRunner); } + return command; } private static boolean findWinner(final ChessRunner chessRunner) { @@ -93,17 +49,4 @@ private static boolean findWinner(final ChessRunner chessRunner) { } return true; } - - private static void runStatus(ChessRunner chessRunner) { - double score = chessRunner.calculateScore(); - outputView.printStatus(score, chessRunner.getCurrentTeam()); - printBoard(chessRunner.getBoard()); - runChess(chessRunner); - } - - private static void printBoard(final Board board) { - BoardDto boardDto = new BoardDto(board.parse()); - PositionDto positionDto = new PositionDto(Position.getPositions()); - outputView.printBoard(positionDto.getPositions(), boardDto.get()); - } } diff --git a/src/main/java/chess/controller/MoveController.java b/src/main/java/chess/controller/MoveController.java index 6613c3b2e70..5c13028fd18 100644 --- a/src/main/java/chess/controller/MoveController.java +++ b/src/main/java/chess/controller/MoveController.java @@ -4,6 +4,7 @@ public class MoveController extends GameController { private static final String DELIMITER = " "; + private static final int COMMANDS_SIZE = 2; private static final int SOURCE_INDEX = 1; private static final int TARGET_INDEX = 2; @@ -14,6 +15,10 @@ public MoveController() { @Override public void execute(ChessRunner chessRunner, String input) { String[] commands = input.split(DELIMITER); + if (commands.length < COMMANDS_SIZE) { + throw new IllegalArgumentException("잘못된 이동 명령어를 입력하였습니다."); + } + String source = commands[SOURCE_INDEX]; String target = commands[TARGET_INDEX]; chessRunner.update(source, target); diff --git a/src/main/java/chess/controller/StartController.java b/src/main/java/chess/controller/StartController.java index 78edcede867..7ce8debfbac 100644 --- a/src/main/java/chess/controller/StartController.java +++ b/src/main/java/chess/controller/StartController.java @@ -9,6 +9,6 @@ public StartController() { @Override public void execute(ChessRunner chessRunner, String input) { - chessRunner = new ChessRunner(); + printBoard(chessRunner.getBoard()); } } diff --git a/src/main/java/chess/controller/StatusController.java b/src/main/java/chess/controller/StatusController.java index 76c3613c5cb..c3443a15bc5 100644 --- a/src/main/java/chess/controller/StatusController.java +++ b/src/main/java/chess/controller/StatusController.java @@ -9,8 +9,8 @@ public StatusController() { @Override public void execute(ChessRunner chessRunner, String input) { - double score = chessRunner.calculateScore(); - outputView.printStatus(score, chessRunner.getCurrentTeam()); +// double score = chessRunner.calculateScore(); +// outputView.printStatus(score, chessRunner.getCurrentTeam()); printBoard(chessRunner.getBoard()); } } diff --git a/src/main/java/chess/domain/ChessRunner.java b/src/main/java/chess/domain/ChessRunner.java index 3a8845d409d..feebf2fdc9c 100644 --- a/src/main/java/chess/domain/ChessRunner.java +++ b/src/main/java/chess/domain/ChessRunner.java @@ -1,9 +1,13 @@ package chess.domain; import chess.domain.board.Board; +import chess.domain.board.BoardScore; import chess.domain.piece.Piece; import chess.domain.piece.Team; import chess.domain.position.Position; +import chess.domain.strategy.direction.Direction; + +import java.util.List; public class ChessRunner { private Board board; @@ -17,17 +21,57 @@ public ChessRunner() { public void update(String source, String target) { Position sourcePosition = Position.of(source); Position targetPosition = Position.of(target); - Piece selectedPiece = this.board.getPiece(sourcePosition); + Piece sourcePiece = this.board.getPiece(sourcePosition); + + checkCorrectTurn(sourcePiece); + checkUpdateBoard(sourcePosition, targetPosition, sourcePiece); + + updateBoard(sourcePosition, targetPosition); + changeTeam(); + } - if (!(currentTeam.isSameTeamWith(selectedPiece.getTeam()))) { + private void checkCorrectTurn(Piece sourcePiece) { + if (sourcePiece.isEnemy(this.currentTeam)) { throw new IllegalArgumentException("현재 차례가 아닙니다."); } + } - if (!(selectedPiece.movable(sourcePosition, targetPosition, board))) { - throw new IllegalArgumentException("이동할 수 없는 곳입니다."); + private void checkUpdateBoard(Position sourcePosition, Position targetPosition, Piece sourcePiece) { + if (isSamePosition(sourcePosition, targetPosition)) { + throw new IllegalArgumentException("같은 위치로 이동할 수 없습니다."); } - updateBoard(sourcePosition, targetPosition); - changeTeam(); + + if (!(sourcePiece.movable(sourcePosition, targetPosition))) { + throw new IllegalArgumentException("선택한 기물이 이동할 수 없는 곳입니다."); + } + + if (!isEmptyPath(sourcePosition, targetPosition)) { + throw new IllegalArgumentException("경로 사이에 장애물이 있습니다."); + } + + if (!movableTarget(sourcePiece, targetPosition)) { + throw new IllegalArgumentException("목적지가 잘못되었습니다."); + } + } + + private boolean isSamePosition(final Position sourcePosition, final Position targetPosition) { + return sourcePosition.equals(targetPosition); + } + + private boolean isEmptyPath(final Position sourcePosition, final Position targetPosition) { + Direction direction = Direction.findDirection(sourcePosition, targetPosition); + List path = direction.findPath(sourcePosition, targetPosition); + + if (path.isEmpty()) { + return true; + } + return path.stream() + .allMatch(this.board::isEmpty); + } + + private boolean movableTarget(final Piece sourcePiece, final Position targetPosition) { + Piece targetPiece = this.board.getPiece(targetPosition); + return sourcePiece.isEnemy(targetPiece); } private void updateBoard(Position sourcePosition, Position targetPosition) { @@ -35,19 +79,19 @@ private void updateBoard(Position sourcePosition, Position targetPosition) { } private void changeTeam() { - this.currentTeam = Team.changeTeam(this.currentTeam); + this.currentTeam = this.currentTeam.changeTeam(); } public Team findWinner() { return this.board.checkWinner(); } - public double calculateScore() { - return board.calculateScore(currentTeam); + public BoardScore calculateScore() { + return board.calculateScore(this.currentTeam); } public Team getCurrentTeam() { - return currentTeam; + return this.currentTeam; } public Board getBoard() { diff --git a/src/main/java/chess/domain/board/Board.java b/src/main/java/chess/domain/board/Board.java index d42f958b544..53188c00728 100644 --- a/src/main/java/chess/domain/board/Board.java +++ b/src/main/java/chess/domain/board/Board.java @@ -12,9 +12,6 @@ import java.util.stream.Collectors; public class Board { - private static final int PAWN_ON_SAME_FILE = 1; - private static final double PAWN_SCORE_STRATEGY = 0.5; - private final Map board; public Board() { @@ -25,22 +22,37 @@ public Board(final Map board) { this.board = board; } - public Map parse() { - Map parseResult = board.entrySet() - .stream() - .collect(Collectors.toMap(entry -> entry.getKey().toString(), - entry -> entry.getValue().toSymbol(), - (e1, e2) -> e1, LinkedHashMap::new)); - - return Collections.unmodifiableMap(parseResult); - } - public void updateBoard(final Position sourcePosition, final Position targetPosition) { Piece selectedPiece = this.board.get(sourcePosition); this.board.put(targetPosition, selectedPiece); this.board.remove(sourcePosition); } + public BoardScore calculateScore(final Team team) { + BoardScore totalScore = calculateTotalScore(team); + return calculatePawnScore(team, totalScore); + } + + private BoardScore calculateTotalScore(final Team team) { + double totalScore = board.values().stream() + .filter(piece -> team.isSameTeamWith(piece.getTeam())) + .mapToDouble(Piece::getScore) + .sum(); + return new BoardScore(totalScore); + } + + private BoardScore calculatePawnScore(final Team team, BoardScore totalScore) { + for (File file : File.values()) { + List> sameFilePawns = this.board.entrySet().stream() + .filter(entry -> File.of(entry.getKey().getFile()).equals(file)) + .filter(entry -> entry.getValue().isPawn() && !entry.getValue().isEnemy(team)) + .collect(Collectors.toList()); + + totalScore = totalScore.pawnStrategy(sameFilePawns); + } + return totalScore; + } + public Team checkWinner() { if (checkWhiteKing() && !checkBlackKing()) { return Team.WHITE; @@ -66,32 +78,20 @@ public boolean isEmpty(final Position position) { } public Piece getPiece(final Position position) { - return this.board.get(position); - } - - public double calculateScore(final Team team) { - double totalScore = calculateTotalScore(team); - return calculatePawnScore(team, totalScore); - } + if (!this.board.containsKey(position)) { + throw new IllegalArgumentException("비어있는 위치를 선택하였습니다."); + } - private double calculateTotalScore(final Team team) { - return board.values().stream() - .filter(piece -> team.isSameTeamWith(piece.getTeam())) - .mapToDouble(Piece::getScore) - .sum(); + return this.board.get(position); } - private double calculatePawnScore(final Team team, double score) { - for (File file : File.values()) { - List> sameFile = this.board.entrySet().stream() - .filter(entry -> File.of(entry.getKey().getFile()).equals(file)) - .filter(entry -> entry.getValue().isPawn() && !entry.getValue().isEnemy(team)) - .collect(Collectors.toList()); + public Map parse() { + Map parseResult = board.entrySet() + .stream() + .collect(Collectors.toMap(entry -> entry.getKey().toString(), + entry -> entry.getValue().toSymbol(), + (e1, e2) -> e1, LinkedHashMap::new)); - if (sameFile.size() > PAWN_ON_SAME_FILE) { - score -= sameFile.size() * PAWN_SCORE_STRATEGY; - } - } - return score; + return Collections.unmodifiableMap(parseResult); } } \ No newline at end of file diff --git a/src/main/java/chess/domain/board/BoardScore.java b/src/main/java/chess/domain/board/BoardScore.java new file mode 100644 index 00000000000..9525bd8ec69 --- /dev/null +++ b/src/main/java/chess/domain/board/BoardScore.java @@ -0,0 +1,26 @@ +package chess.domain.board; + +import chess.domain.piece.Piece; +import chess.domain.position.Position; + +import java.util.List; +import java.util.Map; + +public class BoardScore { + private static final int PAWN_ON_SAME_FILE = 1; + private static final double PAWN_SCORE_STRATEGY = 0.5; + + private final double boardScore; + + public BoardScore(final double boardScore) { + this.boardScore = boardScore; + } + + public BoardScore pawnStrategy(List> sameFilePawns) { + int pawnsCount = sameFilePawns.size(); + if (pawnsCount > PAWN_ON_SAME_FILE) { + return new BoardScore(this.boardScore - (pawnsCount * PAWN_SCORE_STRATEGY)); + } + return this; + } +} diff --git a/src/main/java/chess/domain/piece/Bishop.java b/src/main/java/chess/domain/piece/Bishop.java new file mode 100644 index 00000000000..7151af78465 --- /dev/null +++ b/src/main/java/chess/domain/piece/Bishop.java @@ -0,0 +1,17 @@ +package chess.domain.piece; + +import chess.domain.position.Position; + +public class Bishop extends Piece { + public Bishop(PieceType pieceType, Team team) { + super(pieceType, team); + } + + @Override + public boolean movable(Position source, Position target) { + int fileGap = Math.abs(source.calculateFileGap(target)); + int rankGap = Math.abs(source.calculateRankGap(target)); + + return fileGap == rankGap; + } +} diff --git a/src/main/java/chess/domain/piece/King.java b/src/main/java/chess/domain/piece/King.java new file mode 100644 index 00000000000..d671b45b632 --- /dev/null +++ b/src/main/java/chess/domain/piece/King.java @@ -0,0 +1,21 @@ +package chess.domain.piece; + +import chess.domain.position.Position; + +public class King extends Piece { + private static final int MAX_FILE_GAP = 1; + private static final int MAX_RANK_GAP = 1; + + public King(PieceType pieceType, Team team) { + super(pieceType, team); + } + + @Override + public boolean movable(Position source, Position target) { + int fileGap = Math.abs(source.calculateFileGap(target)); + int rankGap = Math.abs(source.calculateRankGap(target)); + + return fileGap <= MAX_FILE_GAP + && rankGap <= MAX_RANK_GAP; + } +} diff --git a/src/main/java/chess/domain/piece/Knight.java b/src/main/java/chess/domain/piece/Knight.java new file mode 100644 index 00000000000..c7908365708 --- /dev/null +++ b/src/main/java/chess/domain/piece/Knight.java @@ -0,0 +1,23 @@ +package chess.domain.piece; + +import chess.domain.position.Position; + +public class Knight extends Piece { + private static final int HORIZONTAL_FILE_GAP = 2; + private static final int HORIZONTAL_RANK_GAP = 1; + private static final int VERTICAL_FILE_GAP = 1; + private static final int VERTICAL_RANK_GAP = 2; + + public Knight(PieceType pieceType, Team team) { + super(pieceType, team); + } + + @Override + public boolean movable(Position source, Position target) { + int fileGap = Math.abs(source.calculateFileGap(target)); + int rankGap = Math.abs(source.calculateRankGap(target)); + + return (fileGap == HORIZONTAL_FILE_GAP && rankGap == HORIZONTAL_RANK_GAP) + || (fileGap == VERTICAL_FILE_GAP && rankGap == VERTICAL_RANK_GAP); + } +} diff --git a/src/main/java/chess/domain/piece/MoveStrategy.java b/src/main/java/chess/domain/piece/MoveStrategy.java new file mode 100644 index 00000000000..75726bc7ee6 --- /dev/null +++ b/src/main/java/chess/domain/piece/MoveStrategy.java @@ -0,0 +1,7 @@ +package chess.domain.piece; + +import chess.domain.position.Position; + +public interface MoveStrategy { + boolean movable(Position source, Position target); +} diff --git a/src/main/java/chess/domain/piece/Pawn.java b/src/main/java/chess/domain/piece/Pawn.java new file mode 100644 index 00000000000..6d34deb7351 --- /dev/null +++ b/src/main/java/chess/domain/piece/Pawn.java @@ -0,0 +1,51 @@ +package chess.domain.piece; + +import chess.domain.position.Position; + +public class Pawn extends Piece { + private static final int START_WHITE_RANK = 2; + private static final int START_BLACK_RANK = 7; + private static final int SAME_FILE = 0; + private static final int DIAGONAL = 1; + private static final int UP_WHITE_ONE = -1; + private static final int UP_WHITE_TWO = -2; + private static final int DOWN_BLACK_ONE = 1; + private static final int DOWN_BLACK_TWO = 2; + + public Pawn(final PieceType pieceType, final Team team) { + super(pieceType, team); + } + + @Override + public boolean movable(final Position source, final Position target) { + final int fileGap = source.calculateFileGap(target); + final int rankGap = source.calculateRankGap(target); + + if (this.team.isWhite()) { + return whitePawnMovable(source, fileGap, rankGap); + } + return blackPawnMovable(source, fileGap, rankGap); + } + + private boolean whitePawnMovable(final Position source, final int fileGap, final int rankGap) { + if (source.getRank() == START_WHITE_RANK) { + return fileGap == SAME_FILE + && (rankGap == UP_WHITE_ONE || rankGap == UP_WHITE_TWO); + } + + final int absFileGap = Math.abs(fileGap); + return (absFileGap == SAME_FILE || absFileGap == DIAGONAL) + && rankGap == UP_WHITE_ONE; + } + + private boolean blackPawnMovable(final Position source, final int fileGap, final int rankGap) { + if (source.getRank() == START_BLACK_RANK) { + return fileGap == SAME_FILE + && (rankGap == DOWN_BLACK_ONE || rankGap == DOWN_BLACK_TWO); + } + + final int absFileGap = Math.abs(fileGap); + return (absFileGap == SAME_FILE || absFileGap == DIAGONAL) + && rankGap == DOWN_BLACK_ONE; + } +} diff --git a/src/main/java/chess/domain/piece/Piece.java b/src/main/java/chess/domain/piece/Piece.java index 5169eb6c99c..a09e9aacb87 100644 --- a/src/main/java/chess/domain/piece/Piece.java +++ b/src/main/java/chess/domain/piece/Piece.java @@ -1,25 +1,14 @@ package chess.domain.piece; -import chess.domain.board.Board; -import chess.domain.position.Position; - -public class Piece { - private final PieceType pieceType; - private final Team team; +public abstract class Piece implements MoveStrategy { + protected final PieceType pieceType; + protected final Team team; public Piece(final PieceType pieceType, final Team team) { this.pieceType = pieceType; this.team = team; } - public String toSymbol() { - return this.team.symbolize(this.pieceType.getSymbol()); - } - - public boolean movable(final Position source, final Position target, final Board board) { - return this.pieceType.movable(source, target, board); - } - public boolean isEnemy(final Piece targetPiece) { return !this.team.isSameTeamWith(targetPiece.getTeam()); } @@ -40,6 +29,10 @@ public boolean isPawn() { return this.pieceType.isPawn(); } + public String toSymbol() { + return this.team.symbolize(this.pieceType.getSymbol()); + } + public Team getTeam() { return this.team; } diff --git a/src/main/java/chess/domain/piece/PieceType.java b/src/main/java/chess/domain/piece/PieceType.java index f50f5efc873..6640ffa3d86 100644 --- a/src/main/java/chess/domain/piece/PieceType.java +++ b/src/main/java/chess/domain/piece/PieceType.java @@ -1,29 +1,19 @@ package chess.domain.piece; -import chess.domain.board.Board; -import chess.domain.position.Position; -import chess.domain.strategy.move.*; - public enum PieceType { - KING("k", 0, new KingMoveStrategy()), - QUEEN("q", 9, new QueenMoveStrategy()), - ROOK("r", 5, new RookMoveStrategy()), - BISHOP("b", 3, new BishopMoveStrategy()), - KNIGHT("n", 2.5, new KnightMoveStrategy()), - PAWN("p", 1, new PawnMoveStrategy()); + KING("k", 0), + QUEEN("q", 9), + ROOK("r", 5), + BISHOP("b", 3), + KNIGHT("n", 2.5), + PAWN("p", 1); private final String symbol; private final double score; - private final MoveStrategy moveStrategy; - PieceType(String symbol, double score, MoveStrategy moveStrategy) { + PieceType(String symbol, double score) { this.symbol = symbol; this.score = score; - this.moveStrategy = moveStrategy; - } - - public boolean movable(final Position source, final Position target, final Board board) { - return this.moveStrategy.movable(source, target, board); } public boolean isKing() { diff --git a/src/main/java/chess/domain/piece/Queen.java b/src/main/java/chess/domain/piece/Queen.java new file mode 100644 index 00000000000..c7379c01f75 --- /dev/null +++ b/src/main/java/chess/domain/piece/Queen.java @@ -0,0 +1,15 @@ +package chess.domain.piece; + +import chess.domain.position.Position; + +public class Queen extends Piece { + public Queen(PieceType pieceType, Team team) { + super(pieceType, team); + } + + @Override + public boolean movable(Position source, Position target) { + return new Rook(this.pieceType, this.team).movable(source, target) + && new Bishop(this.pieceType, this.team).movable(source, target); + } +} diff --git a/src/main/java/chess/domain/piece/Rook.java b/src/main/java/chess/domain/piece/Rook.java new file mode 100644 index 00000000000..791c12d4c66 --- /dev/null +++ b/src/main/java/chess/domain/piece/Rook.java @@ -0,0 +1,22 @@ +package chess.domain.piece; + +import chess.domain.position.Position; + +public class Rook extends Piece { + + private static final int MIN_FILE_GAP = 0; + private static final int MIN_RANK_GAP = 0; + + public Rook(PieceType pieceType, Team team) { + super(pieceType, team); + } + + @Override + public boolean movable(Position source, Position target) { + int fileGap = Math.abs(source.calculateFileGap(target)); + int rankGap = Math.abs(source.calculateRankGap(target)); + + return (fileGap > MIN_FILE_GAP && rankGap == MIN_RANK_GAP) + || (fileGap == MIN_FILE_GAP && rankGap > MIN_RANK_GAP); + } +} diff --git a/src/main/java/chess/domain/piece/Team.java b/src/main/java/chess/domain/piece/Team.java index 6ae03e8124d..593352c6ab2 100644 --- a/src/main/java/chess/domain/piece/Team.java +++ b/src/main/java/chess/domain/piece/Team.java @@ -12,8 +12,8 @@ public enum Team { this.expression = expression; } - public static Team changeTeam(final Team team) { - if (team == BLACK) { + public Team changeTeam() { + if (this == BLACK) { return WHITE; } return BLACK; diff --git a/src/main/java/chess/domain/strategy/move/direction/Direction.java b/src/main/java/chess/domain/strategy/direction/Direction.java similarity index 97% rename from src/main/java/chess/domain/strategy/move/direction/Direction.java rename to src/main/java/chess/domain/strategy/direction/Direction.java index 857ad66d9a7..50aa5d53255 100644 --- a/src/main/java/chess/domain/strategy/move/direction/Direction.java +++ b/src/main/java/chess/domain/strategy/direction/Direction.java @@ -1,4 +1,4 @@ -package chess.domain.strategy.move.direction; +package chess.domain.strategy.direction; import chess.domain.position.Position; diff --git a/src/main/java/chess/domain/strategy/move/direction/DirectionStrategy.java b/src/main/java/chess/domain/strategy/direction/DirectionStrategy.java similarity index 78% rename from src/main/java/chess/domain/strategy/move/direction/DirectionStrategy.java rename to src/main/java/chess/domain/strategy/direction/DirectionStrategy.java index d9d3f558288..ec27cd66a4a 100644 --- a/src/main/java/chess/domain/strategy/move/direction/DirectionStrategy.java +++ b/src/main/java/chess/domain/strategy/direction/DirectionStrategy.java @@ -1,4 +1,4 @@ -package chess.domain.strategy.move.direction; +package chess.domain.strategy.direction; import chess.domain.position.Position; diff --git a/src/main/java/chess/domain/strategy/move/direction/DownStrategy.java b/src/main/java/chess/domain/strategy/direction/DownStrategy.java similarity index 88% rename from src/main/java/chess/domain/strategy/move/direction/DownStrategy.java rename to src/main/java/chess/domain/strategy/direction/DownStrategy.java index 9d0cae3a260..4c934153ce7 100644 --- a/src/main/java/chess/domain/strategy/move/direction/DownStrategy.java +++ b/src/main/java/chess/domain/strategy/direction/DownStrategy.java @@ -1,8 +1,7 @@ -package chess.domain.strategy.move.direction; +package chess.domain.strategy.direction; import chess.domain.position.Position; -import java.util.ArrayList; import java.util.Collections; import java.util.List; import java.util.stream.Collectors; diff --git a/src/main/java/chess/domain/strategy/move/direction/LeftDownStrategy.java b/src/main/java/chess/domain/strategy/direction/LeftDownStrategy.java similarity index 89% rename from src/main/java/chess/domain/strategy/move/direction/LeftDownStrategy.java rename to src/main/java/chess/domain/strategy/direction/LeftDownStrategy.java index 0b2927ebcfb..9eb5797914a 100644 --- a/src/main/java/chess/domain/strategy/move/direction/LeftDownStrategy.java +++ b/src/main/java/chess/domain/strategy/direction/LeftDownStrategy.java @@ -1,8 +1,7 @@ -package chess.domain.strategy.move.direction; +package chess.domain.strategy.direction; import chess.domain.position.Position; -import java.util.ArrayList; import java.util.Collections; import java.util.List; import java.util.stream.Collectors; diff --git a/src/main/java/chess/domain/strategy/move/direction/LeftStrategy.java b/src/main/java/chess/domain/strategy/direction/LeftStrategy.java similarity index 88% rename from src/main/java/chess/domain/strategy/move/direction/LeftStrategy.java rename to src/main/java/chess/domain/strategy/direction/LeftStrategy.java index e95cbff9e82..9c03bab43ba 100644 --- a/src/main/java/chess/domain/strategy/move/direction/LeftStrategy.java +++ b/src/main/java/chess/domain/strategy/direction/LeftStrategy.java @@ -1,8 +1,7 @@ -package chess.domain.strategy.move.direction; +package chess.domain.strategy.direction; import chess.domain.position.Position; -import java.util.ArrayList; import java.util.Collections; import java.util.List; import java.util.stream.Collectors; diff --git a/src/main/java/chess/domain/strategy/move/direction/LeftUpStrategy.java b/src/main/java/chess/domain/strategy/direction/LeftUpStrategy.java similarity index 88% rename from src/main/java/chess/domain/strategy/move/direction/LeftUpStrategy.java rename to src/main/java/chess/domain/strategy/direction/LeftUpStrategy.java index 03400dc3e29..7be9d112170 100644 --- a/src/main/java/chess/domain/strategy/move/direction/LeftUpStrategy.java +++ b/src/main/java/chess/domain/strategy/direction/LeftUpStrategy.java @@ -1,8 +1,7 @@ -package chess.domain.strategy.move.direction; +package chess.domain.strategy.direction; import chess.domain.position.Position; -import java.util.ArrayList; import java.util.Collections; import java.util.List; import java.util.stream.Collectors; @@ -14,7 +13,7 @@ public List findPath(final Position source, final Position target) { List path = IntStream.range(target.getFile() + 1, source.getFile()) .mapToObj(index -> Position.of(index, target.getRank() + (target.getFile() - index))) .collect(Collectors.toList()); - + return Collections.unmodifiableList(path); } } \ No newline at end of file diff --git a/src/main/java/chess/domain/strategy/move/direction/RightDownStrategy.java b/src/main/java/chess/domain/strategy/direction/RightDownStrategy.java similarity index 85% rename from src/main/java/chess/domain/strategy/move/direction/RightDownStrategy.java rename to src/main/java/chess/domain/strategy/direction/RightDownStrategy.java index 9a304efcfaa..6f8988b2d0c 100644 --- a/src/main/java/chess/domain/strategy/move/direction/RightDownStrategy.java +++ b/src/main/java/chess/domain/strategy/direction/RightDownStrategy.java @@ -1,8 +1,7 @@ -package chess.domain.strategy.move.direction; +package chess.domain.strategy.direction; import chess.domain.position.Position; -import java.util.ArrayList; import java.util.Collections; import java.util.List; import java.util.stream.Collectors; @@ -12,7 +11,7 @@ public final class RightDownStrategy implements DirectionStrategy { @Override public List findPath(final Position source, final Position target) { - List path = IntStream.rangeClosed(source.getFile() + 1, target.getFile() -1) + List path = IntStream.rangeClosed(source.getFile() + 1, target.getFile() - 1) .mapToObj(index -> Position.of(index, target.getRank() + (target.getFile() - index))) .collect(Collectors.toList()); diff --git a/src/main/java/chess/domain/strategy/move/direction/RightStrategy.java b/src/main/java/chess/domain/strategy/direction/RightStrategy.java similarity index 89% rename from src/main/java/chess/domain/strategy/move/direction/RightStrategy.java rename to src/main/java/chess/domain/strategy/direction/RightStrategy.java index 112de22e38f..f665648ee0a 100644 --- a/src/main/java/chess/domain/strategy/move/direction/RightStrategy.java +++ b/src/main/java/chess/domain/strategy/direction/RightStrategy.java @@ -1,8 +1,7 @@ -package chess.domain.strategy.move.direction; +package chess.domain.strategy.direction; import chess.domain.position.Position; -import java.util.ArrayList; import java.util.Collections; import java.util.List; import java.util.stream.Collectors; diff --git a/src/main/java/chess/domain/strategy/move/direction/RightUpStrategy.java b/src/main/java/chess/domain/strategy/direction/RightUpStrategy.java similarity index 89% rename from src/main/java/chess/domain/strategy/move/direction/RightUpStrategy.java rename to src/main/java/chess/domain/strategy/direction/RightUpStrategy.java index ffadef2983d..f321d432ef1 100644 --- a/src/main/java/chess/domain/strategy/move/direction/RightUpStrategy.java +++ b/src/main/java/chess/domain/strategy/direction/RightUpStrategy.java @@ -1,8 +1,7 @@ -package chess.domain.strategy.move.direction; +package chess.domain.strategy.direction; import chess.domain.position.Position; -import java.util.ArrayList; import java.util.Collections; import java.util.List; import java.util.stream.Collectors; diff --git a/src/main/java/chess/domain/strategy/move/direction/UpStrategy.java b/src/main/java/chess/domain/strategy/direction/UpStrategy.java similarity index 89% rename from src/main/java/chess/domain/strategy/move/direction/UpStrategy.java rename to src/main/java/chess/domain/strategy/direction/UpStrategy.java index 8c7e704a4a8..c309ae1f086 100644 --- a/src/main/java/chess/domain/strategy/move/direction/UpStrategy.java +++ b/src/main/java/chess/domain/strategy/direction/UpStrategy.java @@ -1,8 +1,7 @@ -package chess.domain.strategy.move.direction; +package chess.domain.strategy.direction; import chess.domain.position.Position; -import java.util.ArrayList; import java.util.Collections; import java.util.List; import java.util.stream.Collectors; diff --git a/src/main/java/chess/domain/strategy/initialize/BishopInitializer.java b/src/main/java/chess/domain/strategy/initialize/BishopInitializer.java index aa96685bbe1..59fdbc8d981 100644 --- a/src/main/java/chess/domain/strategy/initialize/BishopInitializer.java +++ b/src/main/java/chess/domain/strategy/initialize/BishopInitializer.java @@ -1,5 +1,6 @@ package chess.domain.strategy.initialize; +import chess.domain.piece.Bishop; import chess.domain.piece.Piece; import chess.domain.piece.PieceType; import chess.domain.piece.Team; @@ -13,10 +14,10 @@ public final class BishopInitializer implements InitializeStrategy { @Override public Map initialize() { Map pieces = new HashMap<>(); - pieces.put(Position.of("c8"), new Piece(PieceType.BISHOP, Team.BLACK)); - pieces.put(Position.of("c1"), new Piece(PieceType.BISHOP, Team.WHITE)); - pieces.put(Position.of("f8"), new Piece(PieceType.BISHOP, Team.BLACK)); - pieces.put(Position.of("f1"), new Piece(PieceType.BISHOP, Team.WHITE)); + pieces.put(Position.of("c8"), new Bishop(PieceType.BISHOP, Team.BLACK)); + pieces.put(Position.of("c1"), new Bishop(PieceType.BISHOP, Team.WHITE)); + pieces.put(Position.of("f8"), new Bishop(PieceType.BISHOP, Team.BLACK)); + pieces.put(Position.of("f1"), new Bishop(PieceType.BISHOP, Team.WHITE)); return Collections.unmodifiableMap(pieces); } diff --git a/src/main/java/chess/domain/strategy/initialize/KingInitializer.java b/src/main/java/chess/domain/strategy/initialize/KingInitializer.java index 31346c488f2..598495e1f75 100644 --- a/src/main/java/chess/domain/strategy/initialize/KingInitializer.java +++ b/src/main/java/chess/domain/strategy/initialize/KingInitializer.java @@ -1,5 +1,6 @@ package chess.domain.strategy.initialize; +import chess.domain.piece.King; import chess.domain.piece.Piece; import chess.domain.piece.PieceType; import chess.domain.piece.Team; @@ -13,8 +14,8 @@ public final class KingInitializer implements InitializeStrategy { @Override public Map initialize() { Map pieces = new HashMap<>(); - pieces.put(Position.of("e8"), new Piece(PieceType.KING, Team.BLACK)); - pieces.put(Position.of("e1"), new Piece(PieceType.KING, Team.WHITE)); + pieces.put(Position.of("e8"), new King(PieceType.KING, Team.BLACK)); + pieces.put(Position.of("e1"), new King(PieceType.KING, Team.WHITE)); return Collections.unmodifiableMap(pieces); } diff --git a/src/main/java/chess/domain/strategy/initialize/KnightInitializer.java b/src/main/java/chess/domain/strategy/initialize/KnightInitializer.java index 610e7e8864c..d2863dde2e1 100644 --- a/src/main/java/chess/domain/strategy/initialize/KnightInitializer.java +++ b/src/main/java/chess/domain/strategy/initialize/KnightInitializer.java @@ -1,5 +1,6 @@ package chess.domain.strategy.initialize; +import chess.domain.piece.Knight; import chess.domain.piece.Piece; import chess.domain.piece.PieceType; import chess.domain.piece.Team; @@ -13,10 +14,10 @@ public final class KnightInitializer implements InitializeStrategy { @Override public Map initialize() { Map pieces = new HashMap<>(); - pieces.put(Position.of("b8"), new Piece(PieceType.KNIGHT, Team.BLACK)); - pieces.put(Position.of("b1"), new Piece(PieceType.KNIGHT, Team.WHITE)); - pieces.put(Position.of("g8"), new Piece(PieceType.KNIGHT, Team.BLACK)); - pieces.put(Position.of("g1"), new Piece(PieceType.KNIGHT, Team.WHITE)); + pieces.put(Position.of("b8"), new Knight(PieceType.KNIGHT, Team.BLACK)); + pieces.put(Position.of("b1"), new Knight(PieceType.KNIGHT, Team.WHITE)); + pieces.put(Position.of("g8"), new Knight(PieceType.KNIGHT, Team.BLACK)); + pieces.put(Position.of("g1"), new Knight(PieceType.KNIGHT, Team.WHITE)); return Collections.unmodifiableMap(pieces); } diff --git a/src/main/java/chess/domain/strategy/initialize/PawnInitializer.java b/src/main/java/chess/domain/strategy/initialize/PawnInitializer.java index fae533df5d9..e9296b8bc57 100644 --- a/src/main/java/chess/domain/strategy/initialize/PawnInitializer.java +++ b/src/main/java/chess/domain/strategy/initialize/PawnInitializer.java @@ -1,5 +1,6 @@ package chess.domain.strategy.initialize; +import chess.domain.piece.Pawn; import chess.domain.piece.Piece; import chess.domain.piece.PieceType; import chess.domain.piece.Team; @@ -13,23 +14,23 @@ public final class PawnInitializer implements InitializeStrategy { @Override public Map initialize() { Map pieces = new HashMap<>(); - pieces.put(Position.of("a7"), new Piece(PieceType.PAWN, Team.BLACK)); - pieces.put(Position.of("b7"), new Piece(PieceType.PAWN, Team.BLACK)); - pieces.put(Position.of("c7"), new Piece(PieceType.PAWN, Team.BLACK)); - pieces.put(Position.of("d7"), new Piece(PieceType.PAWN, Team.BLACK)); - pieces.put(Position.of("e7"), new Piece(PieceType.PAWN, Team.BLACK)); - pieces.put(Position.of("f7"), new Piece(PieceType.PAWN, Team.BLACK)); - pieces.put(Position.of("g7"), new Piece(PieceType.PAWN, Team.BLACK)); - pieces.put(Position.of("h7"), new Piece(PieceType.PAWN, Team.BLACK)); + pieces.put(Position.of("a7"), new Pawn(PieceType.PAWN, Team.BLACK)); + pieces.put(Position.of("b7"), new Pawn(PieceType.PAWN, Team.BLACK)); + pieces.put(Position.of("c7"), new Pawn(PieceType.PAWN, Team.BLACK)); + pieces.put(Position.of("d7"), new Pawn(PieceType.PAWN, Team.BLACK)); + pieces.put(Position.of("e7"), new Pawn(PieceType.PAWN, Team.BLACK)); + pieces.put(Position.of("f7"), new Pawn(PieceType.PAWN, Team.BLACK)); + pieces.put(Position.of("g7"), new Pawn(PieceType.PAWN, Team.BLACK)); + pieces.put(Position.of("h7"), new Pawn(PieceType.PAWN, Team.BLACK)); - pieces.put(Position.of("a2"), new Piece(PieceType.PAWN, Team.WHITE)); - pieces.put(Position.of("b2"), new Piece(PieceType.PAWN, Team.WHITE)); - pieces.put(Position.of("c2"), new Piece(PieceType.PAWN, Team.WHITE)); - pieces.put(Position.of("d2"), new Piece(PieceType.PAWN, Team.WHITE)); - pieces.put(Position.of("e2"), new Piece(PieceType.PAWN, Team.WHITE)); - pieces.put(Position.of("f2"), new Piece(PieceType.PAWN, Team.WHITE)); - pieces.put(Position.of("g2"), new Piece(PieceType.PAWN, Team.WHITE)); - pieces.put(Position.of("h2"), new Piece(PieceType.PAWN, Team.WHITE)); + pieces.put(Position.of("a2"), new Pawn(PieceType.PAWN, Team.WHITE)); + pieces.put(Position.of("b2"), new Pawn(PieceType.PAWN, Team.WHITE)); + pieces.put(Position.of("c2"), new Pawn(PieceType.PAWN, Team.WHITE)); + pieces.put(Position.of("d2"), new Pawn(PieceType.PAWN, Team.WHITE)); + pieces.put(Position.of("e2"), new Pawn(PieceType.PAWN, Team.WHITE)); + pieces.put(Position.of("f2"), new Pawn(PieceType.PAWN, Team.WHITE)); + pieces.put(Position.of("g2"), new Pawn(PieceType.PAWN, Team.WHITE)); + pieces.put(Position.of("h2"), new Pawn(PieceType.PAWN, Team.WHITE)); return Collections.unmodifiableMap(pieces); } diff --git a/src/main/java/chess/domain/strategy/initialize/QueenInitializer.java b/src/main/java/chess/domain/strategy/initialize/QueenInitializer.java index d13feded160..64ea4cfc49d 100644 --- a/src/main/java/chess/domain/strategy/initialize/QueenInitializer.java +++ b/src/main/java/chess/domain/strategy/initialize/QueenInitializer.java @@ -2,6 +2,7 @@ import chess.domain.piece.Piece; import chess.domain.piece.PieceType; +import chess.domain.piece.Queen; import chess.domain.piece.Team; import chess.domain.position.Position; @@ -13,8 +14,8 @@ public final class QueenInitializer implements InitializeStrategy { @Override public Map initialize() { Map pieces = new HashMap<>(); - pieces.put(Position.of("d8"), new Piece(PieceType.QUEEN, Team.BLACK)); - pieces.put(Position.of("d1"), new Piece(PieceType.QUEEN, Team.WHITE)); + pieces.put(Position.of("d8"), new Queen(PieceType.QUEEN, Team.BLACK)); + pieces.put(Position.of("d1"), new Queen(PieceType.QUEEN, Team.WHITE)); return Collections.unmodifiableMap(pieces); } diff --git a/src/main/java/chess/domain/strategy/initialize/RookInitializer.java b/src/main/java/chess/domain/strategy/initialize/RookInitializer.java index c1409b0f6c0..efcfbe69b8f 100644 --- a/src/main/java/chess/domain/strategy/initialize/RookInitializer.java +++ b/src/main/java/chess/domain/strategy/initialize/RookInitializer.java @@ -2,6 +2,7 @@ import chess.domain.piece.Piece; import chess.domain.piece.PieceType; +import chess.domain.piece.Rook; import chess.domain.piece.Team; import chess.domain.position.Position; @@ -13,10 +14,10 @@ public final class RookInitializer implements InitializeStrategy { @Override public Map initialize() { Map pieces = new HashMap<>(); - pieces.put(Position.of("a8"), new Piece(PieceType.ROOK, Team.BLACK)); - pieces.put(Position.of("a1"), new Piece(PieceType.ROOK, Team.WHITE)); - pieces.put(Position.of("h8"), new Piece(PieceType.ROOK, Team.BLACK)); - pieces.put(Position.of("h1"), new Piece(PieceType.ROOK, Team.WHITE)); + pieces.put(Position.of("a8"), new Rook(PieceType.ROOK, Team.BLACK)); + pieces.put(Position.of("a1"), new Rook(PieceType.ROOK, Team.WHITE)); + pieces.put(Position.of("h8"), new Rook(PieceType.ROOK, Team.BLACK)); + pieces.put(Position.of("h1"), new Rook(PieceType.ROOK, Team.WHITE)); return Collections.unmodifiableMap(pieces); } diff --git a/src/main/java/chess/domain/strategy/move/BishopMoveStrategy.java b/src/main/java/chess/domain/strategy/move/BishopMoveStrategy.java deleted file mode 100644 index 2d6b99cda57..00000000000 --- a/src/main/java/chess/domain/strategy/move/BishopMoveStrategy.java +++ /dev/null @@ -1,20 +0,0 @@ -package chess.domain.strategy.move; - -import chess.domain.board.Board; -import chess.domain.position.Position; - -public final class BishopMoveStrategy extends MoveStrategy { - @Override - public boolean movable(final Position source, final Position target, final Board board) { - if (isSamePosition(source, target)) { - return false; - } - - int fileGap = Math.abs(source.calculateFileGap(target)); - int rankGap = Math.abs(source.calculateRankGap(target)); - - return (fileGap == rankGap) - && checkObstacle(source, target, board) - && checkTarget(source, target, board); - } -} diff --git a/src/main/java/chess/domain/strategy/move/KingMoveStrategy.java b/src/main/java/chess/domain/strategy/move/KingMoveStrategy.java deleted file mode 100644 index 1b7c157e9e1..00000000000 --- a/src/main/java/chess/domain/strategy/move/KingMoveStrategy.java +++ /dev/null @@ -1,19 +0,0 @@ -package chess.domain.strategy.move; - -import chess.domain.board.Board; -import chess.domain.position.Position; - -public final class KingMoveStrategy extends MoveStrategy { - @Override - public boolean movable(final Position source, final Position target, final Board board) { - if (isSamePosition(source, target)) { - return false; - } - - int fileGap = Math.abs(source.calculateFileGap(target)); - int rankGap = Math.abs(source.calculateRankGap(target)); - - return (fileGap <= 1 && rankGap <= 1) - && checkTarget(source, target, board); - } -} diff --git a/src/main/java/chess/domain/strategy/move/KnightMoveStrategy.java b/src/main/java/chess/domain/strategy/move/KnightMoveStrategy.java deleted file mode 100644 index 7a2e2676256..00000000000 --- a/src/main/java/chess/domain/strategy/move/KnightMoveStrategy.java +++ /dev/null @@ -1,19 +0,0 @@ -package chess.domain.strategy.move; - -import chess.domain.board.Board; -import chess.domain.position.Position; - -public final class KnightMoveStrategy extends MoveStrategy { - @Override - public boolean movable(final Position source, final Position target, final Board board) { - if (isSamePosition(source, target)) { - return false; - } - - int fileGap = Math.abs(source.calculateFileGap(target)); - int rankGap = Math.abs(source.calculateRankGap(target)); - - return (fileGap == 2 && rankGap == 1) || (fileGap == 1 && rankGap == 2) - && checkTarget(source, target, board); - } -} \ No newline at end of file diff --git a/src/main/java/chess/domain/strategy/move/MoveStrategy.java b/src/main/java/chess/domain/strategy/move/MoveStrategy.java deleted file mode 100644 index 5b6395ce053..00000000000 --- a/src/main/java/chess/domain/strategy/move/MoveStrategy.java +++ /dev/null @@ -1,33 +0,0 @@ -package chess.domain.strategy.move; - -import chess.domain.board.Board; -import chess.domain.piece.Piece; -import chess.domain.position.Position; -import chess.domain.strategy.move.direction.Direction; - -import java.util.List; - -public abstract class MoveStrategy { - protected boolean isSamePosition(final Position source, final Position target) { - return source.equals(target); - } - - protected boolean checkObstacle(final Position source, final Position target, final Board board) { - Direction direction = Direction.findDirection(source, target); - List path = direction.findPath(source, target); - - return path.stream() - .allMatch(board::isEmpty); - } - - protected boolean checkTarget(final Position source, final Position target, final Board board) { - Piece sourcePiece = board.getPiece(source); - if (board.isEmpty(target)) { - return true; - } - Piece targetPiece = board.getPiece(target); - return sourcePiece.isEnemy(targetPiece); - } - - public abstract boolean movable(final Position source, final Position target, final Board board); -} diff --git a/src/main/java/chess/domain/strategy/move/PawnMoveStrategy.java b/src/main/java/chess/domain/strategy/move/PawnMoveStrategy.java deleted file mode 100644 index 51152f41ea2..00000000000 --- a/src/main/java/chess/domain/strategy/move/PawnMoveStrategy.java +++ /dev/null @@ -1,49 +0,0 @@ -package chess.domain.strategy.move; - -import chess.domain.board.Board; -import chess.domain.piece.Piece; -import chess.domain.piece.Team; -import chess.domain.position.Position; - -public final class PawnMoveStrategy extends MoveStrategy { - private static final int WHITE_POSITION = 2; - private static final int BLACK_POSITION = 7; - - @Override - public boolean movable(final Position source, final Position target, final Board board) { - if (isSamePosition(source, target)) { - return false; - } - - int fileGap = source.calculateFileGap(target); - int rankGap = source.calculateRankGap(target); - - Piece sourcePiece = board.getPiece(source); - Piece targetPiece = board.getPiece(target); - Team pawnTeam = sourcePiece.getTeam(); - - if (pawnTeam.isWhite()) { - if (fileGap == 0 && rankGap == -1) { - return board.isEmpty(target); - } - if (fileGap == 0 && rankGap == -2) { - return source.getRank() == WHITE_POSITION; - } - if (Math.abs(fileGap) == 1 && rankGap == -1) { - return !board.isEmpty(target) && sourcePiece.isEnemy(targetPiece); - } - } - if (!pawnTeam.isWhite()) { - if (fileGap == 0 && rankGap == 1) { - return board.isEmpty(target); - } - if (fileGap == 0 && rankGap == 2) { - return source.getRank() == BLACK_POSITION; - } - if (Math.abs(fileGap) == 1 && rankGap == 1) { - return !board.isEmpty(target) && sourcePiece.isEnemy(targetPiece); - } - } - return false; - } -} \ No newline at end of file diff --git a/src/main/java/chess/domain/strategy/move/QueenMoveStrategy.java b/src/main/java/chess/domain/strategy/move/QueenMoveStrategy.java deleted file mode 100644 index 06b05f8db8b..00000000000 --- a/src/main/java/chess/domain/strategy/move/QueenMoveStrategy.java +++ /dev/null @@ -1,12 +0,0 @@ -package chess.domain.strategy.move; - -import chess.domain.board.Board; -import chess.domain.position.Position; - -public final class QueenMoveStrategy extends MoveStrategy { - @Override - public boolean movable(final Position source, final Position target, final Board board) { - return new RookMoveStrategy().movable(source, target, board) - || new BishopMoveStrategy().movable(source, target, board); - } -} \ No newline at end of file diff --git a/src/main/java/chess/domain/strategy/move/RookMoveStrategy.java b/src/main/java/chess/domain/strategy/move/RookMoveStrategy.java deleted file mode 100644 index 91f0bc112c3..00000000000 --- a/src/main/java/chess/domain/strategy/move/RookMoveStrategy.java +++ /dev/null @@ -1,20 +0,0 @@ -package chess.domain.strategy.move; - -import chess.domain.board.Board; -import chess.domain.position.Position; - -public final class RookMoveStrategy extends MoveStrategy { - @Override - public boolean movable(final Position source, final Position target, final Board board) { - if (isSamePosition(source, target)) { - return false; - } - - int fileGap = Math.abs(source.calculateFileGap(target)); - int rankGap = Math.abs(source.calculateRankGap(target)); - - return ((fileGap > 0 && rankGap == 0) || (fileGap == 0 && rankGap > 0)) - && checkObstacle(source, target, board) - && checkTarget(source, target, board); - } -} diff --git a/src/main/java/chess/view/ConsoleInputView.java b/src/main/java/chess/view/ConsoleInputView.java index caf9c36fe07..0649abe99fb 100644 --- a/src/main/java/chess/view/ConsoleInputView.java +++ b/src/main/java/chess/view/ConsoleInputView.java @@ -11,7 +11,7 @@ public String askChessRun() { System.out.println("> 게임 시작 : start"); System.out.println("> 게임 종료 : end"); System.out.println("> 게임 이동 : move source위치 target위치 - 예. move b2 b3"); - return askGameCommand(); + return SCANNER.nextLine(); } @Override diff --git a/src/main/java/chess/view/InputView.java b/src/main/java/chess/view/InputView.java index adb656d5da3..d3a8f06a520 100644 --- a/src/main/java/chess/view/InputView.java +++ b/src/main/java/chess/view/InputView.java @@ -2,5 +2,6 @@ public interface InputView { String askChessRun(); + String askGameCommand(); } diff --git a/src/main/java/chess/view/OutputView.java b/src/main/java/chess/view/OutputView.java index 1399b824401..5869d4291fd 100644 --- a/src/main/java/chess/view/OutputView.java +++ b/src/main/java/chess/view/OutputView.java @@ -7,6 +7,8 @@ public interface OutputView { void printBoard(List positions, Map board); + void printStatus(double calculateScore, Team team); + void printWinner(Team team); } diff --git a/src/test/java/chess/domain/ChessRunnerTest.java b/src/test/java/chess/domain/ChessRunnerTest.java index 093fd56c2b9..e311062b9ee 100644 --- a/src/test/java/chess/domain/ChessRunnerTest.java +++ b/src/test/java/chess/domain/ChessRunnerTest.java @@ -22,11 +22,35 @@ void validateCurrentTeam() { .hasMessage("현재 차례가 아닙니다."); } - @DisplayName("이동할 수 없는 곳일 때 에러 메시지 출력") + @DisplayName("같은 위치로 이동할 때 에러 메시지 출력") + @Test + void validateSamePosition() { + assertThatThrownBy(() -> chessRunner.update("a2", "a2")) + .isInstanceOf(IllegalArgumentException.class) + .hasMessage("같은 위치로 이동할 수 없습니다."); + } + + @DisplayName("선택한 기물에 맞지 않는 목적지를 선택했을 때 에레 메시지 출력") @Test void validateMovable() { - assertThatThrownBy(() -> chessRunner.update("a1", "a2")) //화이트 팀 룩 이동 + assertThatThrownBy(() -> chessRunner.update("a1", "b2")) + .isInstanceOf(IllegalArgumentException.class) + .hasMessage("선택한 기물이 이동할 수 없는 곳입니다."); + } + + @DisplayName("경로 사이에 장애물이 있을 때 에러 메시지 출력") + @Test + void validateObstacle() { + assertThatThrownBy(() -> chessRunner.update("a1", "a3")) + .isInstanceOf(IllegalArgumentException.class) + .hasMessage("경로 사이에 장애물이 있습니다."); + } + + @DisplayName("잘못된 목적지를 선택했을 때 에러 메시지 출력") + @Test + void validateTarget() { + assertThatThrownBy(() -> chessRunner.update("a1", "a2")) .isInstanceOf(IllegalArgumentException.class) - .hasMessage("이동할 수 없는 곳입니다."); + .hasMessage("목적지가 잘못되었습니다."); } } \ No newline at end of file diff --git a/src/test/java/chess/domain/board/BoardTest.java b/src/test/java/chess/domain/board/BoardTest.java index 9a0e11c066b..f932e6b1a32 100644 --- a/src/test/java/chess/domain/board/BoardTest.java +++ b/src/test/java/chess/domain/board/BoardTest.java @@ -1,8 +1,6 @@ package chess.domain.board; -import chess.domain.piece.Piece; -import chess.domain.piece.PieceType; -import chess.domain.piece.Team; +import chess.domain.piece.*; import chess.domain.position.Position; import org.assertj.core.api.Assertions; import org.junit.jupiter.api.DisplayName; @@ -20,16 +18,17 @@ void updateAtEmptyBoard() { Position target = Position.of("a3"); board.updateBoard(source, target); - Assertions.assertThat(board.getPiece(source)).isNull(); - Assertions.assertThat(board.getPiece(target)).isNotNull(); + Assertions.assertThatThrownBy(() -> { + board.getPiece(source); + }).isInstanceOf(IllegalArgumentException.class); Assertions.assertThat(board.getPiece(target)).isInstanceOf(Piece.class); } @DisplayName("상대 편으로 말 이동") @Test void updateAtEnemy() { - Piece rook = new Piece(PieceType.ROOK, Team.WHITE); - Piece pawn = new Piece(PieceType.PAWN, Team.BLACK); + Piece rook = new Rook(PieceType.ROOK, Team.WHITE); + Piece pawn = new Pawn(PieceType.PAWN, Team.BLACK); Map entry = new HashMap<>(); Position source = Position.of("a2"); Position target = Position.of("a3"); @@ -38,7 +37,9 @@ void updateAtEnemy() { Board board = new Board(entry); board.updateBoard(source, target); - Assertions.assertThat(board.getPiece(source)).isNull(); + Assertions.assertThatThrownBy(() -> { + board.getPiece(source); + }).isInstanceOf(IllegalArgumentException.class); Assertions.assertThat(board.getPiece(target)).isNotNull(); Assertions.assertThat(board.getPiece(target)).isInstanceOf(Piece.class); } @@ -47,16 +48,16 @@ void updateAtEnemy() { @Test void checkWinnerTest() { Map whiteKing = new HashMap<>(); - whiteKing.put(Position.of("a3"), new Piece(PieceType.KING, Team.WHITE)); + whiteKing.put(Position.of("a3"), new King(PieceType.KING, Team.WHITE)); Board whiteWinBoard = new Board(whiteKing); Map blackKing = new HashMap<>(); - blackKing.put(Position.of("b4"), new Piece(PieceType.KING, Team.BLACK)); + blackKing.put(Position.of("b4"), new King(PieceType.KING, Team.BLACK)); Board blackWinBoard = new Board(blackKing); Map bothKing = new HashMap<>(); - bothKing.put(Position.of("a5"), new Piece(PieceType.KING, Team.BLACK)); - bothKing.put(Position.of("b7"), new Piece(PieceType.KING, Team.WHITE)); + bothKing.put(Position.of("a5"), new King(PieceType.KING, Team.BLACK)); + bothKing.put(Position.of("b7"), new King(PieceType.KING, Team.WHITE)); Board drawBoard = new Board(bothKing); Assertions.assertThat(whiteWinBoard.checkWinner()).isEqualTo(Team.WHITE); @@ -81,7 +82,9 @@ void getPieceTest() { Board board = new Board(); Assertions.assertThat(board.getPiece(Position.of("a2"))).isInstanceOf(Piece.class); - Assertions.assertThat(board.getPiece(Position.of("a3"))).isNull(); + Assertions.assertThatThrownBy(() -> { + board.getPiece(Position.of("a3")); + }).isInstanceOf(IllegalArgumentException.class); } @DisplayName("같은 세로줄에 폰이 없을 때 점수 계산") @@ -89,19 +92,19 @@ void getPieceTest() { void calculateScoreWithoutSameFilePawnTest() { Board board = new Board(); - Assertions.assertThat(board.calculateScore(Team.WHITE)).isEqualTo(38d); - Assertions.assertThat(board.calculateScore(Team.BLACK)).isEqualTo(38d); + Assertions.assertThat(board.calculateScore(Team.WHITE)).extracting("boardScore").isEqualTo(38d); + Assertions.assertThat(board.calculateScore(Team.BLACK)).extracting("boardScore").isEqualTo(38d); } @DisplayName("같은 세로줄에 폰이 있을 때 점수 계산") @Test void calculateScoreWithSameFilePawn() { Map sameFilePawn = new HashMap<>(); - sameFilePawn.put(Position.of("a3"), new Piece(PieceType.PAWN, Team.WHITE)); - sameFilePawn.put(Position.of("a4"), new Piece(PieceType.PAWN, Team.WHITE)); - sameFilePawn.put(Position.of("a5"), new Piece(PieceType.PAWN, Team.WHITE)); + sameFilePawn.put(Position.of("a3"), new Pawn(PieceType.PAWN, Team.WHITE)); + sameFilePawn.put(Position.of("a4"), new Pawn(PieceType.PAWN, Team.WHITE)); + sameFilePawn.put(Position.of("a5"), new Pawn(PieceType.PAWN, Team.WHITE)); Board board = new Board(sameFilePawn); - Assertions.assertThat(board.calculateScore(Team.WHITE)).isEqualTo(1.5d); + Assertions.assertThat(board.calculateScore(Team.WHITE)).extracting("boardScore").isEqualTo(1.5d); } } diff --git a/src/test/java/chess/domain/piece/PieceTest.java b/src/test/java/chess/domain/piece/PieceTest.java index 088f7bc1eab..926051f7da8 100644 --- a/src/test/java/chess/domain/piece/PieceTest.java +++ b/src/test/java/chess/domain/piece/PieceTest.java @@ -9,8 +9,8 @@ class PieceTest { @DisplayName("팀 별 대소문자로 출력") @Test void toSymbol() { - Piece whitePiece = new Piece(PieceType.BISHOP, Team.WHITE); - Piece blackPiece = new Piece(PieceType.BISHOP, Team.BLACK); + Piece whitePiece = new Bishop(PieceType.BISHOP, Team.WHITE); + Piece blackPiece = new Bishop(PieceType.BISHOP, Team.BLACK); assertThat(whitePiece.toSymbol()).isEqualTo("b"); assertThat(blackPiece.toSymbol()).isEqualTo("B"); } @@ -18,16 +18,16 @@ void toSymbol() { @DisplayName("피스의 팀 구분") @Test void isEnemy() { - Piece whitePiece = new Piece(PieceType.KNIGHT, Team.WHITE); - Piece blackPiece = new Piece(PieceType.KNIGHT, Team.BLACK); + Piece whitePiece = new Knight(PieceType.KNIGHT, Team.WHITE); + Piece blackPiece = new Knight(PieceType.KNIGHT, Team.BLACK); assertThat(whitePiece.isEnemy(blackPiece)).isTrue(); } @DisplayName("피스가 흰 팀의 킹인지 테스트") @Test void isWhiteKing() { - Piece whiteKing = new Piece(PieceType.KING, Team.WHITE); - Piece blackBishop = new Piece(PieceType.BISHOP, Team.BLACK); + Piece whiteKing = new King(PieceType.KING, Team.WHITE); + Piece blackBishop = new Bishop(PieceType.BISHOP, Team.BLACK); assertThat(whiteKing.isWhiteKing()).isTrue(); assertThat(blackBishop.isWhiteKing()).isFalse(); } @@ -35,8 +35,8 @@ void isWhiteKing() { @DisplayName("피스가 검은 팀의 킹인지 테스트") @Test void isBlackKing() { - Piece blackKing = new Piece(PieceType.KING, Team.BLACK); - Piece whiteBishop = new Piece(PieceType.BISHOP, Team.WHITE); + Piece blackKing = new King(PieceType.KING, Team.BLACK); + Piece whiteBishop = new Bishop(PieceType.BISHOP, Team.WHITE); assertThat(blackKing.isBlackKing()).isTrue(); assertThat(whiteBishop.isBlackKing()).isFalse(); } @@ -44,8 +44,8 @@ void isBlackKing() { @DisplayName("피스가 폰인지 테스트") @Test void isPawn() { - Piece whitePawn = new Piece(PieceType.PAWN, Team.WHITE); - Piece blackQueen = new Piece(PieceType.QUEEN, Team.BLACK); + Piece whitePawn = new Pawn(PieceType.PAWN, Team.WHITE); + Piece blackQueen = new Queen(PieceType.QUEEN, Team.BLACK); assertThat(whitePawn.isPawn()).isTrue(); assertThat(blackQueen.isPawn()).isFalse(); } diff --git a/src/test/java/chess/domain/piece/TeamTest.java b/src/test/java/chess/domain/piece/TeamTest.java index 6578588c4a4..e792ec8643a 100644 --- a/src/test/java/chess/domain/piece/TeamTest.java +++ b/src/test/java/chess/domain/piece/TeamTest.java @@ -1,17 +1,20 @@ package chess.domain.piece; -import chess.domain.ChessRunner; +import org.assertj.core.api.Assertions; import org.junit.jupiter.api.DisplayName; import org.junit.jupiter.api.Test; -import static org.assertj.core.api.Assertions.assertThat; - class TeamTest { @DisplayName("팀 순서 변경 테스트") @Test void changeTeam() { - ChessRunner chessRunner = new ChessRunner(); - Team nextTeam = Team.changeTeam(chessRunner.getCurrentTeam()); - assertThat(nextTeam.isSameTeamWith(Team.BLACK)).isTrue(); + Team blackTeam = Team.BLACK; + Team whiteTeam = Team.WHITE; + + Team blackExpected = blackTeam.changeTeam(); + Team whiteExpected = whiteTeam.changeTeam(); + + Assertions.assertThat(blackExpected).isEqualTo(Team.WHITE); + Assertions.assertThat(whiteExpected).isEqualTo(Team.BLACK); } } \ No newline at end of file diff --git a/src/test/java/chess/domain/strategy/move/direction/DirectionTest.java b/src/test/java/chess/domain/strategy/direction/DirectionTest.java similarity index 98% rename from src/test/java/chess/domain/strategy/move/direction/DirectionTest.java rename to src/test/java/chess/domain/strategy/direction/DirectionTest.java index 6e099801ded..9c160a57849 100644 --- a/src/test/java/chess/domain/strategy/move/direction/DirectionTest.java +++ b/src/test/java/chess/domain/strategy/direction/DirectionTest.java @@ -1,4 +1,4 @@ -package chess.domain.strategy.move.direction; +package chess.domain.strategy.direction; import chess.domain.position.Position; import org.junit.jupiter.api.DisplayName; diff --git a/src/test/java/chess/domain/strategy/move/direction/DownStrategyTest.java b/src/test/java/chess/domain/strategy/direction/DownStrategyTest.java similarity index 94% rename from src/test/java/chess/domain/strategy/move/direction/DownStrategyTest.java rename to src/test/java/chess/domain/strategy/direction/DownStrategyTest.java index 60eea0efeb5..95c10219872 100644 --- a/src/test/java/chess/domain/strategy/move/direction/DownStrategyTest.java +++ b/src/test/java/chess/domain/strategy/direction/DownStrategyTest.java @@ -1,4 +1,4 @@ -package chess.domain.strategy.move.direction; +package chess.domain.strategy.direction; import chess.domain.position.Position; import org.assertj.core.api.Assertions; diff --git a/src/test/java/chess/domain/strategy/move/direction/LeftDownStrategyTest.java b/src/test/java/chess/domain/strategy/direction/LeftDownStrategyTest.java similarity index 94% rename from src/test/java/chess/domain/strategy/move/direction/LeftDownStrategyTest.java rename to src/test/java/chess/domain/strategy/direction/LeftDownStrategyTest.java index 7b0ccb44a14..662a64c0ed8 100644 --- a/src/test/java/chess/domain/strategy/move/direction/LeftDownStrategyTest.java +++ b/src/test/java/chess/domain/strategy/direction/LeftDownStrategyTest.java @@ -1,4 +1,4 @@ -package chess.domain.strategy.move.direction; +package chess.domain.strategy.direction; import chess.domain.position.Position; import org.assertj.core.api.Assertions; diff --git a/src/test/java/chess/domain/strategy/move/direction/LeftStrategyTest.java b/src/test/java/chess/domain/strategy/direction/LeftStrategyTest.java similarity index 94% rename from src/test/java/chess/domain/strategy/move/direction/LeftStrategyTest.java rename to src/test/java/chess/domain/strategy/direction/LeftStrategyTest.java index 8b27066e7f4..a8c126e60c2 100644 --- a/src/test/java/chess/domain/strategy/move/direction/LeftStrategyTest.java +++ b/src/test/java/chess/domain/strategy/direction/LeftStrategyTest.java @@ -1,4 +1,4 @@ -package chess.domain.strategy.move.direction; +package chess.domain.strategy.direction; import chess.domain.position.Position; import org.assertj.core.api.Assertions; diff --git a/src/test/java/chess/domain/strategy/move/direction/LeftUpStrategyTest.java b/src/test/java/chess/domain/strategy/direction/LeftUpStrategyTest.java similarity index 94% rename from src/test/java/chess/domain/strategy/move/direction/LeftUpStrategyTest.java rename to src/test/java/chess/domain/strategy/direction/LeftUpStrategyTest.java index 8d3582c09c1..22689bd2bfc 100644 --- a/src/test/java/chess/domain/strategy/move/direction/LeftUpStrategyTest.java +++ b/src/test/java/chess/domain/strategy/direction/LeftUpStrategyTest.java @@ -1,4 +1,4 @@ -package chess.domain.strategy.move.direction; +package chess.domain.strategy.direction; import chess.domain.position.Position; import org.assertj.core.api.Assertions; diff --git a/src/test/java/chess/domain/strategy/move/direction/RightDownStrategyTest.java b/src/test/java/chess/domain/strategy/direction/RightDownStrategyTest.java similarity index 94% rename from src/test/java/chess/domain/strategy/move/direction/RightDownStrategyTest.java rename to src/test/java/chess/domain/strategy/direction/RightDownStrategyTest.java index 196e8560276..38d160091d5 100644 --- a/src/test/java/chess/domain/strategy/move/direction/RightDownStrategyTest.java +++ b/src/test/java/chess/domain/strategy/direction/RightDownStrategyTest.java @@ -1,4 +1,4 @@ -package chess.domain.strategy.move.direction; +package chess.domain.strategy.direction; import chess.domain.position.Position; import org.assertj.core.api.Assertions; diff --git a/src/test/java/chess/domain/strategy/move/direction/RightStrategyTest.java b/src/test/java/chess/domain/strategy/direction/RightStrategyTest.java similarity index 94% rename from src/test/java/chess/domain/strategy/move/direction/RightStrategyTest.java rename to src/test/java/chess/domain/strategy/direction/RightStrategyTest.java index 0487ca15540..b77f11878ec 100644 --- a/src/test/java/chess/domain/strategy/move/direction/RightStrategyTest.java +++ b/src/test/java/chess/domain/strategy/direction/RightStrategyTest.java @@ -1,4 +1,4 @@ -package chess.domain.strategy.move.direction; +package chess.domain.strategy.direction; import chess.domain.position.Position; import org.assertj.core.api.Assertions; diff --git a/src/test/java/chess/domain/strategy/move/direction/RightUpStrategyTest.java b/src/test/java/chess/domain/strategy/direction/RightUpStrategyTest.java similarity index 94% rename from src/test/java/chess/domain/strategy/move/direction/RightUpStrategyTest.java rename to src/test/java/chess/domain/strategy/direction/RightUpStrategyTest.java index c4903e7303a..616ed9fbb94 100644 --- a/src/test/java/chess/domain/strategy/move/direction/RightUpStrategyTest.java +++ b/src/test/java/chess/domain/strategy/direction/RightUpStrategyTest.java @@ -1,4 +1,4 @@ -package chess.domain.strategy.move.direction; +package chess.domain.strategy.direction; import chess.domain.position.Position; import org.assertj.core.api.Assertions; diff --git a/src/test/java/chess/domain/strategy/move/direction/UpStrategyTest.java b/src/test/java/chess/domain/strategy/direction/UpStrategyTest.java similarity index 94% rename from src/test/java/chess/domain/strategy/move/direction/UpStrategyTest.java rename to src/test/java/chess/domain/strategy/direction/UpStrategyTest.java index 8acb305c8c1..4999a795810 100644 --- a/src/test/java/chess/domain/strategy/move/direction/UpStrategyTest.java +++ b/src/test/java/chess/domain/strategy/direction/UpStrategyTest.java @@ -1,4 +1,4 @@ -package chess.domain.strategy.move.direction; +package chess.domain.strategy.direction; import chess.domain.position.Position; import org.assertj.core.api.Assertions; diff --git a/src/test/java/chess/domain/strategy/move/BishopMoveStrategyTest.java b/src/test/java/chess/domain/strategy/move/BishopMoveStrategyTest.java deleted file mode 100644 index 6bdeb3df2ca..00000000000 --- a/src/test/java/chess/domain/strategy/move/BishopMoveStrategyTest.java +++ /dev/null @@ -1,77 +0,0 @@ -package chess.domain.strategy.move; - -import chess.domain.board.Board; -import chess.domain.piece.Piece; -import chess.domain.piece.PieceType; -import chess.domain.piece.Team; -import chess.domain.position.Position; -import org.assertj.core.api.Assertions; -import org.junit.jupiter.api.BeforeEach; -import org.junit.jupiter.api.DisplayName; -import org.junit.jupiter.api.Test; - -import java.util.HashMap; -import java.util.Map; - -public class BishopMoveStrategyTest { - private MoveStrategy bishopStrategy; - private Board board; - - @BeforeEach - private void setUp() { - bishopStrategy = new BishopMoveStrategy(); - Map emptyBoard = new HashMap<>(); - board = new Board(emptyBoard); - } - - @DisplayName("비숍의 우 상단 대각 이동") - @Test - void rightUpTest() { - Position source = Position.of("a1"); - Position target = Position.of("e5"); - - Assertions.assertThat(bishopStrategy.movable(source, target, board)).isTrue(); - } - - @DisplayName("비숍의 우 하단 대각 이동") - @Test - void rightDownTest() { - Position source = Position.of("a7"); - Position target = Position.of("e3"); - - Assertions.assertThat(bishopStrategy.movable(source, target, board)).isTrue(); - } - - @DisplayName("비숍의 좌 상단 대각 이동") - @Test - void leftUpTest() { - Position source = Position.of("g1"); - Position target = Position.of("c5"); - - Assertions.assertThat(bishopStrategy.movable(source, target, board)).isTrue(); - } - - @DisplayName("비숍의 좌 하단 대각 이동") - @Test - void leftDownTest() { - Position source = Position.of("g7"); - Position target = Position.of("c3"); - - Assertions.assertThat(bishopStrategy.movable(source, target, board)).isTrue(); - } - - @DisplayName("타겟 위치에 적이 있을 때 이동") - @Test - void moveWhenEnemyTest() { - Piece bishop = new Piece(PieceType.BISHOP, Team.BLACK); - Piece enemy = new Piece(PieceType.PAWN, Team.WHITE); - Position source = Position.of("a1"); - Position target = Position.of("e5"); - Map enemyEntry = new HashMap<>(); - enemyEntry.put(source, bishop); - enemyEntry.put(target, enemy); - Board enemyBoard = new Board(enemyEntry); - - Assertions.assertThat(bishopStrategy.movable(source, target, enemyBoard)).isTrue(); - } -} diff --git a/src/test/java/chess/domain/strategy/move/KingMoveStrategyTest.java b/src/test/java/chess/domain/strategy/move/KingMoveStrategyTest.java deleted file mode 100644 index 0f54b0d7e69..00000000000 --- a/src/test/java/chess/domain/strategy/move/KingMoveStrategyTest.java +++ /dev/null @@ -1,64 +0,0 @@ -package chess.domain.strategy.move; - -import chess.domain.board.Board; -import chess.domain.piece.Piece; -import chess.domain.piece.PieceType; -import chess.domain.piece.Team; -import chess.domain.position.Position; -import org.assertj.core.api.Assertions; -import org.junit.jupiter.api.BeforeEach; -import org.junit.jupiter.api.DisplayName; -import org.junit.jupiter.api.Test; - -import java.util.HashMap; -import java.util.Map; - -public class KingMoveStrategyTest { - private MoveStrategy kingStrategy; - - @BeforeEach - private void setUp() { - kingStrategy = new KingMoveStrategy(); - } - - @DisplayName("킹의 이동 가능 위치에 대해 이동 테스트") - @Test - void moveTest() { - Map emptyBoard = new HashMap<>(); - Board board = new Board(emptyBoard); - Position source = Position.of("d4"); - - Position up = Position.of("d5"); - Position down = Position.of("d3"); - Position left = Position.of("c4"); - Position right = Position.of("e4"); - Position rightUp = Position.of("e5"); - Position rightDown = Position.of("e3"); - Position leftUp = Position.of("c5"); - Position leftDown = Position.of("c3"); - - Assertions.assertThat(kingStrategy.movable(source, up, board)).isTrue(); - Assertions.assertThat(kingStrategy.movable(source, down, board)).isTrue(); - Assertions.assertThat(kingStrategy.movable(source, left, board)).isTrue(); - Assertions.assertThat(kingStrategy.movable(source, right, board)).isTrue(); - Assertions.assertThat(kingStrategy.movable(source, rightUp, board)).isTrue(); - Assertions.assertThat(kingStrategy.movable(source, rightDown, board)).isTrue(); - Assertions.assertThat(kingStrategy.movable(source, leftUp, board)).isTrue(); - Assertions.assertThat(kingStrategy.movable(source, leftDown, board)).isTrue(); - } - - @DisplayName("타겟 위치에 적이 있을 때 이동") - @Test - void moveWhenEnemyTest() { - Piece king = new Piece(PieceType.KING, Team.BLACK); - Piece enemy = new Piece(PieceType.PAWN, Team.WHITE); - Position source = Position.of("d4"); - Position target = Position.of("e5"); - Map enemyEntry = new HashMap<>(); - enemyEntry.put(source, king); - enemyEntry.put(target, enemy); - Board enemyBoard = new Board(enemyEntry); - - Assertions.assertThat(kingStrategy.movable(source, target, enemyBoard)).isTrue(); - } -} diff --git a/src/test/java/chess/domain/strategy/move/KnightMoveStrategyTest.java b/src/test/java/chess/domain/strategy/move/KnightMoveStrategyTest.java deleted file mode 100644 index 84bcf4d3aa8..00000000000 --- a/src/test/java/chess/domain/strategy/move/KnightMoveStrategyTest.java +++ /dev/null @@ -1,64 +0,0 @@ -package chess.domain.strategy.move; - -import chess.domain.board.Board; -import chess.domain.piece.Piece; -import chess.domain.piece.PieceType; -import chess.domain.piece.Team; -import chess.domain.position.Position; -import org.assertj.core.api.Assertions; -import org.junit.jupiter.api.BeforeEach; -import org.junit.jupiter.api.DisplayName; -import org.junit.jupiter.api.Test; - -import java.util.HashMap; -import java.util.Map; - -public class KnightMoveStrategyTest { - private MoveStrategy knightStrategy; - - @BeforeEach - private void setUp() { - knightStrategy = new KnightMoveStrategy(); - } - - @DisplayName("나이트의 이동 가능 위치에 이동") - @Test - void moveTest() { - Position source = Position.of("d4"); - Map emptyBoard = new HashMap<>(); - Board board = new Board(emptyBoard); - - Position upLeft = Position.of("c6"); - Position upRight = Position.of("e6"); - Position downLeft = Position.of("c2"); - Position downRight = Position.of("e2"); - Position leftUp = Position.of("b5"); - Position leftDown = Position.of("b3"); - Position rightUp = Position.of("f5"); - Position rightDown = Position.of("f3"); - - Assertions.assertThat(knightStrategy.movable(source, upLeft, board)).isTrue(); - Assertions.assertThat(knightStrategy.movable(source, upRight, board)).isTrue(); - Assertions.assertThat(knightStrategy.movable(source, downLeft, board)).isTrue(); - Assertions.assertThat(knightStrategy.movable(source, downRight, board)).isTrue(); - Assertions.assertThat(knightStrategy.movable(source, leftUp, board)).isTrue(); - Assertions.assertThat(knightStrategy.movable(source, leftDown, board)).isTrue(); - Assertions.assertThat(knightStrategy.movable(source, rightUp, board)).isTrue(); - Assertions.assertThat(knightStrategy.movable(source, rightDown, board)).isTrue(); - } - - @DisplayName("타겟 위치에 적이 있을 때 이동") - @Test - void moveWhenEnemyTest() { - Piece knight = new Piece(PieceType.KING, Team.BLACK); - Piece enemy = new Piece(PieceType.PAWN, Team.WHITE); - Position source = Position.of("d4"); - Position target = Position.of("e6"); - Map enemyEntry = new HashMap<>(); - enemyEntry.put(source, knight); - enemyEntry.put(target, enemy); - Board enemyBoard = new Board(enemyEntry); - - Assertions.assertThat(knightStrategy.movable(source, target, enemyBoard)).isTrue(); - } -} diff --git a/src/test/java/chess/domain/strategy/move/PawnMoveStrategyTest.java b/src/test/java/chess/domain/strategy/move/PawnMoveStrategyTest.java deleted file mode 100644 index 41e2d60050c..00000000000 --- a/src/test/java/chess/domain/strategy/move/PawnMoveStrategyTest.java +++ /dev/null @@ -1,107 +0,0 @@ -package chess.domain.strategy.move; - -import chess.domain.board.Board; -import chess.domain.piece.Piece; -import chess.domain.piece.PieceType; -import chess.domain.piece.Team; -import chess.domain.position.Position; -import org.assertj.core.api.Assertions; -import org.junit.jupiter.api.BeforeEach; -import org.junit.jupiter.api.DisplayName; -import org.junit.jupiter.api.Test; - -import java.util.HashMap; -import java.util.Map; - -public class PawnMoveStrategyTest { - private MoveStrategy pawnStrategy; - - @BeforeEach - private void setUp() { - pawnStrategy = new PawnMoveStrategy(); -// Piece whitePawn = new Piece(PieceType.PAWN, Team.WHITE); -// Piece blackPawn = new Piece(PieceType.PAWN, Team.BLACK); -// Position whiteSource = Position.of("d4"); -// Position blackSource = Position.of("d3"); -// Map entry = new HashMap<>(); -// entry.put(whiteSource, whitePawn); -// entry.put(blackSource, blackPawn); -// board = new Board(entry); - } - - @DisplayName("폰이 시작 위치일 때 1칸 또는 2칸 이동") - @Test - void moveAtInitialPosition() { - Piece whitePawn = new Piece(PieceType.PAWN, Team.WHITE); - Piece blackPawn = new Piece(PieceType.PAWN, Team.BLACK); - Position whiteInitial = Position.of("a2"); - Position blackInitial = Position.of("a7"); - Map emptyBoard = new HashMap<>(); - emptyBoard.put(whiteInitial, whitePawn); - emptyBoard.put(blackInitial, blackPawn); - Board board = new Board(emptyBoard); - - Position whiteOne = Position.of("a3"); - Position whiteTwo = Position.of("a4"); - Position blackOne = Position.of("a6"); - Position blackTwo = Position.of("a5"); - - Assertions.assertThat(pawnStrategy.movable(whiteInitial, whiteOne, board)).isTrue(); - Assertions.assertThat(pawnStrategy.movable(whiteInitial, whiteTwo, board)).isTrue(); - Assertions.assertThat(pawnStrategy.movable(blackInitial, blackOne, board)).isTrue(); - Assertions.assertThat(pawnStrategy.movable(blackInitial, blackTwo, board)).isTrue(); - } - - @DisplayName("폰이 시작 위치가 아닐 때 1칸 전진") - @Test - void moveAtNoneInitialPosition() { - Piece whitePawn = new Piece(PieceType.PAWN, Team.WHITE); - Piece blackPawn = new Piece(PieceType.PAWN, Team.BLACK); - Position whiteSource = Position.of("a3"); - Position blackSource = Position.of("a6"); - Map emptyBoard = new HashMap<>(); - emptyBoard.put(whiteSource, whitePawn); - emptyBoard.put(blackSource, blackPawn); - Board board = new Board(emptyBoard); - - Position upTarget = Position.of("a4"); - Position downTarget = Position.of("a5"); - - Assertions.assertThat(pawnStrategy.movable(whiteSource, upTarget, board)).isTrue(); - Assertions.assertThat(pawnStrategy.movable(blackSource, downTarget, board)).isTrue(); - } - - @DisplayName("폰이 시작 위치가 아닐 때 대각선의 적을 공격 가능") - @Test - void moveDiagonalTest() { - Piece whitePawn = new Piece(PieceType.PAWN, Team.WHITE); - Piece whiteLeftEnemy = new Piece(PieceType.PAWN, Team.BLACK); - Piece whiteRightEnemy = new Piece(PieceType.PAWN, Team.BLACK); - - Piece blackPawn = new Piece(PieceType.PAWN, Team.BLACK); - Piece blackLeftEnemy = new Piece(PieceType.PAWN, Team.WHITE); - Piece blackRightEnemy = new Piece(PieceType.PAWN, Team.WHITE); - - Position whiteSource = Position.of("d3"); - Position whiteDiagonalLeft = Position.of("c4"); - Position whiteDiagonalRight = Position.of("e4"); - - Position blackSource = Position.of("d6"); - Position blackDiagonalLeft = Position.of("c5"); - Position blackDiagonalRight = Position.of("e5"); - - Map entry = new HashMap<>(); - entry.put(whiteSource, whitePawn); - entry.put(whiteDiagonalLeft, whiteLeftEnemy); - entry.put(whiteDiagonalRight, whiteRightEnemy); - entry.put(blackSource, blackPawn); - entry.put(blackDiagonalLeft, blackLeftEnemy); - entry.put(blackDiagonalRight, blackRightEnemy); - Board board = new Board(entry); - - Assertions.assertThat(pawnStrategy.movable(whiteSource, whiteDiagonalLeft, board)).isTrue(); - Assertions.assertThat(pawnStrategy.movable(whiteSource, whiteDiagonalRight, board)).isTrue(); - Assertions.assertThat(pawnStrategy.movable(blackSource, blackDiagonalLeft, board)).isTrue(); - Assertions.assertThat(pawnStrategy.movable(blackSource, blackDiagonalRight, board)).isTrue(); - } -} diff --git a/src/test/java/chess/domain/strategy/move/QueenMoveStrategyTest.java b/src/test/java/chess/domain/strategy/move/QueenMoveStrategyTest.java deleted file mode 100644 index e1cc32da9fd..00000000000 --- a/src/test/java/chess/domain/strategy/move/QueenMoveStrategyTest.java +++ /dev/null @@ -1,113 +0,0 @@ -package chess.domain.strategy.move; - -import chess.domain.board.Board; -import chess.domain.piece.Piece; -import chess.domain.piece.PieceType; -import chess.domain.piece.Team; -import chess.domain.position.Position; -import org.assertj.core.api.Assertions; -import org.junit.jupiter.api.BeforeEach; -import org.junit.jupiter.api.DisplayName; -import org.junit.jupiter.api.Test; - -import java.util.HashMap; -import java.util.Map; - -public class QueenMoveStrategyTest { - private MoveStrategy queenStrategy; - private Board board; - - @BeforeEach - private void setUp() { - queenStrategy = new QueenMoveStrategy(); - Map emptyBoard = new HashMap<>(); - board = new Board(emptyBoard); - } - - @DisplayName("퀸의 우 상단 대각 이동") - @Test - void rightUpTest() { - Position source = Position.of("a1"); - Position target = Position.of("e5"); - - Assertions.assertThat(queenStrategy.movable(source, target, board)).isTrue(); - } - - @DisplayName("퀸의 우 하단 대각 이동") - @Test - void rightDownTest() { - Position source = Position.of("a7"); - Position target = Position.of("e3"); - - Assertions.assertThat(queenStrategy.movable(source, target, board)).isTrue(); - } - - @DisplayName("퀸의 좌 상단 대각 이동") - @Test - void leftUpTest() { - Position source = Position.of("g1"); - Position target = Position.of("c5"); - - Assertions.assertThat(queenStrategy.movable(source, target, board)).isTrue(); - } - - @DisplayName("퀸의 좌 하단 대각 이동") - @Test - void leftDownTest() { - Position source = Position.of("g7"); - Position target = Position.of("c3"); - - Assertions.assertThat(queenStrategy.movable(source, target, board)).isTrue(); - } - - @DisplayName("퀸의 상단 직진 이동") - @Test - void upTest() { - Position source = Position.of("a1"); - Position target = Position.of("a6"); - - Assertions.assertThat(queenStrategy.movable(source, target, board)).isTrue(); - } - - @DisplayName("퀸의 하단 직진 이동") - @Test - void downTest() { - Position source = Position.of("a6"); - Position target = Position.of("a1"); - - Assertions.assertThat(queenStrategy.movable(source, target, board)).isTrue(); - } - - @DisplayName("퀸의 우측 직진 이동") - @Test - void rightTest() { - Position source = Position.of("a1"); - Position target = Position.of("g1"); - - Assertions.assertThat(queenStrategy.movable(source, target, board)).isTrue(); - } - - @DisplayName("퀸의 좌측 직진 이동") - @Test - void leftTest() { - Position source = Position.of("g1"); - Position target = Position.of("a1"); - - Assertions.assertThat(queenStrategy.movable(source, target, board)).isTrue(); - } - - @DisplayName("타겟 위치에 적이 있을 때 이동") - @Test - void moveWhenEnemyTest() { - Piece queen = new Piece(PieceType.QUEEN, Team.BLACK); - Piece enemy = new Piece(PieceType.PAWN, Team.WHITE); - Position source = Position.of("a1"); - Position target = Position.of("a6"); - Map enemyEntry = new HashMap<>(); - enemyEntry.put(source, queen); - enemyEntry.put(target, enemy); - Board enemyBoard = new Board(enemyEntry); - - Assertions.assertThat(queenStrategy.movable(source, target, enemyBoard)).isTrue(); - } -} diff --git a/src/test/java/chess/domain/strategy/move/RookMoveStrategyTest.java b/src/test/java/chess/domain/strategy/move/RookMoveStrategyTest.java deleted file mode 100644 index bf977aa2c90..00000000000 --- a/src/test/java/chess/domain/strategy/move/RookMoveStrategyTest.java +++ /dev/null @@ -1,77 +0,0 @@ -package chess.domain.strategy.move; - -import chess.domain.board.Board; -import chess.domain.piece.Piece; -import chess.domain.piece.PieceType; -import chess.domain.piece.Team; -import chess.domain.position.Position; -import org.assertj.core.api.Assertions; -import org.junit.jupiter.api.BeforeEach; -import org.junit.jupiter.api.DisplayName; -import org.junit.jupiter.api.Test; - -import java.util.HashMap; -import java.util.Map; - -public class RookMoveStrategyTest { - private MoveStrategy rookStrategy; - private Board board; - - @BeforeEach - private void setUp() { - rookStrategy = new RookMoveStrategy(); - Map emptyBoard = new HashMap<>(); - board = new Board(emptyBoard); - } - - @DisplayName("룩의 상단 직진 이동") - @Test - void upTest() { - Position source = Position.of("a1"); - Position target = Position.of("a6"); - - Assertions.assertThat(rookStrategy.movable(source, target, board)).isTrue(); - } - - @DisplayName("룩의 하단 직진 이동") - @Test - void downTest() { - Position source = Position.of("a6"); - Position target = Position.of("a1"); - - Assertions.assertThat(rookStrategy.movable(source, target, board)).isTrue(); - } - - @DisplayName("룩의 우측 직진 이동") - @Test - void rightTest() { - Position source = Position.of("a1"); - Position target = Position.of("g1"); - - Assertions.assertThat(rookStrategy.movable(source, target, board)).isTrue(); - } - - @DisplayName("룩의 좌측 직진 이동") - @Test - void leftTest() { - Position source = Position.of("g1"); - Position target = Position.of("a1"); - - Assertions.assertThat(rookStrategy.movable(source, target, board)).isTrue(); - } - - @DisplayName("타겟 위치에 적이 있을 때 이동 테스트") - @Test - void moveWhenEnemyTest() { - Piece rook = new Piece(PieceType.ROOK, Team.BLACK); - Piece enemy = new Piece(PieceType.PAWN, Team.WHITE); - Position source = Position.of("a1"); - Position target = Position.of("a6"); - Map enemyEntry = new HashMap<>(); - enemyEntry.put(source, rook); - enemyEntry.put(target, enemy); - Board enemyBoard = new Board(enemyEntry); - - Assertions.assertThat(rookStrategy.movable(source, target, enemyBoard)).isTrue(); - } -} From 8888b082d88f14f068106b6afdffb044c69ac3bf Mon Sep 17 00:00:00 2001 From: giantim Date: Tue, 31 Mar 2020 23:00:24 +0900 Subject: [PATCH 26/75] =?UTF-8?q?refactor:=20Dto=20=EC=B6=94=EA=B0=80=20/?= =?UTF-8?q?=20ChessRunner=20=EC=97=90=EC=84=9C=20Dto=20=EC=97=90=20?= =?UTF-8?q?=EC=A0=81=ED=95=A9=ED=95=9C=20=EA=B0=92=EC=9D=84=20=EB=84=98?= =?UTF-8?q?=EA=B2=A8=EC=A3=BC=EB=8F=84=EB=A1=9D=20=EB=A9=94=EC=84=9C?= =?UTF-8?q?=EB=93=9C=20=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/main/java/chess/controller/EndController.java | 1 - src/main/java/chess/controller/GameController.java | 7 ++++--- src/main/java/chess/controller/MoveController.java | 2 +- .../java/chess/controller/StartController.java | 2 +- .../java/chess/controller/StatusController.java | 9 ++++++--- .../java/chess/controller/dto/BoardScoreDto.java | 13 +++++++++++++ src/main/java/chess/controller/dto/TeamDto.java | 13 +++++++++++++ src/main/java/chess/domain/ChessRunner.java | 14 ++++++++++---- src/main/java/chess/domain/board/BoardScore.java | 4 ++++ src/main/java/chess/domain/position/Position.java | 14 +++++++------- src/main/java/chess/view/ConsoleOutputView.java | 4 ++-- src/main/java/chess/view/OutputView.java | 2 +- src/test/java/chess/domain/board/BoardTest.java | 6 +++--- 13 files changed, 65 insertions(+), 26 deletions(-) create mode 100644 src/main/java/chess/controller/dto/BoardScoreDto.java create mode 100644 src/main/java/chess/controller/dto/TeamDto.java diff --git a/src/main/java/chess/controller/EndController.java b/src/main/java/chess/controller/EndController.java index 5447a5811c3..0beb80032d8 100644 --- a/src/main/java/chess/controller/EndController.java +++ b/src/main/java/chess/controller/EndController.java @@ -9,6 +9,5 @@ public EndController() { @Override public void execute(ChessRunner chessRunner, String input) { - return; } } diff --git a/src/main/java/chess/controller/GameController.java b/src/main/java/chess/controller/GameController.java index 1bab9902963..ce494b93043 100644 --- a/src/main/java/chess/controller/GameController.java +++ b/src/main/java/chess/controller/GameController.java @@ -3,11 +3,12 @@ import chess.controller.dto.BoardDto; import chess.controller.dto.PositionDto; import chess.domain.ChessRunner; -import chess.domain.board.Board; import chess.domain.position.Position; import chess.view.ConsoleOutputView; import chess.view.OutputView; +import java.util.Map; + public abstract class GameController { protected final OutputView outputView; @@ -15,8 +16,8 @@ public GameController() { this.outputView = new ConsoleOutputView(); } - protected void printBoard(final Board board) { - BoardDto boardDto = new BoardDto(board.parse()); + protected void printBoard(final Map board) { + BoardDto boardDto = new BoardDto(board); PositionDto positionDto = new PositionDto(Position.getPositions()); this.outputView.printBoard(positionDto.getPositions(), boardDto.get()); } diff --git a/src/main/java/chess/controller/MoveController.java b/src/main/java/chess/controller/MoveController.java index 5c13028fd18..4bc52b69329 100644 --- a/src/main/java/chess/controller/MoveController.java +++ b/src/main/java/chess/controller/MoveController.java @@ -22,6 +22,6 @@ public void execute(ChessRunner chessRunner, String input) { String source = commands[SOURCE_INDEX]; String target = commands[TARGET_INDEX]; chessRunner.update(source, target); - printBoard(chessRunner.getBoard()); + printBoard(chessRunner.getBoardEntities()); } } diff --git a/src/main/java/chess/controller/StartController.java b/src/main/java/chess/controller/StartController.java index 7ce8debfbac..d952290efec 100644 --- a/src/main/java/chess/controller/StartController.java +++ b/src/main/java/chess/controller/StartController.java @@ -9,6 +9,6 @@ public StartController() { @Override public void execute(ChessRunner chessRunner, String input) { - printBoard(chessRunner.getBoard()); + printBoard(chessRunner.getBoardEntities()); } } diff --git a/src/main/java/chess/controller/StatusController.java b/src/main/java/chess/controller/StatusController.java index c3443a15bc5..1b950eccbc9 100644 --- a/src/main/java/chess/controller/StatusController.java +++ b/src/main/java/chess/controller/StatusController.java @@ -1,5 +1,7 @@ package chess.controller; +import chess.controller.dto.BoardScoreDto; +import chess.controller.dto.TeamDto; import chess.domain.ChessRunner; public class StatusController extends GameController { @@ -9,8 +11,9 @@ public StatusController() { @Override public void execute(ChessRunner chessRunner, String input) { -// double score = chessRunner.calculateScore(); -// outputView.printStatus(score, chessRunner.getCurrentTeam()); - printBoard(chessRunner.getBoard()); + BoardScoreDto boardScoreDto = new BoardScoreDto(chessRunner.calculateScore()); + TeamDto teamDto = new TeamDto(chessRunner.getCurrentTeam()); + outputView.printStatus(boardScoreDto.getBoardScore(), teamDto.getTeamName()); + printBoard(chessRunner.getBoardEntities()); } } diff --git a/src/main/java/chess/controller/dto/BoardScoreDto.java b/src/main/java/chess/controller/dto/BoardScoreDto.java new file mode 100644 index 00000000000..d7e457a2076 --- /dev/null +++ b/src/main/java/chess/controller/dto/BoardScoreDto.java @@ -0,0 +1,13 @@ +package chess.controller.dto; + +public class BoardScoreDto { + private final double boardScore; + + public BoardScoreDto(double boardScore) { + this.boardScore = boardScore; + } + + public double getBoardScore() { + return boardScore; + } +} diff --git a/src/main/java/chess/controller/dto/TeamDto.java b/src/main/java/chess/controller/dto/TeamDto.java new file mode 100644 index 00000000000..073908e98f8 --- /dev/null +++ b/src/main/java/chess/controller/dto/TeamDto.java @@ -0,0 +1,13 @@ +package chess.controller.dto; + +public class TeamDto { + private final String teamName; + + public TeamDto(final String teamName) { + this.teamName = teamName; + } + + public String getTeamName() { + return teamName; + } +} diff --git a/src/main/java/chess/domain/ChessRunner.java b/src/main/java/chess/domain/ChessRunner.java index feebf2fdc9c..180715f61d4 100644 --- a/src/main/java/chess/domain/ChessRunner.java +++ b/src/main/java/chess/domain/ChessRunner.java @@ -8,6 +8,7 @@ import chess.domain.strategy.direction.Direction; import java.util.List; +import java.util.Map; public class ChessRunner { private Board board; @@ -86,12 +87,17 @@ public Team findWinner() { return this.board.checkWinner(); } - public BoardScore calculateScore() { - return board.calculateScore(this.currentTeam); + public double calculateScore() { + BoardScore boardScore = this.board.calculateScore(this.currentTeam); + return boardScore.getBoardScore(); } - public Team getCurrentTeam() { - return this.currentTeam; + public Map getBoardEntities() { + return this.board.parse(); + } + + public String getCurrentTeam() { + return this.currentTeam.name(); } public Board getBoard() { diff --git a/src/main/java/chess/domain/board/BoardScore.java b/src/main/java/chess/domain/board/BoardScore.java index 9525bd8ec69..fc46c94ffba 100644 --- a/src/main/java/chess/domain/board/BoardScore.java +++ b/src/main/java/chess/domain/board/BoardScore.java @@ -23,4 +23,8 @@ public BoardScore pawnStrategy(List> sameFilePawns) { } return this; } + + public double getBoardScore() { + return this.boardScore; + } } diff --git a/src/main/java/chess/domain/position/Position.java b/src/main/java/chess/domain/position/Position.java index 4ba4ddb7fd5..f0794eb275e 100644 --- a/src/main/java/chess/domain/position/Position.java +++ b/src/main/java/chess/domain/position/Position.java @@ -52,13 +52,6 @@ public static Position of(final int fileSymbol, final int rankSymbol) { return findPosition(File.of(fileSymbol), Rank.of(rankSymbol)); } - public static List getPositions() { - List parseResult = positions.stream() - .map(Position::toString) - .collect(Collectors.toList()); - return Collections.unmodifiableList(parseResult); - } - public int calculateFileGap(final Position target) { return this.file.compareTo(target.file); } @@ -67,6 +60,13 @@ public int calculateRankGap(final Position target) { return this.rank.getDifference(target.rank); } + public static List getPositions() { + List parseResult = positions.stream() + .map(Position::toString) + .collect(Collectors.toList()); + return Collections.unmodifiableList(parseResult); + } + public int getFile() { return this.file.getNumber(); } diff --git a/src/main/java/chess/view/ConsoleOutputView.java b/src/main/java/chess/view/ConsoleOutputView.java index b0cc85985cd..8aac91e3d1b 100644 --- a/src/main/java/chess/view/ConsoleOutputView.java +++ b/src/main/java/chess/view/ConsoleOutputView.java @@ -33,8 +33,8 @@ private String printPiece(String piece) { } @Override - public void printStatus(double calculateScore, Team team) { - System.out.println(String.format("%s 팀의 점수는 %.1f 점입니다.", team.name(), calculateScore)); + public void printStatus(double calculateScore, String teamName) { + System.out.println(String.format("%s 팀의 점수는 %.1f 점입니다.", teamName, calculateScore)); } @Override diff --git a/src/main/java/chess/view/OutputView.java b/src/main/java/chess/view/OutputView.java index 5869d4291fd..2a2d3c2b96c 100644 --- a/src/main/java/chess/view/OutputView.java +++ b/src/main/java/chess/view/OutputView.java @@ -8,7 +8,7 @@ public interface OutputView { void printBoard(List positions, Map board); - void printStatus(double calculateScore, Team team); + void printStatus(double calculateScore, String teamName); void printWinner(Team team); } diff --git a/src/test/java/chess/domain/board/BoardTest.java b/src/test/java/chess/domain/board/BoardTest.java index f932e6b1a32..f8bfd051ce5 100644 --- a/src/test/java/chess/domain/board/BoardTest.java +++ b/src/test/java/chess/domain/board/BoardTest.java @@ -92,8 +92,8 @@ void getPieceTest() { void calculateScoreWithoutSameFilePawnTest() { Board board = new Board(); - Assertions.assertThat(board.calculateScore(Team.WHITE)).extracting("boardScore").isEqualTo(38d); - Assertions.assertThat(board.calculateScore(Team.BLACK)).extracting("boardScore").isEqualTo(38d); + Assertions.assertThat(board.calculateScore(Team.WHITE).getBoardScore()).isEqualTo(38d); + Assertions.assertThat(board.calculateScore(Team.BLACK).getBoardScore()).isEqualTo(38d); } @DisplayName("같은 세로줄에 폰이 있을 때 점수 계산") @@ -105,6 +105,6 @@ void calculateScoreWithSameFilePawn() { sameFilePawn.put(Position.of("a5"), new Pawn(PieceType.PAWN, Team.WHITE)); Board board = new Board(sameFilePawn); - Assertions.assertThat(board.calculateScore(Team.WHITE)).extracting("boardScore").isEqualTo(1.5d); + Assertions.assertThat(board.calculateScore(Team.WHITE).getBoardScore()).isEqualTo(1.5d); } } From 08cbd7398bdad36ea8d4bbb319abc0cc59a52885 Mon Sep 17 00:00:00 2001 From: giantim Date: Tue, 31 Mar 2020 23:47:56 +0900 Subject: [PATCH 27/75] =?UTF-8?q?refactor:=20=EA=B2=8C=EC=9E=84=20?= =?UTF-8?q?=EC=A2=85=EB=A3=8C=20=EA=B2=BD=EC=9A=B0=EC=97=90=20=EB=94=B0?= =?UTF-8?q?=EB=9D=BC=20=EC=A0=90=EC=88=98=20=EC=B6=9C=EB=A0=A5=20=EB=A1=9C?= =?UTF-8?q?=EC=A7=81=20=EA=B5=AC=ED=98=84=20/=20=EA=B0=9D=EC=B2=B4=20null?= =?UTF-8?q?=20=EB=B0=98=ED=99=98=EC=9D=84=20Optional=20=EC=9D=84=20?= =?UTF-8?q?=EC=9D=B4=EC=9A=A9=ED=95=98=EB=8F=84=EB=A1=9D=20=EB=B3=80?= =?UTF-8?q?=EA=B2=BD=20/=20=EA=B0=81=20=EC=B2=B4=EC=8A=A4=20=EB=A7=90?= =?UTF-8?q?=EC=9D=84=20=EC=B4=88=EA=B8=B0=ED=99=94=20=ED=95=A0=EB=95=8C?= =?UTF-8?q?=EC=9D=98=20=EC=A0=95=EB=B3=B4=EB=A5=BC=20enum=20=EC=9C=BC?= =?UTF-8?q?=EB=A1=9C=20=EA=B5=AC=ED=98=84?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../chess/controller/ChessController.java | 15 +++-- src/main/java/chess/domain/ChessRunner.java | 18 +++--- src/main/java/chess/domain/board/Board.java | 13 ++--- .../initialize/BishopInitializer.java | 32 +++++++--- .../strategy/initialize/KingInitializer.java | 28 +++++++-- .../initialize/KnightInitializer.java | 32 +++++++--- .../strategy/initialize/PawnInitializer.java | 58 ++++++++++++------- .../strategy/initialize/QueenInitializer.java | 28 +++++++-- .../strategy/initialize/RookInitializer.java | 32 +++++++--- .../java/chess/view/ConsoleOutputView.java | 6 +- src/main/java/chess/view/OutputView.java | 4 +- .../java/chess/domain/board/BoardTest.java | 9 ++- 12 files changed, 190 insertions(+), 85 deletions(-) diff --git a/src/main/java/chess/controller/ChessController.java b/src/main/java/chess/controller/ChessController.java index 0c45cd5ad61..f5bb64d8294 100644 --- a/src/main/java/chess/controller/ChessController.java +++ b/src/main/java/chess/controller/ChessController.java @@ -1,7 +1,7 @@ package chess.controller; +import chess.controller.dto.TeamDto; import chess.domain.ChessRunner; -import chess.domain.piece.Team; import chess.view.ConsoleInputView; import chess.view.ConsoleOutputView; import chess.view.InputView; @@ -26,7 +26,8 @@ public static void start() { private static void runChessGame(Command command, ChessRunner chessRunner) { do { command = validateExecute(command, chessRunner); - } while (!command.isEnd() && findWinner(chessRunner)); + } while (!command.isEnd() && !chessRunner.isEndChess()); + printWinner(chessRunner); } private static Command validateExecute(Command command, ChessRunner chessRunner) { @@ -41,12 +42,10 @@ private static Command validateExecute(Command command, ChessRunner chessRunner) return command; } - private static boolean findWinner(final ChessRunner chessRunner) { - Team winner = chessRunner.findWinner(); - if (winner != null) { - outputView.printWinner(winner); - return false; + private static void printWinner(ChessRunner chessRunner) { + if (chessRunner.isEndChess()) { + TeamDto teamDto = new TeamDto(chessRunner.getWinner()); + outputView.printWinner(teamDto.getTeamName()); } - return true; } } diff --git a/src/main/java/chess/domain/ChessRunner.java b/src/main/java/chess/domain/ChessRunner.java index 180715f61d4..4652a0e677b 100644 --- a/src/main/java/chess/domain/ChessRunner.java +++ b/src/main/java/chess/domain/ChessRunner.java @@ -9,6 +9,7 @@ import java.util.List; import java.util.Map; +import java.util.Optional; public class ChessRunner { private Board board; @@ -50,7 +51,7 @@ private void checkUpdateBoard(Position sourcePosition, Position targetPosition, throw new IllegalArgumentException("경로 사이에 장애물이 있습니다."); } - if (!movableTarget(sourcePiece, targetPosition)) { + if (!isMovableTarget(sourcePiece, targetPosition)) { throw new IllegalArgumentException("목적지가 잘못되었습니다."); } } @@ -70,7 +71,7 @@ private boolean isEmptyPath(final Position sourcePosition, final Position target .allMatch(this.board::isEmpty); } - private boolean movableTarget(final Piece sourcePiece, final Position targetPosition) { + private boolean isMovableTarget(final Piece sourcePiece, final Position targetPosition) { Piece targetPiece = this.board.getPiece(targetPosition); return sourcePiece.isEnemy(targetPiece); } @@ -83,15 +84,15 @@ private void changeTeam() { this.currentTeam = this.currentTeam.changeTeam(); } - public Team findWinner() { - return this.board.checkWinner(); - } - public double calculateScore() { BoardScore boardScore = this.board.calculateScore(this.currentTeam); return boardScore.getBoardScore(); } + public boolean isEndChess() { + return this.board.getWinner().isPresent(); + } + public Map getBoardEntities() { return this.board.parse(); } @@ -100,7 +101,8 @@ public String getCurrentTeam() { return this.currentTeam.name(); } - public Board getBoard() { - return this.board; + public String getWinner() { + Optional winner = this.board.getWinner(); + return winner.map(Enum::name).orElseThrow(AssertionError::new); } } diff --git a/src/main/java/chess/domain/board/Board.java b/src/main/java/chess/domain/board/Board.java index 53188c00728..13ef182755a 100644 --- a/src/main/java/chess/domain/board/Board.java +++ b/src/main/java/chess/domain/board/Board.java @@ -5,10 +5,7 @@ import chess.domain.position.File; import chess.domain.position.Position; -import java.util.Collections; -import java.util.LinkedHashMap; -import java.util.List; -import java.util.Map; +import java.util.*; import java.util.stream.Collectors; public class Board { @@ -53,14 +50,14 @@ private BoardScore calculatePawnScore(final Team team, BoardScore totalScore) { return totalScore; } - public Team checkWinner() { + public Optional getWinner() { if (checkWhiteKing() && !checkBlackKing()) { - return Team.WHITE; + return Optional.of(Team.WHITE); } if (!checkWhiteKing() && checkBlackKing()) { - return Team.BLACK; + return Optional.of(Team.BLACK); } - return null; + return Optional.empty(); } private boolean checkWhiteKing() { diff --git a/src/main/java/chess/domain/strategy/initialize/BishopInitializer.java b/src/main/java/chess/domain/strategy/initialize/BishopInitializer.java index 59fdbc8d981..de5017b6892 100644 --- a/src/main/java/chess/domain/strategy/initialize/BishopInitializer.java +++ b/src/main/java/chess/domain/strategy/initialize/BishopInitializer.java @@ -6,19 +6,37 @@ import chess.domain.piece.Team; import chess.domain.position.Position; +import java.util.Arrays; import java.util.Collections; import java.util.HashMap; import java.util.Map; +import java.util.stream.Collectors; public final class BishopInitializer implements InitializeStrategy { + private enum InitialBishop { + BLACK_LEFT(Position.of("c8"), new Bishop(PieceType.BISHOP, Team.BLACK)), + BLACK_RIGHT(Position.of("f8"), new Bishop(PieceType.BISHOP, Team.BLACK)), + WHITE_LEFT(Position.of("c1"), new Bishop(PieceType.BISHOP, Team.WHITE)), + WHITE_RIGHT(Position.of("f1"), new Bishop(PieceType.BISHOP, Team.WHITE)); + + private final Position position; + private final Piece piece; + + InitialBishop(Position position, Piece piece) { + this.position = position; + this.piece = piece; + } + + public static Map initializeBishops() { + Map bishops = Arrays.stream(values()) + .collect(Collectors.toMap(entry -> entry.position, entry -> entry.piece, + (e1, e2) -> e1, HashMap::new)); + return Collections.unmodifiableMap(bishops); + } + } + @Override public Map initialize() { - Map pieces = new HashMap<>(); - pieces.put(Position.of("c8"), new Bishop(PieceType.BISHOP, Team.BLACK)); - pieces.put(Position.of("c1"), new Bishop(PieceType.BISHOP, Team.WHITE)); - pieces.put(Position.of("f8"), new Bishop(PieceType.BISHOP, Team.BLACK)); - pieces.put(Position.of("f1"), new Bishop(PieceType.BISHOP, Team.WHITE)); - - return Collections.unmodifiableMap(pieces); + return InitialBishop.initializeBishops(); } } \ No newline at end of file diff --git a/src/main/java/chess/domain/strategy/initialize/KingInitializer.java b/src/main/java/chess/domain/strategy/initialize/KingInitializer.java index 598495e1f75..caec8420870 100644 --- a/src/main/java/chess/domain/strategy/initialize/KingInitializer.java +++ b/src/main/java/chess/domain/strategy/initialize/KingInitializer.java @@ -6,17 +6,35 @@ import chess.domain.piece.Team; import chess.domain.position.Position; +import java.util.Arrays; import java.util.Collections; import java.util.HashMap; import java.util.Map; +import java.util.stream.Collectors; public final class KingInitializer implements InitializeStrategy { + private enum InitialKing { + BLACK_KING(Position.of("e8"), new King(PieceType.KING, Team.BLACK)), + WHITE_KING(Position.of("e1"), new King(PieceType.KING, Team.WHITE)); + + private final Position position; + private final Piece piece; + + InitialKing(Position position, Piece piece) { + this.position = position; + this.piece = piece; + } + + public static Map initializeKings() { + Map kings = Arrays.stream(values()) + .collect(Collectors.toMap(entry -> entry.position, entry -> entry.piece, + (e1, e2) -> e1, HashMap::new)); + return Collections.unmodifiableMap(kings); + } + } + @Override public Map initialize() { - Map pieces = new HashMap<>(); - pieces.put(Position.of("e8"), new King(PieceType.KING, Team.BLACK)); - pieces.put(Position.of("e1"), new King(PieceType.KING, Team.WHITE)); - - return Collections.unmodifiableMap(pieces); + return InitialKing.initializeKings(); } } diff --git a/src/main/java/chess/domain/strategy/initialize/KnightInitializer.java b/src/main/java/chess/domain/strategy/initialize/KnightInitializer.java index d2863dde2e1..fa95bb0823d 100644 --- a/src/main/java/chess/domain/strategy/initialize/KnightInitializer.java +++ b/src/main/java/chess/domain/strategy/initialize/KnightInitializer.java @@ -6,19 +6,37 @@ import chess.domain.piece.Team; import chess.domain.position.Position; +import java.util.Arrays; import java.util.Collections; import java.util.HashMap; import java.util.Map; +import java.util.stream.Collectors; public final class KnightInitializer implements InitializeStrategy { + private enum InitialKnight { + BLACK_LEFT(Position.of("b8"), new Knight(PieceType.KNIGHT, Team.BLACK)), + BLACK_RIGHT(Position.of("g8"), new Knight(PieceType.KNIGHT, Team.BLACK)), + WHITE_LEFT(Position.of("b1"), new Knight(PieceType.KNIGHT, Team.WHITE)), + WHITE_RIGHT(Position.of("g1"), new Knight(PieceType.KNIGHT, Team.WHITE)); + + private final Position position; + private final Piece piece; + + InitialKnight(Position position, Piece piece) { + this.position = position; + this.piece = piece; + } + + public static Map initializeKnights() { + Map knights = Arrays.stream(values()) + .collect(Collectors.toMap(entry -> entry.position, entry -> entry.piece, + (e1, e2) -> e1, HashMap::new)); + return Collections.unmodifiableMap(knights); + } + } + @Override public Map initialize() { - Map pieces = new HashMap<>(); - pieces.put(Position.of("b8"), new Knight(PieceType.KNIGHT, Team.BLACK)); - pieces.put(Position.of("b1"), new Knight(PieceType.KNIGHT, Team.WHITE)); - pieces.put(Position.of("g8"), new Knight(PieceType.KNIGHT, Team.BLACK)); - pieces.put(Position.of("g1"), new Knight(PieceType.KNIGHT, Team.WHITE)); - - return Collections.unmodifiableMap(pieces); + return InitialKnight.initializeKnights(); } } \ No newline at end of file diff --git a/src/main/java/chess/domain/strategy/initialize/PawnInitializer.java b/src/main/java/chess/domain/strategy/initialize/PawnInitializer.java index e9296b8bc57..523acea9c0a 100644 --- a/src/main/java/chess/domain/strategy/initialize/PawnInitializer.java +++ b/src/main/java/chess/domain/strategy/initialize/PawnInitializer.java @@ -6,32 +6,50 @@ import chess.domain.piece.Team; import chess.domain.position.Position; +import java.util.Arrays; import java.util.Collections; import java.util.HashMap; import java.util.Map; +import java.util.stream.Collectors; public final class PawnInitializer implements InitializeStrategy { + private enum InitialPawn { + BLACK_A7(Position.of("a7"), new Pawn(PieceType.PAWN, Team.BLACK)), + BLACK_B7(Position.of("b7"), new Pawn(PieceType.PAWN, Team.BLACK)), + BLACK_C7(Position.of("c7"), new Pawn(PieceType.PAWN, Team.BLACK)), + BLACK_D7(Position.of("d7"), new Pawn(PieceType.PAWN, Team.BLACK)), + BLACK_E7(Position.of("e7"), new Pawn(PieceType.PAWN, Team.BLACK)), + BLACK_F7(Position.of("f7"), new Pawn(PieceType.PAWN, Team.BLACK)), + BLACK_G7(Position.of("g7"), new Pawn(PieceType.PAWN, Team.BLACK)), + BLACK_H7(Position.of("h7"), new Pawn(PieceType.PAWN, Team.BLACK)), + + WHITE_A2(Position.of("a2"), new Pawn(PieceType.PAWN, Team.WHITE)), + WHITE_B2(Position.of("b2"), new Pawn(PieceType.PAWN, Team.WHITE)), + WHITE_C2(Position.of("c2"), new Pawn(PieceType.PAWN, Team.WHITE)), + WHITE_D2(Position.of("d2"), new Pawn(PieceType.PAWN, Team.WHITE)), + WHITE_E2(Position.of("e2"), new Pawn(PieceType.PAWN, Team.WHITE)), + WHITE_F2(Position.of("f2"), new Pawn(PieceType.PAWN, Team.WHITE)), + WHITE_G2(Position.of("g2"), new Pawn(PieceType.PAWN, Team.WHITE)), + WHITE_H2(Position.of("h2"), new Pawn(PieceType.PAWN, Team.WHITE)); + + private final Position position; + private final Piece piece; + + InitialPawn(Position position, Piece piece) { + this.position = position; + this.piece = piece; + } + + public static Map initialPawns() { + Map pawns = Arrays.stream(values()) + .collect(Collectors.toMap(entry -> entry.position, entry -> entry.piece, + (e1, e2) -> e1, HashMap::new)); + return Collections.unmodifiableMap(pawns); + } + } + @Override public Map initialize() { - Map pieces = new HashMap<>(); - pieces.put(Position.of("a7"), new Pawn(PieceType.PAWN, Team.BLACK)); - pieces.put(Position.of("b7"), new Pawn(PieceType.PAWN, Team.BLACK)); - pieces.put(Position.of("c7"), new Pawn(PieceType.PAWN, Team.BLACK)); - pieces.put(Position.of("d7"), new Pawn(PieceType.PAWN, Team.BLACK)); - pieces.put(Position.of("e7"), new Pawn(PieceType.PAWN, Team.BLACK)); - pieces.put(Position.of("f7"), new Pawn(PieceType.PAWN, Team.BLACK)); - pieces.put(Position.of("g7"), new Pawn(PieceType.PAWN, Team.BLACK)); - pieces.put(Position.of("h7"), new Pawn(PieceType.PAWN, Team.BLACK)); - - pieces.put(Position.of("a2"), new Pawn(PieceType.PAWN, Team.WHITE)); - pieces.put(Position.of("b2"), new Pawn(PieceType.PAWN, Team.WHITE)); - pieces.put(Position.of("c2"), new Pawn(PieceType.PAWN, Team.WHITE)); - pieces.put(Position.of("d2"), new Pawn(PieceType.PAWN, Team.WHITE)); - pieces.put(Position.of("e2"), new Pawn(PieceType.PAWN, Team.WHITE)); - pieces.put(Position.of("f2"), new Pawn(PieceType.PAWN, Team.WHITE)); - pieces.put(Position.of("g2"), new Pawn(PieceType.PAWN, Team.WHITE)); - pieces.put(Position.of("h2"), new Pawn(PieceType.PAWN, Team.WHITE)); - - return Collections.unmodifiableMap(pieces); + return InitialPawn.initialPawns(); } } diff --git a/src/main/java/chess/domain/strategy/initialize/QueenInitializer.java b/src/main/java/chess/domain/strategy/initialize/QueenInitializer.java index 64ea4cfc49d..e23871b6bd9 100644 --- a/src/main/java/chess/domain/strategy/initialize/QueenInitializer.java +++ b/src/main/java/chess/domain/strategy/initialize/QueenInitializer.java @@ -6,17 +6,35 @@ import chess.domain.piece.Team; import chess.domain.position.Position; +import java.util.Arrays; import java.util.Collections; import java.util.HashMap; import java.util.Map; +import java.util.stream.Collectors; public final class QueenInitializer implements InitializeStrategy { + private enum InitialQueen { + BLACK_QUEEN(Position.of("d8"), new Queen(PieceType.QUEEN, Team.BLACK)), + WHITE_QUEEN(Position.of("d1"), new Queen(PieceType.QUEEN, Team.WHITE)); + + private final Position position; + private final Piece piece; + + InitialQueen(Position position, Piece piece) { + this.position = position; + this.piece = piece; + } + + public static Map initializeQueens() { + Map queens = Arrays.stream(values()) + .collect(Collectors.toMap(entry -> entry.position, entry -> entry.piece, + (e1, e2) -> e1, HashMap::new)); + return Collections.unmodifiableMap(queens); + } + } + @Override public Map initialize() { - Map pieces = new HashMap<>(); - pieces.put(Position.of("d8"), new Queen(PieceType.QUEEN, Team.BLACK)); - pieces.put(Position.of("d1"), new Queen(PieceType.QUEEN, Team.WHITE)); - - return Collections.unmodifiableMap(pieces); + return InitialQueen.initializeQueens(); } } \ No newline at end of file diff --git a/src/main/java/chess/domain/strategy/initialize/RookInitializer.java b/src/main/java/chess/domain/strategy/initialize/RookInitializer.java index efcfbe69b8f..8b351c3088d 100644 --- a/src/main/java/chess/domain/strategy/initialize/RookInitializer.java +++ b/src/main/java/chess/domain/strategy/initialize/RookInitializer.java @@ -6,19 +6,37 @@ import chess.domain.piece.Team; import chess.domain.position.Position; +import java.util.Arrays; import java.util.Collections; import java.util.HashMap; import java.util.Map; +import java.util.stream.Collectors; public final class RookInitializer implements InitializeStrategy { + private enum InitialRook { + BLACK_LEFT(Position.of("a8"), new Rook(PieceType.ROOK, Team.BLACK)), + BLACK_RIGHT(Position.of("h8"), new Rook(PieceType.ROOK, Team.BLACK)), + WHITE_LEFT(Position.of("a1"), new Rook(PieceType.ROOK, Team.WHITE)), + WHITE_RIGHT(Position.of("h1"), new Rook(PieceType.ROOK, Team.WHITE)); + + private final Position position; + private final Piece piece; + + InitialRook(Position position, Piece piece) { + this.position = position; + this.piece = piece; + } + + public static Map initializeRooks() { + Map rooks = Arrays.stream(values()) + .collect(Collectors.toMap(entry -> entry.position, entry -> entry.piece, + (e1, e2) -> e1, HashMap::new)); + return Collections.unmodifiableMap(rooks); + } + } + @Override public Map initialize() { - Map pieces = new HashMap<>(); - pieces.put(Position.of("a8"), new Rook(PieceType.ROOK, Team.BLACK)); - pieces.put(Position.of("a1"), new Rook(PieceType.ROOK, Team.WHITE)); - pieces.put(Position.of("h8"), new Rook(PieceType.ROOK, Team.BLACK)); - pieces.put(Position.of("h1"), new Rook(PieceType.ROOK, Team.WHITE)); - - return Collections.unmodifiableMap(pieces); + return InitialRook.initializeRooks(); } } \ No newline at end of file diff --git a/src/main/java/chess/view/ConsoleOutputView.java b/src/main/java/chess/view/ConsoleOutputView.java index 8aac91e3d1b..b85b029b013 100644 --- a/src/main/java/chess/view/ConsoleOutputView.java +++ b/src/main/java/chess/view/ConsoleOutputView.java @@ -1,7 +1,5 @@ package chess.view; -import chess.domain.piece.Team; - import java.util.List; import java.util.Map; @@ -38,7 +36,7 @@ public void printStatus(double calculateScore, String teamName) { } @Override - public void printWinner(Team team) { - System.out.println(String.format("%s 팀이 이겼습니다.", team.name())); + public void printWinner(String teamName) { + System.out.println(String.format("%s 팀이 이겼습니다.", teamName)); } } diff --git a/src/main/java/chess/view/OutputView.java b/src/main/java/chess/view/OutputView.java index 2a2d3c2b96c..155d5eaca09 100644 --- a/src/main/java/chess/view/OutputView.java +++ b/src/main/java/chess/view/OutputView.java @@ -1,7 +1,5 @@ package chess.view; -import chess.domain.piece.Team; - import java.util.List; import java.util.Map; @@ -10,5 +8,5 @@ public interface OutputView { void printStatus(double calculateScore, String teamName); - void printWinner(Team team); + void printWinner(String teamName); } diff --git a/src/test/java/chess/domain/board/BoardTest.java b/src/test/java/chess/domain/board/BoardTest.java index f8bfd051ce5..c1cb9c4df07 100644 --- a/src/test/java/chess/domain/board/BoardTest.java +++ b/src/test/java/chess/domain/board/BoardTest.java @@ -8,6 +8,7 @@ import java.util.HashMap; import java.util.Map; +import java.util.NoSuchElementException; public class BoardTest { @DisplayName("빈 칸으로 말 이동") @@ -60,9 +61,11 @@ void checkWinnerTest() { bothKing.put(Position.of("b7"), new King(PieceType.KING, Team.WHITE)); Board drawBoard = new Board(bothKing); - Assertions.assertThat(whiteWinBoard.checkWinner()).isEqualTo(Team.WHITE); - Assertions.assertThat(blackWinBoard.checkWinner()).isEqualTo(Team.BLACK); - Assertions.assertThat(drawBoard.checkWinner()).isNull(); + Assertions.assertThat(whiteWinBoard.getWinner().get()).isEqualTo(Team.WHITE); + Assertions.assertThat(blackWinBoard.getWinner().get()).isEqualTo(Team.BLACK); + Assertions.assertThatThrownBy(() -> { + drawBoard.getWinner().get(); + }).isInstanceOf(NoSuchElementException.class); } @DisplayName("지정한 칸이 비어있는지 판단") From bdf1a0a509de22b62819536e3fdacadbd303ba6c Mon Sep 17 00:00:00 2001 From: giantim Date: Wed, 1 Apr 2020 11:23:22 +0900 Subject: [PATCH 28/75] =?UTF-8?q?refactor:=20=EC=88=98=EC=A0=95=ED=95=9C?= =?UTF-8?q?=20=ED=81=B4=EB=9E=98=EC=8A=A4=EC=97=90=20=EB=A7=9E=EA=B2=8C=20?= =?UTF-8?q?=ED=85=8C=EC=8A=A4=ED=8A=B8=20=EC=BD=94=EB=93=9C=20=EC=B6=94?= =?UTF-8?q?=EA=B0=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/main/java/chess/domain/piece/Queen.java | 2 +- .../java/chess/domain/ChessRunnerTest.java | 21 ++++++++ .../chess/domain/board/BoardScoreTest.java | 28 ++++++++++ .../java/chess/domain/piece/BishopTest.java | 20 +++++++ .../java/chess/domain/piece/KingTest.java | 20 +++++++ .../java/chess/domain/piece/KnightTest.java | 20 +++++++ .../java/chess/domain/piece/PawnTest.java | 54 +++++++++++++++++++ .../java/chess/domain/piece/PieceTest.java | 5 ++ .../java/chess/domain/piece/QueenTest.java | 22 ++++++++ .../java/chess/domain/piece/RookTest.java | 20 +++++++ 10 files changed, 211 insertions(+), 1 deletion(-) create mode 100644 src/test/java/chess/domain/board/BoardScoreTest.java create mode 100644 src/test/java/chess/domain/piece/BishopTest.java create mode 100644 src/test/java/chess/domain/piece/KingTest.java create mode 100644 src/test/java/chess/domain/piece/KnightTest.java create mode 100644 src/test/java/chess/domain/piece/PawnTest.java create mode 100644 src/test/java/chess/domain/piece/QueenTest.java create mode 100644 src/test/java/chess/domain/piece/RookTest.java diff --git a/src/main/java/chess/domain/piece/Queen.java b/src/main/java/chess/domain/piece/Queen.java index c7379c01f75..ca246843c48 100644 --- a/src/main/java/chess/domain/piece/Queen.java +++ b/src/main/java/chess/domain/piece/Queen.java @@ -10,6 +10,6 @@ public Queen(PieceType pieceType, Team team) { @Override public boolean movable(Position source, Position target) { return new Rook(this.pieceType, this.team).movable(source, target) - && new Bishop(this.pieceType, this.team).movable(source, target); + || new Bishop(this.pieceType, this.team).movable(source, target); } } diff --git a/src/test/java/chess/domain/ChessRunnerTest.java b/src/test/java/chess/domain/ChessRunnerTest.java index e311062b9ee..2bc1178c4c6 100644 --- a/src/test/java/chess/domain/ChessRunnerTest.java +++ b/src/test/java/chess/domain/ChessRunnerTest.java @@ -4,6 +4,7 @@ import org.junit.jupiter.api.DisplayName; import org.junit.jupiter.api.Test; +import static org.assertj.core.api.Assertions.assertThat; import static org.assertj.core.api.Assertions.assertThatThrownBy; class ChessRunnerTest { @@ -53,4 +54,24 @@ void validateTarget() { .isInstanceOf(IllegalArgumentException.class) .hasMessage("목적지가 잘못되었습니다."); } + + @DisplayName("점수 계산 테스트") + @Test + void calculateScoreTest() { + assertThat(chessRunner.calculateScore()).isEqualTo(38d); + } + + @DisplayName("게임이 종료되었는지 검사") + @Test + void isEndChessTest() { + assertThat(chessRunner.isEndChess()).isFalse(); + } + + @DisplayName("게임이 종료되지 않았을 때 승자를 출력 시 예외 출력") + @Test + void getWinnerTest() { + assertThatThrownBy(() -> { + chessRunner.getWinner(); + }).isInstanceOf(AssertionError.class); + } } \ No newline at end of file diff --git a/src/test/java/chess/domain/board/BoardScoreTest.java b/src/test/java/chess/domain/board/BoardScoreTest.java new file mode 100644 index 00000000000..f7528351431 --- /dev/null +++ b/src/test/java/chess/domain/board/BoardScoreTest.java @@ -0,0 +1,28 @@ +package chess.domain.board; + +import chess.domain.piece.Pawn; +import chess.domain.piece.Piece; +import chess.domain.piece.PieceType; +import chess.domain.piece.Team; +import chess.domain.position.Position; +import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; + +import java.util.*; + +public class BoardScoreTest { + @DisplayName("같은 파일에 폰이 있을 때 점수 계산") + @Test + void pawnStrategyTest() { + List> sameFilePawns = new ArrayList<>(Arrays.asList( + new AbstractMap.SimpleEntry<>(Position.of("a3"), new Pawn(PieceType.PAWN, Team.WHITE)), + new AbstractMap.SimpleEntry<>(Position.of("a4"), new Pawn(PieceType.PAWN, Team.WHITE)), + new AbstractMap.SimpleEntry<>(Position.of("a5"), new Pawn(PieceType.PAWN, Team.WHITE)) + )); + + BoardScore boardScore = new BoardScore(10d); + + Assertions.assertThat(boardScore.pawnStrategy(sameFilePawns).getBoardScore()).isEqualTo(8.5); + } +} diff --git a/src/test/java/chess/domain/piece/BishopTest.java b/src/test/java/chess/domain/piece/BishopTest.java new file mode 100644 index 00000000000..e063194bd80 --- /dev/null +++ b/src/test/java/chess/domain/piece/BishopTest.java @@ -0,0 +1,20 @@ +package chess.domain.piece; + +import chess.domain.position.Position; +import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; + +public class BishopTest { + @DisplayName("비숍이 이동 가능한 곳인지 검사") + @Test + void movableTest() { + Piece bishop = new Bishop(PieceType.BISHOP, Team.WHITE); + Position source = Position.of("d4"); + Position movableTarget = Position.of("f6"); + Position nonMovableTarget = Position.of("d5"); + + Assertions.assertThat(bishop.movable(source, movableTarget)).isTrue(); + Assertions.assertThat(bishop.movable(source, nonMovableTarget)).isFalse(); + } +} diff --git a/src/test/java/chess/domain/piece/KingTest.java b/src/test/java/chess/domain/piece/KingTest.java new file mode 100644 index 00000000000..f621c911470 --- /dev/null +++ b/src/test/java/chess/domain/piece/KingTest.java @@ -0,0 +1,20 @@ +package chess.domain.piece; + +import chess.domain.position.Position; +import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; + +public class KingTest { + @DisplayName("킹이 이동 가능한 곳인지 검사") + @Test + void movableTest() { + Piece king = new King(PieceType.KING, Team.BLACK); + Position source = Position.of("d4"); + Position movableTarget = Position.of("d5"); + Position nonMovableTarget = Position.of("c7"); + + Assertions.assertThat(king.movable(source, movableTarget)).isTrue(); + Assertions.assertThat(king.movable(source, nonMovableTarget)).isFalse(); + } +} diff --git a/src/test/java/chess/domain/piece/KnightTest.java b/src/test/java/chess/domain/piece/KnightTest.java new file mode 100644 index 00000000000..24ac2b7bd85 --- /dev/null +++ b/src/test/java/chess/domain/piece/KnightTest.java @@ -0,0 +1,20 @@ +package chess.domain.piece; + +import chess.domain.position.Position; +import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; + +public class KnightTest { + @DisplayName("나이트가 이동 가능한 곳인지 검사") + @Test + void movableTest() { + Piece knight = new Knight(PieceType.KNIGHT, Team.BLACK); + Position source = Position.of("d4"); + Position movableTarget = Position.of("c6"); + Position nonMovableTarget = Position.of("c7"); + + Assertions.assertThat(knight.movable(source, movableTarget)).isTrue(); + Assertions.assertThat(knight.movable(source, nonMovableTarget)).isFalse(); + } +} diff --git a/src/test/java/chess/domain/piece/PawnTest.java b/src/test/java/chess/domain/piece/PawnTest.java new file mode 100644 index 00000000000..42222b383f4 --- /dev/null +++ b/src/test/java/chess/domain/piece/PawnTest.java @@ -0,0 +1,54 @@ +package chess.domain.piece; + +import chess.domain.position.Position; +import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; + +public class PawnTest { + @DisplayName("흰색 폰이 이동 가능한 곳인지 검사") + @Test + void whitePawnMovableTest() { + Piece whitePawn = new Pawn(PieceType.PAWN, Team.WHITE); + Position initialSource = Position.of("a2"); + Position directOne = Position.of("a3"); + Position directTwo = Position.of("a4"); + Position nonMovableInitial = Position.of("a5"); + + Position nonInitialSource = Position.of("b3"); + Position diagonalTarget = Position.of("c4"); + Position directTarget = Position.of("b4"); + Position nonMovableTarget = Position.of("b5"); + + Assertions.assertThat(whitePawn.movable(initialSource, directOne)).isTrue(); + Assertions.assertThat(whitePawn.movable(initialSource, directTwo)).isTrue(); + Assertions.assertThat(whitePawn.movable(initialSource, nonMovableInitial)).isFalse(); + + Assertions.assertThat(whitePawn.movable(nonInitialSource, diagonalTarget)).isTrue(); + Assertions.assertThat(whitePawn.movable(nonInitialSource, directTarget)).isTrue(); + Assertions.assertThat(whitePawn.movable(nonInitialSource, nonMovableTarget)).isFalse(); + } + + @DisplayName("검은색 폰이 이동 가능한 곳인지 검사") + @Test + void blackPawnMovableTest() { + Piece blackPawn = new Pawn(PieceType.PAWN, Team.BLACK); + Position initialSource = Position.of("a7"); + Position directOne = Position.of("a6"); + Position directTwo = Position.of("a5"); + Position nonMovableInitial = Position.of("a4"); + + Position nonInitialSource = Position.of("b6"); + Position diagonalTarget = Position.of("c5"); + Position directTarget = Position.of("b5"); + Position nonMovableTarget = Position.of("b4"); + + Assertions.assertThat(blackPawn.movable(initialSource, directOne)).isTrue(); + Assertions.assertThat(blackPawn.movable(initialSource, directTwo)).isTrue(); + Assertions.assertThat(blackPawn.movable(initialSource, nonMovableInitial)).isFalse(); + + Assertions.assertThat(blackPawn.movable(nonInitialSource, diagonalTarget)).isTrue(); + Assertions.assertThat(blackPawn.movable(nonInitialSource, directTarget)).isTrue(); + Assertions.assertThat(blackPawn.movable(nonInitialSource, nonMovableTarget)).isFalse(); + } +} diff --git a/src/test/java/chess/domain/piece/PieceTest.java b/src/test/java/chess/domain/piece/PieceTest.java index 926051f7da8..5b5268a57b0 100644 --- a/src/test/java/chess/domain/piece/PieceTest.java +++ b/src/test/java/chess/domain/piece/PieceTest.java @@ -11,6 +11,7 @@ class PieceTest { void toSymbol() { Piece whitePiece = new Bishop(PieceType.BISHOP, Team.WHITE); Piece blackPiece = new Bishop(PieceType.BISHOP, Team.BLACK); + assertThat(whitePiece.toSymbol()).isEqualTo("b"); assertThat(blackPiece.toSymbol()).isEqualTo("B"); } @@ -20,7 +21,10 @@ void toSymbol() { void isEnemy() { Piece whitePiece = new Knight(PieceType.KNIGHT, Team.WHITE); Piece blackPiece = new Knight(PieceType.KNIGHT, Team.BLACK); + assertThat(whitePiece.isEnemy(blackPiece)).isTrue(); + assertThat(whitePiece.isEnemy(Team.BLACK)).isTrue(); + assertThat(blackPiece.isEnemy(Team.WHITE)).isTrue(); } @DisplayName("피스가 흰 팀의 킹인지 테스트") @@ -28,6 +32,7 @@ void isEnemy() { void isWhiteKing() { Piece whiteKing = new King(PieceType.KING, Team.WHITE); Piece blackBishop = new Bishop(PieceType.BISHOP, Team.BLACK); + assertThat(whiteKing.isWhiteKing()).isTrue(); assertThat(blackBishop.isWhiteKing()).isFalse(); } diff --git a/src/test/java/chess/domain/piece/QueenTest.java b/src/test/java/chess/domain/piece/QueenTest.java new file mode 100644 index 00000000000..59a70e90cc1 --- /dev/null +++ b/src/test/java/chess/domain/piece/QueenTest.java @@ -0,0 +1,22 @@ +package chess.domain.piece; + +import chess.domain.position.Position; +import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; + +public class QueenTest { + @DisplayName("퀸이 이동 가능한 곳인지 검사") + @Test + void movableTest() { + Piece queen = new Queen(PieceType.QUEEN, Team.BLACK); + Position source = Position.of("d4"); + Position diagonalTarget = Position.of("g7"); + Position directTarget = Position.of("d8"); + Position nonMovableTarget = Position.of("c7"); + + Assertions.assertThat(queen.movable(source, diagonalTarget)).isTrue(); + Assertions.assertThat(queen.movable(source, directTarget)).isTrue(); + Assertions.assertThat(queen.movable(source, nonMovableTarget)).isFalse(); + } +} diff --git a/src/test/java/chess/domain/piece/RookTest.java b/src/test/java/chess/domain/piece/RookTest.java new file mode 100644 index 00000000000..7826eecfbee --- /dev/null +++ b/src/test/java/chess/domain/piece/RookTest.java @@ -0,0 +1,20 @@ +package chess.domain.piece; + +import chess.domain.position.Position; +import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; + +public class RookTest { + @DisplayName("룩이 이동 가능한 곳인지 검사") + @Test + void movableTest() { + Piece rook = new Rook(PieceType.ROOK, Team.BLACK); + Position source = Position.of("d4"); + Position movableTarget = Position.of("d7"); + Position nonMovableTarget = Position.of("c7"); + + Assertions.assertThat(rook.movable(source, movableTarget)).isTrue(); + Assertions.assertThat(rook.movable(source, nonMovableTarget)).isFalse(); + } +} From 74a6cd1316eeaa1974c9474bc197b9eaede1f6d6 Mon Sep 17 00:00:00 2001 From: giantim Date: Wed, 1 Apr 2020 15:12:30 +0900 Subject: [PATCH 29/75] =?UTF-8?q?feat:=20index=20=ED=8E=98=EC=9D=B4?= =?UTF-8?q?=EC=A7=80=20=EC=A0=9C=EC=9E=91?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/main/resources/templates/css/index.css | 47 ++++++++++++++++++ .../templates/image/piece/bishop_black.png | Bin 0 -> 51989 bytes .../templates/image/piece/bishop_white.png | Bin 0 -> 82030 bytes .../templates/image/piece/king_black.png | Bin 0 -> 62959 bytes .../templates/image/piece/king_white.png | Bin 0 -> 99635 bytes .../templates/image/piece/knight_black.png | Bin 0 -> 73592 bytes .../templates/image/piece/knight_white.png | Bin 0 -> 93586 bytes .../templates/image/piece/pawn_black.png | Bin 0 -> 23615 bytes .../templates/image/piece/pawn_white.png | Bin 0 -> 63414 bytes .../templates/image/piece/queen_black.png | Bin 0 -> 98820 bytes .../templates/image/piece/queen_white.png | Bin 0 -> 115369 bytes .../templates/image/piece/rook_black.png | Bin 0 -> 30413 bytes .../templates/image/piece/rook_white.png | Bin 0 -> 14616 bytes src/main/resources/templates/index.html | 43 ++++++++++++---- .../resources/templates/ttf/BMHANNAPro.ttf | Bin 0 -> 1063060 bytes 15 files changed, 81 insertions(+), 9 deletions(-) create mode 100644 src/main/resources/templates/css/index.css create mode 100644 src/main/resources/templates/image/piece/bishop_black.png create mode 100644 src/main/resources/templates/image/piece/bishop_white.png create mode 100644 src/main/resources/templates/image/piece/king_black.png create mode 100644 src/main/resources/templates/image/piece/king_white.png create mode 100644 src/main/resources/templates/image/piece/knight_black.png create mode 100644 src/main/resources/templates/image/piece/knight_white.png create mode 100644 src/main/resources/templates/image/piece/pawn_black.png create mode 100644 src/main/resources/templates/image/piece/pawn_white.png create mode 100644 src/main/resources/templates/image/piece/queen_black.png create mode 100644 src/main/resources/templates/image/piece/queen_white.png create mode 100644 src/main/resources/templates/image/piece/rook_black.png create mode 100644 src/main/resources/templates/image/piece/rook_white.png create mode 100644 src/main/resources/templates/ttf/BMHANNAPro.ttf diff --git a/src/main/resources/templates/css/index.css b/src/main/resources/templates/css/index.css new file mode 100644 index 00000000000..8c8783ea354 --- /dev/null +++ b/src/main/resources/templates/css/index.css @@ -0,0 +1,47 @@ +@charset "utf-8"; + +@font-face { + font-family: "BMHANNAPro"; + src: url(../ttf/BMHANNAPro.ttf); +} + +#chess-board { + width: 600px; +} + +#chess-board div { + margin: 0; + padding: 0; + width: 70px; + height: 70px; + float: left; + border: 1px solid; +} + +.black { + background-color: #D08B48; +} + +.white { + background-color: #FECE9E; +} + +#start { + position: relative; + height: 100px; + left: 30px; +} + +#start-button { + width: 80px; + height: 50px; + font-family: BMHANNAPro; + border: solid 1px; + border-radius: 5px; + font-size: 20px; +} + +#start-button:hover { + background-color: black; + color: white; +} \ No newline at end of file diff --git a/src/main/resources/templates/image/piece/bishop_black.png b/src/main/resources/templates/image/piece/bishop_black.png new file mode 100644 index 0000000000000000000000000000000000000000..b12c826bf9d869eeb2cc2b4c49314aa5e85d853c GIT binary patch literal 51989 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 literal 0 HcmV?d00001 diff --git a/src/main/resources/templates/image/piece/bishop_white.png b/src/main/resources/templates/image/piece/bishop_white.png new file mode 100644 index 0000000000000000000000000000000000000000..3b251c11841fd6df42e5d8778be2837b05bb4770 GIT binary patch literal 82030 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 JU_b8f{{gU_=nnt@ literal 0 HcmV?d00001 diff --git a/src/main/resources/templates/image/piece/king_black.png b/src/main/resources/templates/image/piece/king_black.png new file mode 100644 index 0000000000000000000000000000000000000000..41528fd00183734002e2027f974dc7ea4ec015ed GIT binary patch literal 62959 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 UK?1&`28|!3rgNiO#X9VN0F9fZ*8l(j literal 0 HcmV?d00001 diff --git a/src/main/resources/templates/image/piece/king_white.png b/src/main/resources/templates/image/piece/king_white.png new file mode 100644 index 0000000000000000000000000000000000000000..179ca63927af54c5029f962bd3cb848e64893419 GIT binary patch literal 99635 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 J9pw7k{|5qZS(pF- literal 0 HcmV?d00001 diff --git a/src/main/resources/templates/image/piece/knight_black.png b/src/main/resources/templates/image/piece/knight_black.png new file mode 100644 index 0000000000000000000000000000000000000000..d097828c7c158232c4e163ccaac2a11f5052e867 GIT binary patch literal 73592 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 CujTOo literal 0 HcmV?d00001 diff --git a/src/main/resources/templates/image/piece/knight_white.png b/src/main/resources/templates/image/piece/knight_white.png new file mode 100644 index 0000000000000000000000000000000000000000..139647f9e46b09eb99f525ec22d3af1cf391250f GIT binary patch literal 93586 zcmeFZhdX$*8Q7k&$fbE`^kf$QDYd>_}FNE}N1) z%HDgg-*JB2-{0%^FZ^Dw$Mf7z&nutL`8m&HzK{2DocH4k+Ug8@kM70ca16wAD!Mov ztv~u_Hx2xaNU}yH{6TX~Q(XnOjsBBVnih`39m5e-&g$Qdo9On+j(77Bp0Sz6%S!FL zc5L5|2kgiCc)2fDTsTFObNSRif;ZhtEUF?SJ7ttE-g2kn!{S%_|9vdePG~pF>oXttw z=jK!ll;H1^J{_unKPI!iNG(LhcF}c*Kidw+$yCHCt-11WZ$WZAaqDz^E(<&ZKmIfm zaRc{>Q^d3%lS6W01Ml&Ekpl(9*HQ~HI}hLLmhF|7eJxf?F+tp?}jZf5`6Z|f-_W1#EOEkXW0xXrJiBv~^Ph=$8$o_s# zT++dNASI@i{c4K@a~;EH7W-KECv=L( zd-)pqh0_1MlFLxVhHb_+$BO81?vr76_w#}79Ql*<_jtlL@QaCT_vN_S#!?uuhw|&E zi0{wMS&r2No7FLe$B`_pqe595<@HG366CvMih?vgmEjvpzd3xd$CHF!^RGJ5xMvRA zN7G7`3{CR;EciRTNUY!dl&Q$pAu%4#UUY_^0(+LlyC&RQd{I@kW#bq*hxl4+Nr|#^ z!XMwOvpIa0ZMZjlB7ZQAa_3QfJyKl4K+`YgLz|+#T63?792YH2*x3@5OB2d9hsC+D zr)<+r!#8}!G#~rMnKT<8W?1;WfcFbqv-7<)6e1)mggsM{{SQ=h~>sXa2bQzD!=b%(=v>GZ!+;%f>w^eY-;o)1+1GS3@opZ`28y5=Y8`@tQ%W95|_9UyF_rI&NoMK;vM%0X2IKT76Brx&fhWH&q@zIK>WIZIc{ zL%yC~PE+^0;ZLk|;?6TUQmJJsqVcPpMIxeK2fw*~IQYJ7srEyiA|I>AZ)0lgq3YW6 z&W>Z6yXJ#e9Y|3My~O*G(r~`m=neMG+Jki1Grv~De?`%PSe!^aiNhtIlVk-KTcbzo zy#);^Fkvd0vuMus!!y=D=Pe1H{r|*<;6EN)Y>gV7DiPk<%g4f3WfG#XiBBuX2pv}? z$cbrNF=E|`@wsUmdlRs7%L3dpSXT7jyK`h_2Ekd-iY5r(`}#U z)DvQ)ejq&Pe{-(|E~%Qkg`$lwv$?(4>!RDfHp&#_s!LY0q^e-JAoK7-{ z7~mpJn8r~_TH(pxFK#iW#FN+!IFN!*3iwm_?=8Q~;s5^9GwnSkI=30`zNWh-*mrg5 zQwust5{Z%p_a;g7*3<50fdKO>un0krOm5*m;dY56zq7Z))S|cxSJTFDt}XA0TMA^& z%=@AX+K^b>c2_^)Ta6#v2Mb+LMfGHN|u}{w>RqCVy_>M!UI(b|acaz{%%n5_o4wW5?*9d=0-6 zYpLP3Z>`=W6X{=xx}2K{CtjUXbt~QME;rOGG51k z7Eb8TXAB#Ys5@EuCmSDs%^_;+SpM&3yp-B%jY}sl`Q^@cZy+_@*xUCfM~9Tf7j44v z@9*fS0nOWrwU8M7x4qr;p`VU{tcM%3!jJ? zcszCto^3oN2vUD-Od;pJq%-#b>67KI9_j7lxhSFKFZiqsMkIMHT^uZ^hhs|nO7bRb zZIK7AkOm%&?W1R(W`$or3=-+X`M=hB$EXxt$SYG$*hMwIN%Td365&8#D;LrGv4$M} zx@mY1N4MQH^=#qZ`S5$Y2E53B-`IKPB8R`TU(5hU3pWdkh|XN}O8W!y>JuP&UhQkAISK-N`4UHii+PRX8@)yCYf3uYa(2WdkJR#Am z5Bi&E&5nUh+|FmTC~AjpMGdUsT{7=CK1vDSxajssGFHmb%rMK$lq1D_;<=@n+iuwT z2rqVeYEhHF<-EqR^+6ULcGIwT7e_-+i#L74^AH(#c8SB;JKrGf zx&FaPnBM*j4}i99PP<8Vzm3_0Pvw`|zM-F$m6dNKUd?LpMRMFuj!m+Aue}+yZJj;T z{ql)0anmdFxwy~T!sE>M#W(*(_iS%1N7;;rf80s7O091-cOGuSXYID1d;P0C>$1%J zP+jcGT5I{%+d21Z*RK6F>0LAQC{u{8BGrQZ!B691a}D&`%#b?q4wHSh4JlA}JK<*c zDf2S#zh1rTJ$yC2PnLSTrsv{(#LB^xaJK19D9klRn{xOENGOush?N=lMFoC_za{1> zyFL3LGxvkXW&B;C_3Yp84eQgTe;6EXPh9MkO(I|)#N~gFPd8t+qH$N)Pt%_GYD@lC zvCL>{IA4P2So*N(>ZhhUsopCIg*rpx$ir~B;=fbB{AL|#yn6Q2G&%CJ>TIs3oe>uk z6T3b2aoFMF?5C#wr-}+WUm0a1Y^Lw8M(upXboTzvTfUK&9xQk-0GDIEvhSjEa&jIw zcn^u27;HH#L>893lJn!LJxH`hVEgh9d1SU9X+^`&2$Ict+j9uJO)O85JEYA`^EQ_{ zhhN7!RLl0{*a!bHU+-wWBh#c56Ju$NnFYw@{vtY8$7v}%>z>W2{&c^reCs>iZmo|U zedl94^XJ@CyrxSFH{2G;>^q>)Lics*7M<5iygy-5|ewK4YWX zmQ3Ou%t~V#3P&OENG`Pmt})fPg~B%8C7k^d$2~32tEBQr1|6n3uA|M~lXm7c30_m} z&#Sx^GtIl7SFt(?W?-RK1UVyL-CM>BH>x89q7{5R-9kRFYUc7yiF7_y2(v64+h;%1 z991S!*yXHwMEFWuLDiK~Pq$W1JAWY^8=JkDKrPsWv^OIYt@3_q%W8Fbj=wwjX(CtC zBl1XnaidNTX>D0W(0Y4wIq~kyXWCD>lk-1)mOu3h`Puu3iR>(pUALsQ8MSGZ=k({x zWAroax4nL_CQ?YS;pZ0_?uGlSM9%Y@>sR}RE2x;_?vA_+EH>M6knr2um}_mLo&Ny4 zP^xL8Jc_ezzTik9?_xbXC~`UfL}9P57o+0F%wLsv^NQi@`W)AOJi&kDBX^A*yFc|z znUM_E6vuI=?WIk_Y_(BYuFX?W?A0V~NGuNfCD{yCKR>v=nz-GbXP=lj^`X;2(67`- zRPp}=6nYK`$OVqBV6)$)lGP?+*sh(OEk+_{fJ@h}ht_kc)3N+9Ethw8*p4@csdGlZ z5VO))9iO^C+O5!u?WWOLJ#8y^E7xOl+-4#_gs_rml~wvT2ZQ(oi2IUoZnN6 zw+p{z#9_I+-UNx%V1jxm=xlA7Dv z+N`(Z!E}U}OH`gzI469iNQqIX5z<*+?t4r?%8_$^n1ppYgK$QMTBoj9k;7E z=B51RrP^&0eX7MSQN(@2GR|eSodpX06C~|x%(rr?IAeoF%8CMSJgnv?{W^1NvcQDo z0*A_g5aB%=Y<|i-z+`j7=gZF92pPfWjc|@y6mfX|IH!Mvi${_?ZQZ zM~FAb<SSUs#{OR4|!wpS~#XTET!M7QwexhmET4Mnc%jBK)J+1_>5^T!Z2D zB<_@y&Ml*?u&}Tzx4$2j`TK~c_=W9>$>#(2#`aN7B;l(J0$EgO*`1UWmOnOFLCk5n zm@vpI;z4x#*Vh70kHfvg;E047n8wP=fZ5isbiKSglO1m_7i4HYe)xNuS0t89u>T>PaM?i*s9 zXFZ5Qb=mq<=K~exNj>5a>_~K4^IH0dVGOviL&J{S{*lt2{`QBg_@T|LrRoK@&@Ar>IkACDMMIt$y*$C4JPUUbWl{5Ajuofh_x& z`J*p#Tx*Q;S!!Rc>)oguV==KDZGKr!J;lg|G7=4fFt((_6{h*#t8?C4^NH@$_2iGo zrZzvysPlT5x;;8OpRioQpO)wgL0#xIPMdVJDg>=R9xi;{1F^JD^O$vp7rs-sb<{G?38_4+oY(U}{^$gEbx#qko zh3S%c=U*4q7bj)|D-!X>h8)Qar_Rl(gQ=6-+Ah8SG*vtS5wYdshmJ1~=)|vAHuesA zoW%m{2o0ta^-L=Lwe|+z-+5J>;9@q4>+KT|{^h+wBiS^at!`0ox(>g}QF3(M z%c!u@H^$Ow2@3L>EHH8lxoHSE5ZAaDRSCpWJ0)5r5hL&)i2W{`i>)?k@pr~X=kwdP zh&?78$vW($fkFrdq?D%$1pb7(*W5ygx4A5qF#&O40`lziU;1dqTtUpO;`FlYE_RES zw7=YtnE6T}V&HoVcaRp*`64L{($F=q*N=aL1T(Im@A&&YIFm;oA=3Zb$=*Jik}-p< zo2sk^mY$>rKGq?c&2RXn1HJ!<+tk-GNOe8qaPP_?RHq7EmROKICK6)q4Th0K{hyNP zM$CGsR-$_r-@6a4^gnf+SiNkmN(#?ZJ`^23ppyY7$ZJrLg*2NP+H{!i$f-A>7wkPr zfVg219M0m|M408ZOE#4utOvC`H)gB&8RZum=UU~H@)XDltO{J3n>k!BWX9g4@Ksh- zv6a5}8igDrqWIcJbRETbnz+L|wn8@oxl@8ke&NFP1}XcF{I{l`B2pg!T zZ|#j@=9ftai@Q{E_xAhZv5b(Ae48o@6D5A)&`!1>AAK#7kMs8gH|8f(G08QK%uklg z*MFQU9v738{5>-N;ae7dm8*sOsH-92yHxCH^cCYgK9`}|^w4GlFdw_uT5Lm|=KMJT zlyEp9%mEf`QGuzyHv81CYsIDP@8PT;517r`R$w)CD7QJ1DFjI+rLZsQ;W(Gvn=Kh* zET&QfLQJ=NZz(~oz!XDJ6_%(1e|@Hq)|u-jxP@93hx-*I@#k{O{;|&og7A~=!|p#7 zjwrI-3gZctKAx7~dDAT%Sux`%e{Vn?Jf;*GUDUE-`REh zXtK?v5$|L&Hc_RFmPkrox3t6?nYtMa)dQLFD(z4OX7i#e$XI@kMOG{YOnVQ@zG^5R zPVgFvv3q}Gac?DOJ2#m>LwTX1^XJEHk=WaRAM+1oe`N%FaoMpK1e0(T6<8Uihhw%| zmp|_{Qb;PvA*e8G={Org7{~?$8s|0jvE}s9oEl-}a;lCeVL$(G79bZZ!vfM!G?avR zAivxdK07-*#v-#mk>}DEKxs=7iI#GN;2io|j}pAEq5?xFY>-BYevlsVnvti-X$p(!V=VVamPsWUgl~9` zMD6Ih`Aa$1R23FpG8t6aMu76f7HUwQV7aA-hzw<$5xPD{zx7U;iR`Z#*YU)jh1XJp zMg5^Q{EDmOu@m<#@#H~bJz&W_)0vEo)30?B6YSo9B!Bh zxJ78}D60`u)>Ibbg-HmC8KEH+hW^mO&*VceS;KLDej`a@-N zJr~EuSQ=2m8VHr0`T=`0<)A)V2=RB|E7z8jTZl6NRTn@RqA`}AA9@V(ZEcWUr*3SQ z;N8DsIeS|2CVvcJQ^lN5F9 zg^j0J{PQo%3fH%U$c5o@Ef>^~IB%u`@)C`>^YrkAkMs4i^K((ot@Gyx7PI_( z5H>MV4@ig=x6z&|TX$G4>$a$iIpfjU*<;9Y{gQl~xtWZ&4#|(0#=hloRTx&Jd4yv2 z11??ppMAHsJl&9o2tE+0Cw3QD$Q^%XWtj zA6DgmV||E1k-`(_PMH-}eDA74Bh$)3C(7*W`blWD^gBfqr--CvSIUR#>MF88qp(We zy5w5vepKF5BA(!uTv8%OP|et17b^vELq_68GoHYEThg)T{MoY<&!0bU63CF94l9ni zI%lI8NlAw*-;GukV35H@;)xeO@Vd!anYo@zg;gR?8UF)jo~&2))2-FCN^xuU=?Hzg z+QL{%Fr7$=D1j&E=$V_}zzI^s57~)}GQU_bZ?G&exkQ2m4>VA~*@G62Wc#_QfK$yU zZfq@=KdoQUj+L}e_E}##pCBhgQ0+K5*->zPV`X+=$djjD>PAyC^>q2Ruj@ln8vP69 zn=Biv-CwQ;w1izmYo?00;NaxPoMMQ7rs8yuXdi&LBvhE=s5 zF`m2Eo@XQOxiB&kaJcbhYw+dc<8s^O30VToI9qJ*=fJc++_6T^JZjj@p5y8kw|nf;}wqiUm1R8^%`XTPn|LI3Vm z!x@LJ7x1Z{xmGnJ5#MA7o+;m*uaim zR62Vp9&OI*SqWx{Ehqi^1AaGgH&xfv2%I`K@FpcRNIRW0S=gKKkbzCi^2f80L+Kij zN~99J=ZJIj^C^1G|MZsmL_?M1`cSO*LuzQC!jU3e5xw-@l^z?#!o6+#4Ed2TZ&Wi_ z5J`vZ&$}w=b^(v&z49lpiPhlF>R{B*m&$=)J{k_iqkMb!UJ-tKQp*2u>Yhf{q9b=H zE|H@O|MmOV$QUis?Cy;8octt+@mvs-;>I(84E%(YYPr3aNB;&YZgAVg-Bxo|yF9yG za3J+?t633iyZ+CSvjL>Y*zMy_fWk$8dl|FgZXcNibO1_sm3{PxQpzH|= zJr`tk4yX#NoCGDqvYm-2HYW(L6S|0uCTlUnw-^b+N zR8gnItXrjl_N8lh8y$?4BuzL*bSPakgnE!Q{-RYP7qw}*@8-y%QB6?m$H7RGWbtMa zTZP7T2LD8y5fzpHV1;NOA&KJ|a}*zvklR;uJ`GCRift<>DG=w>#M+X(+~ehSDE~m3 zNudL~Qw7AB8)S-Xv2#9s=lb|8DAU8$&3Min+uHx^;La)qUmaaxQwM%g_0Yzs1>#lB z%s3D7YY!ydX9RP|4GP)|`Ns*1p2sg{naNu>B-BlPn&ylrMWP(yxirBFvGl=es=}kC zqcenTK1p>X{0|9i6%bJNNK$2~spE+r9x_p;cUZB=V-Oh|TLVt{O|tXW!T94%rC#oV z(Wp6_YAez*Ea)e##-lB>-$`OVSW)`tV%x5Og zE#Tejfl^|Xakg{~%Dn{P4dTixVmM!uzzsWqhV(3=#|X+n7gWYe{3V43aPiQ%F%! zk#JVyp11DTzDy#={!*5^l+s+b`=hXZ_SR!M2`ccnOEJ&6*>V!$_mPmB0w+%Ny$s|$ z&d<+JP&IzzySa7+Dot1pBIH8BWy)@U^?<{vp}}QzBlN%MCXfVEMRx3DV0FYF?+N_% zNN1s=t6G8UL|fSQdii#6{e>gND}RIA!4^}*n-i!k(lt78QQ;koX1f+BeJLb@LeMh! zRxuD9X##hO$88{as|FmpD*wjMwi{{j$$A;LApfJn7)p%eu(9N%B>&a<;k1_N@YJIO z*Aq}SHzbRvx*9N^r=X#r3Lq<4*@7dGQs4fiLAFPFUXeZW2*1{MpGg{`Qu^ETiOWxe zgMx|xYeOJYtykRk4lF-o8OU+xk@mA@W6tzX_p@mED8>E#C=|aleMG9wpz>&-@GGf-*G7ZxK%E@1#{n}zP)|BbYnjY`kx6fMQUn}!|d=efhtQ?9dDqm&B&u3 znyMVg*d$-n6DJQh=5|((J%fKRLSCE^*VlQdTJpo`(dw{?*0Kv<`(o9 zSYvrWtOD@^YP9D_c%LV&#M0UHtc%9RWPleMR#s~z%yEf{4FKkK9Nvp48qE6w`>x7w znF??S!dCk&_daKfL)rU^=tlgf`(X)U24(r}XK-$PiiM!ibGhkyX>%QRqXqcxG9NEr zXdtNCocNmW*qeaLSppBw>i9|CO5u&|uYEEVLKWP1Gh&e{9Q&l`U|Z>T_zGr8%w1uZ z(&C)=ZmumtK#m0VGjF;KtGz}JSv>-VDn`6sng`Z;XI`F=oO~RB3w!+W(eZaQG~on3 z&)t2mx{=Uuv?#{3(@^q5j4=S)0N#iZ!FpGX0=c!3lq*i3she1$UzXbu6;2=PwcgqnK?dlDqZVOP#Zh4#jvh7plIR}1p<1y2KxGq*;kcA<>r2j zMBGID*9l=^YhY-a1TB8AJE3*>(4lPGrsJ3MZTH8Mnj{^% z&Ox#=hSrK}P^wVgi(l3=*OhME3PO@BCb4lGBa#+`P6l`-^N?=!lz8mGfezo9`&^AF z>HyGQeF?%Xe7 zJbd`@X~!P9*IKbh;*Y0W4?OFj2TXBjMIn37UD_E38f3{-82D-a%$V8}af^k6q|yuB z%%68e^)6mK`{~Z)3po#G*Pv#Va6YXUXY7s$nS2P*CZ7~Ed~4C`vpo2fNijq_Oy5fZ zm%v|eSdR3|fE^va`I$RTla%V3ec-Mr;duH`Ln2pv_ICuQpri7mq2a0a#h9W$582qa zXl&bad7)_UO%}(uyr1;vtk`YAIiqfo_5*YPiK!A(u<&IHI)8{Tsbn%4g{7{ph0R;N zXIig(6)NmH5dZRDS+JfL(zlO$c=T8vL{9*PeH!@gkwZkcv;!=3auf?RlHZ0fciW4Z zb$l1yl>-nD!46U`rl>Wsn%wHIe8TShgS!NZ3^2hr_wG@ug|d^m1KAJ6lUg)1G)CHT zcmP=k!GV_zpB>$$NMF0h0Y$C_p=Nh26#z0Ru>m?MJfsn5gNACiodl)W0Cwb@%*=Wo z9mY*4&lIKRu2M3BU^{6!i?!BNXSGfJ*12f#xW z2v;*Fi^t!WEHrCM*ft&`sP37MD&KejT?2lCa^mRkcWelmrikOeukCl@&pvdQaU>+I z7K!iipI{fT7>7H!A*xP5A7qGeGJXCK+-|A>7?PgM|M}+4n@8FgDG~22w>l8+5XX1k z%8C~#I7Zap)((qcckx&Eukv5MriZ*^B9a+-hrSk@zrDZqXO73s?@XjF7dmjnU*rKk zQt@)Z&F`66Wn=rKYY@MHmc-)1h@i8xv-Iq@gC6UXh0$m13|&K0E!z@)@y)!dSoS|t zk=%G38Kb7hu6#&*>V;I(>gsQn7Dk%x2T;*A7v1h3IYj+&EF*KIHH(Xynz~6~jRyW$ z7;k;ryE*0FBtRm)+9%C+H~yF5Op8(;wipt?jXzRKuXM%`sJ7yZ0akbr5W|73@o_zO z9baGHL0~ucZN5soS-icqE;v6w|FzuL+uQrVdISa4?0axFe7g2ZvIzb*XnE(eU+m+~?=dGin} zgDbDwmtdspcLNv-ac@9;jq<45{C3U~EjhaYF#| zKT;gpF62jb8>>?L5A6>jY~22~U%fHsx;o;8Ldvo(_u7Ab$PfbO4C7IsgC%B$VjXjD z{Cs_LQyzLujyT{V^w=JgNH%yUkw&f)bXY`azDI>Z^;812c5vvUUztWC!XTWH5S4VG zCe{{4&nGIxL!E;lEKIf3Wf)|h5D|G=UvusWo78J)5904UEs8F|i zmF4cPB8E%sUC2FoN!Y3Cmnf`N)m2Q&yk$^2sDGBa4-ySv+Aci0QCp!J^|c+>ZSe!oJO@zRG| ztU%Y<0I)EZn;&kl0h?%gO#0Bp(s#sS-vw4|Lk}>rqPbnE@7u_ua~uR$i(hXpHnEZ- zmLSEiDBl0mkk}AdNjl)TH{I*rI?n2|5E8$%tL=4|_8>TxE*=4`T~vA(vA9INMb)Ko^O!eX z_Nja}R(M3Y36LO(83NcIi^<$>?w$3( zj%)#Qdb`EI2uMB>C4!?6-JqW&p`ocMAS7f36(;Iw60|hijV7`;dvo~*1Ujt0BB|Hn%-UT%^s0cK82?%5(EA;al;0hBQf5ixh|z* zwP}CTUOGDCPj`f{j6zD4$hk9lxd-e)gyt)(a1BgRUteD(jYyQBDdJ=~!hxK?APRE= z?GMzER17J~$prw-bFNpZ!2z1PkR!vk=LX2;?A)6$aF7kP)`*0F008Tw#rPc=oZJB* zaa3}w9AUeRuH2?}@4Bt-`Vg=fnpXkVE}BF-0Dyx<(N_*8FoNny$)$U{a4UP{kP|{F z3ZX?iC?EykX_8}a*#;2N;Dvar$B>dP=<0s?ch5lqh=OZbHD)Kwg;eEFLeJg1&q#RG+}sRdgj9w;cs@>gHu&WXa6q3s3hYwyQakju z$2>{n0pE9&$Gl@Mjr;C0+aBd0?Em7<;tw$`;y#=5LG z#Ai;-7+DxQp}aJJ1NQUP1G)gSrv1dzKo?>a1bjThesyjT-dziR=>!oTViFu(s~y)x z)kXOhLu$H5cI@V?fYSv4R}wdWJwnA%on)s<+Bs5wOQf)A^^Y(f)-yK`q5J@ZC)mB3 z4bf!Wr;o3X!a@(*K<+b41FnHMUf99yiJYprYQZcOFaUkQ-&y85@a^lBAuo%HUce!; zZ}(S@oVuYYM7>2LM;Sql98Dk?!+6AHjPcg(0*l*NDlC5jI!xF0hTbpYRUtU*UAa;_ zKn@o`sezO+Zr?|+u)sVn_dd1*%TKs@e^01;PW!C6qKPD=f`4wcWe0#k>R!2W{`T!0 z_uYcsC0aLmiX5>w#bS5fETnq>$=4d-iUrg+;Nf^)%)MD?%D2|WOMv8RBI+8HoWIF) z_wvqr;n;inb^fYK_W_6(LC+ExoGqx0iMq$3hMxOv;&>7En|<}`-To(10F!)NBNwzz z`ltEZ5xWnc0?Tb-!3;nBJ@pnRuuT0`Plp?onb4^PgrLld21y}x1_cL4i(aL)va)J2 zZZ>*H>p2qDe<%cj5gCITTL0RYQ?7hkdu6-%bngMEhE5O_((6WRX zmXieHnj>9+V&5i|vcwFEvim218+^m>WaFwrT9{}Lmz`dSQX!?rTre}!CKC7Dr(w7@ z)A#v&JmCzy*>$dOZ;}M&HKQ2YsS!hy`oYgc1&}o8RvKUvlq~?}fWg1EGV_O?UHTco z)m%UkBY3MqjXsaQ<%;A!lqFtqV`snd9`8mQqku;Da_-JvgNi5xV0HCfa5|*(v-fF` z41tkJ4v#36#BEbLd|nR#>Pw#ib6V0N%J~3}6lKx?NmKX_jDljq6BN3X?f>`hH5x|t zA9h)#l~CXxjZdAJ7oJh?BkFd3Mq#fI3wxvi=f3wNk5XA>@0^h#H8HL!P5R8&>6YVZ!r z1{wXZJ($ma9<`Z``G)zw!6I{8>(g+CJT1O6yM-U4n5FByV>(XE>Fa)r=AjB}whtLO zpic!{>X(JlpQD|HA`No$^m#T7q4gJs#^|m*tojG|^%aof$ zdx~*EsQ<)5VbB|e%7_a9OoyQ}lWfzF;5yaC>JNy|Qzbtmh1ZF@k)DO&RuEz)b+ufm zK#VN~X#wJpa!)8KCQ{QKX#{Q)=mk=Q8bqNg#O?qYa-K*ex`sB_$n{a`y6*z}`7dO- zrBjI>Fu(8pPS~_q6nc}`*DGN*q()Ci{yR)IRRg$6afwh^qb#Q}R1btCabtXSC=+6q zphtyDUlN4eqhgl3tJq!6qcmBKgNQ-Tr4Sd$>G=p8w}~g&;IN>-W`Hk-aykfDxG?>A zsE8l?-wKyoSQRj7C{ms@bP0=nzR*)_rN@aVPgQO3s zP#%C&@_(KtP*WE#8?`=No(O4ZS|v`4M${Z~p9cT3LSwBOa9K zy8`={I_yLcvy4yyYN!Oza|8O={=^GYmGk6tQN>)Sg2(_j8aena%EU z+r+yWA{94F!3@-4(_+^@U+6?2Bk%zQ5a>4kTh&IOr>7zs;%mZ=lV>?$*7=alUlF)% zV`$MpDgFwcL_vm#(c92UuJBpzu6nee2NXuHgNvfzQbk7>_|C%$HG|eVg_D-6O0y|2 zx{QAC7ain=hBUj@_sGNwdpv{9H^+=H?nyJJp87RqAZDQg-w`>dA3o=QTj>)}BQEPk zz=4tA%dsFs3Fs8RK-u2@2 zZgu1f5Y*l5Se=ALPa)tSU^1Xe3x1RDzI*0S!l}7<6o2Za`$JF!NF}tEc(`aQtXlfQ zg!s>-vs8!*MqZVtFZF@Cn4**7>+CsOc<}NtqGCFZE(VY*%D^XEi*8>BR#gW`kYvQm zeeqdnQkPq3R7O}5E{w>*Cen6E(_Pw!Tsnf>^$X&dNxwDwmLd7Mk=ZB``lvXN4MQ23 z@2>&m?gI0efFZvoVg_3v<*U?(7+&IaKqb16+pZacZ_eE zhbBY6h~Fw5Y$d4vV)qEs23Iy8cJ!Ys58uJ24|M)1EjL&iR@`p?lZBwjkGi^7U|TS5 z^#pVX)8Aey{OL>alp(Z?Sbb3~vGdv46HdOaDg@i^;xjN>`0~GaFJKQf+00yx$UNMo zc@BP|I{fC&a|%Dotv&h}O0?Qlcn6}K+a|cN!5zS&2yYNGUIWvPdONX>Wn}2@*tWhm zbtT=@QE(EUp}cSi<(Y{6SQu%^;Sr^7<0jxaHb&GHuR%36Ftipe3tD(*0N^ZfYk?nX zvt&JeuOk#T&j?2mYishuod?{;U@)wBxfP}uxkMM(X{ z$+p8R6btlIko+|4%6J5za2exE(sNZQmfl?WIog(U9l5`5eht>aseW%*+ zo1w!nuJV+M;l2rIyqTn~1iHzP-g9@qxvW0%>Q!!-QniHH=wNNob+s)d2!vL~v&s{I zPy!(h)lq2kyD>b0mot7KUsy1`L(Td9kK=Pwm>tJEU>HPPnYp4|&-V`tX2h z>N;Y7`BZT30mf3Fp)5=g>O3t@(L*z&f|ECYzhyJpt+OoXJmUBkbcgItdRq1rc=nPuIStlH&0Uw7-%Mzz^(z?kahZWoc>2t|c@a^LTI5Uc)>Vc`jUpDh|S<*MYvMt$TQbw=&hqEUF6Hq z3hchq`2k8)3IEW$$zDQ>|Dx0-2Y6nco9PFxq5YF#)R<*y)u*2?0GwRGZxU ze4o~(?o8_pgc8*>+i}nqjWw2^cpsoNGg=-`xp9VYycjD=G)y6RbK7L?u@H7BcsOp(9!M$660PhSJ ztC~K!J0gj>AhV7z}7RGYzd1flnM13zd3jGkE#=1GhHU^MI~aL(wYzh_|oe4BP-?8*9m|0*>T_ zpkQ#l?&2ZJVH_7FFP0?SFlM9Oj=%3r(rwps#UFvu{s<&9G*`g(Yv4uoH0^lQH@O6@ zL{uzj>n;vZR#9|Pe#MEnL*vHyGfxsPv08gI^S6B<`jH(1{9 zbY#YP=S?*HpnFG#lLa@R8kiaj=uiweggafgs}QEe^ZtM^vI?TeyvzZtBJN8EFltmg_xxG zykVlp$nlKZD7;5-1i^rqLKFAs8z|Y~76{wG&=964fzLfY%cd~-LfqckOo4Cv1kC$C z!K~xVcSJlzizNOUnr=d`W@kTxx!3Flh5C9_C7)4#NDtS`5&##-5>ySuIag$6e6a&- zIXzJ&rPeMpfoyZ2LDhj|OUf98s|&0!g(eA(&(FXn8B*WmzJB_`ULe0Ad8hNC-l(p% zEZ1EL!f{g$7=8=kkd1`dS5;(C0$O#D3=uRs#LTRoHuA}bK5h?v5Q&V)2`F0(oOEyf>^v}Y>zXBxvVQdrsePeaLluf$bIiNq_pT0%J zIHU^wMZ+0Z3DydNje-oHD-C?r_N6R+1P+ovSTal2;(hm^BIi2 zEfIKuJc(UBINw7Yr1z-LY~om|3RwZs6{LvI3L7)ZTQh-*Gl|<9fz{R3BkVqTvr5bs z2AHr72GMXt>d|moIjH&H&B6Q%mVWE+ZjyU z8HgB+ka3{aeiVAn2K-i-KhfJ6WkXW#xvEf(Xfdn3h%5v~vPovmvzN!MuAT`CH5p$p zucMEma93AP%>xAf7{S)$EDo1sMh^Luo~dXExQLllZ{^d&V9r~@ zxTz|pJN7x?DhLT;)1@dkocaxS8Q_B1aZpeNcy0-sw8t2g4W+oE7i{YQ8GTp7u^h+w z<Q|$JEAwQrcTkAF(c5L8>=3EjugQ;7vNi=lcL;g3Iix2r3(k(rh*O@Nb^;XN;#Y_ zbm+DPqjD^nr9ladsBwdeoq-ZzgVKuC6hUI7P_dBi@$Rlu4*fm|?d3L(z^ zIi$e%C370UaeuxV$Z;e-WxMxt#V&9bNPQ8d*qK+iC>BCOf9!&((p^vG<{m9W=)((K zhY{l2aIqY?T{R>wpekKSNqc5oEcVTuMQlm+KRqaLZ6Ogy8i&%2*7DD-o5AQX!9%clCwoOe)9d!+MW||gQ>9;=om z{xv@fa_jvAcWDPu?|Exu6=oGYxTI-b9L1y-jA$Ct_{l!=rv1^!AO%L5`$ogWK1_Sn zqZS=F0!raPZGQ!qHn{Howcu7eDJ7H;1P_G*J<$lw_M@xoaLya!sH(UEL;iAbn-4x? zOvg?e@)X6lc8r-K|2lkEm~dPVjU5j|B(QN+duLMYDgaCjck4Lgf&^8jJW3-C+HHAq*vPcOg-rAS?C z)Me0h{zc1&TUQUXya$GcVhW%&u6W%Pg|!hLhfkA|z=U!FC^#5D|L#t^74z2SwBJu? zprU}4`ql_44VmG%uP`RW98a384sZ#8TnV=4vJ+cHy8ivzdvqQ$f_%!ua+pf_3rGy{ z`REFa$=|?o98hFKso~mxA<7TKG}_a8IC%BVcv*Mrzuz8X4Kr=>9gm8G7419gB4n;B zwy~RqX#njxT$}J1F~V_iwRh9!q1pgR1>gv)Fs}hujc9=sPy{Lb zBh2)mfs%T%^MqBbA0%_xq!5D45(G`AqG_o-)}I5eBS1AEPzp@1n5bSVq+5$?K@$H01XO5 zC_Cq>5x)*lx_-Vv5skv2kgEF|rsf7=mL5f=$J%7W=M}Fid@%DUU458`C!U@Ipw0xr zxEn!p1ffr!4AO2t4pSlhFp^}Y*1c$AiY5eu_UOn^frn*>ZO;r2${-M^19CWH4EFkkH@9^&d8 zZu&dhv};VFfB|)yMBg=m>s6so>d9&{6}KyHS$HB-(9lDskm02jz#Qqo5_k-QiY&e>U%9YBWK6Q9;H#)PfYLDtxe}2v;kjDEPGad4 zGqngFK!9_WvcDF+fEQ29i}3A1_n}FMf#!I zk^xexL}!u>CaU-m=apAa5S-lV1e3MOK+G9TBj(&{7lWpGic4M1&mSYR3^&hsdKX%v8H#tje>Fz1Q@%TxoV5;SjRWPu^5BGzP#FHcyHW&0@8YaruFy70C;}{j z50ikgNyI7=&HEuhpl-!qxMUZqO_t=sDN?^ivqB2uE+;KCa>7QcrsS&k@E>FYs zDXOP|tEUH=>xni|6Q<~2=jJvGL26F@_aqFfL+VaN6#<*%DFT1&FWO?tEZj5(S^nKw zRBD$~P{9L&+t@c4Bil)P&$Z&D!;s1V!l z6yo<~!L2DjK8F9DTmx>mux+_)Sst1^iH2W$Vb%iOF(qugqe%3g+k{d42!KUu}dCN()gm+EhpfgN!ImDQVHFvLqGCGKAFRBxD~YQi&$*iA{4?tY zwo+D<@w2Y~D&~^h7I7-%JR)dQaBe@u=%1Xtq93NCmV>no{&)($9&9Dhwy&{C_>SGa z_l~WH1^3z9%A;Mp1wL-9D;PrPPUh_J8?U~Mq+uDNQfIyT0u3I5V@LNiJV6CE;_u^HMA!bW7aOkK#%Xcsppe;&$S?b`Vt=v~t zp3<3w;?=EMMF!TKy_N`WwKc?5Cmj(O-$itXFQ2+_@G{01Y6ifDpGw1ZDuKDYiiHR7 zjP#TKHGcst*tK`;_AO%)e76?w=q@?GTTzt1J25|!vnC>6Ue-cxm{O>o?ntQ|pC?Wu z7Z0o0rBNZLBqwL+b8csgbc}_8{)h4D7JAYSMMV~}2B)R_N#FU?zuLj$&NiL0Z>68V z_(ipDO7Op$YGS)Vr_GZTuus_gD~Oi$bypR2!sSZfQzSu{&qspWXc;_cwZn zFGY3NK$2a$Q2?eSSAM;8w6u&8Sf{IUTD>IDee&5oQz*sAC#~fF;Z%C;4&j4xQncgG z=K5^6N8HqhVZDEvvH-<%w|q_zSX*_WC0q}hxr9WPlpcZCmW+efiu}3IZh+iYQCRA? zyhvy*Xhn^nC#+sGxo0FF23&+}e9?ij{zFECP4KU3_~6T+h&BwM=Ze5QDSDoZK^7>$ zcS!MVw0{(l1eWh1DOE<;{6V|5pG4kR&-?0S&_VL*>YOAo<}<^(O8`1%WoJ*6#2o$( zaMe`@UzQw+8nqBKKpgHGE=Os;)$bf}RRc5ulGjXTWElGm%S2<8T?~}mSFRKzTTDUv z?2)GAzHVJEe0etd?rv$3*%;cm&&2~Ua~0)f$#sF3w{Y07VGT3FR1Ez86*sV7_;C{Z zh10C><{xa2=4mFsy%(1Sw4_1LVgovJZ2(Y?`V7+1NbFU3#hRjKv^{ zQrV@2wfjWZaxmS_Yh8vx+T_kLN0j_EUdf@Nse!XmmJgBq+>1kQ3l`rILBF0#uvGmL z@k~MoQ9?rY+GiJ9&+IcQuh9OG2q^yW^rM~tsxIi znB3yZbWPv>GrR9u>|tIBGd32210*LcB^h0ospo%QtWEZ$IGQ|;lGj;rub;-NQXJU_ z2{RsXQ*PTOOh2tPFX{sdfd;+X3+B&{WWP%R#4&f&q2g=TLK57p>t$D;>yVFiHg_tJ~Ddd=7m7h@~e1Su?8+x?B3rb*8pPM zx6Q|EO%^!JA+Kp4%C5(nDDixWeB)9~Gq%;H?h{xZu{}O%Zd2&D1A=}7_4M@auwO9b zLsMB9vU&qoInV0_ zj;USJtPHFlxX{&HIg7&y32W$VF}qi;S`~mJ5q;=Tv0X<>o5-uCYcd1{L*$1RN--t* z-qvj^vB$txKcGM?uF@^Ib5utHl((RYH;fGnSNl zGmGN`T`OUVzSYybZ>K^m&0dDQ9*m$%4}{8LwxG4v;^M`N4SKp~XwD+xGrp_58d-T9 zFzO6M`q$DW?6~=aH|2BKj$)Hec-c1=hOyj1Aha^ZGld+edVe z=z&UI?$Vi8z)?$(HPSfB8Jth9Vi)ald3eA?|I1k1yK%;OpqaR0anUU~4Pe8=FIg42 zN%jc*-R2TF(m>>0)>c;eb{!{$Vn0ri2|e1ba`s!|jo}in2>^W{>nX}MiGBl8L_Ov| za!l+OBFXJDw*DA*T#R(XdHM1)a5gbV3+*l&Le=#>#h!M@IGeT=SlE~tCA5mGaCp%9 z6@#~jCpjK(8n}wxokM7)CcfMzF?7y$t>IP%1z11T)N3Gj?5QdPiK$*4huZOQ$CI}I zTvK`D243jSr7u^rz*TkiOO^$3wC{zq@R+rr(!|EZtW0c~wpM$#FD;U;TfEa&naRivaqLFt2jb%vw-)xNy<% zMRH$~_=`cdQ!K8YL*0ajj*Z*muKfdQQ`1q51a9)xhQ^kJ;iCEI5 zyEoSl6D7qt-J_-HR-&bGSiql`J>D}8p#z0eH5PbPRYC@4^{TisoS3Afb$tsgd2&9D zVt;zNu0&~0hLL}c_A$sYjlPDRmKPvFP-z^ev>H%K(xqu+_O;Ni$uUus1tFe|rdhYFUM9ue^ns{pbecgrjZI8kn;4;q6nh`* zA4AWeY<4eLxflL%s`~uDoCD{`X5V*YOk{YvHZg_X4$czAILsro0>`m`c42LfWAq#P zzX0xI7%kb0krHBq~H4DZTRka@t=2zQf`aPFo zc(=*9L}pIqugJm59zL855dd=526>my0BA-4nR`ug3RYq74iGd24cmv@>x=aH+vX0B zn<&Hh=sqV~8DDJ^uo|WhVp$em903RjN)~{WHo%Y#dh((f8{eg)5yWPy?HTv)FNCEm z?ET^0>zml3Vk+pln|gqPVx<1d)c%aT#b50!Yw&eAKOZpHx){kEd^ad8?vzAU@eVs> zEwSA_M8m;V)i@W=#%sNE@7|;KSJ!`_QiQX*Gg!35eF36cbcm=QBX2rc^bUD+1@;+s zmo#&W9cs5SLBE}3t3KTjhvsDrl9hHZ-IM`}U;qqvkqweQ#Av0Cse>8CfC<*t=MDxh zMf+9o#5az%97q|4OwA+;vKT|Z!X8P*aXo&r?=Zo(_gLW)2W56&2ImQ}x}s8%*-@oH zjh2Gr$5sDACCR}$x_I+f^g}aornn*P$%279wa1M!UvO|Vux^n6yUm#2p3~d42#$5> z*s#vif@tsTxJ|L*S?t%!=^%ADz4C%;_@JrFuE|y(C=-1Li(qok?}acQwQ$<5clu80 z$tG!%C-z7Hz-*E-~-`@Z~ zahg^l*DkWdd+_A57NSDHWB4Al zCNl7^zcEFU?Wj24(7muZ+!5b3ec7L%pGuJw{s2zrp4M5hgg=|})*V5z*^m57=Tcw( zP*-GAvu1fx|3P4Rj`#_uAMQqM@nOA#l?atiHh>h}apSIWD~B2#{hmxoN7yZ#?e_#a(4LQJPM81Lv*Uy@6eu(Vji`yb#8g{(NIhhNLx##(Z)8D&9tIbosZ9H^Q)~} zu7IQ(BW;He)ZG@q&%^uYqW=HgetoF&n9o-dyHQfxgHIE4@?>D*PR)U`(qwTI8EHv{ zr!Z@o0>)h+;5H0?st=ZlC?%H2#_WX0nnHo7+!2BH`_sTYJudetw^EXOZ0buYE6Ui3J~JQN115&$^|D*oIo^_o4NU;J#dq3cALj}pzg>m>)H19?RsI6>;`Q? z?00W+bs-u@t7Fz*BIb;&qR zj>xHk-XZU`)(ocHI5+mjHYcG$ZizWiKa`Wm`VY1Oc)L)=(*p-0h7Cpb<4_XRV{LLw zF6TywchT;KXpm#-oSPutA-cRhW33wUX)?|FLVrg|%<}Dkxu&Aa4)^9}Zoabz(-s+! zab$x$Z|_P!KLZmJ$C+C`7ut1{26FyZ(bD9#(6SDl5Dmk{WBmBuX~0KbUTnwHqh1H= zl$r-ko;-Qmr=muuG&>E6Qr>n;hw+qcUydd;AumhIzf8L!B^33q8_H_T=73mU0FEh^vz}p-h2bAxUhx3uvj#lwyV=|xcpfQ z@Wg6J4ke8V=h*fBc7{##J;+Q-p9*~MDai--oRu{aO|77JFmBONWQ1{o*h1UTIrm%; zVG2=4?b@~V*G6w(V{rP%4vwC&9H$7afqxOtd=tsmVxke=K47B?s@eYg*TVTpi4tLDjU?i z8hEwR?Ak^;;+z{>A4bYyij;$+t^J`qLM9W6r2^}{Cj3?!8l=;Kc$Ey%LF=df^eXpCWZ-i-v$fY2 z^hJ62ey(JHGEL@eVgtVBo|f0If8b;xC$nacfp9N{Z!}n+mI|^2(Jp^AGm6Bk;2v`vJcP$%o(A$5{JW=%{i?0?b-7Xg%L_F6C8%E^!Q!N~9$aXw$kQ3jTA#y!1a8h8yM7Crezk2##i7{;wTHov@F=-g(vBy;2Zb6ib zh0X5+VqHp8JShYOFO3&3#wI~H;3R0qD-(w~DU|n2LDu3G)E_UO0r66~<1@bjp!CTL#4% zd%xr&95KPQH7N_~Q7--k9jnN$wpQa1L~C?h~bQI=gO5US7W#WHd}8m>J6I#Z0tDuarN;T8HlFlbh8r@MlXdZ$Tl?SVIm)F_=cRs zd1~rW`!K?Xw;#Jg`3{^aPl6C?wEJvOqk%F7P5E;|Cc*9 z$makVX#54yx(j^=rXJKz$$keKPI1-Il+V5RPF?WnX+2j4-_b4xZyn@(=YfM>cdVVf zFy@Bwct&{mUD*m8mOKxRUM2UMZ%s|jHncq1YSuv?QhvEe(VOr(io=GTj`P~ahv{8l z1N$tbla{~n>I7or*bK00o7k$x_dDPLJ->a-3=LWx%LT6obfmOT&>ao0(X z1dNnJ@G@cB<===r4#+U=T$Q)69K*9}arg%|a)$FsIW7EKENaZZe|{O5y)1Ll#wkyn zDV#kK&WxhZu7S#I>cn_=f(w-S{rjfB(Cr1R5Px38wfcRVQrm)?1AOppHz^u|@c!#Z z=k_q*1bWZU|j0q5Kq~g@13SaN2D09 zhYq#DgnvOE3bVyW1(q2zsalbaZiT;gc2}=i| zgpt<@eI&!UZg+Jk5k%fY2q36kvVTekdf$~?sY)bC8f<36TFDh4BxEI5!)H3_eHiDT z%|6GjQ^3KG!m_d9N_RR&EvlK}vUg zgM#1R{qa2&=%HqUulwKkWMDv&paemb%It|5?Ea+g#R2qLRw}k`7-lqR(4a?{hf`NHpC4>b(^TjX^N-2o1i_aU) zocW9^wTocR3@p!op9giM6VW?Zql%Hm9M-|j{|yy&XP_!v6Wrg3`*jWkMz zYj_Hdrd8O6KWJIirN({jV&Z_7E=9w3Z>Cem@kBtcbuqrU21*N{cEqtA83dUecV{HWE}G>@Zn8@`gNq1k zU?YU@vP>ZI@^KdP=dVU%y+Q3PZa>K$5iEr!&nvUZc>413NIX;721dw(d7_XP!`2`W?hRj<-9xm5#e3w3@NH19iZH{OZK6r!RDzS)j0bPS zC^@3NXLPl5`4xy_!v9QJTpLQ+i}g-a6~fxDfhYn#pi#Z5`>zU8p&~n>7&r`J6@8m| zi%>Xd1UrL{32RsxFOFw@hb;VX@>D0$rZPlqNPp{76m3wmSV3K_{zEhLK zv4GRKP}MF9;eTV#$N)k~{7Y;>n=b->vZJ%zhVvYc}mKZCsfoqIs_pW*q$<5irp`+3U+XJR}Y`o zZ~2N9lrIBvc)(_0JiSuz+Un4?#O9tDmr+WN+@cZ=NB)>Re<+$==pb%}pkKNm>io6q z*Xxn6NcJBdE-#C#0yd$uIkDl9ew5eaF@&6+F7)n(UcV{P8@$D>(n=8dD-tD zQV!`)+#gid1tQ~afw>jvix+aQ{B-YIQD1FD>!EY*zc1d`94F#>EC3{?Bqf3I8#~2( z?+WiVFiM7BbU(l9fFSDIkTJ8;*$N^u5_~igRp{GR1&Hx@Q+kcWwwvz|$oHder>+9+ z?4fxKACP z52miU#Gz2!L`^1pMK7trjPBlC(MzOsFF+-k8rm5wQCM{6!2@S&>u89SlmS?^Mz`Px zLO<)=3G!z~uLtQcH8qt6v2gZ+mpF{#Z>KWo_E55#O69|-Y9{i#KxE9p9YNVVVYR2S z1sainii-r2B@(43kftIqvURf)ofM{72bC6?BGgULDH?QbQ;&Z3ds_9|Ll>ps3xC+~ z4R9cSfr-_IvHo*a?P8EWus++k)O3x0Pc{rZ-4TzPLkJf$9SyQYv$y}OL)Q%naEmp6 z6xB#2hbNIa=)@kK`V7ehmfg48Fal0GknL_H-D007SrZ8q2m{%}M~uLVEk9k=)L(%S z9wl5VdHUzWn+_niL7(6UN|6*En*Yc<`Q&Q z(b-vzb`)03esS$D(Mtlmn%`3diPm>}|E1?Z!I1S&AZe5fl5G|D`Zp{JK!h>qECmm$cOm%SbWV_iI(;~$A9MGVNU zp3|G);wQ&P&EM9Tmq!!}rRvqsOU_+b^W+RTRIcp#Yd?XA{=Mf`~f)CM6(_4EQTAc15W9DYL&q*`?ev(9_B3g`Oytw z@y#l2oEI(jtr`0;df{oK>0`=P0|4Vaa(hQ?Yp-6+>VrjT0p_frs5 zAP>O;HEnAh`qD|O%eWWHetOxl!pHC=xR>TP_{XvF@#sMWg4jbD1A265@I_L}?pb1w zo38e;?Ez-&Z(zrS*J;eSrd+(M9cUXxox`kQ`V0__A>5VJS;Ft}aNH2aogn=wQQ8Pc zT~8XdeeWHQKWGDU{(Mz?v>Ufq0X6hS%7K*LNKvgR;Bnls$S@h&@ow z-#C2Pjti+9YJ9cx3|^1mqTt);BmY1TxD|%m0F(iLe(qHF5i$OEs@uO-ymyL;Nj(UO z$OqMWr{M(B!34qf#LLicwh|@d5MJ$6+B?cbx-vNaW#SDDT1F@5gkQx(M^NIh4dkW~ zJlX(~HR$bsk|JJ(BM99%AKUYp~3&K#sF!ktxT3ff{YA(X+fIraep2NPrSYA&qxIG{S& z9CY0!7dM2CRAe+kt#JJHeB&V`^xc-V_IPF9YHGuIT6yrt?)lU5jpFGK5dXR3#jLk> zc3H~WPlI0SI}}f;cmwf`8}o4jgr@=S`eUqN8z9@e9|x;~$IzI*IA!Ykmifs3j@@aL zWlCBh`9KKjkkQl8l`Y*Ua_8f$$TOOoD8&e~vUoj?`92`d00ziCN|dbh!TthM{S1b3JD1BI+`G31 zmu;kAz<(~aud1-JPcLoB!&pH2f-zg?>)0hsl1yLU5{U+Q8gMKR^aS4fX)^MQsivmU z3Q~r`PY3GypA_fqpNVRWAZB5>3djGD*b-JX$}F@5!fVSDBTkVVx<3Tp;re2LHYV)U+tVf2^+D4`A$J+kL z7e7N}J|=?x*7jfe)H#vcwW+O6j~o|01dzF$jZpMoytwUIaUQjk(Fm4|W`yIRcDV_| zysNRQpcvF*JQiG9yFOlla7rPN9>7V?Ten_*Rl*eWx7~+tR&*yf(VKEn{Gw%>FqHm2 zWlmMR$q8J6HMu2B4*1i+)P%t(UQ4^)oiqh_?)6Q9>D-HTAWjc)!m#5C8eAs|@hHxc z_tRMg`@N_t_{C)YV9t&p1W|bnDtCK3;>BjLTnX|`)+bn5pwY8s~Upznm-(XOipnrK9 z<3d*86FZ>yR0k5K=14RIS0m;^31!cF@6&3?nNK!#Tfz|$k`{9s)NkuDD9YuSc>YQe zTZ(!JC6ymcuR4i8)+&G+)@ac!hKoF3#Z&8qJr-^G;`QmpCF+b2&WdRMr1$T8#4ViP zZh(%+Y*NKyQWOWd{?DB`GEB0jcUV^{x@lwxl9=Q@`}RFT%cCzAF+8;y;GN=1Ou{nh z{6vTcpn4HLBvwvmtT>JA>G0uXnf^n9{S1i2fX@cNBR8nctt?Vw6t}UIqtDNud<#0S z>-&Tot}-bNW|3-iAG8FY%$;I2V9zIKZJk1xn|vvd#5-GF=V?O#$&IaZXcyo!`0!)r z1yPda+AsW2d&v(*2oyftoG0#&S{{;$p&>Xk(H-BNlpm(u_t(9oOfK5<6eW5CN>G6_5$OiA?C~8if zt^HE^NFM1K20S_of*hdV(~wzu&OLp97SxWw1{O})jB9u@F`(X{mMhW8_!p&Nd09y3 zQ0DY|b-pnO2@{Qs?Ed`v;)0nz3N*s%k1%)mM_@|On@L$~2*p8Ph5RV%zJ3nirU8|ITaM-s&;ZymW{T)#Mbv3`l%cnk3>< zIn})v!9me|UEB@dSzT6kb`9tQJ3)w+Qq1OgI8(Jy!wE`Ud=?1|x^Mqr*LZ4wumos< ztk5tEeT@AHvM#NITWX%en$BW=trLpn+2BS{1()oUFl(y=OXRRT@$BNpH1s4_V9Rt@ z;65n;pT}T(rIK#G4;ZIZ=9=G9;`8BZY!)qQM5|&YySr_eOLIYkOJI5858>b2f33rV z2qQqxOh*ciB|WM2vTgt)KLzEf{NTabNZ5m4Aoe3WDz?Nza4!TktxNQoQ0KLMFf-j4 z%~XWjLhPak{|Z$^J=Yx9;e+Qn7AVrQ!Q=TKV%2^QwSb4t@vY!J6W7I(;9}xI;5WD1 zCrI~WWQPGP>Gam&|HaCW95W^tN=vs1{_lLw8l%sIm|H=N@H@njAmwnEd)+sOvMc;~ zfBK*YuXcQkqqwUS7frC_VmcNZ@dQP7lW1!11!w|3=}^s5pCLM#F)+9cP`NxKoHGgk zC|hdaUxdX1dBVuVq9gA@z*+O+m*_A}0(e}uVM4Y1GM79o(*VQXLHEEekIuv;vPDTUzXET`Wq6vKMu1C{;+vMRWxOH{boYHzTwkv&4VmYUjC#p zi{7t@4+$H}=uWsAfi1nS+}o6t2R%sI^S%!eiCE`2TjQgu)go}Pxx!O$^3YjP*fRL+ z_6e5KO#7iEQAoIh8G37C43oL~!G$O)x9JGa!%x6)4?@-T?D7>CEA_`ZR+@w|yvgkk z5GA!d-!JMNHx{Y1GjR@R`xYzfJLTI=BG{^P3+O_1EOzPH;OXE^miLR+Wlpy>3%>yV z=&<1cUQr$~Vnw149pLtjpCJ!)xc9J=)aQaBu&trk>=5r6iQyc@uXrzoUAtLaTc|ja z%0!=N8q%1Ph6alIoUqG+sC!Rs+SbxrjU@ZJx?U83TI?h6jv9dCYsnp$d!`R9hg!~g zJLJ>>7*b_B`ce1Jy7dR4Vi%s_a!w|7gFQ#0JJa>;Jqx3M01uSLGN$Xn(QbKp=kElT4W{xG<@lhfCq z321n;Z6(7r_v`0_*XH#=P(Fit-wJWI=V%exzwhY6|4UIh#d5IO4ETwJ4Idv*mdH9% zc*dLEvaqxaxU2L}Rp|GlbL@DW(#9GvE7=c*jjQYLLw%ru1nUCEIbRk0WUwfJLdkP# zzP%jI@jnYhug|!zR$>v0BY!ia$D)cwRNR9x>@1Yw@Sf2kV2F6ef07Q$2#fb0i$Oo8 z0Gw3!IL{4x$q>uKJAX^^u#5!aVHszQQhPZPNXyYhVA;`I!Dr6@o&R` zcbQ9a0_cs8BR`^k8s0clvvmTUpp#@ZqgGi(BZ+x}aewsPIg||vPZfpthDl`mP>5UL z&jltn7n~D~qaXZCp6^%D(W$qwB|yPyp)1O6iP7p`pI^Y;!dC)`Ax=YkG5~L<+1tM7 z<8^oN8{KJhh>`I5q>i2sRvC;dj6>dKS8FHn0ANFC;L&*sc?<~}R9LIuNKe@N-V(J9 zeQ@0+%i2mXzmW#?Q9&J%dR?GTyMnH;2`bHq5}B!D7M58@55C31 zDt;Y)8F+o`qb>uW?(3di*=F&P*-F>_)T)Y#q zZuVur;)jf|LjUp7Lp--_E5(dr5KPxgR7;WkGc{tS#l}(V;vPn(rs7sI_Hm`J0KUb> zKnsF~1==G}A1zw8Y*y`6;Q;#0E$uIcGtV~_i`(c$Auk#u5-leua5xW8%VfsJnwlR7 z+dL%U0u1xI`<1k*h}v9fb<0x+FwIF^(NBJK(UA2pyVyKcQZF{cu%A69-GU@9dtAY2GAuN_l&GBw#-`o#R;!sRQxv znyXPT{I|XVCE8<-vxrgolT>-)h1VA?dc<9D2JO!AkzQP&3~HfOqvep45M{phG`+7EyWyuci> zlDsUtsRQ4FBzfL0*c_Y5evAm_pyVN<24s_)9SLVy@`}r!rFL%tZu8lM448H4O4ew9 zVR9}gaT)PmQ3zkC!UokLPstwPDL5h?Le6X^yt|LFb?qh!#^^2n7mS%*7hp?l3VYoX zo=jOq#g7h81|3+eIu0x-S`3p<2jFLzA&oxWqk&F@#QSt~k{_b;yCSh!cFbMa?=u`^ z{OFHC=(fWQ|DiL!#Df2eGJDXL9;I#MspEj$!r7xKK8b=3m@*U{LUWWDcjGF^$1 z%7MOCP4XIoy+1xTyxA0Li<=dR-WFnwWZWyP%NMU9PD?XE8}06V)Z%oFnnb|`t#!1D zw$odroD-i!AZ~zs;R_J>Sxd3_3coHvR)LOU2__zLke+D00kFCRP6#D=ox6hyp=M9W z$Bx=ac2}|njj4e{hZbXh8QtMtf4jqRZvjm`$ZH|`#Up|WqO#VV9|Anv@G~mdf=0L6 zOE}2?hgi_^X@_^+^Tx3zFadBdm^a+bA5|N-fBj1Fz^ zshB0}``u@kx1PWHyUjqN;O9wnNBX=o0th_f$KLZ>-gh|1ZFzZfj?O5p> zG_sdf(uzEs@cxkNKy%Fjce-A_@6P=d{%FaD6ODn2-)8*Ufuotemo-*lIX!Cm39Z%u zoG-(rrA{D-vD@tY^ZMAHhujJ^ba$z4FRv>A>vY(#Wr?rGeZJL?ImCW2eY`&=#E2t9 z^Brz}SR$tM%RsomHfPd~Yg8^oz77^_U6m9A};E+B-`v4Z|I8kqItrQwKyic$2W_4G6mv>)D z#@tjQoetSlAhnSlzZ4LHX~tsuYvQci1uxbhf&`v=AD%kE<+7Lq1GTZX{=ZP3nJpI2 zCq}6t%8|_=k*yj6*q||4LDasH)^OMiQ#S^QPx{h8P9^y6ci(?&#oZ@It8eYY^J{jJ z8U#B$V3GjsYnnJMcZ25P>cr+Vvi$4pukSupBE$RCs@uAQ|9q`y1n3lP)5^M7)Pjei zCN=}n>M06!L9_{aZ@9I<%$nOz>cM? zk5|+__rgZ-XkVi66@GKi_ldxOYhdCl^;377q%l&WX%;_-DSEBUmq98_1KUJ*bcWkv znQ56HiOxWr-Y7??DWwt|J8^&Y2|)8s_V&qrLp-JnI7Knvi_iy1Ueyt_in0GzP}#YC zE;>wuSg_1GtjrtqC7?W2K#!>wwj;Ho-fXUm4BwHm4AVo%obAt#)Bbx3K}IXrdf`G0 z>RnR$ukmH?TLuN7J|6jdx*DU68ufTPl^Dc-OyM?guba-~2#&m=?q}U-v#+v@Y2aDa zaARsMEGLfa+>Gq(g^-I!&S@8Cw3K>vbCNKrL%1#v#aas#8=|(?oj0KOs1Hob!KkK#q+Q7=>Ojnc$UuR??Z6;2Pqyq zhRJ@IWLg3s@7bVMh1?{9O+f%=#6q}1cgmDnEc{Xqhkc8Fcni~ zD4a3M1O?eOi7g4ZByTms^4G4;bJC1v$PbL?K{)21AS&>k_3sS!>w*!UGxN&Gco0KZ zvBr}Hy~B=T>8`FWU~t0ZX>|BxRn}MbXCj%NwS$?=TRN?_fWGE=#sXt5!-dq*2j6W) z0jd~EVI4B7x4GB(Ku@0n<|nxl!UK)azc@mN3ixp?f@GuhHlozo?;zZ-?ar{*U*wcW zj-)9PVKO9^&$2@<*WLbOeMd$T85S3;UmpP9 zSQD2J-Y3K)?N&m!G+2Fv!A@QuBCwhhDRC$gtVELBGzsVs5v{~x|IdlUQ zg6karGil7XqzxHswkGk_L_15&BMj>eooSpK(NCy(6SGhDro~q7L2zP-9B%)sA)SFs z|AVk+gN6k98xEKxLBAlS4}@a^oZQ?_U}5vX5e;LfgTH?UUH00!T?))+@(qz<%u}%C?sZeM^#fIzog>-Lg=w~0O5|O@>GB6- zoRtMY)Z)cLcy`|Jm%pz1VF73i4?_cvAOuiID{4WXoEoIKbaGW#YKS)4bMAG2lW#NC{~+YBTmT3P(}NWv{sy9-h}_wKg5Etc4gnd* z-L73?H((Ia=x)LVC!<+H1|`&o9$9=Ck}`L{=?3U&qccc77ux@HXI!)D0&MNgFYt9d zzhT}m%7O(2QvIhZ*jBnOySQ53_a7b!7MKsOmWJ{DV z*@!({UE%X%(s`w@Wd)FUhra8Py^;8UbDb+o8BCn$v}scz8%|@XCkXys4W`es z9TTWUiIF$*REoh6P78hf*Yi9@gjkvaRQB-GXf7b1(=f5;<4{;1^tqm=U>vg=?(`B0 zXv)-5n7@pT_;GjBOmEk;~CF2WiW2@*Z|Uj;V0f19e0L!bl$H zFQYX&egYg!!Opz%eLTj~Xo9pfpeLX!sX`3M=9YQgrIIBCX4D%CW z2!@~=v=tnl%e9XlQKB&k!#iiukECl9FW9ZW(`&8nqk%d9>F_M&7booPC^kn12ghN| z+6foTgQ2g3IR8zU&HDe_0Ja6R}@ zz|!ZLFVDd^D{E!g-FH7fzsSOw&&kYC=3Gc!5xff^j;qZF9>rHgBaB0&NbCkGu8JwnHkRV3FE(+RR- z7&mZDn{JHc5|^3mCrh!LvGuFi{lc1zvfjU68uW~|@@mIXoUWt-=&ic7JK;AFo2219 zVe*ES8v|?;xv?F^!x6hTVZg#2Ce@q(nq}X}p6P#hfj*&vZ;$b#QS{TnE5t|zo2KZy zq4B@@?9Kh;e@jz52iTmx;qpv2)y=x3b;d6386zX6XR^^P$f*n02kRT?;#OXv7l%7owSrH zpV56&p*$onej!Z$2J(`DnVA>zqVsm^ z`E&SrgeUb-@AC5MWYus3l$EDJI`2!s?xK8jwzv1ez!k*lD1A>q3+7zF^Afn|+!L!b zP*#mXcnhfsBw(r}0I~Tu6b{$X`3hc)(@AWfADBsWO_M!9bGMka{I3Nrn}dG2Bl@U_ z23^**%A#nB25)IY1EXj|0V=p(+<=iyMBY^B+DCO1M`OC80t;ErX@k%Sm?zjzk!2qg z*Mo5eVPkgDkYETGenWl54y6SzCQ=6E+2|cW&Jq7dc~%^bX(|82=J*UCmcsCsfvXuW z(fC$9M19kB&t1cDIRp!1VKai~QX+||PXXCpO!C)1O}$=hI~h~#k@)(BI1KuRhG>UZ z^7)3^8ihze5MG5_BKf6{0K4KnO~`Eqd*O00)B^W9JuDF9$S&(BfDhK-f|JczEV@Yn z;4Wan_GrGS6zfT&^V6OO|4VC7Zt?d0`){9vOfdmNdPBm)CIbE9G2ypDU`RZYyYW)Q ze5x02qs(HfC)$F!Wu2AA-@PG{0J1}dSbT&1;L*6aG`7Ak(YAQo$dh6A({Jun6S-gN>+!PC z0CXam9NM*A2gl6LBwZNDNHplpl@Prb-IYk~+z7M&_+6n)C|2M8-aDJ$)3ESMcl@Zw z^yj{7*E(l`(HTsHBV5M)_bzvQIyghSr8F3!d-Jb9SVxBJFe zo^GHf+s4Iyms84@Z~-K^n@#HWo}SsbV1T@u`N8VCy7q5?)s7>9KFuankuh*7RK=M$KqDR)Y0J^6G&g;Dzd^E8AKE(jA#${j!+|-yvPjIukH>=@iih-Pz1A@x_W>|(@bM1`tZ&Z* zLy$(`wGIU)S67T1!t|r3jrStjEKTBZnY~OtPEwn|6!Hv-|Y4}7YeFvNyl~#f% zn+dM{G3|^;kykd*-bJ1g_in(Ao?}tlhW;W!WEO-Ra@l$isb=%UMYDgzfRer{@s%EIh>^XC5D2Qqp_kQ@ULqH~92GuL zN?xvbZ&S6tldCJqr?8ftKxNhcEpZa5+VFhP!tbNi7^$tG6~68xt@(KAc>fsuDtbyO zxSg9d%11xHH01&K-SO?gG?3Fb5-AHtIcr6&wo%s1dHrLXnxVg3TJ`MI$ z4jPN}X@>t+#~vCb88{Z8yc`7-NSSc^evqCFNKWHAhirp=<>UBq5YDrZv6ZLU!sR*Q zvi4+5k-y+xKMw&>qLH-k#~duYFSHFfBPz8pF{nyE{L!eR|E+=OV;o!*kKOaj_Ac`p zI{W)!K~x%n@WOI+lc=WA*NMP&2JSiGI}0?`zJAoZB`26d8MCo54HE=mso0j@zU z>DDM(;Rdt|+1d72!$+?F?={;tum4?aPUS6pm*E(OdAuE0F_El_-6^h+?6;gYn@zSo zr#z*N*(t#Ehq|s^?-E@Avmi~fH4n`sA;40n$SsXWJL-xXNiPd_+Mt)el1>`=TGbqi za!-pww+}=?Ac4v*ekHBD4xCxE~c5pPXP4bu)KOOg^_1yNha7jgu~1Fu3V`* zV+I7&0Np;v;9@Gc`$%%2{^du)6ih^8@?4q!LJ}T8k)fq|pf6$Kh{uKa!Gw6CkS3xj zJ64Q?Lyh&=~{Ds&&z_0aCNu|ASUQY~8h|sP`jQGa> z*gxnFvot;hmrm`st_v7mI!Mfl3qR)%366!MhA1+7DrbErqHuNCPZNoP6D=q+3XqDY z%#I7g5J42%a3*E3o$2;;($xf(N}vN3qQdhaLZwl=L?Lef1+Nii#Px0lASN z8T(Pnj*0b4jdQRJnYmgZP#;k5`2MN5jjv8>X{SLf5#9?GEy43i zjWuENZ<#*yyA!KKw3^d<@S|DRv|o^~hBov5M@W4%n{o7MFJ|KkroN}u0}Y9?L$%yJ zN9&qsbBGblD#@f`F3+n=}0r%K_R_+@AbRaChZT9 zDBz%!TR=t+&X&|}NSKM;nBx%fg_LLw9RSS_tjJmgXFR715nQtl-SXfXUH($kdjd33 z=n4@!m*w-q+W#H<0gUtuRplJ29hh~Hv2+BMfgZ*YUFz6CA_^zP6P+eZ^JG!^$4WL} z7lv-ded3$$85UDj#zgK1c!m81fEyXqkExr4Ma{i4GA-Poa8s*;#exN_^&RRYK?)R! z>o-iD-x>Nm7iplf7e{EW@@|` zv>!({G!WwbEH^B;(p2=64w^1d<7Uw;A~lrI%rvMKx$FW7!QnbY6mDE3knL#yFYRV9 zi8ewMV_o8_;dbcB4JHd5cuMSy=vhk5q*DMF@jJ78P*~i3@Sq-Wd5)v~b@sD1USm$a zSLIec5%9w*u! zsi0o3avElUS~4xDQ1Mr#inlI2;He!yPY4DE41mor>oUB{uChX0ucCwbRMGXVoYFs2&b@FoQ&9aRuBu}eD#Z2@PnQcNM(NJmZa3^pYuF);^I4HaBD zDGJ=elO)JD!c*jnpnV$7QJDHll#376Qy(vXQrJm6vgwzxI^o{iS~-w3QDhfLee&{1 z#FZ&IfY6olCo=ghM>o;I#`RRE5sS$Rg^Er{oT;q^PGqs&Tp{IB%`8rYK?K?u6@E?* zHs&$@AYX*)W65feZohVg(xK73L4X=07zbjx{pZzlcnLeM-uF7gS@6(IxXC| z8TYQx04}?@lY3RePeC9`qNIw&XUdl1SKgZQ9_l2#3sQ-Td+^5R)rN zPmT%(DxgYWMaP_yLHi5z>5 zdXq?Sfq8z6I-||etNH)ZyB(*jt?;zyH=PrV=v@Ab!XjXQ)0ak?0}B6B9Dd#|LWVW; zQH{J)y8@G?nuo(s<)>mfG!fhXoA1?(d>(v#@HV)DY?EgBTp`|UEk+d_QDTq}S&Pl9 zfbb$uGZmnt?{1JOnR$kElWd@}NRrhLc$7Cit*S5bF1XMNdvx&Kfv{Pm$>?J_Uc-_mGM z3s$7$HP{=YD{um69g$F5`ULzV;#zCdKtO(arlzbaN2CzonFq^y?>D-VT{;&`E~KVy zjB4@tt9>p?hG$9(5t%D0DLX4oS}_!W<)zRTt;fh1)?pIxMd-!?bStzXz?D(lkCl|Y zrq4H%$gB9ST9paDC~Hi&iS$qkG7&yCozC0N>zLqDW}D#A%P0w;Pu5+?WwDe1v<%4B zG;fnEbMIH7P*Z?XN$k==i*V1!Ht#I1VKvdx(Y|WnHEosUui^=in3t;nO-Vv<&54{+A)i>XkL+ zk)Bi9oWF?vJLT!bRjj~$)kx}>4el@0$0pdHTqjZj6nF;WA9lTf0t5663>*QNjR|cB zYeaS!S~cjr5E>}7rk107@w&DDZ3k5^MX9^Q{{PQen0p&%;f{#Y2f*yq909-*ryrR) zZ_+FE50AE42M`EX5gGnR#@++mzgygE7DNdP2*_j)-V`)zDM3TS-v{zkH-1#(ZBNm7 zjjT%~pTrD>K5#h6|J<;Nhel~8rhe{GaFIPh^JBGQ{_i`B!bsSP2!XtIHIO0Eu7+`w z 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%0AFfJPzIiqaFX z$qM^m(jwc4(h{&i01mcxbT{C>9N%CpiwJcqMZlucRP2BR!;PuHk#9)~ShAZEw&VeX zUO?Rae|yNe^9vmbbe59a^4ef=1r2q{WMix7=tF1+?yL+oG2do`05otZb^_Ohy%E?) z5*W%nY$*TdhmhyGQa}TA%&wL4wu9wUAF`tjUbYEgs}4))*oho2VB}E`Zf)OI(V@Vt(+(~MS{6F z&Cr8?4+0%L32Yj7rbA5zg`HT2{g!<<*d6>0><5D!mf#Og4o@I-9UHOQ<^-4(kA(xj z+Cg1snz2FGVs%bfjBH7-_)~m2yI$n z3p?H=m!%sK(tWlPzB%R1g1x9q8!yI~=ED@?N^qVs_@Clgu-D=Z>e6l~(E$};a>O63 zW&cRD<0Z&O3Ml#S4@Biy!RBeFldtO3T}6%W)r@Fk7iAM^yd79;SVhp8V!Z~lnq z8!~Nv;%;5Cs%7rnFDK|fA8J}g+1GQ#sMNLgX$sLFK1mHtTZr)Ba9#DF#MQi?!~ z)3eY`c|>8(o`*)31njq>O7aRG)eKS4p4|G?&{4ubx(~LQN%H1^o~|HC-ofV}LdqP$ z#q-wwR75xYuMzIaAMFU83C)Ai)?44e945L!e~D9mHW5wMd! zjPUzgjgC+X&YC0OTVQ!`dwe?|h_7ZM9)Bt#$fUV{aOG(v2gLp*nfc$x1F z@`Aq*+iN;s56ech3Cci=}F7 MP^3H(HYNMEN<4_0)O{_nNo|c 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/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 UQ#xM$7GwfE8z=59EBA>10$hV@WB>pF literal 0 HcmV?d00001 diff --git a/src/main/resources/templates/image/piece/queen_white.png b/src/main/resources/templates/image/piece/queen_white.png new file mode 100644 index 0000000000000000000000000000000000000000..09aa27786892a60bcbc51e2dd83714f5453aceb4 GIT binary patch literal 115369 zcmeFYi96J7*akcZWl1Fwp)$x4*^{-bV=aZGK}E8J7}*W=q->S3WiLxY$eyvcX_Pfg zb|S{U@7s6%JkR@n-{0^ZujlBgW5(R~@4oJ9InVRDCit>}7Bd4U0}6#=#%QY>p-}Vz z$e;am@QQe<&Nujr?zXO$I%*gB?{!sXBnovBg;BqF%`}St@WOSH$ zMG}2R(yfF^;QAv8^eIv`e(GJoKYC+{vlXj5zMbBkt=4CoKKl=NxHWC|)eI!S!~EaR z|5@PwEbxC8_&*E$|IY#~*o|yPI94qx?xpo@LM|Z;-#xHBv#YXFtb!LMea7(U7kXaq zp@QEybPfd->h-uLf0qzx#i6h-a%Z)@_-S<{-QZ?%8_zzKc58*gPy@QLh=A1OsIl1HASa~OT#w^WbNSixr| z^z>muP+MmSyb z1X@Mk^*&)1T`oW(v}wXhOZ)Z~r27?y&exL^oHnlJv!9GIix}BJn+ldoPTx<1<&YoF z*(Vs~_>pAvS+8%sNh5p?79#(?5un+1mh`lZ$I*nvRN<@#zq}NwiEAsH=HGXjUP@p_ z1Z>l0lCpTM8{YnXi>9al_f-l;D)Oi9_Mj1+?0|lu;lD2iB!BQCxJ4>P zY~0FVGDy~THRx`}fm0wq#P%x~|A-B$3?}^<14)H{UsN^i5+ku?@oMYniy0Q`|NCOV zb2&K@KGT1{P>I>Ak&pkrh~l;jMaRDNpF7jo5F4q7pd=PNWmW@H{MchuwG#R8J0g-KttER}@&qMI}Poc`NF zZA2b3n&E%_OkW%?f0r<o!WcvG9jpvGDT(AH8VgS`*5ZW-^pW{qb++U0Z z>%XsBMJBzpHlBDI(AHxXHxdr3zi!>gK>~R0eSgfzC-mp+(3Zs@elKH!2F6Kr26m{u z!GQw1Ns}%4<;5|U?uW0ZiIYSKiUezm2kh{{egP6TIjQ{%#ZK)$!N!{fZ6R2CVQB}UC4ho$Li;eYxC4g_9-xSQC0vY+xJPrMo# z>(GFgy_5Eysp{-6o}HO%@Mc{f#v;o4iu+*{D!@YaJrRCK^#xbtNCG_Z;&jvqUhudv zb{|+H){Ke?HTUzaK$mwTS;)?rbU}XlV&gxG%a3tsd|KQw^gSn zB4o-v8V9JVa>YsPktfWt`{-J1BP+{^u$F4RBqTiVjt^)BbQd4V2~%oV*cY$TqfGjE ziZbUy*o^Eg6IeyBn-OU3RCEth{AcwSh9-`j+uxr&aKBnR>OrBnwC2U_8f-Y+FFO`9ht9?gtpeUN= z0$vXYG?72`7Csf1+0Eb>BYR)2G%kVJVy(UG_^j^SPZ<%kb3V(`HxY>5}tDSCPeR99#VDb z7{8Z!cTeVyEJk-B6rEz=YE8WJRSK8mc6HbPlw{O=q66H*sdh$@JE(w}0$qX}+6&v= zJZCco3HEM?YLij$A1%>mU=gSr>B9SN8%`)zsUc zut*TaY%|+oX7m=Gqwl0lzoz2)+1Y&BuyO3a-|_M%81kDXZzQxV)UO*8YA`;!PFBAv zg_p_2+N@IlrbAq1(l3kUqSMQA$u@mvQ6owiO_g7D`#S9w(KUM8C8BL#dRY|=;Q5$B zb|9mu8vd3fsi5Hu?BAMCCf#-7*z% zB)tR_&`P7uUDg!vvLyU!>)(j$cd;cz5`6PN(o1XL2?>#UIbzh@Q0RU5&Hjy1t|e1Q zJj72+#bqwOYKpUkWIcn0F^mAZT$#jL;{LkVoPb0i?$z1It<$94TqIAnFuwXgvc+T9IeVqSlra@!%=1jtIsk_$Q#ddMB z_isGx_Zkc1Rq=nkBmY8a<@yY9GEemShm(xQM8D^j^~ak#mGiSGEw!AKu|4Y_u_A26 zd-73}v^?oKrc}3ZJF`fV|Mz7|rd*iz+7>elz0bt?K zG*&1pwJ=@RD+IDB`x`#Rn2{vA{G(5uJnRWY*}Axj1FQnpO^NdIl-G|J3S+B8D`u;G zHa6&H$=yD)RdQsk2R85HpOCH1nq8k`;uebc20{mXYzc-Yv8d#ZyO_89an%C9I<4(( zvNG526MBB_ocr@g#&S&1>qFsDa3lYh(zZQ#sOX}jeeY^+() z-4d~?rMAw6zdwEiRXY?pb`^GJ#9DNF&xcyx+_~UxXR!aW-6k3zH_}#Y`qQLFkm;^} z!bm)NS86(N?t?yl9f^y0s2ImFCK)@UVL1O|{PO4)Y!Lst*F=7P-uJno&*t^Kc;Cs< z1n0cu`Mff(#nF=I3Ns%&;hi6rHDV2qJgwQ7GOl0_>MqO|m+9yEv%LHH32mvjz;4$W z(}}E4bNePCKVwHA3}*^B%jmVwiRg{V?BQPn0|W629!`@@3bXH%$DE24W-E&j`1TVvc3*T$oLN zuj6{Zo7cM6SIyEBSC$=sMjJ zC#JnE)BfPNtmE~`sH+BcXUz)Jy)_jm;C{W{n>_>l6O)r7_&x>cG5X)vKmYRAt1D~k zZ}_<3J=576zjCZqxg7x;(rpEpn9Lo4kR^-JdbbXW;xIumeq%B-tq>lmIIn7@d!l^m zWyL~+h`IUw665vBfxz`y^c`x)X9q9_PzBp9KUYP4#Wd*`4ii}bgrI6$&MTYHY2TmG zDfD~omiTgG@@<-=&&pJ1szzwGZGjDsH|10_UH``uyjFgWNh5a(5)9o<1lH{dvC5l6 zNXg*1>5M59UY65U_m8k%Rki(iYMHF3m7brU@4hjfS!R-V(@g2{*)sc%?9TDb6bpa7 z3!-FNPuU)U^=ky1tQw2IS>>llhaFUKuomj^@CZ8RD&9?f#KY@6saUmWI%dNmgHO`F z{axpn%I^9^xx?_*WX+C)!^roDzxA1Fg%?OoRLM?bXv^m;t`9Gb3VQWP@oK_K0fEaZ zMtCXpk+=mHf)aJ(a#>c50cXnmaD7?zYSpZ9^9`=ac!xYY{a5GSY@K)4Rz5W70X4Je zF0bKsi4a#z4q7e+|AT+WpR-ru@C7e^Z% z?iYML_P0KVrtoC#?_!mJrJi=n$ijKEXmGV;UgUA8mWXJPtN2AVYizj+>0#jAF2QB8 zW}1}yM0@Af`eKf44)^fe1Sfm_cJJB zW1E`VU1)AjXP=H6@v(DWS1d1Opm9`(0te*v_a6k;tJ3#~lbnrq?K~ow8x09zjMAU6 zSv3NjaaYnbOR9IbXHCW5O_^4A--?w44mJ+`7HYR5I+hQj~I5C5E{85O zHL1ncjvz${V*)-?xXp*c)nG8y2`h&m=#+%lPWYmmOfIDVoZt&%N9_1O9*!4NGkIGr*uuEa;ERGdzc@qe}AmI8<$ zwe$UZaSE5ow%x;szy@;~_dNY=nU;?~la(q;z*8r_7GdxFZHUg5cN>l3B?pZT(Dd2u zqE!sHWds^Y!x#gDHg;4%_~6t1D2mfAVWhEx-wLG^G4c{kHfDb_7G~(f-vkInf1!6w zS+1L!Hsixf#wXx;44TGa9Ak@p-+1rNz+d1VqF zVOtkM$KFw?u3nG`s==ik##AR-Crq4PN>sbEwt3Xg&#!##Pbf2%^$>?F$?%Mi?hlAI#4aA zd_NsR5t~PfozL7i1+3o%nm{3OpVDw9#^N$IRp{aGTTg$csHhBo3(v`G>wpxOsI>B% zk414#)je7uF2!2Y{lIT+zDVEG!G<0m3j7HpC779ffJf2^Y_%w)0F|SIYLS(wqG27YXc$_2L_m z)Bdo-9E8)VQ68ZyOk!V8a&uG&Zubv8XUj<=d>e+!US36*a?(xY0e=-`=@Rxk@?u-UV4-GwK`W!L_xbG330e9NKi>$x+} zyIVliY?fc`b%U~IiA}>;+{B_}Yegb^Us=~roW@08v76mmn*UhCh*G3cIf+vB;D}sd zMyZ|iZe;}4?|y(7Pc_HsHrCWQQ_;ih^G-iO_AC^goA6u@^xK4hhjC$KbHpx@FYuFM zf9?1kLJh7u-l0SF4Gr7vF0fSDyAvMo(NS!s3MuWuqB5Um*!StOfn;uv;%B*^upWKU z?3IJGX63FnVE;9JLa<%Usv7Gu|GE`{mR+|>5eju3XeV}X5G`mL8*uwG zVM~`#05ZUZif?mrn1u~;P5)e33zY1{J1>+_W)y3Rid#%Q5^BHUtC4k9((Y2l@a%0ZSuis&pC9y|M}|H zF^l^tek&whiv_|2r~c4C>2{iLw?$2Km$Ql;2)ox8*-(^Q$o-YC=q{Lc@V~wllvy?X zXAUlfS?w)aFxm6AJ8h?nsDCqqRlKzxAz#qT-Tkn(5AB@$yz&8*Qscu2R7>1OIP z=O1J<1>`GW|Dm0wHIoo?#{vx=&%wYjPMK^X113fc8$YHr>t$By`M^Ee-s7uVfL)LT zM$FLF#r?2n{1ePUox<0^XwNMH0SIVXij~-UV(X?!7&DE1Jscjsct(rYuXxD$aTvFP zY`%YqMiAzq_Mb25pb%LG4~aKQ%aF?MDBMF)Fvw}V1o+o`CXTeY3=@3QiTk*nGk?nn z)t_+FbEi!nbn=QdaOFfp9%e*5}m zf*d#&^9MCT4nYqQj+mH{3l`J7YrYgc zn=3}eb<3OZ={ut`r65)ijt4}8vIqb=6N)aop_MC>)wdyl5G z8C%?*YcB+YqaHYjalPn%0A)1?q)K&c?db${%bQYN*GujPE*KfAh&WHQXLZ@cVzV7S z9P^nf&=Sy(zlKe_VQ87gRK88{6~X`k`>pPbalL^o;^Os+6@?4x!iatrmbPh#ngTY| z>gWH=|ZWt=gtH+3%5$bt-L>bw|egeQ+_|ErYWM^}> z8HrVdqwSh66|eHIlhHqNLR+ptS-(6UKyy&rGDYj2T*rr7p9^<)HpeD%^7HbHvNH3p z1hp>`eECQpCr+PJRZg_NNDx8j^W)EOFY)=}qyf`d3ctd1@zuLciE)0beR97t4V#z7 ze-(9@nBQ+xaqGx7F5jG~aGT66ySuZs9w+B);q-ARNYtXzGvG$i!Dd6BlFx$3g9w5fU7!Q^Vq^u5h!^L7g7Gu z`ru!xx4nKNK4oh}u){g@{by#m-pl^U(kD%*q+azWZn)jF{@`ZUU15MA2epyf_JKo` zY+$+7%XuDEIqqXg9wq~2mN~{bCM9{53k{tRJKcL|zL6;EAu!JJz9%nB#ZvcI6ifYw zhd_TXuY0uxOr793v5EFlTps)Q{qhJFSvu&aDL~fOB9aIwtXEzs==}3FG-sCV{BnJ9 ztZe6x_)e+}1l0ohL#Qjxs&7SqyZlDXgW+$+HQNO|Cixb9oJ!uf^>w4fDjFK+B9KFN zwvHXoe*Y}DiRyI@6QbR|?|6=}z+zK>=_f17^X|+&b!%2y9dX_nb(ZwsTAR?}LU=ra zE!=wUm;GgS_EZaEUL5X0d3v~0UHJ5Bf;#%G9;A)H^gs14r5Dn6Q)qt{Q$=$ zJ_0bcM#KSWK69(1?&V#*ozopId;80?%1P{O15$)m0eW{i7Byy5NzAMM&n$q*eFEYO zu{T{Y{!3}RHW2n5?icz3F$dp?T^tUF7$99Pa64}T!e~IA+cg4fj;?ATcVwa^mKw#u zfn))_1b(kO?!gA`wN&&YaK8=mV~LT$tb!)wGk;J9-nagDX~8P0-rekE7R2UxGUgA`Sp>=#bMsv^FXuR+>;CzV}M3D7J|%%dy<7| z%7T?#^?XlKqb|flb&!7Xrrnzpm}=97$@jkFx|R)h6YiT}Guy+COSuk*%ZkAVM9f|Lm{&9=cL)Kj+p@(z8tXxRBh__MiZr-)w z{`Qa3}i2QQ<)n8=Wc|(F;;&};E3ojdk^F#kk2q#%Pxl?iGWMcu&AAF~4G1?702#tL=sSPq_i3o1eR zXuN~#VBo_UKUv$v2b#(otuIW-lzowrC$3>1X-wX_&nLUgq`Uho{hw!vsq!gVU|$p7+_t?} za^tyiA#??}9dgjK0A0BUzha)l-zY~8TpKxV|3+t-3Hcrf**~)(5|_3f8_$A{h7^IS)qZpA zn*%!)@ThkAXlI~X+|~)`S-5Z1dllqSgLcqQO=It6<9EjJO+YGg9B{>p%_=Hxqd&9q zTCGbh$Hx7W(v7jHZ4ms%*g*G>!_O76MXs5%fhC)|>~^=9-`CU_EL2V$LDg>x2MAXPj1Sovt_i{!`_cjyKI74GBu3%pWBlXd(Nj{UPN&bC1^z1@OzTa6X+oqqx zFH|hBnRcay3y;t$A~P3@pxI>P9xPne@9hAvu}-3auY;DNjR$~K3Sdd`>RUY$Ffu8~ zrH-XtcaKZlRwsm?QFP{F*eM>_hPLM4+s2Kf4-97le+u!d$HZG!m(tZyO7xtOeRN3 zSsZ-KGP=^^-28}^vCyjS5klDzwhB=8f_9@9UD_`T+N~x);k8AJ35uxp9%0hs`GLQg zYd~vb%iYEx7Ibn=M6|fwuT?MSIvbnX#m}PUi;4TfUCjt&lh}7SATidl*oRqpby6Qe ziIcqFT|B|rQ5`k%apDLr$_ulTPE;@JflzQ=8+tnSR~+w!fHvzNXUk3$&z89UZRqt~ zY+MJDkl^e$XwWoC~CQ&krTH{CO(PkOM2>7048|N*qgXvImi_Wu~V~Q zai#fsiM_GI?)Iv<$|&;>9~!)i`b0CSO%GJ8lG|THCdx#T?{*d1gc}C z=4t>R6#^i=+f4qHYIZz(qZrKKQuQ9BX?GHTY_Y}KC-#_{hu9b?M9))9o5z^E-HBb* zv<3zLp3?jm){fO@-VH4Hwa+FX;H(!oUlwE8sw-|!iTqnWk)4x0knI`o?7x`scT7XA z(A;YKCShZ-WLOIDaHp2?LPRHlUpISzPOcj&o6{jh7icO;P@y>OuDesAC=bMSpj((K zgcKSkUS*&ghH>(4cb|h?0CdjPick$j^;;hj!|ztWKgx;JhHm2-fbZ`;GRDm0h+WhI zrY_OJf1wM2_Cg?w?@3_chW(4ltJb|AA9O^^b|2O{5dl)2M689kU1{ILo{0-dPWFVo zl7v!a^*gtm((9ydv6RYgEWV#&=F$5=%VBM9=6zf+gjhF>5z z`VG!=Bf+`aYu&3gpqK5s3O)tSd&jN)idM-Ck{`>eFBag&+d4PaoM2;=<9=T$8E2fQp_r*3Uv`h9Zvg)I6^vhjs4xqq~-1f%k2r%9ET6z zfQ!ToY>mow$i%-M%h&Jx@eJ*pCDs}YIE;W~zV&Z%)e#U{d4Nkez_FSX7k_Sz;dg9T z2JpLZRQqPMI8s2iBp@rlD=`I)@HezTAiE__a4Jo=Up3UXOktVLAA-%Da>ZKqv14&p zAh)e8WvXDYL%T&DW33O3ZMs+TBO{enyID_a?mt8ZA_sI0GSo>b5q@u1$4g6gRnfM~mrI&zDOBtfhS2|m#tK9D3$ZD)lCGC!VTZqa5*St-<2~=?y%nqh&w3k#~-F^LM@HL{{c+=bG)* zoDqzNl@aa$hOlJ8gVH4&t*5cFYKRiTO?I9o1_gX(QAw|z?w{R|YEdPNX$0BAB z;ZTUSgo{>`7a|6rG2Y@e`(a00Ph8;9MArtPR<>dbcXt`6Wx;t74A9odqw*9csxtti zL7eR{Htj?8N=g0|OG{obq9Jv7D}PiaYZ~K79Yp)#yFXvmfj)Es%P-Vd;W74&%XuU< zR4gQqzgzbIuj9uFTVk()#c7o=;Y?akE}d4%-rY+Ht=FAe=0Zh zS;26JQ`Wu+ri!FnJq1^2*rhhZ1z%Hy?A{CPyH$o^81}K=SQ>{*YTN(wnb@0j;~}a! z0d7!{dLQ=OU!t_~5p|q=p?$X`u|GkMiQ_Q#5&<3Ui4w&ag|Sd~wDO;3=9GR0lthc% zqItr9ZK##a=p33DKvbQV zr$c4&$WLbI=mvy}SDzRsc!iGcoEExmFr0K^|4GO%I!%YYK= z%-$}xO9>M@i6Q9hUCXzJa4pj{yF0CH?f>LqD+-&HH`U3{WDlL$68hLbyxK}@w3x=b z{p=}^_ZirQ2)N}VfFbaK@36}{;;QbGo#8-cB9XW-C6!D}*gI9uYtCA?7q>>uJmkj^ z9(nDVEjNu(y~ks~FHPhg>rGx%X|UMqbUk|eG~M*{f`SO4t8eE30cn|Lop-LBr%T!F z9s4fHtF*1`5co7r_l%wSRU&P1KO(u@&97Ps$-8p6^!IH>r<(1D8_SarQpU=LnuPRy z|K1Q)EA8p!sjkRdpM$_?0_RWeW2iPf5oSxPu1>~8 z3KZOHO{EA6ZP0wUK>UXwOEq_#Z`SS80YMk&ooSKZoq@{0x4S*C%Z=qTMiN65iY0&_ z6LN*}I0K}Wt5_^IRxRP2>&SNsgAj!mt4fMHhCQkA>#hDUL02p|?}~&Nk#hR2;i^QL zz6*=Jo1&+8$|HI7KA<;EpV%Xi^dujIS{q`!j8;CQ%(5$POn&j_QDZ5)^H~rWDf(MQAw7aGf#30QAWFLd13li4f zUs5<*8T>M;WhdmVoFICVpinA;n%FAiIvGgMGYAMKEH9#PERY?!p3n0|n@UZ}n~q4e zqj0j_4?SBtShF)(11F-qM*NvAiN2PA{(5Gqc~0s2PkNS#E@23lrAZ2PR(5Xg-*;)x z|72w*Lw-^Kw8McIcdf$%Baq%=;?x^jUJ-mT~oz9xo57>=coM*RD8l9Nm!5z@;`fGV zk+hujCK{{zOX25o_r$U**lVk?%RXdiXW?1l-8z-i;6;U$)oa z-^>OiaphetSj~!GVw$^z3yy+D@;@;3v9R>ZP|Fn4f7MXw>&FMfo}fyl=A_S*FGtAQ z)WB)iTAnI@ff123hocRHb&tyjA2EWFtVOJ>k+Ku=b1&?1;bMnKkH7kIoO?a@q7@FP zUoJ#codDVL6RhbgFeiXyvoJ2X=U+qFA?#@KE6JmdG*cYd(`*Pz8E+>=SZYC7E^h5? zS?ruqBc!YPb48(rkc+P5#wvqmJ~SI}lj4`Hzrp`fBUZbwEkif%+%0NkBm);cvNdI^ za_7&NU{Ui@QKAlyb<|2?u@LWbv6mr`L1Q5&tCP>9pDpVpFp5{6BWmibgg{a;iugCw zFIiIcmN>lGU3N<|FZ+~&Kej`AIdXI_`shnaN|54)B;em9eaty#fm-2#%}5R0QcmQ!sPoR3OU~r7k=%dI6sDAWbZ02Xt6&Vp>k3F zXz;Z^v-^FDCj0kL(H|d|+H~drJmX{Vs~DE+_k0X@;=0^n3RdD;jc_#G+ryx;1xfgO+ z7>`ms^sCMhb)IfEI{Sa7w5F~9N~v_IjEg~esK;Iw3j<3%LSW%u-ab=V)N~SigJpRSRb}ML-hs?GydNORcFq3C(; zDX+gL*v!+t8jZR5zmX0?Fe~<=jZ0EUm7#GAFAY@3N;^l#k?fp2Pzeujt(4V-=lyb; z`8a$~GmN9o(0_ro@TZEv*_TvgO*kA={rWNJaWEl+4LIgp4**Y^fV!UTg}L!i%}KCf zdP{7rm{}p3_^9FEy#5TLM|RB1${Y5ISHUZ5op`X1cXzEmPRiB*mn6Fg`NZY>si!W0 z-sgdBYmiArn}O`9x@Xuczlyr_KB(6)ZJ|4;vgHD0n-$AP3$O*U*Sozl1<}{)B=22P zA@(@-4C{%*4_!2HRDZu2K=tcrZ$I~N z>Nkb6Ta}!LT?bAIzCinAAccU|nBTjj9H?A?=*m(>-ZAY(e8WRtq{@4lT3R-P%+Phe ztnZbi4Fl9pM_fjs5=eX}pl89vB^w6xq^n1%EZjDb9*!axq|W~AA;|A7K-wvs-YJGa zZT~|KkYE1pIkgG=jx>H}YtQk%EKsN$o-nQXWuqTn85|my(5d3t@ocdB7 z)O(I_96~(t^uM0?q`EARK6HI<;fJ`E=`)kHrzdk9$u!RDvG1f`C~uq*O!1X`Ovn5u zJ<{NhT+KT3Wan3lYVbV>%;a@i1?4IjW#Y&yQ8Dy zgzNWHtun=jp;RH}cn-ihM>kNOFee7k?Kt#gtmprHZIwx7gS^qz zNj>mYB(Udeq0NuAuj2l7;{NlDNbNtUyk_<71#k03dhRbU1(lVZZ6Awwx^ssQri?~` zB-5-8;8j56Ka^vV3-84A5Bsb!J&ewmI(LSso_?55vnA6og~Dn7iHiP2Ei_}&z#=@J zl6#qc_`lkVQbY;{LpKw7|Cu#q<034h?*XVR5jv%=e|2Wc$9RxGsEyUx=6;`9M9hJy zA`W1ZjL__1rJ+CQ*omKo=YA#U%mYt#7h3y26Xhdeex|t+2*LDx{+qW|3|rEOowykM zJrwfK=_gFm9Np65{9osLQeEgW^yx|E&c-AY=ZNS@<2^5Xa?}&`e)KxyO@^DS*mP~A zF2FU^!=KgUT`#y_N=FX6lK0YU-B>YeGfl7x3ZOu0c6JDncmcxybGC8LCFirbs~@A< zEC>z8kZQY?H>V&gBzyq=brsNN4BJM*Xyc}F3>st4y2piv8!6PS2(QRg*&atM2P!mR z?ALRf*BV!(2C02Ju^#~qdc8|f5vSQ@#a=3xI!RP5Mo_Y8i@?%MUjjg$fBh@CT?L^$ z8rLX2Bie+c6lVxTC7_mY{|E9|L;^E_%P5r8l7XnmFU!0Z0}Exg(CcD}xLaj?4@2|b zG;+whT0@C{(x3UireXvH;4@c8pChYnwLS`hb4LR%M&jZf3nOH#~AI~19lQB@Z>PqH(yr6wsVPsMkWD>mlzoQ zQj|+{lwACA2ZU^!XgC4;#BOLpz#@R@ze*vDF*>@pMgjHp6WG&6F*ZoaK%5^e>x_GH z^ydq)*EcIz*6zb1f=;wNA!2WOyH68U(?LEEgM|5Ed!+{nL5ko1E+vIL4v=CQ;-mgC z5U2hCl?GNwosTkcNHQFct0lyj(yf(Ijx?0aAQh#(UETEZ@tcC)>PVJ+wwEQFLcz$; zxJ%;KjZr7J&^c8tn{aY+0{8%cNAQ~04u3Bny3i`K zcUgNy_d)Utu|v6edCw7H1P&Ewxw8-pIZQ&37$E$K97qdmsGmhubHnwU0y)7-Zd?fEp+;8rNwPk7FlhR%&b7IwMU*NZfDGXVj2k(W6y$O+E z{&?vfU~9u@KbYZz)PFCg*0yPE?q@-BM~c^oM_t?C?Ocl7S-tAwH1HHOXg+9rCMUqD4$K$=Y9wT4}F6 zI7Tz38T<0cJgwC&+yUdTZVGk8UWNa!?gDw(Tc;p71fW7t5MA|pqcg1Yo=wEW1<@_Y z+N4NWC&FppOqkdy+KRZg>6DC8Bg$ibmSc-`?x}O)5I~3bZniT8(CeQdE~mk-?3RFD zwN=2muUG!A_?1_7aIJ=NB>Q?MRlZj2%SV;eh-KLzmTDn0fb}Im8tmOj-5%yq;snUG zyu5r9+O$BEZ6WdeM=2JhKgbgQ5$?P_h<+_WeAZsa89-7UGQ8M63Jj&#nnd`|`+4ml zoI&e>lwL($c?{sFN57XK^t)f=T{#0_PU1(*+0eX*BlxH{D=Vl$C9<(}EY%BuOd7&V zFG`P{y>WC8m|SPYs{T)9^5i*xe-QE|Fg0aB|BBG5+G^h2GQ@?qf8^~rTurTb40~zf zBn$N}uyi&D8z?yWKy`r!)VT|xZy>@$|Juo31+|c4^?1 z3t3zrSkGDel@1Kg*KO=>i3}=brgtu)Jo&_Gwp>BH z<5k`s2lAA)-z??<%oIvNYXwO8je}dxxC3mRcD0wSQYfd5xYqbwG~or!A!mslm`05w zMG9(>FS90l{y9)68k%=F7b=qdsj(Wu4e&&v`yI7;wfn6`=yv6;w|DcZjIV5*Ze{;X z_1lMUSB|;%N3GtVyjAB$<$mdhs#;k_iu>ECu&JTx=pT{>@_&yaR3V6&>ljvW6;UDq z6F&zfXJeBm>hyam<%{E5`xR(CB5n-R4o03od9B_nv~2*R@MpFj;|-06|Fn*sV^~$4 z#6?TYbSjYE^i>MYRE08c#!_H~&Aqf3^Mi^P?Ow{?@rwzPCA6*j488;bsr%MbZosN^ zdqQY*FY#}T`FYs8lKPEZ3avj6_R^Cw#*A5mZMc`SbH_4j>MKuR)t@Xf%+*njT*=PK zG5hFpYI|cjG%q!rL*bz)GVFj0zvn|`r~x_Y&z7mtQ*gVG68>{eeh29u(qDKYYrjd? z;PgMU04m|Ni?wRCG_^P@n|pjhO1lhOfSR&F`VoI?n9>wuKDs=s@qovF?G^&bJM*wy zAi*rxmad(+m@$+V<$tJM3X%jb-?dYpq z4}gaU?RIIO{P8k`wC*g_gy+Yw&8pRU1bBVH&%KSWp&qc)OHrqQmq}6y&_(3b+$c`;v zpknB?6HRzIUU0zlkPjj*$1_+;DJZ!(-URxaHlIyz9`!k6@jrK67=P3G@2h0 zaKQ3ys=SvOEYlK4%Czk^6?v!=mfH3w21f<4u+|8ELPk$D@U$ItP8HLob1JOCBj(!C z_3O?(-`4ZdLUw$CIe}%tyDjhAMd_+pri@18wY?sKJ;d182kBK_DZwCc>ta$mQc;`1 z89$Q+wB+f8{9uzP*yM54bBm}v?HB!AZ^pZdY)hd>L&;CQ;S6%a5MJO237y_Bv{kk} zyk$y=`p2NQW-!0%!Ug82yv_?p-*rz3W7cu|=6%k}b-DgHTh!xRqvZXK)d@zZy3#R` zpU8Z+X8+WjGx7I5mU6)H&(#;r`lj&~Xn*`aV_GU3SC&kTY|Kin>ZtKA*I$HPYLFYN zk$A8pf?;S4Z)+JA|AOZ@rX&^EJTzw!oyqC>WKAh10T{fE<<=keB7n9U%|4ev1{dUl z`JS~4Bj-#{{{0~lm2A#k<)J5WmGQ*WsJG_91AIfs~9yh5MKGr{`+0&$1gUG{TjKO>NgE{-1+CFh3pNUs9k!uu@O7mr=(!k}K*3SkwKGM& z9|RFSH%C^eU*|LO=YH1ABgGy2wRT6_Zt<}2WD!7EExi8OVrTqj&k&yONJDeP!sm5o ze@H2Wc6)5VuK?OF_z!WTe{HNJGsbY>7J~DeLS^)J)DWv$87vl+Fp(oNrbrMp#)Ii02%-T)nzw3_N;O{O&) z9djjyqG=Irqg!Q?$QiH2_yyJn?+!}dPoNJ}idY!8`?Gp^<`-bVDflu8X$K~AHJhKr z=N1%5R7~bo6e8o+Tkh{)`yR-0#bx3`zf$~cghj|yeJ>aOvVWOPvR*)jfi@f*-&6uN zFl$a$`b<`OBTAbc(KZ5GB4;eVVoq&J<^BbKJ#GcV?ZTg7>#gl28N9ZARU#`duj#q` z=&PH(oS_KaR*IrB?mUE~~(kP30o=URm|EZc>2 z=BHr5A}pD`svaTxenX6w-#1pKxpp{>@8zjx-}Iqgd^TV!km7Zm<8hSb=imV?%wI$* z-my2|4{OayewNxUJI0X&Nraa&7^$tjEhVJB;TAh|dTM4m!=D-h#wu#RpR8{W-9y&tR8&5Er_< z#*&U-z@1T;`alEXf^{u?nPqk$Wu~vl5Mq1EsEYT)e>l|q}5Z`F_p8T zn)mtos&bTG`)hk_+Xp^xmiS^5=S6?qpt%RQ0-1(wuvxaYUOt=ltfESBiJpGR9JMG#*la zc(t~D@AjgA1#?=%DpC*1ksfV=#2wA0ayyOd1-CV1p>HxLqkmr6`Rd`s-FR2zvW35# z95jRk^~(3}l`Y25wsu<2;5DV&di}0K1k}c5B4>Zja7e88V2`R{dc!L3m)UZ(l*?eP zV}GSr>sV$v%w41)9mXMtIG5y$6P|E^x`+$APF=2Ss4G^~4LG1ZE+4bDeM>KSLEr-$ zK~|dTmDbjdGz~h%8cbMik#kxQk6y1wId3z_noy8Ou%gS^Z4^M6aS0j%`s6S zNjL)m%Gl zGVQlhc1HnPts`^w=Fl2l>at%zz5!-qY-~I<8U5IoIcr;fS7!P+z^16zN=R*dc`iE1 zt9C})j`E_pT;lH4@&lO0jsxe9d&aFPImXAb2eOj$-=q`9f(H^vwlHDUi10_hZ}I8S z+M9aBD7N1+?Zj8F;O>M)%U_3)GJilG#d1-v-sbQJaU)Ix0e?e|$lEd0ysAdJ?$poe zEKd5XBmlB_B7mC@H1GN0eAYc*4EQNp}U<_DViZ= zd>=yAly2z>uk-a&8{0cz129o}vf=&18qGzu){1M<4el)So3e7_z2$BzeY5^@4vvmt z%8!}dU{cAJhK^~!WoV)e8x#h=^Sd$;h)JlF8Kn>Hp0Wx_^42LEj864~!eXVzU`8_) zl)hp_dxEZ)Mfyn1SZEZz5H@fyH#uWep0Ku^P=O%iE|}-#@jKS@22xKE(g>OaHGFL{ z<@45wy$yuE09tf^UF0%o-GS;SCFJihbFB~czWsB7CD^*ys-VbK|KpT(up(hYQ*iN zi(3}w1WxM))M*JU<_c9-ZYLamhUn04zgTQZoW_Sm`z63>;jIH z+U(e)uBN8;aC@0-`jek zVzSn`=4Y9`NDgOx!}+6~h39>gR$+?GYwiCGw1?Xn zbfS3GLW)#&zLJje8KU}LM#ay6sZkj@`?Qo29n*edm9>T}A`H_f%>stWiAwO*gI3#0 zt`Znj8R;iHSQDbz-+bkw_yQ%AAt_D^c4dEYE)n1swRTDjs5WN}MV^U}Z7 zV2>!iQZ{_HHGcA;Z*qD2VIEo#7gO7y#qsb2w8@cX#tE1efeCuq>6PXiP<4@}HTdE= zq~i|=;cY=dLEnxSwT?$Z_i;~t;xpIg^?c#LMN57dTgrGxKX>SZA?|P%vm!$nO{WI? zl~c>Fmuy{{k?On2Img?|kCqv?vC_r`Cwd+KEkXR}8frKII!H$wVZ7#3vd;|Z-IcW8 z@HiX*2h^S(%&=`vw%PTtHiI#r$~vUi1(PN9@6C!lK~(XA{@lBq9EbXq?q?1Gc<2@O zy6xoXz+GaX^OKcD?N57x3v8jbOXCYdJA;GIAjV1+o-Vxi;<#|RDDhc(_{57Ef9K$^ zHrwT%R*iIO&;94m5dV1%yDm+1gz_kPU&dnfp~(O^`F>?Uo_G8|WPN!& zlzaRC%m_tDktIV}5<;@e(qfm&*dn4j5fU;&mKklfq9#jOi=l=rC0oR_pvan~A|_?e zmThb^zw73l^E}V@_s2P}*XcB$`~F<}^1iM+*R}{cB?Z6D-`P9wnJOI?uU8$a&d~=6 zbyKc7y7GGYj$3RBh^L-2*Yq;=LFb^)BLNalEseeqRXNzQy|R~-=8&su5?9ssoppk%Z;vsMXYC~CPH+oB)!1f$*S9A<>V(B&%usE|ST(%RAJ?zD@ zEvytGq;GrE5A#axGF6|ks?xxBuj`}#e%BbRj;Bj)y4Bu2VRFh*M13{g1ml>*-eW$kMOg4GyYh*y(ot-(Wt1xr)Drq{VC##$DyzCW-H*kj7FZxb{ucqyBN zytSrshs8-rHKzni(+VE9KhJ+#choq!4VAJ3YW{;Owgv+$wm-B{He`=59>ADf3r5l1 zAZE13daFz=4~w@g|3w`NV@4{7Q@&PSEuIVJ%8Ie(Ofer>4kr`lx6vK~bwNsG_YYNb zKua{^Xa;_2C;wLq>NFG|FMtHUkqe8Dx!socCLcM&VE(qk2{dwuI`#py)=gW+;?m;f zi{oaTJ}wqu0>@YlzOV&|4ugoBQpKGG3pHLvaOBBNnXN=WJgbU&(vPyK&lQFueI$p{ z-8O%H6YLYQEX|rupx6x&)*h%Sm&1LQ*x_w{@Kd9_RYU1!1X~sdsH5MsH5=)Q(2G^b zc$>o-Q}fPArn&NR@%V3E$AhwuN@c#^)W>}s51{9Ef}vl%KI3!~YHrwZrzsBQk=5NS zKQqmqP6-p6EtbrZ+V9z*jWDHPc-mzFWpUzAuzZ$aDas$I))flUyVgkpqhgF)ZU6>p zwIxsqNO!?cz6ErELy@H^Yc}P{-m>VZA6&GZGzLwSWZx`D?2akO;v3pqsgsG{J>>#o zk}%^$acd%UJO=g{E&0<}kZ#TR!I2ho(>JAIk<_SR@th0C(PEgi+dx|LfDZTW>EgKl zN^}ZPmSa}AQaRQhLX&otq3Y2S*3h01tiTiz6%bnGvEE{t0pS`O=j_?E`L;qvl&_xm z=0e1Ls9CV=y{%wzh7A*)VP?#FMII^NQm(%?9$`0phPBWb1jtVt@W9urjID7kGNGDjWA~CafC%hSmvrZ*fsZj^Dp$ zusHkOI1(lSPtu$=L5ituY^PauIf5ahy6h#CwNU0uT%swEz9odmdo~ZD%%0n@)a5ge zQ#Ll$85KQ6&KW?+`~zM1?UbrF^b2KN^D|!hldalWoY;<`Y*_s*bai-sv-I$TVpmK( zEcR^fvWimY^kT_7TZX1Luk#8w1FBR3$er==B5DMveA8z3W04BGJl_`(uM-!atHvq& zv#_HS^?~J=bom?~VHT52-RM%@pv@F)W38Ch(>ZvRMj*?0K2(im?fq#|&fa)lnefx- zE7`LmqB5!>VPY&sU~JktF#@=&gI?Qv3~{WP5*OySizcL;YIAtLB) z{8sF7eFx_kZo0^n6R`SD0J{boee={dQ}(xQx6-ol4c-My@v?oVTUlkT__H3bOoA9> z#I*VMN&D13u5aCVwDz4-aoS9uz6P^VYN*=X_B8t0d>bcSuFwyEPaMLUGZ5S%z)vlY2rVTVCD*I13AU#4DUI9q@Zs>pS^{QHQIiPC0?R3^GoB^+7{)Ls! znl)5mdM7ST?8>gf-DT0_7$075K(=uB@lK5oZzc84?V|C-4PtS&M#jc6hDD=E9a3VJ2ART!_NRq_k+n` z{a7uYRgl!S%#iJ0xE{VSzg zz!b=+U&VNBW!Bo=8|g0fx&n<3SEMs+bLv!gz8F3E1yUYEd^|)=zZ1je8*>k;lY<5I z-A-a(dmXKFVf9wfwbz%;VSQiCW9>eeSiPB~)nW&Mm*D5N9`h0QN}LCjgzGez@(v(C z^<2#T?cAC$A5jEg6wOnmmmI%@hgw3(KKVPKmcNEBj|(ugtS{(B$B9`}`J8u62i3hK zh_YQVz*%%`Vd`3qP-KEsCH=?^5y)N214X>foe7a7oIYy5`e+CovKMI^!&#UPcIWB${pzng5Ms&Ytx;oKv>a~gN zt9KCuy_{JQn|XKRQDbXrF+_TTmX}Vy9eSBFuEF$t2La+3r0=*tx`$Sh&rbl{G8Gw| z41xiK487)4zhT)KLJ4=&G=Jrh!N_??H)!C7dhsQm$cwcQYsD=#Js=*}AaP!y|Ut~gOEk8*0O)+%V zz*YIN9m|^KoE_FVU*D`l4QB*uN<{+8jjXQ@CRPZN-s0IOq#3JkA1n;XJNuI%@-OB0 zVR)!*gT#g8$2ILmDmQy_EcFFoilx`mZC8B7sgjF!S0EyEMN;m9pkp%<U zM_BhtF}U{I3IXnNzU2sy0YSmP3|Z{d4JpMtC#J|C*7Q0n1&3#8LJe-MuKuKVS*&n! zcc(cC#Vx^D&Do>*?33y}zT6$X!hPg>T~qZ=#XLjR@)0wAbkz@b2s4^oBMH8rtO4kg zE`PdGW2s2v6NvFh(JuQ08RPgT92z&;@@{1=oU|wsrlWPmj^Y*-fbh9{7B4^a5SKaa zO1s+Mr+(B&8Tx%lO6uv7!qj4VoyqolQ(^Y~3#WKr@Reb{RNXGVN9GEQKUFtSvcF3oC#>~D9%p{k1%3VQH>jUN zy>>w?g;}x(0$izcw*7s4zV|?z&v!WyLS~09T@Hn6kE>(F6)var6f&=1l+|L%W4zzP z((p^^?dT^gr{XGhl4f-|BM6Ferh|#4lBBIOT>X7|M}7WmY!RTWf=VkxW2tG;s|ccZ z+>Sa=aIDcKA7f*;pRyUu~WVLDibmK{O zlW!-urYFxBn3>zjNywW(!VhrXDQ52FGCgk*k1jHWQtUJ)iw2u#LT z08I0)3ME&<7AoyA0AkXw4(u$t7v(1Byx&{BFagR$3)){Q6P-xCeuBvH4QI~h-6r#e zYzT;^FYsChx}lm3Mg`&JK|Tk37^kiP2RKTlr@d~OJb_d{S=Ga4*45+E3M7V3ouyuV zQ+^GHZb|T;5~E4dbWKZ@V|wog9+fEc^>qp`!6@uz=sdfyXo}pxy5eW1`O$6{E^l$9 zB31Dam@GO}eICrZeU>GHYf%EAG;~J9kf9GHz&8Q__&IbT_j!I(Df#A}J1k2%p!JH# zcTvV0>#dO`cb$iI@P=A_x-6{-(y)QH@C;7Ay9MQOUIg?!I#j?>pZ^Cx?I7*eu(<5z zq3UGXO6g(>GocZ@$O*=^;z*;o-7S$5F?XMB8*7TEUkbx{6A!9p`Y5to;$PECW$yPU=LMd6h` z+Vl8Gabld8&=i)ohc-@As88HXSIf$Mlfdq8@f_%NZKki&mr-E{fuXD@DpyrRQ2htM z)_*{+8?YKdPf{*(ASfR|{eRNgLy?DA@E|V#cBH}y=c;+!K-rEjECCv2;eXET%Bp5M zZBW_ZZ!xVAAh138RvXFob z$v--kz*d=b95i@0BP93fqN&iBgp5-T(KihILEQrt-)$}IGEGO`PhS58uE$f8`TZ}T zOAXLPzL>wz2_M;h5t@}Ne-f+7meQp*r=U492mo4Fn6m^Nc?L_EJcNYxua8kbB7Chy z`1+vWwN>DL8hae$lDc|XblZ#V8e$rvCxv?qY6e#PB|wvPfW^O7Y~=?l;_OFHJTe2E z_sVKHkE*I}Qf?js9rYWv0(JnxJA21IK**4zytjrb##yE5WUe1yF8Ty-HY|p@^Tv^H zGB%E(9h}}4yMYWAq7S^zvJayh811ga9^y_plEFzHgdvbKFf-YzD%%Ov(p;SdU?L1# z0NH;Vk0>sXUdpIaA*N+5VaZaxYxU3uJ#^w~@4_}X{T#3N=B(V;r#DWBhbccH0F6Q* z4j=_t$oDtPwBwptDgffr z%0E~D5v-$l-KCnY<89ekwxiJs7T(*4eUO;6PrO3H&WWp~G=)*YQrr@nx&uNnE)ZDa zOkWJJJ`?z3fbgeP?2G&>ebfB%L1Dd>0|%kvUk=?axR{GZi#kHIsZGw#Ah;&oa<7QN z+=W(KimB?vd(@COj_p<3Pb`Uss)#aV<=1J3Xt@Q5syK+Mlx~!5Y_$h;j$!h07mQy8 zFMUpTfq5BZvS-tmwX<8|+lq)%6d6(7T3;^m*}zQ?j7Po_l&@Dj^^|8}h!rY(ANLk; zJD0+|L|yc%yUbWVj=VM`NM^w*uMWy;`A>Y}w{?JVD{pA~$U-|C-uo{=@{?q1DfGl( z6Z4rVr8JM7{GX3d!^0HOW^l0Iewv~4hAEau3MDb^z~3=V=A9oa3+a$y7X_l8B}{Qr zufk3em(uT*J4}ssD4pGaZ1=<8i7S(qDvoy~vVf$T;Y2jC2AzqbSY0$3DL+JN->%Ctdq-iHjAoF5Kubj>*GoyF6t#=^gUT}Yj`pMA zPtE@x%tP#O$ON6}hrSg8%tN~HnR4X6{=%b8_%qqFy4y_JZfWC>hI{OCJ5qoiLLDJ` zVZ6diEF`kzLKhz67j6qZ_akoyj|L=yUQOS-#eyWL`lxmd4`XCBz-$Vs)=wU8orgiy z^|=+w6c3qPg13hUe4K7k!sg#3-?7`cLWoQ23RRfu`l5BSNVshKm-x1GZlbYy62(x2 zPGM%hU7QS}v*Q{8&zIDoE<}6zIVJkZ+v0%4YSjJq1Vc0=^t)t)RO7h$;%<%0Lig#cNh{T~XsWV^QpY zQttU{hs18KL2j?8Mt^OhK`(LH)A+uDj;kLxaeJPs(t zH{3+RKB?lYZA5uMP7Tp7+cmcF5Ud}jF#A{3Re{t{ zGFhX?Iq6FGlyfnfyAj~(aOP_o&(rK#se`0%_1gmsipg7fc6|PsWGq`Z(#m={e>+iQ)$^5jLjO)#`a5=Wxk_U?Bjc2GCSqi!Ljd3l=JN9=7ixa@-U2E5Fv zKCa4br;J9un+U1Q-5(bxD?s@#LVh|ZxD_zbut8=toN(>cmGOF*y8);y)rn~0?jeRY z1T-aI4jT`_@+BzfJ#w~4Y!sf%(~+!T@%JJ@b;D^+G@e*=U8GtUKW0Ny@eOay4R*RU-|4ojFy# zqDKSE0O023$!Y@Nh%dsN8O|VSGd>pN>l5&$T{4|zFQjWfmP^SAK8&#yb#Uou&`~x} zC6Vg@kIsQy8-P$T`Hy!a;|WzE%Z6P5G}e)&e4k~}<##-c6XX&4Jn+rfz5XG*+JMbt zSFhIa`B>ufK;Qb~9c10wutG zN{uMfoz^A{I=&mNgShUz!_5gG4v@D$UwE1XlezJ^$}KRGL%t_rWN6#sQf4??v*2ek zp2-#u7uAbz!1Pr zx|=#-Bq=&67(7&JC`ZQm9SaA4 zw2ft84`CWg9UlW@CbVEa#03g^#;{M5!iw?B=%=pv{6j$O3$0;M$DSf9_|!dg3Eb zSI(CpYh1V%KfzDdItK<5pMC{{X?4^H)eS{kD)@RSj6*aC7>6kgnC=JU^?i>40h9@L zv>nLz?Phr7;?E?Lnj+&KCbf^&WEnSZQ==84QXgaz?+e~ACdOF+X`FU0ALVW_=^e)cTQH6Or;ZU zB7Ah7KVh#$-#)X%BGz+wc%Gd+myKtSc7 zx@;?$os^$Gcfd#)7>!C6 z6@)9sh~a8?(boT@2=9N3mx>0HVGY4s)AsvA!azPm5`FiAT}M!%$e>cb1=u0-32D?R z_1#&~$l+vX-HP zlD}bkeh60A#pLsj!z7I)|2JeWL-9AnCAjyp+2>rWV|k5mKiBiPo4k~DnleoM%idUoK^9G>`Tdzb zf8fj4e~$Bng)2wXb#>slAsCQzg~hRu2JC}LBl6oZ_F!31hV4RN);w#A<7AIJ(Qbgm za-0bT3V@6IwX)y{Z@EVgIcVq@NMn4^o#f3&c+^#JCa(A6ko({~hvv=OEJc_Ij9 zweJ%}K~DI=2>d5f0U=E~$EEvM3Nju7>AzuD%T?&v_rq3_nEZR!7OAh`$s0sA|3+lB zDDc8bO$Rf|3oEoMWK~uW%lj~rg@>vqlK_pUdYzr>p8pjt{2Hc$kmUq0bJGh$0UogD z3*-g{6_ZIM3)WyH_jH+QDZE^kfIF{=`l18>eOPAYHq>Du{}NLCa@CANihF)XhrMCD@muGHd!;Y_ihoAR;XAu6K~(F^L-IM-=Ry0w z9Fm;>C^<_W`Pg}MYuoqP_hC0in)YwraGQ8=Yss!Jo4#CQVLNxRW5tKRTb4q$?+r@t zd%du%Ig~a*yjL~Xc`7=6D1=Z7of!x&rJ4xo&=XPa$DC9iP()D?RIl!I)l2xe-xRQ@rTD2H8rA~l1VsaVeC$~Z=FW$Psg;`?A>qi?u?GP+pg90AjW%M zu(|n-#mcw#+q3%YPp=HJ^kEY8!}Z6;#|M1Vmqio_iw&8U_9L85bPR$)U7Oi6<)~uW z%gSvOZu}-xpiD;VaPxu9DeS?jTKa7!A*e6gv5)hYP*dkxc}atRiB9>$?9<(ZMIGAU z@J5*jGks8usJ+Yx;v1??QtE>jzRFDx!0U6Qh0NQ9P7H-AXk`|M4!VZciZK-Fgz4~V z^6aO~fUYR=?Bb=?!D(OFj=tRv4AUscLN^XoKTlzb)+`pdd}1whd3R(XHUI%?KhYci z$Y~t}V+)I^eT%8Xx8vxlGBVbgdtGb#SX{_b7 zf}!T_wGJo`wG|iN_XzSJ8D`LjZ+8ZMPVRmG<6RYP#DEcmCrX7@Ju3f9W#LI=+YEwx$yCPqZlT-YZ%C$6$HJ5|BqYs0N}cgtERP?h@O%-#?xH{| z?idtQgqsMl5CXc?0NolAX_X&rtN!r!0;=A~Ri(GPcV4Y(siVNqm0Vk3U_xmiI>M`D z{~{HZuk@JC;j!Mx6MlRef!a?l@S$wQzJ2Y@R!#5+-H}a6Q}<$nCABi2BeRKrJgVnC zT7_i(cv#@Dw=p_!R7@++vxt}zZZ^2!7^#kilR#1Ik56t}p`v=3aX_kiyQ-W5QT3D< zTUum{@kdxoQ4Xuz0-(K=X(>DeCC_t!EGQj zMpi`3<}RbBM&S>%Af=UTA~gJ5@i%QEsCppB_OUWf;q~2-l`}pt!RrgVnTF$P5rE0p z=jYh_=(Xw@mblp=>H?6@Ey*yGMG|`sVapJ(<#m926gdvK%RN;6eQ0IjMhert69h&< zmk)b41KGG$`4c-C(RAT<`Vu9*|DD*p8oT9`#|d2OMfPK$ba=kR>y1N0Cv#$1si{B- zmB^weKfM{{4LeT^U1I9fS>VSGtP%G(ydyhaq?Ay=Vl9byQ&28MF+^qfXj(YEhI)KCv$9-GOtzMEV@$9aJ zKi`&0+Fv~{+0lwB+@*DRE9yuqI_Gw}hfIhEF&CjMN7JKh+KT@?2xPQVP|`L5YLc9j zP#~rcmIMYgdYpcT3__;jb|5p`(CiyPaQ1l9(G`f&9q$;j8)KY-DY8F9h*`7a(cE{* z+q@Y;m?na2)8ZtgXB{b^Dh?rA>A`sYdSsqT?NZMNX|S)ualb-Veu@pjs{S7>kB_v< zP?k4~qQxmyx55(jjf^kLd=U@L&w44(HW3lCe(2UF!jtB|4=qR8sIOeX9~?!FM5=(W zjx1LHiR2iv5ehjH42BEd6icr+Gx00gfEY)T*_-XtzVcb)YP5DlA~ykNKxuxZFq@Fp zlSzQ4_XB!zhBV>4o!T^@;=Jm2^p$oLFqaCB!z#X;gi!a(ST-ApkpP7M76l`Y1kIYE z6F61ilrGJB95`haa+^NMds@+fyC>_XFXKQX@M;=lpcQz9!|9r?sMp#%=;-KdLuMVM zp&?s7oL=z*L7GLvcCiC1zPO^Xcg9IkoV2Ts9hb9czbQ*~+~0+@>o*{?zWO={sKf%+1`$_bfvC0j<56sog&H zip#{(2klTW_Pvg&Vwywkj%13$ThD!lgA2AXSKo{cH?S6}08B=?5($q}2iDHrjyb-S z*$5|pbxqfqhNZ^(%)R+N>@W@*$zU+1>Z)&bsfV%t{m#c}3o0`8>=ElHi`|P$`b?bU z{qM7j%E0LmxZSTnl-2bqn)}4LU@>~$aKx)c7;|XKby{`roy}IChTUZbLva(Zq)F}E zxpS3_xq_h`eRMal&^Z>Du0l1yiW*N^VnDZ|f{nC{yK zCI;Af3{*u#aj5#Vr32FD^OT$J+v7o)o1Z^+`}XalEARAHj?6Ys+AXgP>FN2vI+>%h zv$Hq!(zwdic8&byfa;oAy7@C?zf}C-_@<}1ki>VLFP+AuMq#|8PUiyB;a2r#f6D|cdXta1v_G97UQg9z@Dm3^81De znaBj}nC|1L%&vk?KBxIe%VU~SD?V;hbJjbLwBgH8`IB>Xb&J8KqgBA_-q&XfLM087 z*jHGl`#Aseu=nt=F$Lsd1JaSq+OKqvk0hyW1wr4(c83nwhMw>L43kt4i-emkhcRLA zmU%ENl}rkNZ2{8x0HckBQHgNEihTLR;Wm6Z@<@@w{x8QVWQ8EEX{X84&$~SC@_n3q zH{zr~%o_1!oO*-w+ktrTZM^Vt8LYsJ$%^5cFXBu zgl*Vesy*FdK^YQ!qvO5UV=FJtT!YC4O-RU+b5sx?atLa zD<|*(*!alBxQKJ!#-z7klBQyxFZsVG~qJ? zk3Wyx9SX!BP zIdXxe?9ts<=N*AvP@TgrF#FExZp1BCE)L}Dp+a=H3}tfz+Ca#!d<3SNAzF;v z6Kftfm@jsc7t7noI;CWT(^i*^Kd0nv1ovcxf%SiW7so`c9Kzq=`|ZCchIv;K+b2)W z0LdD(Clqw8@0ChtR(CzKI|A!hoh|lH^2N{#dc~1V8r! zX!cElst7dZUk;>Y!tJfL*2D)hmFBC{(p~m+Oc>NaM zoFi124$?^xCvdD>1ln|b!oow%<=JiYjr3=*R7-pGUf{p*ARjFOgxD1PcJUhMn6(f$ zb%eH?mY#WpObX!=%+|o@lT<<^sMp}MTlRzvBUTH`fO{FYSYW+G5e*h7Z1=1nN+G=2 z3GE3^1OmNUT(t?JRa zfltcS5l?L2sY7KT?*jB!O+`@M@GgH`snt<2cTNA;&=i3Mlv>C}$inWcm%YBfqKIAF zw(2k6e|@K4vo%!?LTVWw0wkTPV9eKkJacJHR1;SZ&}`xVQU>$c6duZ|n=qkHh9I(Xts0s0tR)r{dKvcVXqJ_}pGfaNbl5Rvor_V%`6Iz~Txq~YS! z*0Y!W638Z57;3q@;U7t$dsG!qr6@goc#B(%E>90?Wv7-tN%*W{3uK-h`eT#KG|2UjAGHXC6|BO@C?!6q|1!l zSMbj-xZNlNLstS+_ZGLL(2YGD!F!S0xpVe*StZ4ED$Y5ejwkb6Q&Ink7+hZ{(ZblW zH7A%%b}`H)_Oxj3d&l|_EqDW3;9eL=jX`W-!}QIqo4L8K45Yh-@l#&_>9d>Oc3T4J zp~db9|9FBKa9q(X6nGH9eJ|Tv@C(bzF?@t%F;!!q9$2!I|58}4K5KwK*HPi!Pto`7*ebNH79w2rieCe*f4dUT3`U2X}Aq3 z862_SYxlzZoGz8vEaaw^pQ(YdC$&Rz8xLi`94Yu+=E8~1A+M!xWat=8M@_P49+9Nn zJk68Bi`^xaGuNOkKvf>RzO%6hkxNz3gsiuV1@4d_jE<@k&%n}-UGBxlG1a1QDfxJG zDHw-M_S{fPh)~neI9adP?JP$;57zn4GmM%680UAZY&E~lqy8LmW(QVS0xMjrIWMwQ ziD5H3?b&;_Bgd$5BhD|Q1sMIisDW z?^AXBc@TXZWT0f_ytUs#I3=kGJ?d=MGQPn|j>LC7x{n#d22VVs{r34)FCS6mdXLJXAg#8GfRt2`e z{dwy!N=7NqslRbBt*Vz@aH?Fwyz34hQ*@7sZ1XDpwT+Ul*>uJ?=60-jV?3v`YE2^1 z79$qPZ6SAuwwf*}Q-6i_5~OSwoKTKRQx)6bcC{Aj8I&Jt=!y)9c2g#6*=G7>@9=hh z1!9L}I5Cg9eC%nsq>%i>++iEJB2wQr@{gAtL1j)pB&~ZSW z0ePaA*gf(n7p?6uMu3V(%xUs8Q(>LXhb_hfHosIUuAySr-tP!CIa8ut)`^Y5PW%1_ zi<1FLe`K(gVdyi!H$%m#EucvHB>M~C>rD@iCHni8Cl)NA*@C%Eq%ZIAc1M`i9vt=1 z-U}Z6vznz~gDx*tJRZz*(u5Dqo_3m6PTOAmj*XU&aP09J8h8U-VW;Ax1FHEU*n{Hd z!zj@AifNS{)<5@6%}{fR1$EiR17PCR0=5URduvWDypeYg4+`r*-gmzlF&UzogR5&a zS0D~ul&bMHX>0BLdG;`={)KRvwASIgsRh0R*GesaZzdZ;EU309IF(7AGzxz@y&cVt znEIRZpp9X-GFUPO0(GA()30b@|7cHw1Qs*OC9!n@h<1HJN7*G=W%HcqnOtB-a^K5= zLbRuEMF00gr7Xucls^5cX4xYFdrVRrh{bTDyPeg_d28n38FRrdq0ud@XJ-|^z1BB3 zzS5+-l74;rYBrn8Ht3;CQF?6JLOtS0xb$sQ52eU1O4e9#l6`kQ;6|FHwWmLx$VZ+t ztGFccC-?%qB%lm@dlzNT&rd&jK7t))dA(-XsTUfxFleUE-`ZCM%PcZ zi{uhZ5u+7d$)N$UZ_bIaL_ehD4zylu{mLK!DfX1;U&RPLz2v2?alV-rYm%*Xdl=|*KrT*@vBtW-Jmnu=bjk~6XX zYBK%W*8O^C^@oezg+V-r)S1tOXAYg{oPn|CTSN~ntb z)0=l!YR?(k0ufEC3oCd(__S7meF8je`%(CugB|{`dlNbzLNeKwSfk-ZZra3w*#2^< z;*Q)f&b2dpjg@xXcll|?_r&)iO4rz@&&foZhB=v3C5EatomLDxAamMNva$U&G#fUW zG!}VuDg4onZ8B~|I1|>{$5e0j1ta{qSg+vo2z~V>q(%w$p4t%I3%jU#AIINtAF+s9 zUOv5H#f!>w&X>I84GCTkPZ;62&)#n?wBu9!MoCo$d`5@NaJKSJRVe^7)YXFB!$c4s z+(+oF=#L@RzOz_QvEfC&LY&7%2FRKJcon`E?kQ{ zpXM1(GvY|?=I{85_Kp0-ZIMDP-(JQ>-%>SgnxrZ~#rdybr}WT@ESItaYzx&Nbwz4N zELh)fKM%{IVRFO;z_Gz2lf`oJ| z7n{EDV;_@)Ip}UQOw?zW2^NOZOJnzaKn+y}H$5V}Y`k{rPfSIdr-ckDz3GwN) zgKyC`Bn;nfuN2jg&^j#pW(o8cGqE5?wEolX7O@>{`jFTeeQBP%6Md`lmk9n88C z#75sZRS;%I6hnui>B}Dg&I+vTSl(R2^U4<85avk@3ahS3{#M#5OG66$N$2tH>XpYx zKjfM_j^;Tv#RpogWr=m|3YiB%?j%*;SL|^)?Vh-a=1UDCj>)+6?Fe(y`jc*!b9acv z^m!G_%A0$fQDRYvV&(ad1j{NVcboHH<(xVYP<_F~@rB=*O_S!32z)S7$7IC75Voo* zmf(tBhH4IB%J8}y-J{pr4DDOiyr5O&Bub1OqSywBu5FJENNHfvOdGaQ#l*@{gO(yk zIy5imY5rlR`Twf6RG!7~SnOq_b6&dFj(Yw2H89y5KK^R>g#7C;O%@WeUAV+q7DziX z%25j6O{0dssb@gW^nGIr5}k4FOFvsX(EHdfjiqX%HiwAz<&dQQlJIbr3dvMrUqseR z9U~u=**;A5LIyJ!79ZDG$mZ^0Qy#)7X3-Nn2aNJreOH##vrn4p9a5TIbftMv6T=#* zV}taeG1eW#3Zg$WAKh<(kW6t_PjQOq{;rOG{b3ITF(S}rX#JzDIH$XAg%{uOgr4}; zXR+-Fm2d|#DK$|je(2zrH>u;)ARxEGh1JFP z)*`Kym%eKWP<6Z7gO@WPyxYZn;!{bxqjd6{1WjhV)j23oNp^I;87AKPwi$_fDMHYr zF@(=zgE2rN1;@6fEC*{&=S2t0%)c8SY=YSj+$hVz+hWLeKIpw}CERExAGY-ble16- zY}6{?Jv>VnlSn3PQ@xa&>VG4|JM;tY&TA2(>_>AdrIlA^WPGmhpowxx+}VVzi69ud zl5|S|l}X}s3bTnRA~IFsIOX4c)#+(zX`qdWxAbjaT4oLgHc_buM+nX9(fDk&w2uz; z79>cLUJ=~Jjc|jEZIT_$6*3cgxf8zgvTo3agHs8cWSTb?Lf-|qimWa`J^; z4Yj<+Lt_Heb)GPTUaavXi>aeZQ)+?ikG?v)$2C2qgwxqXxfro1t@YndYbPf9SobEcWsO7aM~pB+|cz$*_wCy^|xS^2#ny` z+DfxqWT8NTn%|}aKL1=V`g$uG*5o2E~+C~zfn&>!))f#tVsV$x)5AT(&IT$PpB!|C0NfdoVT+Xd8>H_ zqDXTe{wYW?;-1+TM?qu5(A796wqn}9O;*DWm|`?j+kq za6c|j=gi6?Bp&Lp2~U+j8JsdKy${2c;ej(EyrxMB9aNoGUilxNtlLuP-KpgAKOGl3 zPHqr^c*n}?-Me?l)^Q+R5R_De+*h|Yv3d)NZBTt9M4g8>f!5oi_#qQzAL3cVtUsFn zzD9vzZj%eG1YF3RAM_S3e>PV)0N-a#Wo_kcQs$UxmHu-A_Rsq$}K}Qp_;y4NME~iCy=1 z0|c*Y_Dm70yhfIJ10%A_#ZTLwOPQM?8Kizg87g6&L>;?e>rupZO>7y2kGK#=_=*Oy zoF1hAE7vSI)z4t_cG^GrysIIHFmpQL{I2Ms4U0AxI==3X3bGxIfVC%g@9a=VXdk{T zW3dG5mNy6H2d*fL+OXi2M7Z+pI+S& z3!3@miy#CAtwN->(ls^O-()Y<_z=|SJMEriN08u2&>Kpcp`oF6{p`uKJ9%0cR{u1z zdTWSn=;&BOQOMZ6yl_vEBTfYyE#q<`C!xs3#23smPMx0fax@RqD}?+$LD32Mf}&XJ zy(D=^l{SuSSen)x#c1?`E6T7^&phab*EcQk>T80}0c0vmW=%TsDetjvumi&TqW4mE z1Y6tRE=65Ogw$=#MemR8j|h>mUiTk7uX((le4d`Yad<2}Iww`v*$EH>wRJkYr`k-o z&|Wby7i3)XNP_@7Az#uE!~!q?mQ1cdHD%5h25v7i7KZ@Z;lfw_MAmT(s`-9MipsgX zT(p!aq0Ng;M?SwBh1mbUzUp78@pc#1e@Mc6U*AL#HEsAZ$fxm+g zxa0Wo<2(`)62Q(tA#W&xsod;T{EpMOrg`($2KvsYmufRua78fEJG{YUq+*8?QE)&h z$}U&3F%qGC|7)549!{j9Wu*t-Kzdx-C4fKP|MiQh^;qI1nY~Vy7mSHK*G7L~Xpn@; zXb!|#et|C*A#at(HW3+fLCN(Q=@sM_Z7KCm?&x)GP!WvxUm2_Yd{)UQ) zUZJ>_xIITh7oYIfLeK%3jyHQ+wqfs)e*8ECyS=xj?vn9j-{WE)_2afR&K5+sUA{_7 zzVmO5Qq~&Xaa#H#0yk-sTxZ1ben!PwIt9=c2-?Zef`j^rzWe-SpIGWn8P9io%DZcP zYGo;MV0uQkJEd-)JQS=Bh7&p&a`5e%W8mU~OYh=7FD)0WaUr^CXTuB0?X8=p@>+7P z?+E)02J$kjIaJ!WZwtJg<0=*Ib{P&lfE<_r_O^e$7&F(_-QDovgE1Vaupu9+vZtYI zPy!nuk5Q!V0_~u&uoJAJt|aN$aA@$4qa4WZIe?k31`r#2LvSs!%}IoyWuI4C_4Z>3 z`Ax*oDyb$eW%kyKodElK*_UwCT# zZasvZ^XUy7dJZ3J1*f?VF4+^)e+tU9@>y9Prt)Dn{dq=lB_ZIDz7~53K=%yHPh55l zUy)>uZ;33$19`pOv3pG3$c5@rza1vbB5u=flW42es>TR z!0*#KX!I4;1NjI=cYeIv2owrHo%D5j&bh!{88=4Oo?(#|;Ern2|{L>}#?c~1FR!R?ppJ^B9}Iw5be^K^3NMa&fgqYI|U%fwf2G94{B zLjBpwo7A?hSR?<&7bkLGGOPsy)1*VvzaM*YBy9*_Y!_C2t$(bcFUe$B~6A(j-iqza1&93&Amn9j=4mnbz<5#HMK8#yL=SXB6^2W#r6MYnHkF2ap&#YI7c}^ z4-C4w$jgo5RQOIb75Rt@SR(mJ@`Ft>=1n*$zf_Rl^HU#4FJJQuLdzwt1U|_VpM2?+ z41_NQ7-;I8@OT+Yu?d$*7;8C+7TW-*g5S|G;E5kdpEc8}-!cVFuGG6lRwj;+@Zp4l zJM6z*4GSkOLi*A+*cw(hjGnmt&lv;mSYbI(CF5iw;tI;A-g15|^En5u01rBaMs(^% zN|xy;}SGg3*e~~~DezPq>bvaWt2vg-3`f~@QQs1ZgBSnzY9F=NXhwrHKVYkRP z&)D}k{g)P`SV#DVjb%W5d!bdF;D3Mi>{=?NB9HKOjbs{#1ATnoel6yUE4g=%H*rVZ zpNkjc^X4YohLM8J_EaC7T|&oM3rBPxN8ZNF0P={%e+3OcQ8mAf+=6bOO^`Kl901zc zRr(v~Tx7chv1eR9tn~1OZD@$6=M-(uy<8mn(B?^I{8+oaxY!2kJOprgFKOE6`1^#} z$}>?9W7~!{TO;LXGuddP#P+)D0exyF()-qY-b41=`bJN|5FO3^j4M8tCk0y6@&APg zDzhv+`bHPNr93v3y@|-gbce^B&ss^8jCTwgFHRva7Lja+bAj_C>|n8dPA8>U zUv8T9W=`ixfM?E6eBS|%6T4vf>8ce^(+R0~#I3)ej}~7QTJun*mj5Tv5O!O)LB+2M zEcl!_Sc!nHb#kk2hy3Lo$we!v+|bosqjBPFYh zLtNh5+Y8bG6`lHjLs2k7ZVfM<*>H|+1vRif&o_)fK0#;9681(m-R1LAs<~)12c_wC z!ZjcprUu|9`7EcRnvk*<)j^^3VBh3f^LMbFKVA`3hf3#9t$;RNg;ZlDQOc z`|K@XC!z`uE5i*|E7z4OyVas^O3UO{T`pzWzFI%`=lEz&y8i)m=rQcHA( zTK-Ad&jG-P+PV;9Nu~6&2|sm$M(e&($ZZe}S?zYJu{pjT@MS$IEls?4?;f1vu+aeu zT(tmh1)xKq{N$7F5&VZ4Z7m7bJOX#FmB*CpgattGYGI+R2&h%>cj^)lDXPfQBnvS| zN2{XpswP-%jKCZLau%_IPP?S1FJAOB8)Nrh%ZD?RUG_G-uvf@8qn&zeo&CR21E0rQ ziPWVLc}tDg_pP!aDoQFgphC6YWJD7RAYTv*Vd!4M^2EUCDX)FCcJ7Qtz2But(1ZB% z|0ibPn?%)YHk$hdgah!6ne69vmO_;k$*M+#uyb4m_W_p?8*@V9WoV$ykd%9BcLjKb z^W|I`ssMbpbqY~M7F&QxItkg-j*idg_~5GR8ZmQv``rA_7H9>?$aj}`W>)ukaozuY zhx^3%x?AoDjIxCo*BN)_mWZmEdNyOg0Wsbz!ldj6Uve`uhP%D zWG-EHk)>E6%Ft+A)X}$In6Uq!=)<>lX~6Jre{2V;(8>8*;ZI)6XvzNu4L)lvI~CWa zqf+tESs}kzbT4rUSWBj4u*m3;t%HvN@L&zb`n1HpTE*inZ@oEP@D-K)(09CWO|$J< zT>+jg05Z~aHcIHuX!AceE&+~?Mp;u2AXol765LP*0HflLr7XK`2~Ykx=q1ZZK?vs? zlhupP8jN`fDHeY{AmgHvqX+K56tR$BxzVv;eB{=nK-0Sai9L#1d0vJl_1ze7+opR< z;iSoQO2S|c(zyBCPTF7G7yuo|SN%#+4=IxI(77SY1{{xe8D4i%X!RtNqoXnjz$w?X*%hY1Y$iA(<#Pgtb2$+OQth4EY) z9Np|31c45$kO=;f+J1V?fwfyVnM%bsA$OVZ>gY?PW&x8O(3SzGW)gdxKmxPO3(pZ24Uxojt(vag1 zT|a}y{@YeKDX=LyQAWuspEuUX%}N#bAfJkqN_5x?8vOkrG!IE#OHy{*Vvk>fs;r)OItgi%W~zS^O)-S6JhGa@ZxVq-u6aK zVba(Ga`vEk)uFs*O1T?T5qA`I!v*IJqVSpU>OXTd9fOTA-COV;xdwn#wq0A{teFbm zh5f%`c6bh4AF}fxew5CRXG875-hzxm_;ys^HK7tq)q*WSACdZYA9c{4jHP~mL?Dz; zRW=N%6gYt-slO?}L6nQz`&&`gRj<;>Bnc(z7D|Ix>Zb1tl^;)qin-8mOlT+_N-S`h z*do`>g1*y%W`t-Mkwdah7@GfbD(?2eRnyU_uvXY_BSpUE{hn$BsX7zzDcFBn3u@=6 zC)r3*(_eB<2n>!O18N8#s3>AgdJ!zA3NAzWHz6y9#`zc-@b-Rg@`>il^KGP5h#=cjP4MS3x9HUK(%L>k0FhPC#@#Dv> zJ9k)s`|{vs1_WLWLH}4tZY@(U>FROgVkyr!)^qG_ zUz8Q4HRzG5>AQWVyGWmjZK`HN{G5|)&sdNJ0eI^=Q>e7C`e*^1;KY7ucKB}Cevy7r z_1&+NzapQFRe!vL98+U`x&Ze&cIDia2LwjjSrU>-F>BGhQVVM_=ExWu?A0OGX{UM) z=M}=6{?Z9M*kUJ5MU9d|5SOHC7)XMzc@K`1h$L$qLnp&Km0&GkO<7uTKsOnW#HvKW zPAD6SLpWI z5rt2m)8(m%+ZLLE`NIY=1Wb6bU&@i#=*jbcL_&iIil5npSzjy0Jds08n6lRvUWeK{ z@(eA4pLSObu|(7muaVak&`)jdc}H*YvF1G4srioMLgi>5$4O+-&CO3kWC$F=JqQU# zwLyaQ+SeyB$#2$73+x>)%pvxRv&aRLFzIm=Hv2T(=}mcHw{pyEF`YL31Tl25 zUEw(VD1Yu^4&-+Sh|{6tpYr#wY`2_V&_GM=Pca+f%Fyy8(IXuu1`4zjLhHWNkDSwH zpAwzvpivlDQ&6llQsSP{aTI6Z5JSS(3shn1Cy{uw2jwAbYBzq020<>#-o@-VM8_z{v!**k4t$fx{cf^~4ed5TK-0d$FNN%{>OdD34lYWh4mI{yw zXA*lEc9@|{A60hB5$Iz*c^w<`NbXGxgdU|!yH1ISuQZli#yyy5c!xms)3(CHR7qB+f$`Jos^I69_p^pYO~B+U^$ZAe zTew#f2IeMsZ-O?<2{}gdSVV%w=8K?@gqN`l5Ebsd(ZPj@3vr=zGj4ubzCGY-Oa8ic zEH#-3y-lf2(HkpGdyjmixxHLE=V(64n;XEiV3S_0cC%;Z4_nyWk})k;L~!Ae)6?5W zIAy~iho1CXDQ|N2d<2={&3otw!U0v_0)I~h*2;vhx!WYi8y7SN4({6r0!_9hp38k$ zE_9ZK!vqb&3*V46)gl$9XGpMaxWxJh63$6K>G;X<$`T-k*XkUK=nZJ!fk`1uYi|=w z_wIo2;p?Xrn^ld;<^93~*@_ZayS+bLzzw5DYD|vubww;Id;-AmYeq0u4ac59>%`Cs zrnp+y$FD~RU9nuK*+z*HP3IAVwiX-$8`Brlk>G4ZXDrq#+Skbxz@{bV+pTc+Na35$ zFx>GKZbhMnU4I>$1`6pz8TxK{j>J6^L0gh86g_6hE&!b@>D4QC*aa70PYJ=EdX8uG zG6Zba;nYZ_8j_6>GVFv2)-in;PCbmA9Ubw~V!KQK4(q2*uby$;p<;+uXdd}qoL!Wz zXuAm_hS(zb&~|?cE%t`k@Gugy=Y9T{e8>r4=&Hsb;l6dqYr2xO%3YXbK3E>CTJ&_qnXcW znr^{JK&yoy0g>5z-2Tk$`CeJp6A9fhN)D&&`bw}rg}gb-%R6#$IB>kXtG;7BB|`f6 z#!>p=hfUm_FvBgKdWi6tK%UZn6kn zNtvt}FRxQ}Aq~`g!n11T|35;*R~xZU3gS*@jp9Q-AglKSSv`InbI|0~%aPj)7aGOH zfF2}4M~29*|0*y@;l{EZu1~JdM79~{%o4f&r3n4#PE`U}n8OjfSh5UyOFmCt!GZoM zOW502uY53-cqwTi6dig6`#6!cR(KH+4+Q^&&VI7+6B5@)pouL|oGQy67={<-pM8`t zx|^xSdjSr>Rsm|wy!o#QldYV(q#*qv1MF3SW`c7gDzBxBe&y61J$lr);aQvOES`p> zG>2@1FzX{^pGQe27;|EFQW)@#|2AQY!AHv-5yvx^jkOtN{1C0U1#LW&A;akEwYC!{ zPa;{k*+n2GwS`33d*#D(I;&lmib!=-GG@FW$=FeCLI6v1nL5$`;(A~Q7(#B%3Op0>ZqMk z4`Faqran`zM6=NP7L@Zd#m6+6z{zuA;W;%@;~E3keO`(&Mt*Jm+kUBbP!^D!B7C?j zU4#VRjU<`(vU+5h`Y%~@)gS?o3Csq@dv2H+22Rr ze!-HK@GtX-dJjLRYtL9$gEwcEl;-kwiluzxx@pWUKiWt4Q4K<@k3jM~iO={X@y7#- zNtg~&kK0Ew>M@>Y5q7L#g*NlWxv;c)$UAS6pttYe8M_{}oh*>!hSi!nHY<#s6uN71AFeg-Ob z)thSz-Eff)vZCE+8>Pkhspr%PL7=98N`5t?G-5Y}wYaes6Oz$EuKuO57(h(2d1b!mxNd^tazD$)dx8Q)=27qKJg-XtmxnRDy9*OY$FA6bY%Ue% zO0Dzp&yPNT4))a$)#i1Bm+m9%ZeFcQ7rBIzxOs=pfdP*>q}U3QAR6wIKNnE8EB|rw zH`CT?m)LVT#z`AVOjT{foU1wpy)(_A;~K9CW4zo)2y zyA%ddfT&d(yquc;Lo&c@6aeT0D*f#J)@AvMMR{Sk5ggqEd8(#L2YX8HlM#4~T_^bB zZ^2QB=6!`{g;JC-O5;ya!dEqrR+hk96uwd@a)IeYWmZ^mZ@}!+i(mh?IZS3Wa91Rx z+dh2`I7Z9BFwPfmvi0C#jE$U}H(*qn@zy*?{MIicp#Q_y-IuOwy#wE`lHO??a_Fu6 zEJv#={7Bx9^$2%i?gG%sULqR zv3N?27Bu5g!mtp_PcjC8EV*#Jb2Q@ePyOhj?A4{ z#x=?imr+~yeAvO9o>o+JLGJ_>d2k=!NPMfYKpY{xh?Dv$p(n{7@nkbDM_Etz2*{-z znwpwA&BLQplWiZ7{P`s6wi5C{*`|+p*RNkU;itp;R$qS>P6Lkla;hTnLxRjt1qFqs z)}+fT2P3n|k1G|0|aZj&*;rj8Du(jD%}o>bpL^ef8F!R2$#SxU=_(~OZU^*Uq=)@ES zH?rKoDmufK%fWI*xZTfVc}H;)EU z##gtFD1@9AXGfh(y!(UVpCsG?zu6u->UlD^G(`J-Ol6X_=Ue2FqQMUpG?1 zrO6OqO;k;r>(H^<`d*Q@!}Ahe=)45_6V4@#F*0&#WoXbIJ$goNG-U_(zK#z?aEBu} zAs;~NC&Qp{;?TQZA#dSp@Eiew=vQX=lX3I)mNz?uyv_I@T(5R+#H!HpnfnAjk9N}~ zPq9|go0swwDQ$d_a0t2Bft@ZQteumU735TA`TVnd7M7SM@_-gwzo1p7o8RDLtPqPoubt4)(n#zh!dw?xTQ!0K#o^bMvQgkU1^u@0Nl}Vq|%QLPJBxY%fe5&1~-J znxV^wm5Hb`(eLH*9n~DPc``K15Tu(;J`@!hNjpV^%HjK1d9H)m<*cY^!{p>7u6urY zdBgADIVvclKGrk~Ki~70k*}xN^bsEufI*vUAQ+#dK0xrKv<<(HAgAN9M6v*K;*03^ zssTK8jiR2{u3dHtt7GIm#KP3k0pCO!vIXzdD;vYthO#=Cbz3?+YoN+XH}L(kd{@?# zsHd}(_|X;5W9KY|e}4~?~EE5r;eg> zT=kQ%T@-b6b(1wui~j!JvqN)LQB8tAiQt`YA=_%Rt#S|FT|>jiwncrz{5Lj;&);Ua zBB4DBcSn`NMSmS7`E?TS1DV`SKD^ThrZ7LgmC~Vygp^ME)$%ToNqX z^SW_%@^9_i6&|KhsF9-r9+K4pRYBp-Ew5`8*u*n5PQ*7loDVK=^3dsEhA+n(NeT;w z{60}k4mtC|Noo0eZzGGyiVd;oQAIx0dhUdA@5zTl3I^SxA!%#XPy|nxNUC0ZrZ~3X zXqrbC`E8WOvk4+m03z`z5{XghNVI6Xlcs+A)~$qxCZ!Gps~?ch^|`H$T2HShYKmF= zSTEN{2-tDk3)4m=WH$7nb>rym@&L>`t#~?jFrUsyPk)!4Jzu>ecJ5qFQ`1#KD#zLD{LvCDhso*BSNbry88dto zaL0`+AZOm8+}yUYp{J4zwj-UDP)YvmcttItf5~Xb74|W-^~An6#uo%Kqk3BpZr*12 zKx0)pPq47CpuD+*!9<5M!J#uDZTylFF$u_`aZKKN`1b8ve!2km?VUe3_2>^y(JA-b z}Nos+QAz8qWB3`zfb@ zj=?b`~3A^!e z|HvJRzHWNkGCq^xrSq3-jaWOmuy_h=AK?~ubil_*;c`T4q^UmujUjH`Ar~-88!$=+ z*<~toNfS}s7gMw|c+Z?^^5jpOcgG@YrkU3TsKf+`+Lb!n;+IV4jTt^fMZM^KWky)Z zoNMRfUyik`?PFa_$mCK9$5v**&gu}s-86)+2s}sqZM))5-0}{-dL1<-VH$!W2i)3p z`I6W-*4JNmPBF-Y((Qs(Y;;sq3-4-BOHbGG;|yHQx^df{8hb+6$q{v0HP)BsRze=~ zw=XeAZJip)nDzV!$f1(e`D1#ze{t4?;0)$f!uTj{ni&89q8LOj2nv3N^H6(Y*shi1 zDj)Pla73WD6ghReINnUM9hTW{Tv$n}BojCxabbJNwL)a*5zUPuaDgK5KK0ns zDqVc_wu?(lb8~a*cBUZ~t|^wk??VI|Y5ECgw0z#>=Hz_%{8>uPeFd&kqdxFv?OYm3 zA=#abhrVAL6qLCP#h;<{COulTXY3~Q%)I&R?vcxu4a(+la*TroWP zNYh=0YC;Ss@h>@ac6MsrxM6t@^}U}p?Jj^KI!9h>`bdZYMa8ZD+u2{1raF6LIIa!g zmBU6xUA(vaOKW{2PjO7#FdY|vq$zg*8DoxiH3|a62N(?#S+L zE#And@FZgk^J9DHq2G(M4?VtO(+<6{BkEM=)TY#_7B7%7#maf&BC4FB(c5w{90|dX z)RfXl2xcB|TkO-2RtcA5J#yqo&vUl01}uFfKBmF@(D`7c-vJV`AxQ77o}SKn(bAG#ctk|+^RLGoWKCb7Pz@?Rmn3wLES~w$-hPcP z;B&aU<()ec&T1C*EY?U~G*@kiXP94-dda8C*NMNzFGcEHcQRlpeZ2tt!!%ih%Cv zRXC@#BtkAv`|iz~FF%>6W)Prh)O7RHn401{49Ab}1%^)Vm3@Ix_k|nHqcU}y{kl+$ zjs&aqLf$+CgoJ4tZ+q9ZkQlT-i6U1+V(`c&NAdJb3eW`UvKv-5QR>e4t5wKrH6nMk z@(QPmR*7?CIZjb{o;P8r)TXbI2xcS6m!p<6ea+5)xaYIUkT0ZuVAs!Wi_C#gMXiWf zcfr$sE(w83^Zz|9_Gv2pv16lfm<^XgsM8=0J5cy9%f@>Y9uKw378ZWmQbbSf(n|Q@ zY1V~jdwYS>q~Xk50DQKmK|y>%LdDbZod_$Gr?h#2q{Q6Ip!>?_PpGC;x`R^+?_65ideLveOQ@~2Ln0zzoM@!kIu3hu+Ox|P`GjG;>A z{cwxW+G49RLUVa4-*zyoX6~kuu#8t`2M{uA3j_mX~7#MoqL4f zqR@2fiti5g=XCL8&AIxMT-W+Ui}O8ZvXzPv1c49IK`D`Zfr@2zuEiV9N>Jepvv;9K z0^Sfn7aj04o5sZ&0dHcWqYaFWU$fR6sLnDTyg)gtprmBl-6m~f@oSm5{6Y%b-Hpi} zoZ=dx@&Dn`6aRsya@Lv_gc1Jv(~&65GgZG!EqR)YE88rhd_8)Re(pW;*GIveOn8vk zc9+m&Gf_NpZ6BEgxBGhS$>t~Ybg;-1upML1DCSs|ZX(eN4L(iapY>b*WBq#jAd2fk z+-@=+ZNsOa?EFtMmJbx*<-L-kYEqkxbCww4xF{VykqqLjgWZz9UD+}O%wZ2hY>4Jr zP}gK@@XO%2XXR-zHf<9hEOJ_UV~0oC-S;143a2-7b%nFV#>46B3;+b)IqeJkC|z;tVLr7nEX!K7syi4nfg+sY6KOYs_xZ%8?TotgS+wRu$Kz zKDoSpF-l~`V;|do1!IDLv5M>B4Gb*atyxfS%9EpE7#!aSG=TdSdY&L$-;TCuHDAwVMNStDO@?dy>#iwI0j6{dV zNfhH%^lNRtF4maM;KeX0ZKrR~H;$aY1=UH^IRSz8oUII12{VHNjXA}W0_?rYokyF> zI+WZA1`2>+K(G7W_NF5M$nX36>pWxmptLP_>~>DcYBYyB=*4ucGq5@AoYg?`RgT=v z!jtXzeNuI={2q)}dg8jQ4*LMXT{t%cn0vB$mtfQ`w+av-1cN=}oEZc<4bP3_5}lF? z-}9&Ce_Lh-$0>49AAn0QlE!P=5lDnjg{~eRqJz=k{@rZNF}OpVOU%-*jM(Ka`hC!0 z@x;R)(CK!UkVl>__p2?Fi^l^EY>Q&-NNMog8}q98D#bFy3t2*It;fF}M!%UpE<3Q9 z+h~;P`aNoj0mcWH02t@1_5&ll7;Hx<(88I{eR9JIMCiuE)4;&rBmO+vHP-d~&$7vb zajIw-M=_Oa8jWNy-88Y{Bg--#k1}8zzu|0P>%~bGf81&-xs*V?B$lQ3J{g(9^BpjA|@sml$1j~v)PBe ztfWj#MjD#)2<|uLJxnbYm3Z$i8RGzqKvyuh@q1dk=^fq-rj>5AU}LssBSLjQKviNB zDTh{3t0~ud@@nKTRUcQ4QW_r%ADcuqE{4NM5BL~c{E8(hr%g${^Ldla z5H?Tg91dKXng^ATvf$<4+}w(V_S1AJs%cy`9Y_`X95q6G?W06BO;u2)*>}cM_wL;z zB_qq5UOl;Zs>ur0O>m_}o(BdDr2}yBrzjYw2mwXjrDC39O(f!+r}|0A!wfF|sD@kN zk=kT*3AaKMgp~Qwn#lNgE4a-Osvx=)-v?KaC6k;>n(DdmmDdjy4)wfzrehQ$TkuHS2KRCU5S8X>a zst`G21>}r^&k-!Ro?{M14Kc$*RYNrP6gKUDfC^keJx=7i%8fFj+>{sYS8np-k}y?X z$Gv0)vcpXhG5d%-?f?{xX+zOhwL=OQ?$=}YJ7+w@&V&LlfS}6n{1olbImnYo>FJZT zGxC?{G1YOw52dxK$yp8s%*PxC|^fhQbjGJhivCs3nrwt-E zlsOl~kxBGDXLYQZ$sr$kcqO3{+S5X|+~=QE>Jvx}t30Dg_^zY2IUEB|fw4UJyYR$5H8V2-J z?yYY$P$ZpQiWH#0)*8H!k(Kqnw6rhy-i2S>vKFcm)g;IpS$Q#978V!FB{ffWt%0mf zLPElDQU5>;cKJIX0Lp^G!r$iJ|{&0RCj4s2b%ix+#d zQ=jDdYVRuKsx=LrX#AV%TBARFUlH&R(ePH;R#P;D%D#W?>!XLO%^5^qeRq?5 zBun|q&Nh-?`4?e>w$I$9xf6s4Xe0x1;$vbUqFI|_En+FS`L&#j#n`PIlY)$ z%-Y&oV4T{<4$d1{KVKt+h7RJ1^<=g>XG*A4x3nB8vHubOlud+i(;WGR<_M=}%s9P5 zkr7Z%Zs#F#WV#YCx$$rHilWSwB-}PTy80O^Nmx8+a0y&+Ky$(Ru|9I*;v*+fZfF`xy%};U+&QbS)G_o*!cBX( z#{1X>p6PZJl#XqnIkw9~1d88h4_7d8Sh!>VFS zuqKe}p_>Bn9Oxk`YCV4Hzn;mL}`=bn)nkIT=hnC;W52 z@E)GIljO#KN?TFdXYxH3aL%%mLD!KUhMZ)CL^X4P%s}wny*`~mNn(W^*;h&ggdC9V z%Cx^4d2I3+UB7vm5H#*$(ZR2Gc%jfj_}_6vJrUoF28Rx28+x;y-x6~x6I7eD4+de^ z!l-H^SmuDl$lUfC>(|`Hq!5$G7>!1e@B9$AEUZuUDdZ2x@?vzupy0c}Dhx1noOStq zDk=jt5(6O!^beDQcdpNEwC*O5F$X9{nB$=ssfo^mm-MIMY3c8`fM^JD7)Fawa0egs z?R08hHXFao&o^ZFsNEzWLpdLTEubF{w8Z9P%4xw&tA@1?#H7+zvVi|!}9ta#J9CmCJYJZ9=^)^NI@)MsUK znZuS2VnoQMHJyl#V1{bi8D8Go47k>>mhULgT$U(B2R7$wvjca)hjfj%q@<*pHFL6L zO+xok(@(_rSy0yHt1Oj%3!RpxIAwp2}f9r$fh6x8nVr0qxFwJPYtNVz= z*27Ta#@~dcFj5yI;@klrt8%6C7H}5O(-)VQwQE)nMwlu;Mgourkvq$a_pv{+siQk* zG38u3JQ;&YYgrHw(s&}mq#9|IjcggRrAaT>6EyDBEBQg2 zMY5BP>D<|onn6+g422p{c_c640xDrOS|xmJ_mprKlNdhI?5R+Pc*+(JjoWqu_I~z! zR?+p)irXaZmcx(t*!P3Bb^a?;2RGf79dIm3f4KVcDu?yxXLyZ+#%P^JtLEL2`_n2C zo9L-8L_#kd3G(+t(!)iCGy-p3qIdK#QQD6%rYuB?t<> zO*$)&W=Vh#wwQJu3n=|Drz?-%vy!{AfnRaw76_dxcNoOuj)Mk1NtK}dsQj-)Z5!d6 zKpf(rYw`iEcHsz<>p06;*B+(jgFIoNg(};3^_Qr1qmXw>SlD4fLBVtb;f{THr2XM) zHE~wiGTm(XMka{H3RqC>3Y}g|4GBNG>>+yM_%G)r$D4fsfcCQk(__4EP}n~R-LipF zjMfD4iHTV;jAnPBdnEaRx2CyeArz|R5dfU^Vhr2^zg?RyL(*QPVF~wXZXk4Gsl4c=Wa^{0w(4gsm z)kx$a?p@^fbw7)K{KrOs2By&`x|srYSLXzzDd(e+*ee-|m)V)!vDiAby#Lxu2Gw7cDRcddifHVWJkApd(&%yzdT@ydO{X^{iH^JHGf zVY@+(*T1Uj@|*TIc28f~mUXl-S9Q`$R$F1dqC3jYRozfupJ~YnXp-^`Y&V2PpW%Z* zuab;N$G!h$ui>7XlRlNmp_(L0IihaN_5QC?9emaGAbmbO#i>lm$|~#sc?wd5OniL( zEj#;cL+nNHj<91YIB!cZHw_O{u!o7X;~%$TNW{Hj&L(n6o@7Hj{xHRW$VDs{B;eto z5Z!VYKoXhP|3Fjp?}Uyv>|!F+hycPk9rm}5Z!s9CVPq#*FG(8fV_&ohDT(_R@5}TK z2;LR52BnVByFP%-{UY!+BDavV`!GEM#8#A)g}3v|tmXo1HGdsjRCZNWT2b z+MA`SvNmGt#&fgMrT_F^1`fkJSL};z1w22>&K&l`~c?Sn-8OUB+X#{LIf49lK8$)OdO@7%LyC~)h9O6zevfhsHmtVZC$^E zWzfOg!{W`>qLvmp$>eHy>FCM~e=R5JKKjhUzg5Wt+|y=r)n?*5ur~82R`5E_2mwWa z(Zrgm5ZG$V*RKbT9Xr->HtGnvZwDPe_s3C-^zV!ruCUwzU9*ibI!JD`r)#V7@)Si! zo5Es{C?C`%GuZbWTgo=K^L5Ld+J(GieBIa_rNjQ(nH0wh6Ip z_!xuw!Kz(Z{G-t4{54%2Q)VDFviJyMaP4m*Bma4~tb>neg`={JtNe}Z)j$J8qs2AU=E zss_}Q^N45|!ge`J?LAtxc^8;%ffl0xMMc-pZYUNB2$RUU9$tjqOOW8{ckMRizX&3( z4L6j9T7m$^8`7fkM;v$F%Eb5!-v{2}n(RsRP4-7Wsfwq0WZ?$ao)A?KIO31?83a=V z{8y0A7B?}Yvxp3*SdJGJKd!g(TbBR)_&(A4PzZol+#k@IUkUE|9;HfxudhQLyofYV zT3A-uuMMu4o(z*aefl)Q3TQ*_VoN4J+$X-zmD~9;$f>m&>$C|kVx9vP(0iwGL9h__`0$dUy1;gzQwu+oIcs3`DHipYso4=&Aw%r>LF zppKJbu8%?KVrZ1Y51H`am@t%+>R)?NkMr- zcsP#>ZLR4_9a{Ml7vvBZQf?ns(wZ=?kjbq}$p%WHr3P|ToM8t*&+0g9Z@xcQACZ($ zMZ-w+%g(o2=$^7>jq#KHfEC4xYEgl9MM{Mj+1sc2ZBOkyEPj`1d5qqsK-AN8V}9w#O-nL9+XrvUpXPUj?bKA*$p`Fp;Jgo zJ~<^kSG=l|T9QR?aS`BzYLm(=YT29?<268}04{5A=E=waOZak!7n0{_FQl1EbJ22d zOkOaqpT<5fVQaN9=@=r?KJI`xMDj^cv1dtLp!TI19UV>6jy$fIm&`y^j=V-9<~5Yl zO^)R`E=(vMc;p2jzpFk4UoG7)!>{rm-s`Zr8mO`Cb=X#&tn_hmnOB%x;D$E9A82%$ zM6fzW{Q9erryJy|_n6A|QoATZNFqik*=Te~TC^ErT6)NPvCV}+Xgo94XgRTr^*uw} zylRi2wpq#fLt1H4UOj)pwZ&L z&?qHek5;6RvK_5R1z&aftH-zS0I>XJ=wo^_43PQ=>j}-=e`>-j&HerLa27A( zHL$|1$q?tStzlD0e&ywx^g&J)o(7j(Pbct%$QjU2F#7NM_?SDk<;N0lr zjt+E4rxt_8jG+{iCgyB0vKM&x@Hqe(>^7Of8s@z&tTA0gsZ@Hj~kz z{^wCbPJHN&URR#{j*GyL3pc@+DZ|l{PoqhKR_D8__aX#5!!5T#1Ivz|yUV$V@n55> z_7+32&{DpyNH-7cRcWqC|}vxcgoCQqlMn|7}w#L8|&uS?lbd29=M2$Y^0hPPGDm|!reYZs3&uutbBf^H-Vz6%c(?U5_=21G z588#Q)mD*b3J|x-$8!xeint+(#n4cfNsMJA&&XpCF*U+$o@t&bLz2b*DjJrGg%sTB{2g|iksIz? zc7TUP5;+wqW_xleyWpq2^2Kv%Wu3qFChb~(bu}IwQJ5Xb9HOz`fAHGwX}+BE^lRCw zP6|nuSj;~fWZy3l46gs*&(1p7AcAv0f8h!V1^weffG zj(y;0z?e1>7*QNL1v%8jVSYrizS#M>znMWvAN5ZnF3K3U^{3bcvr84YjauLqf@{_5 zVR#DMLdor&##p+oM`&nHBHg_nZtoryDz7YNppNL;0#O+Au1eWp#Ph#U#qSJIwYEAM zgs?dAzFw=&@zkr*uP?mVeGmc|>YT+aC<|M>RoEjuU&nb{Te$=E&C9NuN=GAkSsl@- zT7LdFFX!s9g(hgc1)D%d(rO~Qr^hmV<>XO|D(;&tLe)%*qc_BhN89KX#9TikJ+|+9 z3;%NN5Dk#h@&8Eaq1)5l80RZS)ggm;v_o?p5+{b}z4|2()Fv0OYr+=52v;&uu|jr! za1tgWDyG^PG5y|a*87k_FIGE5ba+HW?2l!n1U$Dgbc)YPapkDM35wRPgcAS8WS%&s z>^USR>%H_puqK!3LM2DLTM^pa6MQPedFQXi=KNiT5r?W-cbZ-GRM0=?_8u5oL?f$XyC0y^?hRF9i*C+|!&BCd&6U~_^_daa z#YA}xHyM!?Iy9PLbnav>;8P2-fB2LTXKqw86`uY@AiwA+`4tH6YUaR+KT^6R!E5Xu zbH!xE)K_|ub3dOF6&lARfE6&NYWK%0nftoeM_9BUZ|`H-A%g#KsG3Kbd`_fDhUP*q z&OaGi8g2*tkFahcASCqFpQjv|2WVx%y_!yXEUuThNLOj&1Hm8qQD{4BRutuzW{=@W#*B-_@($v^o-ROP9 z4FIx9#jWs&8;c6^KuEn|WNa)nCqe}OfvZ5XzXf&uRf!g~=u$EiVM}bM91(raN|l2e z)R4qow|R0i+RE@FdxJR~kfaHZH-**nV^Sl%_2|IPA&atk4?d#?>$#hAZ-4ves)mpC zXVwY%9z5^}=bUBVyTDthHtl9{uPj zPXxzQVu4_o7Mt(N=_dRl78i!wW&10|NE><&;)%5@)K|_;@)3d@=HL;w;weTOH+TV5 zZgSi1Yr%qlyayL1jTWDoNxDx5;eyayNiUf?(9&Op?$gr!B9TWS+I?Coy9GRH z|4<%$$y9aD`F@8%L>-_VB0&%ytl57w{JKU5)j4_8XN++p`6KA2qhhxN4zD|gq|BoE zHo4P8tjsYmme2XvYIa(}_y(l`%!|o|(u=Zx0hm)nIM~JW|MGv%0v0IYQ*% z(_U`mec+{ZednP*;dOazANhEZn=1^~#7$rP(H;@6eh0N=GK`P&wz07!2?iPS13q598^KhLz(#phZ>aAM9AH-IpI-|S( z3p;w&L$5Nu$}!e{9P!$kB*e=O4BtU42Pr8jL)XQL%cK@dhRhzJLfqbX`^yk{x#zSG zaDxC2#!Zk!Lot$(f=jOe`o=9Fk(!ovAeKtP$g zJfJ^{ksoO%!Kz%x?Gz&s&qAg=xWAQ2^_>8?LCCxA60PW50caXL7>BsF#APo@>id1=r==rm?3T8VjYT&IUs`N(pI%_Aq!3osEdHH zObS{5{fIQyaAHOk9tUr<`?&um<@0dR4KkniSDrHA-4*SHtOJKSE7}iLCJti1d_Rca zdg(f0=P+e}c~Ff4X}tT#tQxXc@`f1V()H zuzp*JO3%ge2<%8y;9mM(PGXPy9+vPNhFRl)(SV=qjLDURt3xop+i^Cg8Evvbt2T5A zzTSv}NGv%gUt$~-vBQZrL?N9B%&?Su$Z03RyE+{dJAV(76QU=NtEojG#WQs|DQSmnqXQW>iwm^ZuWu_>kX+iRph}f3Zyj@>qM`yTBI2`|Ws@1G zO(q5_71V}PM;lZuFoB2oUA#yB2|Ob=w>T)s5au4%@GF`<#0lnH8M7+3LE7ll#j!6K zF067WZCea=Z=JNw?si{2@y0*?UCkwyEh?AuqFS!lP#MXE!__a*3uo>^>69$9T{qzXEzW zwX*|m8y0~K7Y!N2s~yCWX2VlqLKwWCxl5l6_9-=j9H?6=c{&nT4s9Od>6scwPF{Ph z&I!De7i}vKApohK1wE%$uizhau5V=2ksXj@@cLTN`M{;JP~%RAhm4#|iQmnG87?aR zCTCNG{~e}{HEXOxOs{yDK13a&K$eQ7O6-SeRs{RoJ@)}ZnfhVQ)n#R$t%g?nqQS}? zlA!UF^ML{+Qrjo|P-H|hxdxnz@t!Na*1A^Ha1X}9cd%(t%y;iMNWt9n>2`0db^=M3 z|E96DCxzXX-)?H}d|EEz{`!{WhV;t?E=b2!HTEr=|Uq$zTmoDsfz3 zdvv8r=rIpCG;=d$PaH~yImofGWC%dgmZ-AN8z$4XEjLu(D>J4J5<|7>BAxq{rgGp2 zW25t5o5;x9)3qfUeC-=6+ zui+!~AI%V+QTFx3AM7|)abkD0G3Ug7OF1xB6Uw*W|#q9ass1X$U z`Sw5KFAB;9xBG4uryaq2&BlT9L@y#JhgtA2-T$fasvS6WMNl~0Gjm6)vhKZ2aT}Li zEWys5xtQ3JIGX$!&ZOu9uPfLL^?^IpgzV=|3+f~|>QvOhm1xK%-hOgDNiGcoQPlC!mL*okS|A4&71wzsQ`oSOjlmYRY6`X}xu|#V z-d##lhprudyBAhFo+Qf|B+`wM4s)tXe0_9$ypgdnd=F(ee3))#9(fDp6lP2!6|c0S zK7N{zJpYV;MB7*>d-E&-mXA#NDf*DTyDykw+a$eA!vH zCtuHf27{EJrVbw(q(UZ3kEkPNCNHZYPDI{)N2wrLAvV%tQ(-QaOJL;=-#PYA{NKT6scACgDQ;m#|kx>#S}d^_>IY`j%fz^&9$#MyaL0@zXHplngLo4Ld=Hj%; zyGqkY5}b*EnQ%3~tKDtgtNH*1`NREsxB8y*tLvx3XYQN%43}LnM7lc>=JM43gHG~q zu(6Q`c_1J`@gMUc%)S3x!_7CtAy=PEX3Nc>h@-mnerhY$+=zk++#=K_wu!=e)RJ@@ z&$@o9PqtPD+vCl*!*usaWOiD@WkJBn&;;mHq6Tf(uKN(v%_D&*^g~$Ao0pvxf1bxl4R)PPwuN*Kh+&o z7&k|vXJ#x#cQ)^VK;n4pe0lBQ4?=SLVGE|>Km)hN+!S2_U9(Ss5V5`F?yM+E^Xv?dV=M0PrU`Fw_Pg?AO z5g($wThDEM1F{~MPrg&Dgl}_g*RLT=DH%*a$`TcMV2jfFW&dTDeUi248ZFsV3$SV4 zH8GKGabJV_L}ZzTSwcK&&+< zUun$qBKBY2)DNgovilpl2gQbM_8U+8e#OL zoWdKC$e&`7wA0pE{fym9%t!z3^6`tI4KepZY-<<4Me4^8@ovBJl#rvUmwmMm{X=1A zQlT|+TPRYfEY-yPoE?t#a96qocgVAA{pn$(zkaR|cF=iZ>DjMrZOyE#y=Z>GO7fs~ zA#e5P*1C%r(}9~9oAvp;+dkjkqwt?3YPoE5Zz~QT(g_sf)m|x`q$h_~gCCBp*t6$W40v;XK8#K>(SjC`+XWkC zIZJ;StZ3ocgvzj>YHZRCDh=psZVgx36*yC`SIEBkW=K&`va`Km2epTG4OZ!K{Z9Ag zlkdn!@Q1B6*_GpR1B3ZqtjXM7CakRC@W5W}Hi5A&O|mG__V#umx6ML3Ql7P^$#BFF zR_UFc?X3>VKEuf5>2t2%RyMkF!gwb9&7@nVD|~Vd1s)OR=KqezdyyhWP10sKUHydW zO=f03=I0Z!2r#c@epNLKrlkA(`{mf+$Q4^Dd3pb+s3T98l@Xx-FTfztmoJfRi1jlIda4?WZ8Am>Fq7@>qG<(V@CZP{UuPpc&+;b2Ib{gwjACbx1=V* zyFb|k1*8Yfua2d7yE7zU=vQ-fErVD2kS=`)o+B!aO ze0;w1*Xe6=>w)lMBsiWPU{r^4)#4|M$mxciyCnLjk9Iyw{xK;3plyjwc#GuQSBGkx zPOaL;#_L8#>?B>h9$G;xhHh9cfwlZt6&EcSD(T){;Y-TSR>{c7fbDfBK9lA=*34}P zK28n}=t>C^N?Jip?^n*hJc`; zcFh;rZ%!;KSh#Z+kZ?H1@dFk>9wg6eypa(5q2)^%R%xlJa46SxJeJt!)x!@f_1fCn zCRf~dR-ippPZgp8qm=n~>yAtj&7IF=mhG&FI33=0o1xkQ21Jrz4jq;!`qBL@Bf4)_ z6cqz*IQ;-&;KIpBg`enCQ_`1ytbaR*<>HTX6w76sdakSM1tu2NRa6p~w&!51xAaa@ z@{R!m&KyquQ0b%D6*5wShs9v#%P^=M6<-nPZ?HH^)l|wz zi0qt9tAhBq4-#E}{pRgkc$y>~9o>1cgCrB@0|hO5?l62L+h&rL>|pL2^Vi=@)W}@i zk|L>$H4k4DOBa9e3HD6d#DpQdtUoQRpexoTY*MV-*Ip{cFK@YfJza;ZLSI?~pnp6? zFS~PHwftTt*`+-%fE`6;{Q(k^Jog>9siW4xjV==~qW|nfVK|Fy{5$d?LH)I_*V9j6 zS%zm#{U2Fh9*=eQzW+wilxn7xicBe$J(cX5${yLXgd##kmh3#$RMRFNWyw|{d&(|C z8!1tUiY(be+4uE#okyDaet!O#*Uim%CrnNLXP41>sr1OH5-6-yq`eeZ&#;sgBPSLPQFB0U#C7yeozMqkv z9v2^9B6%^$Q?vvjcvO(I#9)6{}>3bjB3pQB_>}Kvho*W&7#n`W{9e|@9W?UQF zMVtNiVIg3{d944(*ctNte$c}s_piHt&MQ*31P;nz&{|RX^StxV?>SkY_eqk~VIS`@ zO%aZCU#6ff0s<{PYZ}Y)W4q*X8-?(t&$YEH7tBkFYDwR>0rx6u-FQ$wP8HU`YBx%n z_S{&0qj=@jmsp~_@o{%hz+eZ0q&IZDss57^uYF{GDIp;N-r*4MGXG}#?>rUHq5ms* zTG8zHXrf-@@R_dha)ICr=x-IDpI;A+zxp40CQAkXg?FkM^S0$E`=`WrqoQxz-Miow zf;{!LVzAiB>x$pwDin;*VKltqOZI({)^~UJR{ud|CC~@?h>5;?cMlR3nZ8YnO3(0$ zHnUL5SRs*@BQCGP{s`dmZH`Mz3vjHmOwp=vN!m-Ds;;PbrspoJXmH7?`Sv;9lOG?R zO=~+_JK=jMPLdx70z1Edx5%Ok9Ld~xnR7j*1ph+YnqRQj^49U;9lLfVWMq86OV0%9%Z(r+!km55J?m6953Gzd|}R5^e(oPq6hae(TL&% zJA4Lhqj%X--^eJ`#@063+;zXaR&Ml$E*_c@*KRb8W4<=;{GKw~{h#-5_yc>`#UY|& zY@CEzlzK_lMukoE=_<*;^{YO7h)+&_D|spRgV=v|0<^;>G2k(yR8 zFbH8txNC{K@=PrhQ?FchB5B*UZCF%!-epHr_eX~}?-mf~%{iQVrf+1SNSa(=`e%&q zp`y<0DO>yoS(L}B_fX?*fwBNMD;Z3|>=!~E(!c|7ZubhVTK2Y6lz@#VGjp!|rKtsj^Q-){BN!qnM0 z!*{(L>UvaVH+CcvImR`FiRd71!^L8tpnOTK>2tsEsufIP<9n4y4B)Sp^Qp%@e*9VT zVvk6r|BDk#DJ`NL=J^HMmKkx^0|Qr~?;r92bUS53TP|k%C>FLQhZN;kVe87Q_ZRK^ zxrwh*Q&YF2mo2uZx>u1(aePx zlA>JqKZ@=#xJ1<*N4wK)LPD9oX9X_*bhr*Tv3nxDcS$Jz{vJ*#Q(0pX4`$fUd+u&Z|~moOV-Q6#%IB)p?n|p zd;>#jOQ}-|*vHB-??jHWYmb_D`$|el-3lr;El<oGqSIj@h zPtVLWRHW+Kq>euANP?3~ghhzj$}alG{{=?8f8-e%aoRUT%=`o#`*zRJP%k<+E>g~Z zJ3Td#ypiYmxu-nsX&ah1`2Tb6=^bZwi>F{`hj39WK{PE_A5W*TTHejb&_!+RtbghF{ufw*)C(pkx!IW5G4gKH!PRh}P$pY$e`j+PhxuEkT*p!T8A}hJLxV8xjf~@u^ zbs$nvxP#ctFL$D0(*?q1JoHK|Dj@48q0}1EeSZ_E9!cK?s9x8S(;kuLOJgTm=R9w8 zUX5Y*L|waV>`#1m6oBIhq?$~D5qtDLvDhBZU_l>N$99RyP=$&_bM*4P7rLG}p+<}c zEALbzo7}tMrI`bOgrYT<$D#--EpxDP1J_bmHZsgLvY^%HY)09>f0 zvw%K!UGXE|b8BB56-8WssQ6)97biDWw?x~53J&Q(2L*P{5$h8tT9g-41E~OitNdF2 z!R|J$G-%(wWYJOwb{}CXIC0J!7aj=yqIC2k8zuJj)OyMiq4)7JztgdqnY%tzS2Nbx zwmL}@&`TIJGS%1nVMk61&)p0q1f;d3g9 zH52__zWAp7!)F;mQW5T*TNz?SHU2rLd}ldDa{XVhLtqK46PpcCl)l)amE7kX$5VTjNL`lQk>!R8B<8xql}|{0?sZj{2^+F z#f2xsB%M{7&>jtoczT^8qge0kd=e8rUnusIKVV&T{Q1Sj>wcrms^MnUBc!dlShD<; zcvoCk0Mze#KZI3o+>95r_sFkT;tdm0u=YoW1~sn z63ZxV&t5>DV7|=83p*d|vEvsKsz#d(JIJBpj-5L@(6$KD##VZQS2UM}R!bmSEj;@U ztCDP^{{Uf%`x#Gp?v@6#>$dM|3EH@FWnmWwCC$SKuEV)ljD16{^IE!4_C~YsR}f&i zGk)SjO-nq$YtIE`c_Bp=vInnVDGVQTmkXcM%CvVMKfcQJrYujw;u0W)tz z>Pc);k{UyBm$m>#w{fXZrl*#J9C!7&p(1*V9KQ=oA|S#zXW;X08-{}-hY(|@oL-C)hClC}*+%&}%vBhv|% zAB&+yzRiFEyvmSxo~L`UM9CW|`yBh-NdbHs(7|=0i417&LUi0^7f(Dnr#ok1gU@$% z+HlEv*AWeM{RLdI7iHF6sI@=f{`_B@(dfXZ9(EA86??O1ga5%DYchO~B9l;`(%jH*8t+EsWk z^10s^98!F`PBhB@MG{u-3R$_b5tr&P!R7-f8kBS&gm1$lTa+x5L5q55@mfM>>NQFF zEB$?8qfpk#+Fi+}1qgDe)nHwMJG;7)&CR%j-zy!}W20R5lQjgSvegT6uld(Gy?Hbg z=>gXv;cL#t5?qAvb8~jx-MyC(=i5J;W13joE^|UgoGE*KA|o#O1!{V%v>=JWI~r^~LsIY#?-NR;N}4yK#uEAyKBizS?=F#%@;LA@rxM`tl{& zVmr*|K-I^Oaqu({USomZ7aV7_Fc)D_*_FMr=Dvr_NS)(00RaT!g)zSrYT)KCi+gLw zaV}=6&KFB(SzN=vsCkxRWEYU1ixu%w=>3*>=T4y{>#4s=ShK!LfF87z(1-W$?^aZ3b#WY`EXC--7%}PK?1)Q3F{0hSj!Wna z3S7GuWbff!*5oOh9SB%-(Ed-~Dau|d_skD1N5?d0c7fm1IF(DkQD%Bje6us2K9}BZ ztE{u{tlE0v`4O^q2{}0i{CY_beb3%__)@6O*S6}gUW&c7`$=_I&b8FPD|QLgVsB(7g;M)?N`t>EP2%OSmL0U@p<5>5Lk* z5EyQAsRgfSC=1O1tSjvkeCIB!w=IElluHx-VZ{Qgs-LQe(^15 zcO2ck@iLjqn%TMZq#K;PZM3df6YQ&%7jyQ7=G~vutZv|#Qk2elef#9kQm(x`wYki} zo8{z8fdap8rke+sC>`C!Mx_zO(K9Z zT?h=6xUd{shW|s%hSr^jVHCmg7Vhut?5wJ;23WNY{2!&vBPhA8sD^*>oKi*`%#kaU z{ar@P-x~we8F;;y9Rb}#vwy;ksk)@7sJ*Df#IoZIl^ROE5GaqiZ)T$$i9K^{o(Mfq z7FKcq{h?}bG#>!nK7{n`ETSlrirdJL30e=}}(M z02Z1AAs%x2rntlt)gATc=n*X1K@p4f$JSsLyC#5a(;5BtDdU#89L!nvBdZXXLI{2% zdvLv{C)>dJb}hCIR5zF(+SL z#(+PO!sTE7Y5O(KYrK{i#OmiD18o?jeU9QtW~Oz0WR;ZK^1e~mIQP>d*S@1N1EpeQ zKJwn)`QSk$B%iSbKUF%q3X)Z%vzlsy=dDkY9lC_B=@BAKe*N$EF14<_e*k2@A~UT$i#d1a5#%HzB9*U_{}dh;}yLM;UHEb2UbEnQDf>~c$fWxL65Yg6ADAR zR{#=U=y&9-yu5J!D4I@FLI>v}rB}-=MHqWpMnv_0{iVUdUtrJpD6XfGZVK9S;_jl9 z<~3zWCu=jUr^aEj@Ro{-msC_$lg)V+{qJtpklmadb#MK(n*yKmy>icV*TEgr76}-n z?$eMRi$-#5zZ)xKT*8MaQjN_2YLoJReC1Q7LQmo=C*dmt#Ewt4{;O1oJpgH21YV1| za@E+k{hJ;tJhXdVbx8mp=65ytiPBM4Hfn$n5d+N=Qubwc`hxz2daGT3;S32r4t59c zZPLQaE7G7_XN%yJFKz!gS-Nm;YC%eqjp* z^&?%zEejvC4tlisE2cZNsz5r}|AX`P1d4hvu&3wETli5|mw}Xw}~x`>ih;Kg|d; zL0zjJ15!{I@vlzk8V|nwzafep_3(G1R6h9yzqJai@o|`AA$BqMrh$V_KJ@6Bq=Gt$ zj6<)4{c(BU3U*e^^%`lhTRwmE(5!y7?)G(F!C}_6;qs@oROwo|{Z!%P*tB|B+VRQ6 zN00n}EMSV{-?HT$qZduf-%tv()eZjF{cC(*4WQ#HnC$ zvZZnj4VTl_d}#RBSN$2Grn)q9_VQo4CuA)pumV#RxYlE* zAQ8a&FR`aEmm?wujX^-r(j5>AFJ5%;SJH&q2(Z^UX(wWvQ#K+dP90i+l|RJM(BSX5 zc`9QtQV2$Q-7^ zzlZ`o8=dwI(~b9w{x6Hi{x8nZxW~Kq!Pn0b1tc0+fcIhmy0o|@^xzDTi~naDY1>w6 zBiwOjbRed#^`^g`JV^gj|Mbc7@_*gGStAq%jtUSc$gFw;;R#j|7G;&CycUvkM&;4D z@W7MxH;RXvF0H>`9~m6{Zgg~1&;SLbv0f3phjSeEmsn__g!nAvj{I?|UOUp!JObd` zRa*APzysr)?LTUGmtD3F2`Guiq0xlAyiY0Tg|=)_nled4nMTWQ-({Cy2%0|sflL6u zu(0sZ(8?7nw#doJ4fPE4_iIVqpT4%XL3ry{O-;@B=?w#IU9V4vSsPu^)6pp%`*;zA z@2$W<^@&4nZe!^)5iei9tW;@u{aWR4p6h9KAK%DZH*b;@4V2Zw0O9dS!OT=r-SWb< z? z^l8^pNwn_Uk2@&nvO-370ycb`H*3v!J2~k9yaq(;xJhb{EiC+!KiMjrh@P#ItTX|L z^ZRzW8T1IZ|D$Z?7NH;(k^IS`_6ad%oSPf`Xnw<>n0D2(U8>=|hIjw+A#}G>Wb)fj zu5u%FJ)JcL(;3byG)7y6ed0~0`-6xheu0X{#1x;YuGgrv*uVb*xIa*b{r&wqCMFT? z3u{lW!y=%kWjweqSE9+l7%_!9`Eg>8E5Ch9lV^!GbJXcG|e zBMw30M|bzSh+%JQ>v*tYx`-0o3*zFo{K%m>;f{$)JQj)J3-prcS;Xu`XGPweR)a;7 zcMl5$s(-sTw21F>dTy6c8gzsaC)Mre6;FExa_XV$}Ea% zIp?(UjkeJtjgyCEhIUmJpBm{yyVSHVJGZyB2AS$HQe)Zgex-3hg~RMHVQr!nb!3HT zFxOM9mV%pn!>2Q7 zP)Eh{k;LU1k+R9f+#bkJ8E+95){vX-yD?Ov;Z5gT*`y*acUdY({DC!QSyR<8QZV(y zu6@$h%DuvMm))B{L2cY3!9~!zh=DB4iS+%BMm;L=snQc(^G?Q^;*(Seh0;bdenz z94sCCt%XjfORajL8YJ|gzx9o-fkFHx)xhJQQjb9d%irmrb($EjDR=-V2Bj0VXc!|287e&HD{lrLrYGB1TAfG-Nw`#3x}_zi6-vsUD2 zuWz?Drl>||7@#$4*H%K@ET?Rd<-#*V+>IVP#ba&LElTKB#qd|VemLTv#71?^Hm}`v z;+=SYA5M+fOZ=Y+a&wTmn0YX4i#fNBqXf4*bHu}ZT?VO zs~WP1qWqZP8^Q-Fix5m1K6dIz*UC;vP{FyNQZua?WW>fR<)*YrvBVbpM;6;lmKSP8 zMx)Id<+lh%hR3VyRq=dMBt7nzQpLv_uaS&#Kl9?dd3fBew(@hL#{ zauSM|hek#c3kpneOd?(|SQvjhdzQ(o_bFSoKNE#}T$-AWz@e3Qd776VMixYNW(-Gy zXm5a8UN(b%s&*Y;O;r#FUD2K%eUju>(FBv3!)2)djc}LU%&=X1dNS8`+%I|v=T@^@ zJL*DA2AqT_iV~4>c6N4W^wcV3DGR$hQ8n~w4aKvV@g|-=2j7H2fPPXt>YdR=cS;gW?(&@i~giZCZ5a^t}gEVo)22i~W!}#{?TcmjYDAnN= zHDaNq|8|ItqOH@~8jpsmG3W%Zk&=%xDR$QvklPRM-raeRbKP6;Wy(+Q*s)`hj&0XS z#YEeZpufm!zw*<{|J#4o|rxk?xUAhclNP*}CTXHj>ApDWcG&qqbo>6KDoM zO1XAE6SX%Bf-`>Z@)jQ^o|9x{o~RqKJw%nxeMYj88@Xc7{gFsdBVfRf{AZFpnk{f! zD&f){hU!fQH5$((|CnLj#=LVj^XrMOMhx39Gd;op{N$TTR~yE{8{P|h_br0f9a222 zD58qm0jP39A(?Qn7&1TDu#QK?+-bf{OK~4=+Vr;@(@JQ-N_SpChB)-l&U+wqyiL4d zt1`TVVTR2uy=21}q&YPv+Hdc))zQ|DlIJlCtqL>^r(UfjllAtZ2coP|OH1n>ZqsXR zJzXkoX@?7}045^xhci+-dZxR3l5mX=X3n=_)vAQdOg(UtC>}LL7yjxL(-ahy#y@!A z>+q2UE(ihtN)#PN9qJ6wISF3efzV9R4gB;>Fz$oHwRW~YK4(B00U!S&{Y^oj1-a)s zbT)5p&+l25YEjF0wwRL8!}2G8u}9k9BEq?-C4`a#2U?W8D0e<%D)u05(%WSX}3Q zWNi6W01TbD3R==6 z7dZBGe$D@K@|3jC2rkz`0T6iwWKUyZ6&IS2p$n7HE;%79OMeEwW&4ljr)CGS*PoH$ z?apcEKKVIanK%a=Nk)y+wTj2<#a1YnR!}@Yn5&s69>pOQLtJvGa{BZm1P`}@f~>e+ zibG}5KBRNC+QK4;ig{{eePQL-zST*^QJ5bBkq%hsGae*7KO zYsG?5mwn+%yy?f^Zy+#S@lh3je39fls%6d0^pAy9$j}vreSR`ET+0Y>u7!z8NW>o! z2y{O;Lbju$GIj{!)&*yHrMUU$qk;nnSsd^TCG#pWGI>W|F6=sP&_|?_!C56e+0Zcp z>?Hr-$fD!at8110ZcLuIsc&JU1U#s=i;IiR)i&}X1V1>VI}LmZzrWHU#d+jCcuwBW z4DfEfrGMWm@8LtF{+#3aF2qi|p|~Ut+~k&%RVgRS^x0J z`CWGPNknu}5_aLjg^QQl`PK|gjiOqDmEzn3wFr5C4Ba~;^&hE2Y@S_M)Y;u#otToJ zU^>;QPb9z@5{4bo>}NbfWa)bE(Yr8x4d28I#@?pikn)Z4=+03@TMfcK@-BOi%RVwd zE=5JBHMf5%S?npdmxZQADo09tr?@=z^}8DiMuvtu20JRpUkZEQ#d?_=mb^Lhmb?LF zQB2Tg(OSE2xV$fTxDQc?kxG*i?>*E9-*l3cD^<6AI)Wv7^*7BK`hVnqtW&FjqJbY= z`V{Q)`-17Ng8M4(AnQR}wF*CY!3V^H{P`9d~ zAq5$DVr&^YPVqbkkAYj0hB`ESB!@DcyY!IouxcsyfZ7gT*6`f0u^{WxvzOQ@M^B%N%BX|p_W1rNY03@vlpP#(BOXs>r3B&kV#&gzKPp@IiN!4@j+{#!Y4D+ z6DMjJD28&li2N8zKwt`nNSS?~Yn>!LMppR)%J_H)i6(FPWP^1mrjOG=m9SyR5f7pZ zNXPo=ruB^ffy007+IJ5@;4LNIBy)zoQ9K?d{)4!^7h{}eg+%HFK|~r*VYvn|B1r}_ z;0Q%!v$W4J%d;|`6OK^e2fzZVTNpo$Liv#)O!Aw*j2%><3jYevTr&H2Dw|zQjC#dW zMzk~GW|bX0GULbIUqu2BsRdNfn{`m#t;v{xz z`!yir?I~{np%_1n%SvBE3y9zi0LlIQtMNGlPRfD=$`&S7|MOAeC<@uOZ5lGVH23K{ zKey$WG_h49`6M4W`){;ICYsaC@Ro(|ok}G| z`>D;>U^o~*g&bnrsaMS44PPzM6Q6yN!k%D%CizwKl2|C3hJgQIKG4JLhubt!U_k3b>O+(%1`C>~X^A|8+N zjM*QB;Ok8Cfkc6ZVe|jb9~l$5p`+571vpJj#=>zR!=~~i5~T|$KCYSoc))p%O78;< z;^u~rg#bT430FI(kl69~aj@6a@i-o=X-?@vV_qPiUxruIZmS~|&M zdx*QwEMFDstN>KABjM%_Gsw^+W2F-{P+Ne#;*mk>4zv!hm$6^{A+`ELHn<=aOr4z} zr-!-qnkAPuq1YxaI(i?Sc=MI3R;lwJ?-{mI(Gua%Ieq%{{Q}Px8rmU%D%>lGa4fbD5D4lWMg*pjjO}8Qz4iL z-=J~=>VPS4P5TiICMxEiPyog=q{f?^5pwZ{;Zj1?6XI=@NjW~#5e zuie_Ia~ijiCz*)^Z?lPA_$f5fdwyO*bTn^9qx`t*pXZF!Zave!FaY0$XeDr4aBRfA zi1Buv)04P^?i+E+{cZ^s5!o>x1Za&HD8j6-~K*`2BWP*Jn%-Ghg%2PPme3VQ^#gytj zH#s?}(_yTuduzDCCxM-N%^DS%m(q|HY#|xm!lK1@lOs|I(%dy*yx?>@2bd^O2}dbE zhUsNI$U<$)3M~*3$bb;S3;Z65iqq3~4E3Sp{=)Mn>z;;5TQHSFLClndt&L_WN~l#Q=|+WCGUJRr|=tY2d4v8%NA8||0a*2lOsYkXp22z;Kc znVCGiais}gKnc6oCW>~07#~^#!w$iNP?X7b-L^8FZ+g1AZ%6w;Lmet+r6>bE=)u>o zUnN!+13tuW7;QT`T2wLG*6-@zu>HL0Z&b@V%OjNEF(NZwhlxE`;rTuIQPPt~rB8C+ z9Y#4jsV#M)D8KXfyAN#R=eL@&Jtc76PUzyq#Dvx4Xkj50BTC7cuVSSPig*`OsVNMf zPbme_>B|I-GSvtl2k8nFI-GzMES3#K70IV1#K$Y&dVDhnI%J1Lg7*Gi^wX%StxcSs z_6F^v;qe8b3>pT5e>YHMr8&*ns=qtdQXjts;9Sf+suYzJi746zxd>np**8=*LF#S6 z;K-|!hz%oZS#gdG4o24(^bO%R1dJA3tEp45KlgPl_LW*|1!kT{6?{KZW6rhPN7{~N zkqW)-Fp)h6zJ$IlLJH*Y)vxh2xB=zynIDE1D{+nk?wiJhy?yw86F~`7J*;HV=TmN| z(l*RIVbB?gv}i=;O2;iLQhfoSXzW{I2w)%rg-sto%%r@#M@L<4x;h9V3U{f0-})wq zKz9Ua9ncNXf0g(Pju52{t^{xnn^{D$LWT-i6W24<=^Z(8mn`T?emxwEF~krWQ)$RB z4`n)az>C;R!MV~t@gpCEkQnIxwUl=~MA``#9v^<}q>M1Svi^RVXg&h<@$qrjdmM$~ zA}lNv3kkb-$?|nXB5Hbt)3iI1-#zJz|AK`hJOOsH67ko{1@@s3ENUbajzvb)v+3Cd z&dAOAKtk>w9wcpKSUlg)D>7gZ*8^a0g9Vsr*Hx6K@JqBJGPwxZP`n)EZZlHE=NwzV zO4#HC*Gdd0A|@i@=kAal8_PH3-Wf><3vhCGNO-?eetb@k$?=Ob^sf^ljqZq!AVZpm z4~K)$%0Td!Y@DNof;FWlxSLTAPjc45u!RFimEOm(b8?FUfop(;!R}sI>2Nt86RgAu zsl~2)wU)^Vu+W&Uuu%^O?(!Dn_>>i>3e+AZBqx6$YY4rx*62rL>jbQ~o10s;CV>c^ zydi2NzHTp%tO23!JU!_~Mhy}=tn#G0qvJgsOi~oHx66L5caYXm5~6(MyoCzfd47rK zo;IG0{20E?B}mYy$RHP^$uEJc*1`QDcyGULmt##DMx8|4m$7i}+!kNT`2KPY>R}}x z$ixMOS5;J0(rrF$6U2soUY;v{sxr@M>x>7PRd!l_e!g|BYQyL_K&3k_U}hW~Wj6UR z8*|UjV=Os(2zw%qY9$66_P{tEY?v)r8T_i-nVgzhA-MsgQIX$3f+Oc7_2UQRRQU;9 zM5^zC><kHj)_uCn8O6?<)>Al$0)WmtUDLxBQ zYNR+XX)-oikO;;NBF$yxn`D4Ml(O>jq(4+u)%CY@lhww1C7V1kgukj5C4=zr<4O`M zfs3&Vn?VYb(-Fb)naFOkg1>;z^sD%KymM71RVa)F+SKRQx$&jpMSY7qlSO*|Q< za5>VG_s}=0;mp+zv=$?-zFPF`*r<{6TgH?Y5*&GB3iM6m8GMn{qJpZ{LwQ>GuzN>E z3^Hz6z6^vZ@$~e%WTPx~RBVU#HSjI_?Qp)Q0q%^*B(Wx%(jD;lQd=9^`l2vNbb^`M z2l8s_v1dt#ppWQ68vyh7wsGzvK@6?zJQniHG zj^T)Kmk}vE&dm98J}ad_7JiBN(?fo6W69X;BDxD$JR~fBzMIHR;3_=S2Fo}8rD5ue z(ezYrZ|}*hKyPRz(mNU7FDVEe8J$xnA$_Gx#+%B{ zKlWF}CTFkMFO#}p!xpB${Z^Lb`(3cG+-_jyF&!*su9qrOGGbzq()Bo{)XQpt-RR!D zo^ns00)r4y^CG6bJ%~=lP6S7`A~-PnhB*7!hXh?V_UAAPugq`A1p4~=R$SJ}pSj&) z6tj`)^k?F@6UHAf8Rs;w73XWLs*?;PCcdYMp)R!a_D=rxFh_OEx3_Ph5Gb$=FrUV9 z;^V_Vk?DC$#zJaJ0ECJiYeD@ZbHxtnZO{4XlRXuGP(!aM_Jd_FmAi$xo?aGpXnEzu zTK{ByZ1@?&4r$0B$94?Qx$Zn$Q4`E+8}1P-$IZQ}?Wey=^Oc2Zr8}ZkRX)6)yy%lBPYj?avdz7PTfagEqCpxuZP?qD&fBG;NL6iQ z5s{a89`IeQLPzrNjWtzOH^s_!n@64=33Dtf`D7It&M9V@%_oc*tvlb{-Tic8QI8C} z-0(+p45|xiRfW&N>2bidX}JPs`*WN$rq_o4E!QgkSa*DUu;cvmZj2z~de5b;G=x+1 z=sw1q#jV9bg_6``Zo| zix3?RMz7Y!8f2Mc1~3!a^Kak3mm+DJiaeHpakhPL7uM);gS|l(UrwIWJozWvaqM)c zfS#A=v@cnz^``cATo7D}^U0BSU5c)8TH83xKZSAPcEYY3JUY4`&Ls?p`xwBM0SW}j zub|d~$`aX3)%)4VV&8%cBx&%DS#9aqc>g_B@a z=N}}Hw-n)GbwZ8UsUp&5r@3al{ z7$CuF@d?x=xP5vf#_hvik2g-af^4jN zni6{;R8JBC2o)y=P{FI!#hrTn}Tmzn0G9oxgP`8 zu(PH2VKDcJ+J=bGQ;*}Fh|e#qboijF-@3LTZi0Wkow|b!`LrcI-P5jYq9b`P8Xgk$ zH}7RUVQ&q86S)K1O)2l&qeDx`z=EoU?H0xHxfpGg+>Is2$od6}|@m-onttY)F;#OIoPJ;}RTlaHM! z`6rIQ9jEmRsXO>|{8OQDea$VPown!z^=;wg!}dBj4_Oj+=Cd{KCU)t#sba4g#>~3q z^>1dhe(nPmhb8Z&~Pu zds8s^23>@HK3*O$rLusn|I;e@3nF+?Unx~K9XcDgE01`c{odJCWby1!HGREzsf>?nrZ%Ad;pk?A>(C!s>x`@*aWtQ7d)n!*~#jx@O zRK7tib1*6>~vGhXr)!t(n?u`UszSeJV#o~`_2MdJCIjFpbtOS)k652g4#aZ-pGSBC}+w=RpKZnb~s zy>Sc5AEj{pHQ;LKRiVdmP75)cgM2uW_cX8ff^aEu7O^@BA(UU7c`H`4qY4GezT-NztRc@~|`L1$(ER$TA3 zqsObqqq3$(UvfSk6?X(}=-kRZ>dhy;Y=mam51zdZF|X3p)WSR*zsO*{j5+_`5}{?J5}YM6OS;I zt$iLu@^-Mr0eVx+-ff@Y@&~{rZ(ulB!mZwUjeObWAY%t*_;YQ^ml@FA@S z?A*0+L*wDuRr(8sM6W{|Cfg=SN;zCh@YEJAs_-rx<+fT4dXf;A=Hl+`W?y6H54s)Q z-9ilM*6~MRl83f5Zx6eC(UpubOj7P|hUZvks0|T_&@!c0^9u9VX|7x)Xm}IBUppkk zYt5RvHj+GWwSiB|=}bs;K#m6jxj9n9!J}gVwd8GVGj+?(fv&53F=$Ersvg&3DTn8a z#iJj+N8@$8*LmD>URGN_oaqTmE)=eH;LN6w2n%gU@{+eOfUj#pTF&vd-@;dKNcStj z3J<*2&rh8dyR(Q6`=>_=-Q^xPFup znar+^NR6@MfuAC=%S+i?yyRlVpOo}YSQF<%K`j@Q%eHZ89q^tWh>S(J7j*cHK?h^& z{+b+%oN<#K$tk~87N?LEJu_WE>Fmb0hCbeGaZyp!3C-<(%#U-RIW2Tm6^8g-z*;(w zAy29+8D;oHxa101&<)w;i>#a(IMcv+Cg-;_&vHPj)KuCGZZQBQ1!!_U5M_OoN z<$bT=DUSt|`XBF}@2N%#<1CQ`%K3VQe|BbkuXffL2N3Uy2Yt%pT`xc$B!&k?9#F0~ zl)Pt1(lXZQ)%nI`IF+HWg{Oz#-|*hSa0b_GM);Ih5hZ^GsY)on$1AL{{fU!O#$yzL zrlIUJ@9WAGCGfi)>o7yJe^5Kvb^}!p{TGBi?>ebu4lVXqF=8100^ru3QH7AGMdzP@-r$z+xOd%RW< z56gkJx2iY;5KxG(9o&dmf8dhO=%um#paNsbm{pTj^a6go;Cu3dDf^Y{170|c?Wlu? z`jl?1Z8DUg&v_R1`py+paI_rmao0bU-E^^HYsMYEl2H1IZCuPhzv--8rtGk%!_UTL zW@^L=g;Z`|x=ezKii#>E@Z3U8&{O?H7JcWb@iu@du1)Ka2#4*7BM^r4(sGmDno!gF&C79R*Gc zC=CsQoi4s$QJ%i*v`-L?Av_#D9SdqL;foYt*qiUiuw_IZuNCa=xhgu%Ts4o6#$;1G z%DafJCdj3w8iAZ>I|?4&{{7o>hRn);sZBkmYSMQ_zvV0&_m*%i+v?2{!pa_yh6q{m zT}30h8~}!`_t+cLHWX2nBYVuS=<foI2@sUF{1^hz5Gj{aBq>V1_=vY$CG`mwWN$I-+2=Hw5~+Z}72RkVX zGqmgAYIp?mNf~eViWyFN-|9O>9C)Ql8RZAUT$)#}6=IL=k0u>@v_aUdMDd+wC?T2_FI4W_35b!*2>LXk35~C+a{O9^pO8p)&8*M&t zT7~%o{%l0_Xvr|HafWbpZ^(Msd`Q5$eK!rrL*zge2SLqcckqoJqYtQDs@k?u1naO) zs=4R4K6(1;mp`6SHpHBI8~e57^P1xm365nFe89U__tiqQ80Imd2!%NBM29bT@~=kU2vF!Ew_ z(Lr%2#87KPfU%L}y+9mS-$HgH)q84ub`Rf2xPHByhhuebQ8Z^F8B;wq!aJh}1F)P3 zPN&9R`q}_vUCHRcw-GW@WR{x`+@3Y!+scqn9!L#(B0wA+Ooxj$-Q~r~CaUuaS%K?N zW_tVT?l^1Gw2Xuzt&Gr*1Q09Dafa0mG9Q7Gjw~mYrXuAI+J!L*DE2trkJ$ zT{oA+A6qInXxlktyx51*F0>kvMQ{YV}Iofft+6??*4vR8QxJuk^#@c@cP zOh6G3YjcYslFQptX2w$nP&o0}NkL}x4e!h$>_|Vp#Xf34H&7PZ!lm`5`*GI;wFqg6 z)ux`OXP?$h+R3z_{7ooab7_8H%U)p9ICc^v#BF&V;K^5F3vo-mfB!yNg*Ub)&88%T z%IFF-I#se3i;RT@5^~Psbu*_wzzgcIvWQRwT+fEU-GeZw~Y7zgXaDOaz=n2WeipBer-soh30ElS$!mO&K`HNOrlt;+?0xN}@xox*?`(uQ?;++(djUp^g(TCs|<4$08 zeD^8RLj&^uRA_8&Bc~betB2oimu{C}NO$8uQz&e5WCWa?8K>OnssTw`xtQf!ZGng7 zb>UzmH-+d(M(bTi(BM*cTG6EU+-fXNBL|ur$pAHSdgh}Y4vwNu_?5#jh9D4MEZczn z!RbMXQBQCtpKwO4ae#c*v1b$r+Ud+0?(~@CWI+TfYTqcRQ(w`GBYBM zKkg70U!Ojo_SywRO$+>CO7@INP4Hr6lQmi2m>UX=gW~PiHGt3fR1PbiKbKA z2$9#Zf_5bpm1F>N5Mu&^xwxjXBGarkisRt;ViK_Yzm*A6jw|Y zxR^L2s$IkZqxHxpBBqb|8d~p8Q z(*uwNJaRpST6w}uKz67~TkOpDkD%gqJ-@WH9Nlu**qYD2am>ohv>feiLO@X0xV7`V z*G!>x$Jw)M8xN9T=f3!ptti=ZgmuW=Jk{J|PP9N4S`guzR^cP@t%K|%v|!A$k!Ags za3<*kxH+^8hxID4W!R!)a1*@r=o6Hig3$$ zdqSuxD=O%a$@8*y*4CfeBP!&b$I;0vXsOq?y)j}opI#5%D0l-1aWEWaRQhm0z~qh+ zH#{9}k+e@e8LG}hq%R!K>}(D_M#1wy<0juM;+23lxB1d{1 zYFNsb4u8HI5s6bV-R10j?{0VxMj;4DQMR+Q!^>ufl(Z^GY=PzuA?y`dv3b*21H)`z z-K-uKjN%fJ*zh)+TKnBBLE_z5XSh;`q3o#VOiJzN&#b1lc6OMDM=FF8ZC{A8Zk@Wp zOs%{7$3_MA2oY`x2Mg4h27&NFH#o~@fB$yAe8k(UvFo?xo7rW>H#~0=G|iVLo&j}U zT0l@Tw_C38t|hPkg?N!$+Ldz5a%nKo?oSt)_>uEbLP3hSmaOyj{R5#(&~evnY3xZR z+TAnR+OH<$hG)ED{o{|JAz~@9{*x&AL*$#-7V9(lg(1#XF#B5$sLd?!JksH3I0zDK zHzVj`-IzM;7y6N9tWsBZ@VHjEm(*%Bfb1B!D4uuMY2nTXxw%p( zaPxd!nWf>pZ8ZqT5goqkk)5K}711b?zf~4n^u_-9Vz-*ydW5xl5@U-B{Sa5#ONZTV zDOQdEys1WjAcVR)Q;=oak{7lS@q;TTLE8Bn8~%Iw#SA!sF2OZ9#xd+grI<+!ej03 zlhV$eRcayIk3}wjdCC3ycsekzGy?s%=jJbhpSxE}&l4&ch7+&ihNCO44CZZ6?!N+r z(*}0Rbeh!NJF)IP4)r1wA&FthBalji>^qWQLF~69^jRmJkqaTLKwUwVe}KB=Rvh2$ zl#RX2ci{F-ZFPxF#P)91hzP?`ajVX%c<+N5MUx$o)7B{JLl~tXIDVQgzWH?08d~!+ zSfRdMn@d~*^70^fBv1!+OV>x$VvM%yLUhnD$Z=>zY0c8%#68$ULs2+{Fc8fXVVmn` zY9QGy*Tl+{aGPp}al|tc)a9W7{{Yqq`Zf>+^_D^acrX|89ku{)XJbhyOe>vy56AwT z?`uQ?-acSAKIhi+Mqs^7opZ-AFcIm1H8QPA(!E1Bw`y0sYcwxiZjCHg&bND4Cm(jc z%M~rjr4Qa*!gMEd%txIH+j2lT|7J`01u2`?s%V5&cc%8FwT;cTa4j)(EFh6UlF1WE zWTZ-v3Qa?yK$1aP(dEMwwWSg4`I@{JgB`Jv5h%X4LfR)}*GWTYTObli8*vCFM$A@0 zLqmhaCcv+`K*eLG%JpE*C`5`JwB_+zr|ew4v#@kIIA!8E^g%zUEN&rsQM^TtC>4p~ zr=l)BDWFV3(e5Fr4CJ?O1^QGvezuNX9I+t+E=JZg(z)7z6Xvp`G{OFhb4{x-j>f21 zRozbEbYU1uQKnvF_#ebjJ76tDO3?Crw|&SNNmFevc$!od+0lA6=Cfp-a!bhaTp zwn3U@Yf@U-8qd-&i8P^lJDGNg@)87r0Os^^zA-cM5@vV_m2n-qt*TT2kwplOfkf`f9mzhf*Js3NNVa;FkPTzngM?ZS>$mwfkKl(9?)R_8s0kZeY(I<}~ zWbF*V4pdAl(rZm&S`8O+lQ=~h+|u+^knbz zmpw*1?ddKg)rN>w?}4#|Ye^fhvlSrR{s}-^^_$q8CB9Fs!kzUnzCXbboaL?xWxJcN zedW6(B_-w9bYZn6iZ1p`*}R$wZ%F}tb+CavYvIP;-^U8sWc|v0rU&?1dNPhYzesX0 zB%+1=NVRWzCSa5)fFm+0E-oX#S>tJOdg!b7h9rbBzc7@%OZ4OoY{&l_+drKjvctOK zH*43KiH696nTZ0qKYdap%_isH*#KxB$LkZ&QUDtM%z*<3a*$9%j3B1X!KU*YR>ee0}v`8qMha}<@Zg9(3 z_(WnRe7L42UR7@C_43VQO4uwV@`@2%bkA(3eHk9ei~8dpfNybf9N)m)B9S`qE$T+M z*szdMW+@wqMlYaCswISL;@UHGB=#mbYODv>hsX@Hq4uYo_hkD=H!_O0UZ2nf}2;hYk@k^VJ&?9Yu*3fi9#F-bHAxPODYvTt9jm_TSL_(J0gyaB-H- zGTpiN`9LeD3Q1jlJ{;U+3)6A>Cgfp_m(lr~dJ9g(s-2%fi12P+gXV@@L9tx>iplzT z;u9DxiTJq8M`Rc%gfvvzvMR!VV*Ic4AbWZc@|4h#G+w`cJsTq~Hh^|3zF3ZnQ@DvW z!zO|QSQUl$X`<|>@$Ow{422QJpCS2CL1U<(JAAqn|G4AgdBE#B-*eIhHs)Z?U^)0U z7)eSv`G2lLqKn2m=U#U~cFr%N=zo{uV}s!VN7(&l;E;^jLjVcMKRu|>|E3@XuoBQt zuXbZe3uo07FQ#x8wN&xFp!Qs2HGD(tot#b=K{oI1dAxW5+~oKgV`E8Icf%|Ko5e@1 zqZ-RuN2c%`JOcBxCC091f<M*fJC2E+j*~V+e2e42$xa^YXa)|8D1b>{+%>|c zGyM5#YN9sY4!BJCVKUcCDf?FuPzQWWqo5!Z)W$V-}m;F))oylr9ZD!-$5e!S1=Ff89X_SpSM5U7eCU`Tc@)Ck90-|t*4c*|26 z>y5>Y0z*kDfPtOK+0yuF%6w6#5Ka_3FGofeh_=6*yql@~g&zAkj3dK|+%fjp*-r&F z(e?-6v}noIBIdTft1Y@H{H(%`k;RD^Uj2_asx+Pfpi1^QK$CrU?4h;t3fURhHL_-~ z%PsfwIBtSyJNB6iKmN?q+lY}1(d@-U@3^Dry-*Z6HkUIFTL~N#n%OD2=!=le#)NqjoR@S{rS~&E@-4Txk5tQ61~N ztXHOzxA#EcFS1O_F<5jT_kDsOVeo$+YPRuIHl*d?4bhZ4GthN1lGqDI0oY(dv<}xt zG~U8gx?D!W(jebygX;l-^4RkEybI@AQ&wCUx9owHd`Ao`D{A_E6N;6t$qA=6mP0rTmWzu!-=9WabdhM_{vYtg-t7&owGhgVf-xBZ6rj=PSDCzVj;>F)xC{S|GpM2dbU@Kx-#Z>YEa#`^*Y^dI9I}#r zvVaI2$8*1q-jl*1K#`(UswSwTLw%jnxDNsj$=tcq^Zu$Fi?aW4UV3p1BRD={wSLcN zpl0|^_^BX|lva$mQPu&Nj{FxN6r6#2;aS*hYLGqhmdVagZSh9CJJdlXq?{f2gj)zWlXC_BN_3+A^!n0 zW;}Cb(thT3!wJqAq45%ARGiy%joWpvw(IJdURX9?bni;j+k0LeZ{0gK-o@>-Jo1@9fr-|-hLcX{WrQ)`~) zVVjdO^05d??h8}KD_JWUUvQ~x2uyxDVLZOz?vATwSK$~tt`skAs-KyenRNZSGISM> zU+KhH0~g3B?Uk{~88k-~+uj1H#kHkEo2VkQM@-=kdY?-~!f0&a$o5H7BmdZyfkDAl z6K3$(5uVEo_#sSPuTwUz(0p!|``5P<-y@Dn0A>NtA0a;7xPkAyxqImN?;3^QwU~^` z9M0`kWj+@N)i5sm8#YMn;46Iymeb|JS;iW&f#jHUF`-#<-Tj4pcww&rFzMmLK^^D) zUjhrHlI_M;hP>PXNcAiA26p6>QVt=gb2XSt|@ z&SAsG84D2_IP!i{a)g1CjrpS@4d@D;+~PeQRTJ;k5B3-Kq9W72HtPua|7>jj8@zYi zOfb=GiHr{NzS8o(`tp4~9UVAv-9!hHO=Ecbl&rR6gDwVBj)|>t5ZY|!j%yLsM`#74 z-1o%j1Pu*;+^3%@#mGkfA$%nLb7-%8c<-oBhwrlSN|i|h5Kq2gEEdDY=wt{5OU%@6 zxqoXR1R~G~WW5AQr|CzHW4IcduNrHA>NqQ>o8!*KA&6D&fU5v}3iqIj6Tx2H>Og12 zn9aEVDrWl2t4l?}oHiWe@w;&biNB2eDsnJfZ?H%y#=Ts;2W=YE(SLnleChh&*&Dg@ znE1=shf3S;9-QL`CA^+RaUH|l%70`O`fXrwlkH)#wDQh#%!=~)*QDSkBPibd)!R5q zz4`Cd7=&^F`z)Fdf}a7s=UWHs^RxkdmjDQ!SfE#V0Gej@NP`+VJTU)cthPuLLWWL6 z%gSC)&{&bUV5c*zMKSrRup!d~GSbY`*?3`PPbzyRG zC1G}yYDK_sjsO5;$*OPf`W^9j9OP7fMWycs%y+X*%Y(0+8G@`MD;Zg^WtfoKBmq(_ z$6C}~ti8k*?Uw>P4DnQ_bj0WWrr*i<<&UNUs!;!_%YDcrPf41;U^g?7zd#f0HO}F` zp2TB+M*~wrFLxt0T&X32hP5`dcja{M`y!G{%&wMlMbaHt0y(@ws7EaWF5vy{l#&G3 z)!1W-(aHzn4oU~Y-XywRTaqgXK2uS^xU8W8aUc0bRB%2-Tr_*-!EK0%W8q9rk1dCg z!$-YR7z1r3W(Nip$iL=**FB0Voi`reLve%ZpJj9uP>NIH(9;Ae_I>FSH}I~!h{)&x!x zjfhmc^+viY)PnXX^9J3>LA2e%5A-YVA0Lx^Sq-tkHSoG$S$sgF_S=V zq6vIadD%au<-h|p#d*@aMi6KwIZw;y5RKNsxq=&pYB!NL{W(jv>%N@I3-H-wRmbk~hhwqbLBI%hQ9eT~K(%#vQ;eVLD_6+S{#x#)m_ z<~cyuo0q^r>F}xk1M?~cz zJM;`ysn*1r5@+Q|o+x(-3jUIYb{>H};-?c0W7~*6J!8w?xQUd37`>MUy;d zYq4A*iiBS!jczKFy+oWuRHp7Hav6Vq*SS!?B6KD||B)S7#9%BGmJRl@jFqKe1$R+Y z6eN!~fYMbuI$u8LWuqH!gs4Q7za|M7 zao?QC#;rV+CG$2dZNE3zp4azKRfSsRVnJC$O83%>1w@f0$#N z_1;+ODGfRL|8Y19H>1wjh>$Y~L4Y?hal63g0!y(;_Mo?%`bSX|sEoG& zlA|S?&c0=r|8T3F=7?OjerV?`#`Ie_#^Ry@Q$ZCF9d|;?A&ELtJ_lVkYrcF&l<|@dfP=o-U6N-e&khQqB%CI2`uyWH;qp`$z8bH;uEeY&VABX%;`YG zMJ2FVV?;Q5I3Mc@`O^ikQCQy1_x^5dp;2K8Zu(%r8`&jR;k1U;3tB|B! z-gmrRxfhP;bt=?30>hL}-?zZvtK+FFD^dD(yhIwL@>v^d8 zgyE4xf_XUQ`M)E#V(=k%xysFO9C#7b&6d~Tr5Gw%919ZqU5Ab}Mi zhy0=#e5-PK2T#C>GadD{VB(KaL%2iR1oZ>g@unFqHMlUza#M_?!zgb; z)NX@$U9k!G8ieBvG=NuwAZgBxPe38Z*k`RRDTCMLQ&j2n{KhQULXiokJSt zp5fRZ;eEgZOj&O$|3?qoUPA!RWCtC>DkF+6sxiqwuwb4S9_z#h>sz z4UPUA*lP=Mr{i)+jwG%y{MqvVwe~$)tL_w5Iv3lR5F+XGr|9?647 zhp;9XzJO&YUHah}ftEyFWl|ojFq97anAAp}<|*;s<>QqT*jMI^ENX>hwf-R)4BUs5 zHN2J~`jBmCP)>l*|H+~xd*mOe*nl0OXr%bVOBUX|)o^i~K?Z{bD436|BC+)kx3D*!I|6*4`< zQ-}54Je$JQjE;mP= z3BVQXQ>|oVYu!COriEN1J~nFaq>Ib`kn-$!>k1H>C-{$SZTHK2UzPU&9rUb)A(>M#~b zd;gIe$kTo9@*h9GyU+!Q(kGDOom}q7^{rqQKZh_#*KkK*f%`h%S)PiqD`8dQGS+~= z#WAnBVdddJ;h^~2X~DO~?>PuYM^0`oWz&zgxR2pRW{@HV7c2(h{{0u8JO7&3=QeTO zD=s%{zSP&~t=d<>;ywSN`*l8igZynmpQrr^ysOabUjApHg`O zKJm2aHvy>txmXX=ehv=s=i2NQG>nM4q|I(mAIcd6s~j-s2-5)*HHkaMuo+*M_z6x% zW@e@0YyHTnNB>>WM2!G71>Vu&FO^-RrS&oEtNdqq){kyTTWXZXd3u*)l=k8EshB#e zztYd0xKo%g;kP-zEOC6w99ralDf+xzi9uXNthaSdd1R31C+(?s{@k=M>_IFOxpGajq(Bmd+V!OqkTC~O(k1K&UFmec64a!si895 z9wbhnInlGDibstRAk)YLl|#xiDL-GA;Fp$`sM%M6$CQeCnP^?qe=UwNpAZp2HmQ`1 zPSqE)Thj_%+W!L@L?~dT{eX?L6k3gh_w2gT*4G4`zfxdpY7m^jXzj&?zaUFKE!yV$ z$$!68%E6&&3K$R_<wwSDLco}#>P6ne_%QG|#C`P7XeIDJpoPka z*YuQQ3SW317I3l&26ge9=C8k+NtSxfyUPJ4y@~R=X-E>4&oQ5YB8C_W!`cDdyY3?&2<=8yXn!>HU7Y!1gL^>9Zo2V-y`C-B>vhGpyUq=?;kP$HCC~_mRSfuQGvUDUuaIfYu-(XwSMPm&`8=&t#J1db?ro=ZqH`w1 zCv;xl5Z#`b8tOT&e~lar&|^r;mzH^rcc?-}bgn;RDtJi8>0UamYig0j-#MA^D3oAE zo+|D;^X`2dL_i1r+MI)-OH7xFPwuREoaFjzf7$AzLl&K7W#*KP14MB(GgA|_jXIxq zsbBr3bfZ94mS12^{s@=M_(iGLXOyF_k`2YSoHK9U^T&@jz%6vEoRJkY5?hhQxU|Q# zT)g(kY@W>Y>HBu>6elYM%M9!GuKMWi9rC|PCURc#-IE31bg!LdYr*~FboJds+cCNk z;6Loea|!+d(e?sySv(DU%Yp{qjWZbLR&Oo_Hb@n-yOd59o6Yh9{DF5jx3!tj@jp0N z(a;bF%acB2Yi^{1N{jMImbbHLRUITpfWIf|oc*4;eN99_kbF)rwf* z_Fw;Y$GT2^X~rDrV(BilTGw)@wxSqX7Kv`!XJE0yVX|Q$liUq?gF<&DZ_2v3a0vF# zxn+!{B)VTw@Tj3C-K(QM`0QDe=#n}@v2NM=zHVx*N-YJ8C>>;A#O^B+g;GpxmB{9@ z50atHt*w+U$0=3b(4c=L+A8T8LYEUd$NiD$Nh= zbkh$Rt%o4WKUu%36bwn$$@7KBORc8CyIDQ*=v(Hchb3wn>67wF9vy2Y+D7b{$Y|x7 ze$;#PKH{=ojY4wVphijTQ`G{UI9#v@kL%T!QY)$W6gnkrO_^0veot_5R2=FU_krFq zXU-g|tWCq}BEC43PRNC&xdw#=)wK>LTJ;)0bBZn&zbx4AW!^@ELBw zk=jdH-*=el06t@9dWB)Gil_i_Ei=7pTcGlIe$9(75rMagjZ$+IBOq2{%K{tW| zgyQW3EL4R$FvOsquD~;&fbv^aWVxT}=&p=J5|p}s|3a)vsw9A_v)f32lf%)YT0~|7 znNAJjh;B9kp0=LVd;60D2a?L?B-+lSt&5@n2yAB9cGmGsCHvU5j)qct}- zYX?0n_Cj?V96Dv8iE-S~iNkjE&S3M?7%otd$U z*EBl(En{(lhN3Bo(*OtnuCp*5VI0;)Pw>zn*#jb8-JX#bq!(R30oz%>(1pgDP-hUB0Ykp^|z{r?K}^6AU#Dlu|% z>)I7Kg37PujJ)6U!A^?hLg{qy*@1}b4ov;W6>P-F3Vy@#q>Dln2<&%BBUbh?1) zBjZcdAA`LgWc#P@VB!}dbIf;gG)hybPe3OO4!w>^P-c;g!qv}9N7plaw@;^mupr)= zw^;y^-8iOiIW0V+2X-Ssd-zfB)yj|rrB0l`4%PqwDPB$r%=4E$?7u0n!J3$3yB!{V z-#-Lj7M=*RwGPU z#pXoHJ`wWcl%)pX5@2mrBj*eNq^NAa(`592jE>08@2q1hk{37hUR=2G;X zi5&uzUWhzYUnZX-bDKcPl(OOdi{sw(x3&?l;b?*^AM*9|=Ypfre zOS`R&V$0N9#4kC^0+L=e0>339Vz^=gwbOK^g^3^uHQC?_+8XNq6@_ti^L^e&5BcEpS9vFtop(=U7EI-s1Su&uyJlFjgKd zTLnY5f>&533}e1L)libbnMWO$V>`~Rh;BU2tEUVGvJ>qi9Q|;6Bf`y;Fk@P7ic0<0 zIr?Ly38x|yGW{+vp&##{bjq_sf+s#$E37WS1wo^;FmH@`QF&odkherc?=+X8P7YjE z?Eh`Lp49}r#I#<&Nz4 zwYAY4B>T;9t_kcVjUtdJYjy?RMH(4QV*mQoc>^8VGwfD{cYLs^E(i=nI?c2>t_~bS zc+&xo?%f64gEGSR-UVObYT-!NT|eY&+T<(6ALpsy%@Yg~?7kE(YvCzJL$LqyZsN>+ z`2uf6?9PF9=vIKyijT^FFMf$C362O?bE|nv8sQ3E#qpCoI^?Dw2dW~X9svgtBLzEs z9rE0ha@=y$DD_21bvq2cNt%w_sRn#@6W6}KhiWe!1@Epp)7eg7Pf-lqV}U&`S)_30 z`?%1vXX%DN-2dcD&K_LcMrehY2ylog_IGa39cj?5(U)O(D>>OJqRlj$TWC=f`7IQs z0+$r`A+%B3`y|XbPES{;Xkv(xjv_u+?;e!!ji)BOFQ`JclP6Tf5$LcxOZS}AEI3v6 z26CfXxR!x@HiV!v7W7bz0bVCU5$|`UaMU1)p9Y7LGPuNXz}aIMaGjBDc(1KBE;o1r z6U|^#=oIuS_8*6V@7d{hw2flIy}3C#6lcL3ruKkmKzs-|wna?7Rpzk};N*p{}KDzkPBYGiuur|N>;shh*2}t`!gF`^0Mm|50I&l2qJA3I12(LkY zS6jZ)8HwuK!dFamTCQNIn4|K&6jS;Dk!EpkI!|wo{)#^)st07hr3e-A5|I%QDgxY~ z)rPhrKDrWemjc)Jc2oQ_1+<8yj`;i(|NYrGgL;Hx6va~vdhp;9M5X!%jY+}=jnnDu z>D=W_lRFl(MS)W-?`d_IKT%T8flS0WCZ*&|HR6CwPJa;RCMM7H5zhSzObN9nH`jM} z*1XZa+SOh|d&v8@YyI?T;qXnyMV5|m%!$&;w+IkVmC6ij>CKiO=s`ruPLWzQqp>?s z@J8rIb(|KFFwh}~cL@fC&p=~Qk0oyn{A2QT-o3vR2TAZ1)NS++Y|kQ>H@MzsU^^3k zGT1J~2d$?d^Y!a(2s)z>xRJOwam1mfC^I-zmWsUi_3lhY{rn5gRs|~}i=_~5zdq{R z@%J5<%jX*$!sUn0iRwS`jnI3xvsCih_Ywc-RTm?HGxc%dwZ0}!rs9#~9*ovxtQpzE zhSPU^?O&VtJKyO7u>5@`(cVQ@#)7|R^pJb6s;V@P{FaHEKfrFVsK@nGil#q;B(H~D z>$6?N)tBqcpmws^!0BPVxx5i0%0T@}k8e*E4keX;Ul^&0(g4tKO{4G3la+l|SXj8+ z?A`R~)2~w5-%7@1DtZal>GS1gvqFP|Wxoz0-~YHifBKZ)=2c&8{Ky$4BAUfn3~az> zeI@U}=5NJCVB;%*aDu>(5Gy6Uj*bp9u+z~`&!S1T5nCtnA7uc@SYY~tGq4N_zJQ4n ziafEWnw z;t{4|x?p|3KGeu!I zl+&>gi6u)oOY!H1{R9Pz=1DdEhJip3LzTr;k%4#4k&~k+o3yM>o%3P~m8BT139#WY zvxACNf6qr27Q?9s%JdTgtPogYRxi0Pj$S$_%v&ZJC7xs={M`K(vlRLR1mL!~a4Cfe zHMgmNBoKJ4w>jxO7Jn>?nZy|U2@AguhGV@=fX~nYiY;(^_jc|K(}x8g#7kqp5&*?vIvA3rhYdeCFiaP zH&Fv%EBD}cpojE-zn~KVl%d0>IK9Y56Iww(ss@ZN+ptdwNxpmK^DFNHAg1a9gxp%6 zU7rPwr&!d(9B$A5PjBn3x`ny`yRh)i+dY~(^Gx}_e6SQ;JymWk8uA9p}<67kkGqQQfsq!P2i zV>p$gN~8(}oUi+TbT*WnD*xW181{OFj*egDIj@nSetktJO*_*XOn9?eFp` zs&(JVnYnuZ(D4lue~I4wjh8}pzWX;0^$9$onsa>~<=bb0gkQ9%zB3eNJaGoH9H)^g zY~7_4MCEBz8*i24?nn_mPW1Dpjn9s{*?d2hKXDJ%eEqPEzzlq#O5n?l$a_a=W&47l z-v};(2OGd$e`JOl>@N>U&PValJJM;x>7yJ|e9HG%(L>&n0Y-f)ENjmVebEA5?X!$` zaFA#Lfw{i(oq7jgKtM_g@i52<%CVvIA?t>_ z1~#A>ycWLOLo7|*L1TetSco_tN3e}w=fj}7Ag>|yRAC;TlRtajJYD=2K9U4<{(Zpt z6T9ZVe4u?)RXiSMQ*1*V{nQ1Tx5UZ z{~~?}F>|hj>iN8WPya>YKusFQs>bMTTC*@|l~)$=5SQR!>p8e{=PxKdXf9f`Bgq?a zf$8&0Nhfg>tEp|`-i-BA6=h&Ck2NH8#7)o(qJa`H%xAc7BUbrV*6w#}I)DzaM4p_x zupc^5i=$Ddi%ma3hrWcwARJz%MR5A}(VBTfufOQcljD`|;3mjX?RVf%abPqRDLXnz zsu0!j1z=G|^yYW?v*jJ*rE5#R{^+MG?L21!1ccHY7@8&!b>JsN$5G4HcQOCFEibjxps_-?~;;@LIx6 zugz>Q-K`-Vf0#(!x)U%+B6r0#_zoVmwL`tZd#~as$8Z}wiZWf?`%ra{{Q!*J4 zZL&v)DKu!-EX{$oKv$b{;3}m2$7W+Z71b3C<`z7~Xm5ca44b$v`H6_~=X(^b&f8m~ z($Wot5>{u8Qrt-x8kds<;AQu`+D-%}kYjQV2>ntKxJNr8yI}sbe#ZL_UT*)#i;&9c zWkczfO2jY{NER$5)=qO+iZ7MnYyAw2A%4sA5}?P2P$ermv!nYm34T4l zD%C>b2EoyVMn}pPrO1no6uD~&*`E&Y3ocOlKx!y-9T-Xj7=z>6P|2i+`whTid|Ft% zEbMs19~1dG;9X+#-0$WDUQEa!y%#EP`(N|sK7$1*hms(PT|rOB$yP8*M1&F!G5>#p zLQx0S$xIT#fE11MUid@o0505#s42Vc?i&K%w@xDG(9FcLI~_*c-X;qvUT zL|gz=Hi07b6sJ2og63twY2Bcp(HQ9v3q24GX~9$_D@*vbB|mBgB3RDTc+@b1DxYf6 zNEU)oQ&$h8`d{c0B`*>^W#2-GVWr@_Y+i5bfjRo2;9Ik!_j0Qpt4P5=oz?g5Oc$<3 z{~)d3w;ID<9nqLh_QIG*=T4$hB3u5Ia=^*yiQQ9$kyRnV9CF;?k&T;ZGp{Ui@m)BBnrZme4~1Kyt#7y zPx_f5tzbVrR?_R7M03j&LvA*Vs&=70p`l55!itB=MNH+fSDfntq~bSOB81AueG%z| zkuSn8D*xIFy$Yf&f-3ZI12=R%pRV+wH*mDqc5O@X zKE-TE2r|)=fI2wce*-nRYUm6OkPH|rU}wP6(MWO!@@b$(!EPDTQQ&b#n0MQKjU^;^ zz55@p*V{xSNdDX&-1(X5{#&?>E!JQOm2X%!b$2WWp5Fv&q&;H5u|;v^R>8=Cjc;29 z=9nskZ0VVM5AoWe$7V@1JlcsY=O+G9{%~8p?{J{)oYcti=F)7%(2>05q9ka_y_hh| z=5P5Su{0nI)=C(heS^pzS%fq=u9(f+3q|E*J-K-oC-E2i{@%=A>~#2WiQVu^yEz16 zYAqmLN9gyUcc-5MYAb98%5830A*|iPy?i>LIU-@#%ux8Wh>qe8}4PN!+D*L@;)rBKLO;hu(}fxF*n?Qo4JJe7)ej5 z80>PU0xI?XS`6y^6RL7UZ8U40<4qApF9nZ)u=3`x@*KfIGV4iDmSj>Me~62F4+^aM z2&}8i7V=ld1jHshU|Rs^C^@R0qYB9}1uDctHKH9m$rJx0xgEO?7}AA{Q`F+QvfvKb zivqjB47;aaZfnY8F}QrKbFVN-oRI?3lYt39KXVOzTW-7|dFc%!ZP0qd_!}J08fdu= z!WzXVQBdlPH?$VyCAhB%9~wv<^+9&m$N_7+>=#TaVkp;DvPJo zIhDuHQD`$!%cgC;m`=rGt$T({1mudWq`5Y?po9NJ`P`8}Ak;LJGi#A6m>d-qCHb0J zkk2YoPAg%euO7X^MFkrBg>Co(?OC|Tx7jZwWM{v%;~wrCm0~JY^oy8a}BPLZq zmhZP=Hxp7-B9**LWsj7BqblIx^6wLgVMDR5tn3mx)fplfA|T$(y^?T^=SjZm=C`)S zOxVY6XTe41d(|xXuK@j(+!w_S9Bp$t+8~O{FTVw*$^_^pVhvfs#mL4iNDI`5#!WY9 zqa9rHA#uFnMRmtba2TpsdM_V@#n;==Z_kHV{!T#I`GP3QU|ha43tE6k&??i4WO&hx zY5A8aT4O`QdqDKJFw~`IvP@I{Bm}<7SUdk)uL%zm$ES$*s`^^7oxbn|;ar62!kceH z4aS?3iy7wbh*T@`*6Bz8nFn`^-$JZow1du!tMKX;Horr6>KSyL(U}2fD|ud<)Qw6Ki{iGTD69`q^CqHrtky`)`^L)8ndzHsHq{`l)&ZGAM2BQr%(<5) zZ#n-W?UJB|#bMWFm3&DLd;0{%yAEJ@Sm)dmX^!P9;N>Mu(nb9@b4(W zaKS}f_y?6w;4r(oNTl>G08=*`Q|Dl`Sx{hDzMY$J8ZW>QiU{Z>a>*Ra%8SS>+@UCc z28gWUgWlT(5%9cHh;&R0PyQtEZD6GKW-9iBlZiS>YU8vi!lBIa?=4@EEu__|IGZ0= zH7abR8Vi?S=_`)Ud3xs)uDEXqM>g{M*nlr%^i$7s;tbWO+*L=OnpUGqTA6FYH8eC5 zuRPELUC6*gR?8*c{kNqTE;f?Vx40iifR=E8RaQ-D1%bgWUH(3GBS_gY=C-Cn_Dz@= z+0dF#(~&;!dmhV5>j~9Hfq|UD#d;?sK5Q;Wr+jATqE{+ zY}kEHpgGRP5JaejkrJg&w+|;MA<4E|_CNLzd?2Ix*yGM8rTI@ff74|g{+-7=44pq^ zm7GtP|C>@kS~f@D{t0Os9#R~}YS*Zz(2nC*ygYwADNuVgE1N^prFE?7x>B2jQ?LW? zjRnuRuzBDmr^^uP1~8sB(CcJR3Gug?weQ~TND}u7o)JzFM03yO3iEL2EX{@-6_EEW z?79mPfAeKgv!TR}Jk?9o(GV}iNK5F$9o5vp3oTLE76$cO5bl=x9GJdi`dnu5eZ2OX zlbPga499a43mfZ(acpL+;5;XgT!lxl4O*53eVZ20WM-XZm8Vc3;#a=0{qa_8JQP&&$8hc%*O#FHfEchv>}q*)ci2 zMXl}3kFStd;zxA}dG{dNd>%^OzvvIWl>yYhg;mfqeVmE=3rS#F8@nFTBJS%2rQmPJ zAIX-NVw76V1U8%SJ3rhk`5b!2V`9&yuK^{cA%-7nEf_gKKiVY-1-&Bv2;#~@(I=xc zHBlJESKi?Y*S)0DHfG_4z|?aHh#){6zv>q9M*hJXJu8~D6S)A;=PyICki;(Qyc%MV z6Btu06e8z!hujEOVLQyaGOp1XyS?lJO=Yl*!W_6jQ>em?G)S$|?0Ib9ptTqG*Bzpw zF~|?yMx>toi)gDb7&|(?QymU_{Jv*qyPxZGuCzq1?pU?&kop~kV$m%@;MN_;6nluLCwm!{?r2DDUkH{&0K5Z@1V~s|_1fldy zmGRRGwLc)p(uupvxx%wX`4Vm|cew{B!k+x9$#_fjW)gLfKp{yFm=vT2Jq{p#?9`vk zce_lP)NrUI+MxtyEw~L&Nr`KT^_?+M>S#CcGk6mxPNZ5O=S{-sT?%B3v3Np+Zz z8g`ltj>z{FO1t7Flk+9XIa^6l4&y+@QnICuvU#J<>zn^x?EU<}4q>T(yBn~jJrsEg z>;e2`e>lIL04hKyY1;*;4Eu)ZDaC3HX_Cwilu3s+JC#6blHXQ1AGt?@S@ycPV7-Os z-$DP+k|F8Dz{7F2ww7oHc4>kxI_6u2uYlb#3mm9$baX`IZ8>`B|NQ_IM8o>7*xp9S z@$O=Mj^rD&@;|NZ&u@Lyz0`{5kDGaKzTW0#D}IK(+!xFuZ;9tUb~*6Ne$ z`T*#>;%!$sw9O{an05*EoBPSmMJK~K_Un5fj{{(>CYtI$RpJJtmF47-ue0KUK`mmn)i!Eug(DPyk8J7r zd+^}upjS`YGGn9ZNEbT0eF$G!`a4tv&`Sh2;%#$B28{K4-SoGzhqn{txzaZm2Bn`I z@3Mt`jupJtC{#O+1>ATcKj%w%#65Mkz$Z8*OABTXEmftKmSYa7?rAxzPfyN($9o`^ zICWDlMB4`dmuR8$Zx3KV^YUq$@bT$8El)@#3S0NC`#MXgkDz5_fL{@D;xiXKpk>14eGpKUf=OSyLa_?#EQvw@UlV@FG-8(L}HznoE69i zk{I!ln2i&T|KE4^I-`7q1-RIz2&A-5VVOj)rQh$}iqD8F&Ypzk5v0VJkeZt6zRr=H zxVdbX(T3i8z4`xrg{BFka|d5p0jd!z{3H7m`%}UH{m%`Lk;`O*LIc|zl<65Ng}nkQ z@n3gWo=1rXke~l2d*4!Sxz*MZ1sfrprL^)%UL#~L5QB0(oM&M3(`2~cp8$EtSmwQ-*YOxR zo3UQjky{<>|Fs$sta${^F4?D#INMPib)PPTArO1)t%s3JSwsqW2oG-2^eWNNcI|KG zr}R}oBMx$(h+WzBvCb{*#oqEFB10s_?Ut{D8OnL zl09P*;#b(XCq4k%^r&8g$~^PEaeYNfWb^m^pOmho9)$1Q#PZd&V55lIX0gL;`i}F- ziSWh=4Pj3|aPrQxlBkA0)M*kI=F1F3j-4@jGC*uVH zU7CRveS>>K$-|(=Xnl{uW`m{MkdY#sXsAm+_mCRCD%-L-ZouL{**MG3yfji;Vh8+G zR+78H&DSXP-huPJk<~0C{J=ng#MTIW1Ar(>la>8LN_+#joXf9r#%XzQoL+-U1EK!R z4-SD}9Z27k)jT&R!4Fmf+ui*Rj-{bEnk%xUO79E=s(^(w;zqiY(s5_b&|tx+FS`yF zzC*gfVXQ>dvdf$%;Ubpxj2^GV@lG$O_!767>k+b-PN{5dG|#1E=%L-vT0PWIb;xBlz-D(AOreb8RnEA1b4%ipN-0eMY>lQ ztpnCT`^-0A<&g87(E@^HNij;L;SjNE=Ew#bDq#r}&gm^2FVpxzHP9Qhl#SfP(<4ho zL2&fV8|YZEe`cJ<wz9{Y33tbGt)Bg(P0b>4bpcla$JwAfMR z5ElpS!>oGaHg3`-=AsN>am*IWQC*QU`MK<=Vim`eoWy-Z2T{Rgb$jP(x+~|@#-l^a z;jx!{V@TBF!B930&U+s!Km2JuwqxW|ow#TOS-+9-rvVlA;KH8pko^`wi`NJLOSc1& zI2c9D$kFlVt^}(AwAc^pQJVh!o(^QYjGA5^_vZ}=wB)80TG7d1p>u%>WMyxG6Gkj; zTm?^V3Cayp-@JLl-u7f(hGee<;QL-A*wKvYU2&>N^n$9oBxYNO+y+;FYEK;6v$^x6 zY~GLR8uq|^g3dk&3eba#0!9O+X_@Gg*q{!eldliXMIpoX%vfQoK-*x=8>*!Dy_)Y8+IN;W-YME3IZtr3<{oy-5>w#NVMK)y~|-zFxdTFETUD)rIUmnF{|NxvZ7ybwkrRG=~`lU&+lC)<>w*fIOF$@ zt0sr#w_l0fK)3FUd0y9?;8F^Z84s(1bO6W)?ED~IOG{zr&UiLSs{jUtad0j;2U-U| zk?t766l?Ce^!MX=^-wI~KLS}o?4GA93Nl)6?vK+vX7=%7eL0`gN5KIH$!szB3yh03 zhD-=?0{N9Ka$LzR=)fcAzc_|B=Zp|r4vsphODFAd6|8@^qcHj^lKh}@>?O`PuK$~T zstIa;L`py%BxGnP-CrgqI)}!ASN6D*7eov0yY6;kbf7S%Jkp}HKmjBObd&I)=7CV& zy=~lM1Da6D{QprnP*6gQeegQyUAUARToN;q9JPS0di1%WKp(m!&q-i{Dg)4D@ZG_M zIiPs5j${^C!+Fi5AhxlT;w>$TwK>IMZ|CK{*N!<}c zqM%sdMEs$@(#s$>!bZk6TCx8H0B2b&q&x=HP2}FiHZ9G~qQXK0VplGojDnl11qJ%> zTzMcv5iCy9b2Ay{^c!##ijEG}hLWfU#s$QA!HbPspC+onJ}Sdxl^vx4=A{~upo{rh zn1rBdMHsyjJREJW0Nov>@zgUcHIyEL(1UZ8DlCbbgsbP%iCjhHQ_H=Ee(a#N0)Ak5 zwu=gqAWHvx!O&=1o$bK{Ut8%f9iDI6-7}rjbL-r+T)z3~oBQ8fiJ$e$cNTxoF8l86 z^4)pA{BZW|zu)Y6H_u63vE|QMb4?7?_fMVpyZYR)SR7Mvc|Ba=)E= zytA`2_k2-L4~ln9M|{p^5YAKcI=z#^{i9Dw0ST<{=%Fp^V1JmUvE z9NZgk|ES)52@I*aUymL>tO7VU+vV+VbfqUQd-#BR*>Xcwad~ETcDDM(=jH!^QB?Tv zzrWqGD~QDfi_kvW(~Ikazv*w=5+he-HQcQaVuCx8v)Z{g#ZXo$gT~1}2iVwV`C1?zhZ?=XSXe;ehy)mPjUS`Z$-r z@s7GpS$ZwL9=zH?zYZxz$J*maE~IU?i#_G@KOF98{V~g6zO#vB7I-kYiJbp_*~P}q zBmwhn;l`{8L00v_tJMeh;ksg6U>q40RkJioNl6L&GqN0xsa(yYN9(q1+2VQTHLje# zapQ))x3@NianSJ1gODxPEe8%TI)6c*As-JnxQuh4FHc>hujq*RC<}d5T)aYCJF>dE z+StToualEg=E7SYFFzcyU0hY#doT6H{;&})GxcxW$y+D5`_gGIE`H6-YEyA-9qc*K zQe4;ZrnYv;um@xKdP7Ec*DOP6DL!rzF6 zq@@Wwb7Mdyy>aW-)w;tDM~*B9Q^+y%4b6_7omp;O36^_JnN|VMlcRYxk?G>FUOS za+COCzpS-7%3_-^w?|@Yc^*bwT>nET+9e$C6r3+Tq z9qXIe)DDi0&9@ZVpj1`U_O;#q5ZWh^xHhMLTln_g-;LV^cZ@J(QJC@{0u)50AnO~9 zaxt-oPw6aQP9uRiUZL&PZbS0~S!{R=gNwt>Vz}X$F;4Z;L}5bp!Fo@b**YGPQ5;Nq zX5E1dYkXF{^gyeqYE^g!Drl{C>?i?`IXx#Q3feC>Zr;SUz@SyXe!cK(jMT#REdn4a zLFKEN_>0sKQ-yv5q9lxCq^}vh&Ee~Pu4nfG*F&72Q)DWjoe~_($bl28g zk2Pr9Viu+M>_F?Os>40q2L%3qw#4X3Gg@U$Lci@xhNl|HZ$fgeyc*n;#+Ql5;q)=J zS8j4rc@i`Ht#I`^IORK&Zz^~j2}-dA@Ucs1!15<{%)kYJVgvVW1fiV%R~QZaX&3L| z)nBmBg+bH`Mk@ne7-z_KD`U>^p;qBmLEd6f2EHmbU4le?!L|*!T|!?qY=FIpqvn|5BrQj2=Kl~)Q#fife5ls7^^vnuF2{=jE>-d#{puto!f{C2&K*CcLdywZej#dKw9;3eI!3zx)}8mcMM6 zKXMcOJ^I~b_>7{bP*YCHr%08N%jn@an}S1${;ocYWHQtHwu`qTyz$D|C@Yn$8|yJY zJ>pm9_&!~<+{Rea_GdbN%qTs$$-y3Tpq4*K1H^Xx^Pq4j;PVuuR~enGn;d5|i4uKy zC7zkMvn+p!C`bT=mn1HCiVrGz!+O)=2t5t8(%J5DW|Dclk=tV*#~-{JHDoz5&gJrJ zsGJISt`I@8L|5dcG)I{ol22}J9R0ACj!DRHZG*t5@Z&{+-!G!;uvU2bK=~#C@*BC- zt%Vn09up$XGTbZH3925IA{ET+EX6c~3qrQ-%5F@U@Uv@*TA#;Qryu(3yi6;4gS(DEZ34RbAggR}JUg1A8TrzEb~jPAN}g zCJkJ)PMo3SQOO+Us*QevuvCxK#*U`G_a$r1)x|sRcjd z&OKg$wrIxK#K^RxW=2`0M21L!Wn6gs4NuZ>?d$j&L&+1)`?VmaVy5@#iE@QQ_Qu2G z_}C?%mPa%u35V7Qnr4>J4w7v@!wXOn`3mn~ney*lVkYvB$CygaqbRD;zY8FLS;J8cjk|;|xyX77{8U6rf+2rFsFL?p`(Kz( zUL!}RF})qXrQ{#8i*8hidH=I8?-$Yj>}~k|vfEhy+M-$9;y|VT1`Y&}*WI^ambu{R zU-oMV{oGO(y?tt1{8VWC-S-sQ1bHf|UwM|P1LzX?L z{c_Xux(OYdQDK!}xoj3QRTq!#&YW`X>+FCdUnjqt*=-0?;~Ab;F+_To1bUq<`-9N{4%c406V=<^zzyL4_`iT zN<;mFFeRorZ5F~D>6v+E3RVkeO=Gkcqjj@QE2;~k-FqeFs(-o8#@aPMm}GrE+w0oL z0iSGiA^sb*%jIt$pT1KTzSHd5y@&qo)5QdeliLy&dlkeE4|aO$uY5R#`TSlclPNr| zC2Y*r&f?sQZWM9$JOt>%Og)*wv3v6NLwl9rVAy17W~w4R(ITh!m-eNn?85Bt;w>nU zfAM5QA<|dL+XRyBq0tb^TKLvNP%PBZf9YCYYG(OERa28^Y;W#lgovr00vn!2;$Q~H zED3FhPO0_J=^8S<#%Bs$BFRzH?8^o?C7moh2Su=#fXmYIwJj7Q3W+go}%c3Ug7o zGwN~OnccoWjc3ZPdzsbc&dhDyyL%k-C7zn7)NoXAhNt3Q65%6PRcuq0p>R!#nfSm* z@H6k@=9#%&wxQ1U&T~Gt4{Dy_prn2qE=p&#o~=0?w^(m~d6u4BXoIR0BUfoEP_DlC zSa-i#W^XKtIGDrlWq`HnK=;Mu`>KkE6}%F!*i{W~wsA|%ron&Se(iLPLx;O}sPJ2CmkJau`ig3R8l$V#{nnP8^Q!2ZE^d!ixs`Ob z)FY&Ml}@a&nn&$@T+*~e$%>a2mEZj4Wl4VGt>T`p9*e`h3GKU^fR2gvXnf-JD}@j9 zg^y(Dg8rDh+TlI`#Gb+!D(EEIkJOQY^0QQzF==C|_Yog)i;D~iv4Hj&fhHo3*L zMwa-_o#B@M+PidJ zQx~?^jNhofxHh!fV(*u_Cm&u|JnXzy;%n-)V?~X3Kwj6qoaER~12;PN46bBCAFWGK z%TU?dy4yoT^xWcM>z0&Fo~tY!eXqOKKdE;WwS8WCw$`@%?y6Ln$1G(UjIvNgVQ}K& zv)GOo*Sk6=y6WE4dDS0npBi?{&i8fxK*RqxR<_e=tC&o0YDe?$3ZK6ArOo!4)!NzR zLB1#Nd4-<3HvjV9dA)?o6~wbc?c+6lU5#~X zH?PGoY#r&yZ$~kVn~MIwnhSoBzN=XP|KU2NrSTiaLjQ};NesrYZ5ZjdgU38#2AYbK zW8AkEj+T?6D+$M+?)kfQ)vgd*owH}FJxCON_g`{e9BtTq@Z}SaUJ?Bf=^q+BP3n4n zeISsOoD_I?P>x_aa^QOm}yZh4`#7-XiYl`^im4j~mZcW_%!Ur;U?; zE{R>_$0UBiIP){jf;&4%YPUL%G%DU{$qQDwy^G6Fxk_iF(J%8NUHx?gb-l3;Ld$_g z1<4PAB(>+4w96Rj08Sj<_8s&%Y+yiqu=?^GR4d+ZsZFnEDHBKgE| zO5L7jK=QrSo7pE$G8a_lOKD;f+-)eSS!YHhWpJ1SmY>>mySG2V+*zpmOt%%z9X!C} zMrUoc883e=Pp(uSUqmv5?7)VU`*S1f|=fPNrLJhPoeY zsiVm&qWc|4!o@TF443`A@Wc;!9K8AT93{pM5?`S3%Kab7k-nFQ=I?P|M0^)0tEpR77oigQzo#Rsk1)J-3 z<@~f&7f!L>(9LL_Hwof$K0H`SX|r}qifebz!T5kh{`_CoKCzoSD*VW zCnlrwO9B`9302~|)kAs>EcMpWR+*oZs1o-Z-mJPh1g%hrLy(%_VTfzsrhDOS?gltZ z%+q^fn{(76fA+@{ctfyCRHyW1n~N+j8HSApKgZ_*KWyW>;cM8Fl}?&t#e~Nqs;ed6 z@{oo~CrBFw8BFf7E-U;EiMB~~^$mCT`%Vv?gZQM@&5KYEkF>9+UN9jEYq>V`9JKtC zRy^@CUyq-5`7@n$aa`$k=VBz&WzFv%TDUr)PMz|DQN)I)ERLPs3QsWGX$FvghtQF+ z>JNvW*iNZCt2K~ruA^N%Gq3s9Lhw)JDRu0#_X~>#CO$jOpL`U$uW? zl|@LZEy_G<;E!%=gVj6 zjO5@2+lg(GMaN0Pq_HRviA$gx$HsrIz|ym}GZKI2=jaS1<;qZ2Z+yq(mim||H^}$m znDG0F&1(dUncVSV7%wrIyFFUUQc5kZvj`?G2ot{}Rh+Kedh~@XqZ!P8x1+Et$eChBDzX>eA7=-@V*cwZ$ety&SA6q`L=#e7`E0%I_&AClXcSUl{h6vJOTm(03h%O{7&`a-vdh_=Zg+_m~tdrB|hO3Hk9#8HNeiH zYnc~-B%YbN#@s;?mZ1Yb)x7Fh3pcMNt^?^8YfgE!@ISj&8vrYnRyc0N4Q~}yzH)wK z^Xjg0;K5bk?goY9mQ2&cl*@%bKheCfw!hV7)p+-TRqSiQK43Y@>{vY<>~(c!UOzu# zx@z18@%5L813XO;=%}0u*7E_J@rpuU8z+-%NP+);`mqioPe%QEOd9f@#n3 z&2PQdtln2_d+(18ImSOLh*=rRsqEztmi)ox!|GiX;u%%NaeE~Fb{DK^D?fT*%hQV& z)~s3^S{zp_b6R=6^?}yJ(Q>ykr51ATI7KyaY6#v~yf4AJl0)c+@Gc#S^<9HpGD4iT2eiB!|bGsR(NX2(AF4iA@? zM9Rt8l*N?9D5XuP00DZGPM<#QIX{>ow|{?Ftg?I8HF4VeU_G_Swzf8v`GK^AZVsZ} zk5rEMHR7>uNB286Mo6T-_(dyBa+fN^RalZNxvNBd(O{Ax9v4F{SDn`L+p=jB<55O) zR2*|6(erbtp{CACD(!a4WNw|lsdPWoAGs`IZL#jn zj6j9v2$6+WZqJTDg_Axr%E6|UeV11d*9>v+VyvsVxw*W&yq%fdv|@$a(RHH&@Z4JE zu87lPrB1$b@Oo1&F0RVj?m01RCIft(5gY4rTI?Q^=bZ&xoJz7i$2H5*Zr*&lIomUH zv|tOl*3A9P)IeQAH%6?5Rko^blr*~KFHG4fVCMEm?=HAE|4;i*Pqy=`PUyoWeac$Q z?Pu6VnU-y@uVk{A^J%BvU9U8N`>0|mMo)j4Zt?TmC}nDd?gRG^tDLFp_8QJn&@c=B#(mA(3-c1Q;#e zz}#t3K;?Kqs$xCznyRzOAS2n-|3oNXw0UO7jk!gEKdlp`W~@B<(V!s{xy3u}@opvz zT@9A=0i(oP#G`0eV*2;zR#{?6U`q9a@9WjDUF8Q2Fj_P-(e=xe&d&J^emWiG(9MUY z^Mpj3pHCH{p7Su^j2C;XFrRN|?wJs)4A-cy#XN^t(u4IJSgaTtv1Q+Uez-a1;rFY4 z@n*_cd=(-|TKfv^*V*c*cF(YGQ=2B3vn?2=_dDo ztvi~j%YkK?S@d#X6~7jW&W2kHE85khWY6^_D@}bm-Jr4t-qDku(M*vT?=CO@^vNhq zFEYCG(SF?()SE8A(0!ge82zOxBTeotrHA-cKXxg>1H?7_YBQ}??Zf>)`f)t?8>s3) zbDX*equ43C!*%S6_E-$dF9T>EvJKW6?EuqGeK}NQpr=}0wg-*iuL`fPqn|0ZqE$|~ zufZyK(6Yy?2pdXOoKKzlrPh?J6Wxu*ik)~P!j##tLC0s`E&1F-Ga`c~oLFov+mgKM zAcZN6=Wmj;?tEG(Ts-z!M^y+O={Xgo&SaasL;igG7DEWEToBv%4pR(Xq>t!Pu{a8~tw5~g4BM*=qtRiZ`Ds^eyLDdaI0X2;XcRVM*C z;j#L*x&FuH=WERr>JrVu3)F9O5|5)*KT~BW;6hac8-{Y{hXQWi?2?O{)t*0rOw^vq z*kNz+78Y|_d_KKJbT-H#f)jfONtloJhPYou$p+uqVvDY4wdTcH=ld&bYisWt!&CXk zw!#7}SaY@GVEbo|(3n>Ud1prnSkGFdM)Nv25AJOxtG8KLxXj6Kz9Gfz<$hR+W4SCm z-1>J8NJnO0QnG9Do(v&Im4EQU=^Nr4#M+2IkoB&cBXEn)|I^_3a!+EMF9q0|C8VO* zn~2oO!FiUw4(CRD4P}b+ ztBeqJRYu=>51bY${zJpFeImOa>D&b}qjKOHWvxIrr-n-1r-_@HKS0?Q{dShXsTfH3JQhkU? zVECPTC6D!-Lk5X)kEB+2opUR>WUq0S+u1N_3mTKjM4RHz{=jGISqFQ2NoDt;k_~z) zw_&jdhO@_Yllc~HaaKjrWe%dkhWo#G{PYzIK;?+gg=8p8OetaF2be_sX~@6XZk}eX zqV|>U1SvbvGfmnk?)iM_>JFNYE9I>PcK=7v-QF&XU`f(gapfU+kovs-c7Z#_I!RfL zx#1XZzMGp2qmQ5vCXA#g{hgm4T`X`I(wQffk|w~0+3pOS$6`fTKOx!NH{*jpCS=}+ zm+VY<43~RWB#J}2@%7TsJEl(I&q%%|Fmy=gIdRN3Mv(cE(4fVSr0wQ=mUc&@`NAs8 z`tc1FScObj=W{|@VcWYMt5^qOJHryIe6iNU0zW^hhO9`Fy$a(# zq4vIuEvF)Uf*( z7fJgGb$`H{C)UE#VoomjBT`rho76vVA<@+sL$HGQ@Djv9O2rT%8Ml{UKe~HgNI_=C z3=bCEDGal+D!}b^WhEGWuT5awc(KbQE<6CSEawQuMctur+sX^~A=SK_-wl_w-+ACV zq*R@bm@Sy%3gp#1dMd^UBk-^nOchT5MlEx3jFZ?esY~C-z}cjX_YWW#i%ie2qK2^* z@|cx7ew_3?ls#kBQ#%96XJP+6`8H=QNBpz@I;ZGwl=}D^%&8{&2wjztOXzQ3M4M@| z-4_P(t;5o9dBJPF9)0IvJkNk0eLLeOBE|_&p7fS>f=Mv=e~5}}Hv^%Drg<=jefL1* zBDgMy8;4q%fT*CoTz_+SLAx}T9_h7y1<@uzv@XW#1YUh511=K9zfDOSc|mSvzu|+V zDN$pA;Wu#kqr+F3;>FykXiA&xaC;Ixo~=T*m%s5&TLB&pNmFFh5VV#^xbf?h4zoFT z|7jEHglOFf;4`QYno<@_>8JMQ%b0$R5nf8N7Bx2WK)#3eJ4^f`;T{NPz8h@RM9&SR z=i+tYR%Y4iVB#uFzKYWejCc?+uIY>pzK67NNn&(9#aSJ~w<4)thn5rfj`Up2_$d3W zLIp?gNtZketY^2JCX_Fjum2@X&4nI)FJsWD>80OIw8=EbbfeWgw-~- z>g8Lkr*g!5=@9B@R!H@7*8vfYJ4pLQGxrCQPhjypnIPg5SND;g6O8rQ@2#q261Lz2 zNZu7yK*TA9-#JG;dxpT6d(k3|P5g!Q4%2CfwK|SFu+>t=fj7ZLYBzHQG00i^Al9?z zzv$gZ2N?zt{{Zqp?Sc)d!b=Rd*P}}_vOLsb91y)PY8Q_Y`Ca%eu^xwiu`cPGIlyiP zK$bD*Uus9xLu!YlN!8(Za9r|326gGX8PD0$-(!5}Y>dhEJglOlQSJwUlCe#$1JK8HCAG~yM*&GnVf%_&7Qx%&uJ6PNn8C!u)PlbANG6e&wXK? zwuJAB_1OKme@VE59N4BfuuW9~pf&ju|3#dLcHfk)!V`^Z@m0jVrC?4y=f8@R8fLlK z6S8;G@qyhSY&)G0_lUI~-z|Ck*(F1c zG4pen78?Gg4}u^IDF=Oj5E8GBWED61NRHVBU5 zBIRtX%VLxwmB`k;B;Z3@K|#UTRD+YvmyP-&C%2|vpLGW*H>$G>iRKV&Hkg0f7u(v) zbz|e6qJ(hss89(*Yj8i62GgrF^;TfibAxqh;(BVcR#*M~$qfz}pJ%({q*Wi9d^38~ zAp(r#SNcVF{`u=(klFzO3vU+`4D0#LRYmSS{X3eI%%BiBU*I5HI%a+jv#+Cz-n&;d zB@m>6r|8jN0_WnrKwXG(U1FK4j8zH#Zj}OgGw&99G}Mb;U*XZx14=Mk-w9ZhxaZ9` zEezPGOQCV2q!XwZnu0Bgj&7JEjiB-;+04KOrwW};P z`i4~2PMa8)--Uf9K4i~!rT5%H+md#JRvZVlD|3Y)7Ljt1pg@?l?A<;%@=(ub_n||F zl-mB1-s-Yw@3bHeRl-4sIHf zIZUQ+>+&V=*oTn>K;}8lyyJPxfX- zgHv8?TG;`Kmlp z7k;sFMi{11qDSP!9;JVgwX+4+f0mF{QHjY_6S)SXZQQV7gHnG=+8Bh3p|r}B?^?u- zrk7s1gQON|_0PmDYg3=eYBaTD_a8r&ZkcbM)-1QJIkLH1AAYQm%^h8d)&KdG4)ZRP zaOX!m2$_n*rOP3}I!-BS;}y-6M+P)KLW0Ucz2G6ounFc36CU%;9SeO7jKK6CLg4H@ zXlEgz+Tjd-ofI0HD|ZrxcG$*PM^ZDQyce0AoIKN#>!UQ=8O#>T`cBXsB&2eC_x?dC z@(L86J%>jl*Rk*OT1zax$x+kQ5noL3U-&Tgxfo>>9yIPsjKLxA6iOR4pAU}N0G^30 za?*PK(!jlC8Ap1zljx33S(O{W>*edYTh82ZHfF;h+NvJJfo*Xs`m#lKmdKS$s)B0t zP^D%E)WNt_Ah(R#3#k$8KyN7_PDj?r^{v19LK`m44-wiC0q-dh?XgVxvMbs8g?3DM&>R?CTS|8f0gfIzePrW1vm->d1N(HBP z#~N(ndNdvrZRIDyw_jEkFO62nXxE1ohSz0#k|jEZnS}1&;0=_&kOG)5IfnNs+YC84 zF`^IO)&n6B=mi7>q_;coAk~Q1HC?~Vfw^6BQbso`Gm;1m_bKtWZ{Ke8PV;MrI$0D7 zLmyqw1Gae~*6N|$NJa8Z&9N4Iq5GkbRZWU<-P6+=CsK?)L>-5D?9H32eoVhGSRW7+ zq&KO5nUt#Q>fDzMvZw`wp)?WkEx7l{5&n@6LB8@RThUb>*OG;v)X15tw^JG~kxK(2 zKNPZ7VHkG!!YlbvNJf185^=RzwUTq7>7@c>m(KjIp<$A-7Q`R|nNCPb7zE}Giz$gC zjYb&{>|=XeaEy8=XUzE;V`NrQxV=#a+{*gFYD0_CRRX5BAj|tuxNnHy*Ki4Tu*1ko zKX_+ipqf82;#`wz7A;`zapz|*(9!)~ZC3=)vQE5h`Da!4PZ0JIVLcu}W-l+CsZKhc zIbNpBwiSFGH># zW#7DclR5ajVQgW%JY!yTSlgBK60{?}32Dbh2mX9NM@STZNt-Lr(!qQ_d;0Y0Kx3vH zH=j_?gceUeM*LY#AHDSP0q0gCnsTKaxKgl{qfnUr4O_0su<5W|hGLUpxs=By!~dI= zx8?dOVlHvHM$MM-<+41R49iFaHW~E)PmKdp#A{mQw2fJh=R(ycn+rvzzwz9E-yU@G zdI%qn=-uYj+v{!f-F|o^X|&_g+w-Cd6otL3+Qb^q2WnnAd-(E;A*uBeDXy6}+MF4JEIu`&k z7wpfnZDf;SITBbBhh@i!O^0R2>Hluy@U|GG`)#8E-qxL7rCZ$o?gqjILzWoOY1SSd zFDB&S@}q|j9}d(%lQ1wah>VDMe_tn>?m6By(46xUE>lkcjuzv44fPUo-I?&ui^G0? zP^*P_dop)kUDxwOclCE;=k=79zqN@dx;@muveq@i5v-tl|jN!Sioq!=S~m z5Lq=fbHMIm&R9oBM_u|^1AtE(!wzh;e~#ueK)koe{@nz^{S z<&=~nSMh9ga{;dEzwYd`LR?l=_1P)XfLo<#1p{cRU<2gG*L8_1eb!fda_Ze$#EIR{ zoZDVQTEAUi{eq_T5CFMO>cBM5JrVPtAv=i7RrqJgLm|rc(wmtw^$4r;0{5X*8xlw5 z!s;D8@$>#;7w_FXusd&Y&`C~KwlV>#7R0k&Qv(cufud?fo4)!1nw5`$7zY4b#GwSV ze+$XA>W;5%Z)F0zwCZSOMS!x>RGat2{gOsIzytx%4#17oq%M&@|1#y_Y$PDmt|wH+-7-_4aKQs)q~bS?ktSAsNh28sK_!dy>L@}QfA?i_ zciG?w2uJ+2o2@Td1B7H{#Z_3m4Js-GhKXnPIIDXvj25~(qcM(Y%rvpgA~UC9$)Riw z5W3q&U`2I4@hf&1Zq9*9_fX?6FxG8UYlFhn4yAS*lCGX?b>v~F!E~>IK^@d?@Ax~9 zG}cHiKW~c$wc0u}dAsDM#V{-o&{TjBJ&(`E9TlE03xvkQK`2}boMuKes3ra(a%=h*A-p^GcG|`iv_^e_D(#l zweAvzr9EZeTtkR#>OF)c!hH@E8V}}<#}2!7d_pTgc0o7tI235|wTx(1W(s@=H%oJ9 zczy-|1Wk${(mQ)1ZD@=w%_CPA+W7r?YD5cyQ-*8WpsfEIiLXH*EX>4TeY%lsoMx?) zag!UgBdhm*bk-)n;7G5~+m7J-wK{u3<;*szKiHcdE#UD^!u)n3jk3E?h^(z34dAhf zin3T`Ij81qC>^CWglDNS60>}O^oKqp{#`@M&5)*p+<3Qgio9no&cF281uNm68g7XL z1CT8+sz6FDEy>}*i1(nJkL**1=%)U6S7;vX*Px|C+{v@pgyI6Vt@sx90CJuaT`oJLOj_nnNWC1OX9IpDA#p&H zF2kroAQ2Bl{_E2BodLuRR$#ltiIn#2&VgZlKPv?B2b%b)xrwMqv0IK`OX-oPG77XSL$9$9jLn zh%A5(Qt>WPfV^E`L*BLm?Dp;w$ab!Zh+st)CJ3T|Jtziqr3G}E3rD;-8YXURNCBWH zF+4!r*aE&)_^q_W;{Uo$*g)zEN66C(QIlXmb{YWUu)=~%iyt1XJWo0iA`C{f;xHN4 z7OgX4UsHjK^hA9&!KA$ja45t@K#GR2k)lMFAcENTDBJzQgaH@-ynt6HXuy|uNdKhw z=+RRr0K7>R-l9j(g>Uid2<7lN0B9|nhX8R@;f5$HNd^t!Lgv;X^_U3k$5VEy!f5eS zCDMJ|UXl$gK}#}U5-&E+@h7?j<26AKt>dFZ`~=)B?Y$T65*01K2YcT^@A9RA>CbWi ztwB@5##eItXuICR%zO|sGe z`AuVEuWcimNE?^%srqpjK^Cd!9$iCND(7u!!6{O(h6llD-j2w80W-n&D!>MZ*lM=Y z61qly$F&KO76|Z3eB%IOWTgl5A*!-jkwiAbe`ZfSJwJwEK-!OB$sgY!x{8--(M6jV z(TkpZXT?@70oxyA$juQHjl+^11bq@SVVEl&9 zvMHMWv4(J(G==am=?#`huzpU}qTglnZ)0?@)ow-s;?jljl`;S>0f}5c%mlqqJo++N zatT%$pTnNQNhckE$b<3zI)#_W!YZyW4o;C^^HsKkR1*$DmL3c{uTbiDfz*$DL@K~R zt5#yRaY(tTHE_zn^~xPE@!j&`jAM8pn(AN&nBG=rXxUhzLdBl%Q!rba!r7%MI7WS; z!aTAvipRc9LGP;a9&arN zM(hQ#y#_cs_Efn6;P(q-!O_Cj%}pMmDa(|)V-U1Y30kz|HF|c(W&*NneB=$k`@Ac%jv3M*s5d}@vOj@ks!VWa(Oipm0esVh?$%rB zC@4zS{or+Zk6ach`S|ge?^tl06@`*j6)w26HBY?4h+asvXS6`B`X}xnpCK14de=Z& z`Ow4%Am$@@c3~T8Nc3gRx43uAfbzX`0ThxNh~0?I4w4vNGTeDbJjVIgT-M^SjeSZ7 z|IhH|^rE+Ke=AdGE!el@=2U4om6k{=4fdiJ&hw)FQ2B!DUgrgXT{#ZD99Bcte;Wh( zz~C>r2uoU}f!yCJ{}tF^C#cFc($fBs$R`A$R6*dD@tTa>X9gO;rDJV{>P(krXeP7) z)L^X21$X=~>G}CFeJtLGZH6|tJug`>H7fL;N{cH6C}BNg2kZ_>&Jcq^P^k#$Q48^) ztxE*yyaV$?dV%bnIKSz0d*l7~pKe{`aEb<6DBkMr?TrCm#@@^)$$~&7LSGi*Kb5l1 zs;fJ1qo~r59!qFmfW_=)m6!wzRX@DJ$H!;w>MF~#QL^XbZ5ZQtR7^|>EcAY2qO#{e zDuJcIh~r-@jbqLZS}e?msV`Q2KvD|*YeZFO4v6U-B!!82npj_Q(tBi@DGTwQ#$#!) zn-!W8hN&gchZ?v(oaumzhzkoE3gsR#ubVOHi=FK$5Rwm=fx{FTS(9&WJ<2{4t)b~FntPelh`jmVSes}^^j`Z z`;wd<%Q_`2|JAuhk((S;&I4);7KxrdaxbINk6ru( zPYc`vZK~PwU|opgIlCBoRjo781RI*CbuY3HkDfuGS-F83MwTTz&D}>^LO5!Dc@(xx^cgDn{sLp4e%49rtB%an$ayfr2LU&1{uQPox?|F$-?jLa1i@+EgYcp8 z&rZ7O?ThLJerAGG(3+2Ea(`MJaG&9!!mdwlsxxO0+7vsPd}jKXwAPrqEO~e>CXbpB zO3Au7E7s~n?{@!FH7O@bVMnqJ+1PAQsyU_}yikay$3m#oQu;PI^?4Oj%KJO@xjtS? zOR28(O1e#G0q6^VetGG;>0^arnaYej1ecG1)>0yQ z!2o|+xr5K}2FnN*pl@0{{7|>JM0F2Vfj#nix)M9q7f536+q2Nyt?pH7XC7?991BNr zKR|}C1MF$UJhZLKzY(Zv2V(1~FS?0|i?h=Lwz1F~oINcOzKvDb$Z!bCl7;D(A}px@5nyinnaT|X~= z0J(^_+5Iwn&I`JpPEkZu0LQbzvLL!>pYkNsTgV+T$FWV{R7y~!|&1w}JaN7U1S-FQP(AA{wGj5iD|Bv)$~*fEp90(l`9-rWDUz-k1^i;SdOek6>`l;+f7R1tE0sIb z9z!luQtAkhbA|ZM+Sc~L1mKdXm+272sxW6dJO`c@j^%UmcS5u3SYNbXnjAv{{8p+j zG=~s3RgLDo;g$!WK43Z_h)zTaJ!<#_Y`oThs)y`mLZW;%(_`IsY$8To1s;HY2UsCh zctpV#>)Fd1mVm#ZAO2T|NU(x(=5I{Sr4B1H53F$D*7-^6-1(kMq+SuyDwFuE1gX$Z zk^^@KO=CaU%em-eSx0LHZnv&GDy?mMVXuIRP1ak7OV-uvoc^Zov#FANxGkV6jQQac z@t^(21+T2uICWck}NH9%IE zC1RNd$Y%Wq$-%YRY6#*p&(D4ixA|NYYW(cn@vuE6VGveInrFYDpbln%d>-lSTal5G zs5j!J`*0ZwwI=R~94}vib=?AAXPp_GgTl_nq2mjjC{@u(-SC{uZ!}24p;o;()v*?5p6nDa5F-`V^JFIyHJ(FU!u zF!CmC@k3cWN9zhNok>WIHkv_~1p8={vK67&yK* zAC96aeeTfUI{2)%tOnMJ%|xPBh>S*8Et=0%-T2~8n+nYN;%plajIM;`O+9;D3S~Dk zl%`6%(EW;~ReI{NTb#1@YTOi3iVJe#T89ZlxMQ68t5G?yt2CN@rc75O@+Y7_$L7?p zZ&p$NfYL(#>e)|)YGIT8wT9&|kfnBtMV=ZY*7YWNu~x~ML=#NEBSnNG2hP+%^+gDI zKbW!?Bu9Z#)Ywh;>>Ya0!;-ns&8FA*8-e)8he^$mo%acb;>O-rrGI}9lHuC_DB}cs zd|n6OY(|T(*CcOQGmp&-bk+nPjs-AGYmaFUn@7<$(;FlW9- z4qllkUv(*`LE=sYC^Dp&WTaBK$ivrp%VKDZR^GMLAHm-V2(t@b(7^q) z#|ql_m~KP-hOR%zfVXcxUy{A|vfKj(q4p;yj#f#JmGb#LFZM75aLFX$*H@lF&RWte zE1iA*5OR>A*3f)Z^)k<}5za3S(A^wu{#KdTX_0S{?LayovKkF*D9ZSys&v*PBAUYLUkoo4o(2NTJ;<5 zr%BJHtbPW0pra@*#B@7OhVquBFmoY$Z396jZz6=&Ue!AuOe1EYh!=|~c(yxn;UJfd z5yrcTL(p=@dnY5OdWRrixjM_6O(exYyW_rP;&O_`D=h!kKE@9(FUAK*^e2?nZ~h!@ zf2ZWuqyJ^G?`{ZmkF>q1mJ<{%#8ZyYAA4|Pi7z+>Enh5{y|wTyYkT8Q9{BXMZxg)u z76DNSv`(D|86 zgEwO&(|coDaAvVavIcewt!P^~p)SsfH2K5TTCkodo3o^(0XjN5sKW~ui*Ho;;n`GtDNa(6GUk0-tPJk!#_z}HfGpQuG})j91XnDNcB?Ne#m+>y>x%c zBM3LGN2jVp?X#0b%ec}ueFS%hWeC~~VO$T+AA<3&fED-dGl)xq^A&-~=N5G*vEK_(5CkQU<7`bYK`|nVkCSa=PR4k0{4}=OmU>c{RbreuQK^*% zVYn%|bYHarEL@ONPj&JbwCx4o(+E1D_h-5XuRL)(hhTi!U4k?mouK;H2RaxaNSdkg z2uP)%h>Li-s;UY_IM6o+v;IK-h0%{|8}f4qYJd>ycNhGf7js$FYpN5qzD=at?S$8K z6--RH4ZY~#8x1Ev+eV{s>q8Ow!FYc)r=XchhGQvg07GzwRy;x*V5RVFn?jSD!E?u^ zlkkGB0iJj`T}i*Yua6_(IXae2b=Xr6tgs;p7^z|i1`+L)s{}C`n1&wm)GB?z6Ff-! zhl1T3hNHa7p$#|f&o@_v)P1uleDH!DeKVsSbx;001V`NrJuNTUXk&pL201(6yTJ07q>U!F!)ElcB%}pAuOcbL@)Bip}vg&qz~mr%$6FDG{Wx=LEguu*(`E?_kmj zcRCS-u27A~0-+Z_0roG-wBgc%joVXr;v+O}uJ{-o2j?SM>}h7dth=L*P>g4rs;;z* z$>bD_Z!RXO8KU|zhLu%y1KuEn41T=x3q?2)E;VUs?%l1*q*Sf3qmw^SUApqi=@VpNNf9D)YEZ~|Ov_{@l^MOl$yR9yi2 z@g@$Eq_pVI*(W<;F|S(0GBd!V&3ms5Zg1@+IM^)Z@zVU&ZR~K9j(yhHA;wnlocj|= zOeMxUlJ7ka2u$E#w}2v*Ur47FyrWDTyhlellCbWWDcA5yU!6h7!D3j!$7=+4(M;*f zauV3p5b*3bGnE-MLSAg=-FCq1VOT);Y4opu+^9Z;d7K#{a0+fU!A&DOdEoEx5!_<& zzE!&~8C^Xu1{<@puCE+pk(9c`6QZ6Ts)P7#9EOJUgN@iV%L{CSqHB zV7Ht{`LKxCtoh(iSlJa=;_oeXcww&PHibrWM5nUW0?ZW6j-Lfe-s5;{TeQFvbVv5%$hCQ`s}a& gQ7c%U?EjDg(k8Q>8@WX)*bWBiuzwUt1?zgf1SC9r6-~w$_?Ci{SlMZG;%R5gLS7 zjAsaKCLz>8L&zcpA>~c!*A`mB2mI>!4ztim%z=s`Xi0|5b($^tR7wUZP%Qn&#~?IA zYwj%D#akL)G;h0nWV2WMD;;y4(o$X<{&*D9dD@_!pgU&Qq=(b;=wqmJxKz$PRXtmJ zjr-=Q7heQbE?;@|FnM`RoUy@d`ZX29Ir_;8KTIu`d!dqUKYiR1I|YKP6y8;Tay%g@ z)h28CbaQ^!_NwcT-`(gQju7Nu+unbDLBCmdOHl$S_WkEO0^bq%j=*;W{(?Z_`gmzp zJe?kX*w=lmk8X_5Rtd-ZI7vZBzxTE)zAIjq9quCS?aY*JNN5h9*4Vr0N_$mPs%OeC z6UTbbb}ro%ZJZcYQR95n6f=eD~!v96lqs(?!|cnYpv8`W$=W<1$;7Cf5 zSFfy}W!2XI_9F65W!ci+m>o;54Nv9f`j@UFhqSG1)@(l`sOyuDEnb_(wdyX*OI;g1 zZid16Qm1-fsX7~R)sjKW`0Jw>R1!a&jMmS>*Xe)h@|=ZgCg&E0_^?_5*nnv>=EG10oZr*2G+T#0qc z-s-w>PLb+5`V4aL8K6^2LB4JM{${gq)-P^X=R~qZIEQ^~`PQLtTTC%Omyh ziJf*W!*!3&dbIMhIx~MPG}olu+TBvR(f~A}b~fRngESJ}8s8@7h0e{Ph{UAb5pE;L zK6u-!V-Gl<3ziz2*tt*N?8nMN>qurHVC$MPRjACqNo+Mvu?ZUi5HH_$5V9O~_&-jn zY0(oboCK=WTo1}sDE3(sM|!WTn`SR_{cd@mI0dkFaHIEeg<>!6fP)B)j^&AAuAB! zMltg$;{J;hZ9on{l-?S|C2n}9G^hqjM1``&h`d6#SN%nEtH@Dcy+N7Gq{}`>q(z?U zSiWJWy}J+aUFEjQO_U-r{icePvRr+P*^lQawrXR&PlLjk$2!W_@8^=NbJ_<_E;~6x z_uQzHOpYija;Btu?Jh2KzuC9oP?ql_sU3LsFb+p_y6}jQ;kqJ9@6M7f&bG+TP{r7` zRi6^oskwAtCRHTOFf37e9N$mz>hP;Pum_MV72KjQo-u{V}FU+&s)6f;N?(+AV>6Pm9Y z^Cz?Z0m(;WsPFpH5G_52Z2NNy4Zpl#Q9(8aR?_7vg3GDnh1uwtzGf7F_09ah#qy6< ze0=(-(nsg~*^0k9X9yiHA9SQm9eOR^qewiJ|6H4swCEI0ksGh74Zft-)0rsXVPRGe z6F-_mHQaJS+OJeW+wWe4;*)te_-Mh2c&=KgB5?DCTk#mi3(v}um# zOU6tB)mcNDG`;;C6^US`LPJky>Ka1vg|bEm;1+V*T$@Jp_0CpkAWbxJW$@ywHVBbtK;j2Y0)bBA8UU_#$pM*btRqH`41UBR4n>mBA zoS%m62KRHbh9gR(Vg<#o!bG1onpX`lRPS{aJeF$RG?%UxrEs=%uRVszK*TL8Yx@gE z!TU*a!NI2$X8dwvC`th$jq7xqT_UA^YoYLhLhb-3O@W8UiB#y@TVaMb>=jm! zZq0D2=Eri%E2@1&?D91-z=Zh)dh7R-aO;DQDs0(1(xF_90{~=NGDg`y5sxe9?uE8|SW<_-#y(pN|0 z3oJYZ+pf%wS5H$jt|UTuoQe|{#@)V9@{7mw#-cs$X?o;RqE*0-8wuic%)q?#lo4KX z{_CqZJW>Zzk5aqKGlfo#RxeA2W;;{F0O)Mrz+sE|72Hd7?}S#a%s_?*|2oIYf9{P; z9}xqSQM|YAzR}~izYG|7%8y%?R%zZsw0hnZQO#e6>F0AvkQZT19(8Zc^a`u+BdQi{ zCiTA!;0MxEg%KMo)a@|mH)!*A3B6j@{ge?Hl2e`h?ziJ{%w$9Up!$ZNGG09#B58&Y z#(^pwPv0~h4)A_7dcRppxggAX&|_bo@VdugTRTe2rW=PEBf2yo0{ViMysYdC-!)-e zXGw%{V{f1XC5dito$*5G9Y>kHrf@l%)ta zJT@{fCc3bmtA@6zqr4~U$3waM=A!WT75mS1`qDCjHBl5X$Yy@JERRL zR~j`E5F<Q8~Rr`#Pe!6DKy9VZ}Vw(5Y)0#}ey_++{wLX)mF5?rF^YBLs9R9D9$ z6ic%mPX=**afPYt2x5_8no-fY1;#eL z`^3wMLUK=a1j?X8wKArB3~Fu_OLfWe^o~|Q4CO~h+|6kc zx-m03E?H+_hpM1NnP-@ISA(YO8krF)uY%qrHK!igPG{s|3>%UUsNvw1&A}oU?J&ks ze|g`dz-6*c<-|$URG60L7FL>VhZmB$Wl}CV){4~9jItXAwM4}2wa!qBMLdCm-?Qk( z$t3i8=z3JXDvWclcb0~0-DTp?)`xcHH~4WqRLGMJyewj8?%}RaS)D&7Ci| znCkG1$cQSx)%bjT5jZB_GC?u78F;T5Um6%*Mub;&mT3usNmwUgpmW)DGRy&2T{b(} z9+?LGe;p}ZpWBFa3sZcPFEGHmT{Spa?g^gjl#bZA(Nqjkn$DT882&L|Xfnq|{DGh^ z-A4lXZ5qxw1Ojo=L?loi&C!a&A)%}k?I0(qr^CNuakU1Tvc)=?KmGm7=H4q!iO(}; zA`Ab3mO}w$o>a7paF~NiJl}sGqk@EbkucdDvkWh$70EM{qEYelX{hb|5KI*3(4>is zp`=g5F$fYOaa6n*V@RAp`n?B~0crgx+`*#vI!z%V!O~%vCQQCSkf08ifmMv(#o|>C za^8!D73F)eAb$=G9V`Ma;Enf`2mcu*MJixiL}EeyA6!6T%sdfrm`Pt$c<1kwpC}B~ z;S(h>Jiu(Ns41imT>h%?AEIo(jN})T9HWAP^g+~n--z7s-Zy{^<_}ElpAh~-VUejA zst^jFQA!hkHygzM&gCB|FY?DHrivm>RFvvAWKBY+s|MB-Qf_&e-11#m5K!rI8Y0V&rjl`1Ow^_`CwY^eIlxv z7Fk_7o{VBl>j_Zc+Pa$jCD6LWqV;WtB;znf)IFgV1#K?#)Z8KQ0YC7(C@O#n2JHKg z_+a7Z!Tkjt+6+I$D5#7+;En!3>hDz+b^j26P@utLk%gjg0Smc1qnZ+vjtI|NPmOVU zW;4>C-X_GU)V>oI?;h@5z#FdOVF;??2_zSTq(a$m{!U#>Lc zR#)ZB;7h81q>>0Kko&<(h~3}iVqpRq0X0t)R9^rE3+zuE!(vMhrKlp6+E(l>l|1H+ z+$2QGu6*B8hhgb>Ljbk}`0D`rpEse9qQTJi#dR=@nec`1`GQ%B2JavszK!Hh#1Ijm zPLV{js!ybRN#55<{_~&~+49ZUi8_8W+~2YLKM<;4EGb{jp|7XLmq`9aaVHAUFUkA5 zE&q9;I+_D3hyShnU4N(8e;(ALu=y87_W$)T{a0f5-y4nog;fEjZ;*@MI{1qqq27iK zZND4cX^6969+1A?S)Bqr{>L`4htA?SkChmjCaCE3dTj*H)O;sn95>J|ob-;4Xi9H` zSC2OqW!3%e!b+kS!VR+6k zo*VrETg^x@ow=IWzN;o zoD_*mXXeS@1^JS&{h<`FCP`oxp65$|?e^@xP0l4JG8DnFZc9(Mo{#rt^9igt8v_lI z5rS!(flGS3InM8<+L?X^n5I+(YopcYD#Eh+7=wZ>asve@_W9`o$3m_LRmtVVl{ANiN*6fjk$Fm30VnX?D;g5pFlx_pQGcwOCAJ$eb^JE;>$dJt* zU}fa1B?xzM3njD;e-8C;JWY)`abr9beN)HTO{3?K%m!U>G z1};sxnp9iX89S6z_*n{K7HeB zcDXaHfO;Zesl9GZpCI4H^I#ED?Agi6Z*nBk__!kcGgWXR6Ffw-gbd)4 zF@Z657a0BKAUjI5tr{`~i?lUPdzYDEJN#E)+Urc=SjhE`~0v_VVy^OpKf@yoYC z8LKh~U&X6y@$XyZ(0V77qHrxRWk{e*A775dorbk6u~z%%El5@qP?Q5?mF&&<%f-O* zS7;PsJY<0Cpr{3Bwy~A)sep0(0^=H-52~cKo=017z;QEgv_4HAcs!X6=G7#r>2j8V zv7Gr}&?y}-$R6-StBQfC6~+dW5R1us2RZjiYX(79B^8*e90C!8fokIKTYE5puN3@f zlR*S+G2q!ztU-Ii#VU#{CUEae4(BM~$ry_XRE(kFVtxaG%YOsRoSPhRa(6)BUhf*hm5!!**cP&<dfo_YF?Jgi->7oU2*Yf&ho&XD(Jo4@E%ljf5 zLEWtx5X4EA!yRNumbjWnH=7dq zX9g~W@*Z|A2+~^MyWooNwwL8sx_Tp`kOZ@Tx#uA__f%KoW);+y%QFRV~K^f*EIP`_~A7V@20Di^a+%a#cEQW4~NJlKvApgDLrd~M>^AEj-?e2LOZSJ-ik*V7u;QB(NhQt~7U-Kd+!L;QX&ruOk_g0Z`HK_-vc1J2J zY`mGU+fLaQyk&=%#3?=4*{@oq1BNbsklQ2$xNYoNNkUOnNQl+DdQAa|FU91&z z;M2>YABbp+&h%p${9DhjVD|VCjE_&>g5>u_$miJof8Tv9_KKH&HdQuv;z{orcB*C6_BT3O zh{abgc~GD5qCR5-TW>|~?a6S=$Na%P+0C6U1;=sq%oVv)R}iC6w6;pc?D~UVc5oc% zw<4!Z`O<^YaKG<-J)5FgVu`(d&Sy`|tRhFV*n^JLHBMD`*b~l>o0SkUNXd9y@-~+o z#%CG%!71I^>@~rgoz27$wb7Jc$bL+u93pR8o7E>gG$f8xk{<;5K1_?!hJ!h#Z;AK1I1_Iz>GTK#u1b7 zDk3GO8$CGNDI5m{%_XIl{V-X3?U-b;li;~O36H2z(PVNy6SmylE?FnT86t~zl6Q27 zOQh@qGNrrxj0$7m^)!^%X6Yxvv27eu;N_Z(ioM|t#F`@qjJX6go*|+-6i(DM!DF+VKC_e;sp};WBW|mO zY_nL_%O+gb@bq}NUaw)MQ?!B5QKdoa2v`r-Nf4{`3eU}+)dD?UE-CRuj73ELW_z&L z>>L?~sBj|<2D58x^WgAzUTztoCaoK}2FMCdDL^}Tai~hvV31_W)|s^gsD;bDU~~y7 zp9*_6JuhVmq(a(7AS-x_$2l4>!cQbj-RW`2AUt@Zzbl>c6>-a4;Hnl=PjBD4->rT@FpbbMqDwKVZr zxFVdiugHLl4~#HREyi>4nQ*_r<=9GX$fkVDb$G-WW3^h8Aq(KclV)Wp+SZ$ z9G|jkQ}Q3l@@O^I`5lJ^s=EEGNhh-O|n4tQPH5 zMnfa>ggx9axw;`dN#T@P7~^!&2pwbO0qG^mc=`_J?Mj5W3vH@zby38yrBC0$&qEg> z=PbHpg!A9A#T*rh?ZfI`SnUX(sMD@Wb_v_A&BA4r=U_Jj7;(ZmrfN}x!ICNTl=SZQ zN;=5+XiJwf?xqDCdwtGuQur55Y;YyKte>eQ(A9t|3k z$39zHR{_izYQZ@}Ct#Jy%&O1qB$tQ59R=-Y0{@a;IyN0<(&2*h(4xtR5!fKQdkxzC z{Fh+?O7UWOUVhNr3=-t7T1Lr~@Pwfgrz0d&+AUIM_MWWI^hw=Fgc5c zD9KQRBX+TM)r|dN{8HFZ?j~FvIu4KBq@CEAJFT3ELp>8e+*^m)BjwZKaI7Wb2FtZQ z?<(#0ufEchWKi!l215J$&vyjABk<26z_555SyC2GFguo02t1~Q%w87a?G@r;$tGz@{o4({k=?=UF*F H(suqA$IW3u literal 0 HcmV?d00001 diff --git a/src/main/resources/templates/index.html b/src/main/resources/templates/index.html index 3a7dbfecdf3..eb628d0158e 100644 --- a/src/main/resources/templates/index.html +++ b/src/main/resources/templates/index.html @@ -1,10 +1,35 @@ - - - - 로또 - - -Hello World!! - - \ No newline at end of file + + + + 체스 + + + + + +

+
+ +
+ + diff --git a/src/main/resources/templates/ttf/BMHANNAPro.ttf b/src/main/resources/templates/ttf/BMHANNAPro.ttf new file mode 100644 index 0000000000000000000000000000000000000000..a9cb718ddd020e1d9d1067f8ebb713d906271037 GIT binary patch literal 1063060 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%0Du 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�@;e!Wf@ek&foU6Xnez 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ɲ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%0D3obJxj) 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 literal 0 HcmV?d00001 From 3fcd39d3a870a789ddd3d6317675b4b61acbd52d Mon Sep 17 00:00:00 2001 From: giantim Date: Wed, 1 Apr 2020 21:12:17 +0900 Subject: [PATCH 30/75] =?UTF-8?q?feat:=20index=20=EC=97=90=EC=84=9C=20star?= =?UTF-8?q?t=20=EB=A5=BC=20=EB=88=84=EB=A5=B4=EB=A9=B4=20game=20=EC=9C=BC?= =?UTF-8?q?=EB=A1=9C=20=EC=9D=B4=EB=8F=99=EB=90=98=EB=8F=84=EB=A1=9D=20?= =?UTF-8?q?=EA=B5=AC=ED=98=84?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../java/chess/WebUIChessApplication.java | 15 ++++- .../chess/controller/WebChessController.java | 22 +++++++ .../java/chess/controller/dto/TileDto.java | 19 ++++++ src/main/java/chess/domain/board/Board.java | 11 ++++ src/main/java/chess/domain/board/Tile.java | 27 ++++++++ .../java/chess/domain/piece/PieceType.java | 4 +- src/main/resources/templates/css/game.css | 48 ++++++++++++++ src/main/resources/templates/css/index.css | 3 +- src/main/resources/templates/game.html | 46 ++++++++++++++ src/main/resources/templates/index.html | 63 ++++++++++--------- 10 files changed, 226 insertions(+), 32 deletions(-) create mode 100644 src/main/java/chess/controller/WebChessController.java create mode 100644 src/main/java/chess/controller/dto/TileDto.java create mode 100644 src/main/java/chess/domain/board/Tile.java create mode 100644 src/main/resources/templates/css/game.css create mode 100644 src/main/resources/templates/game.html diff --git a/src/main/java/chess/WebUIChessApplication.java b/src/main/java/chess/WebUIChessApplication.java index 307309a5b56..0ede806f1ce 100644 --- a/src/main/java/chess/WebUIChessApplication.java +++ b/src/main/java/chess/WebUIChessApplication.java @@ -1,19 +1,32 @@ package chess; +import chess.controller.WebChessController; +import chess.controller.dto.BoardDto; import spark.ModelAndView; import spark.template.handlebars.HandlebarsTemplateEngine; import java.util.HashMap; import java.util.Map; -import static spark.Spark.get; +import static spark.Spark.*; public class WebUIChessApplication { public static void main(String[] args) { + + staticFiles.location("/templates"); + WebChessController webChessController = new WebChessController(); + get("/", (req, res) -> { Map model = new HashMap<>(); return render(model, "index.html"); }); + + post("/game", (req, res) -> { + BoardDto boardDto = webChessController.start(); + Map model = new HashMap<>(boardDto.get()); + + return render(model, "game.html"); + }); } private static String render(Map model, String templatePath) { diff --git a/src/main/java/chess/controller/WebChessController.java b/src/main/java/chess/controller/WebChessController.java new file mode 100644 index 00000000000..16cd2850b85 --- /dev/null +++ b/src/main/java/chess/controller/WebChessController.java @@ -0,0 +1,22 @@ +package chess.controller; + +import chess.controller.dto.BoardDto; +import chess.controller.dto.BoardScoreDto; +import chess.domain.ChessRunner; + +public class WebChessController { + private ChessRunner chessRunner; + + public BoardDto start() { + chessRunner = new ChessRunner(); + return new BoardDto(chessRunner.getBoardEntities()); + } + + public void move(String source, String target) { + chessRunner.update(source, target); + } + + public BoardScoreDto status() { + return new BoardScoreDto(chessRunner.calculateScore()); + } +} diff --git a/src/main/java/chess/controller/dto/TileDto.java b/src/main/java/chess/controller/dto/TileDto.java new file mode 100644 index 00000000000..8074eab511d --- /dev/null +++ b/src/main/java/chess/controller/dto/TileDto.java @@ -0,0 +1,19 @@ +package chess.controller.dto; + +public class TileDto { + private final String position; + private final String pieceImageUrl; + + public TileDto(final String position, final String pieceImageUrl) { + this.position = position; + this.pieceImageUrl = pieceImageUrl; + } + + public String getPosition() { + return position; + } + + public String getPieceImageUrl() { + return pieceImageUrl; + } +} diff --git a/src/main/java/chess/domain/board/Board.java b/src/main/java/chess/domain/board/Board.java index 13ef182755a..63f5877b736 100644 --- a/src/main/java/chess/domain/board/Board.java +++ b/src/main/java/chess/domain/board/Board.java @@ -1,6 +1,7 @@ package chess.domain.board; import chess.domain.piece.Piece; +import chess.domain.piece.PieceType; import chess.domain.piece.Team; import chess.domain.position.File; import chess.domain.position.Position; @@ -91,4 +92,14 @@ public Map parse() { return Collections.unmodifiableMap(parseResult); } + +// public List tiles() { +// List tiles = this.board.entrySet().stream() +// .map((entry) -> { +// Position position = entry.getKey(); +// Piece piece = entry.getValue(); +// PieceType pieceType = piece. +// }) +// .collect(Collectors.toList()); +// } } \ No newline at end of file diff --git a/src/main/java/chess/domain/board/Tile.java b/src/main/java/chess/domain/board/Tile.java new file mode 100644 index 00000000000..63805c3c727 --- /dev/null +++ b/src/main/java/chess/domain/board/Tile.java @@ -0,0 +1,27 @@ +package chess.domain.board; + +import chess.domain.piece.PieceType; +import chess.domain.piece.Team; +import chess.domain.position.Position; + +public class Tile { + private final Position position; + private final PieceType pieceType; + private final Team team; + + public Tile(Position position, PieceType pieceType, Team team) { + this.position = position; + this.pieceType = pieceType; + this.team = team; + } + + public String getPosition() { + return this.position.toString(); + } + + public String getPieceImageUrl() { + return this.pieceType.name().toLowerCase() + + "_" + + this.team.name().toLowerCase(); + } +} diff --git a/src/main/java/chess/domain/piece/PieceType.java b/src/main/java/chess/domain/piece/PieceType.java index 6640ffa3d86..6344a8423de 100644 --- a/src/main/java/chess/domain/piece/PieceType.java +++ b/src/main/java/chess/domain/piece/PieceType.java @@ -25,10 +25,10 @@ public boolean isPawn() { } public double getScore() { - return score; + return this.score; } public String getSymbol() { - return symbol; + return this.symbol; } } \ No newline at end of file diff --git a/src/main/resources/templates/css/game.css b/src/main/resources/templates/css/game.css new file mode 100644 index 00000000000..92ceed69db6 --- /dev/null +++ b/src/main/resources/templates/css/game.css @@ -0,0 +1,48 @@ +@charset "utf-8"; + +@font-face { + font-family: "BMHANNAPro"; + src: url(../ttf/BMHANNAPro.ttf); +} + +#chess-board { + width: 600px; +} + +#chess-board div { + margin: 0; + padding: 0; + width: 70px; + height: 70px; + float: left; + border: 1px solid; +} + +.black { + background-color: #D08B48; +} + +.white { + background-color: #FECE9E; +} + +#start { + position: relative; + width: 80%; + height: 100%; + left: 30px; +} + +#start-button { + width: 80px; + height: 50px; + font-family: BMHANNAPro; + border: solid 1px; + border-radius: 5px; + font-size: 20px; +} + +#start-button:hover { + background-color: black; + color: white; +} \ No newline at end of file diff --git a/src/main/resources/templates/css/index.css b/src/main/resources/templates/css/index.css index 8c8783ea354..92ceed69db6 100644 --- a/src/main/resources/templates/css/index.css +++ b/src/main/resources/templates/css/index.css @@ -28,7 +28,8 @@ #start { position: relative; - height: 100px; + width: 80%; + height: 100%; left: 30px; } diff --git a/src/main/resources/templates/game.html b/src/main/resources/templates/game.html new file mode 100644 index 00000000000..bf07b5e4845 --- /dev/null +++ b/src/main/resources/templates/game.html @@ -0,0 +1,46 @@ + + + + + + 체스 + + + + + +
    + {{#pieces}} + {{/pieces}} +
    +
    + +
    + + + \ No newline at end of file diff --git a/src/main/resources/templates/index.html b/src/main/resources/templates/index.html index eb628d0158e..a954e896a97 100644 --- a/src/main/resources/templates/index.html +++ b/src/main/resources/templates/index.html @@ -1,35 +1,42 @@ - - - 체스 - - - + } + } + + - -
    -
    + +
    +
    +
    +
    -
    - - + +
    + + + \ No newline at end of file From 96bfcc55114ea0b8b9a7cca853c7417455106b61 Mon Sep 17 00:00:00 2001 From: giantim Date: Thu, 2 Apr 2020 02:10:38 +0900 Subject: [PATCH 31/75] =?UTF-8?q?feat:=20=EC=B2=B4=EC=8A=A4=ED=8C=90?= =?UTF-8?q?=EC=97=90=20=EB=A7=90=20=EB=9D=84=EC=9A=B0=EA=B8=B0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../java/chess/WebUIChessApplication.java | 9 +- .../chess/controller/WebChessController.java | 8 +- src/main/java/chess/domain/ChessRunner.java | 11 +++ src/main/java/chess/domain/board/Board.java | 16 ++-- src/main/java/chess/domain/board/Tile.java | 19 ++-- src/main/java/chess/domain/piece/Piece.java | 4 + src/main/resources/templates/css/game.css | 48 +++++----- src/main/resources/templates/game.html | 75 +++++++++------ .../piece/{bishop_black.png => B_black.png} | Bin .../piece/{king_black.png => K_black.png} | Bin .../piece/{knight_black.png => N_black.png} | Bin .../piece/{pawn_black.png => P_black.png} | Bin .../piece/{queen_black.png => Q_black.png} | Bin .../piece/{rook_black.png => R_black.png} | Bin .../piece/{bishop_white.png => b_white.png} | Bin .../piece/{king_white.png => k_white.png} | Bin .../piece/{knight_white.png => n_white.png} | Bin .../piece/{pawn_white.png => p_white.png} | Bin .../piece/{queen_white.png => q_white.png} | Bin .../piece/{rook_white.png => r_white.png} | Bin src/main/resources/templates/index.html | 72 +++++++------- src/main/resources/templates/temp.html | 89 ++++++++++++++++++ src/main/resources/templates/test.html | 21 +++++ 23 files changed, 260 insertions(+), 112 deletions(-) rename src/main/resources/templates/image/piece/{bishop_black.png => B_black.png} (100%) rename src/main/resources/templates/image/piece/{king_black.png => K_black.png} (100%) rename src/main/resources/templates/image/piece/{knight_black.png => N_black.png} (100%) rename src/main/resources/templates/image/piece/{pawn_black.png => P_black.png} (100%) rename src/main/resources/templates/image/piece/{queen_black.png => Q_black.png} (100%) rename src/main/resources/templates/image/piece/{rook_black.png => R_black.png} (100%) rename src/main/resources/templates/image/piece/{bishop_white.png => b_white.png} (100%) rename src/main/resources/templates/image/piece/{king_white.png => k_white.png} (100%) rename src/main/resources/templates/image/piece/{knight_white.png => n_white.png} (100%) rename src/main/resources/templates/image/piece/{pawn_white.png => p_white.png} (100%) rename src/main/resources/templates/image/piece/{queen_white.png => q_white.png} (100%) rename src/main/resources/templates/image/piece/{rook_white.png => r_white.png} (100%) create mode 100644 src/main/resources/templates/temp.html create mode 100644 src/main/resources/templates/test.html diff --git a/src/main/java/chess/WebUIChessApplication.java b/src/main/java/chess/WebUIChessApplication.java index 0ede806f1ce..fdefc77041b 100644 --- a/src/main/java/chess/WebUIChessApplication.java +++ b/src/main/java/chess/WebUIChessApplication.java @@ -2,10 +2,12 @@ import chess.controller.WebChessController; import chess.controller.dto.BoardDto; +import chess.controller.dto.TileDto; import spark.ModelAndView; import spark.template.handlebars.HandlebarsTemplateEngine; import java.util.HashMap; +import java.util.List; import java.util.Map; import static spark.Spark.*; @@ -22,10 +24,11 @@ public static void main(String[] args) { }); post("/game", (req, res) -> { - BoardDto boardDto = webChessController.start(); - Map model = new HashMap<>(boardDto.get()); + List tileDtos = webChessController.start(); + Map model = new HashMap<>(); + model.put("tiles", tileDtos); - return render(model, "game.html"); + return render(model, "test.html"); }); } diff --git a/src/main/java/chess/controller/WebChessController.java b/src/main/java/chess/controller/WebChessController.java index 16cd2850b85..3224ce3e396 100644 --- a/src/main/java/chess/controller/WebChessController.java +++ b/src/main/java/chess/controller/WebChessController.java @@ -1,15 +1,17 @@ package chess.controller; -import chess.controller.dto.BoardDto; import chess.controller.dto.BoardScoreDto; +import chess.controller.dto.TileDto; import chess.domain.ChessRunner; +import java.util.List; + public class WebChessController { private ChessRunner chessRunner; - public BoardDto start() { + public List start() { chessRunner = new ChessRunner(); - return new BoardDto(chessRunner.getBoardEntities()); + return chessRunner.tileDtos(); } public void move(String source, String target) { diff --git a/src/main/java/chess/domain/ChessRunner.java b/src/main/java/chess/domain/ChessRunner.java index 4652a0e677b..426956d8bbf 100644 --- a/src/main/java/chess/domain/ChessRunner.java +++ b/src/main/java/chess/domain/ChessRunner.java @@ -1,5 +1,6 @@ package chess.domain; +import chess.controller.dto.TileDto; import chess.domain.board.Board; import chess.domain.board.BoardScore; import chess.domain.piece.Piece; @@ -7,9 +8,11 @@ import chess.domain.position.Position; import chess.domain.strategy.direction.Direction; +import java.util.Collections; import java.util.List; import java.util.Map; import java.util.Optional; +import java.util.stream.Collectors; public class ChessRunner { private Board board; @@ -105,4 +108,12 @@ public String getWinner() { Optional winner = this.board.getWinner(); return winner.map(Enum::name).orElseThrow(AssertionError::new); } + + public List tileDtos() { + List tileDtos = this.board.tiles().stream() + .map(tile -> new TileDto(tile.position(), tile.pieceImageUrl())) + .collect(Collectors.toList()); + + return Collections.unmodifiableList(tileDtos); + } } diff --git a/src/main/java/chess/domain/board/Board.java b/src/main/java/chess/domain/board/Board.java index 63f5877b736..fece1bd979b 100644 --- a/src/main/java/chess/domain/board/Board.java +++ b/src/main/java/chess/domain/board/Board.java @@ -93,13 +93,11 @@ public Map parse() { return Collections.unmodifiableMap(parseResult); } -// public List tiles() { -// List tiles = this.board.entrySet().stream() -// .map((entry) -> { -// Position position = entry.getKey(); -// Piece piece = entry.getValue(); -// PieceType pieceType = piece. -// }) -// .collect(Collectors.toList()); -// } + public List tiles() { + List tiles = this.board.entrySet().stream() + .map((entry) -> new Tile(entry.getKey(), entry.getValue())) + .collect(Collectors.toList()); + + return Collections.unmodifiableList(tiles); + } } \ No newline at end of file diff --git a/src/main/java/chess/domain/board/Tile.java b/src/main/java/chess/domain/board/Tile.java index 63805c3c727..3a15b0efe2b 100644 --- a/src/main/java/chess/domain/board/Tile.java +++ b/src/main/java/chess/domain/board/Tile.java @@ -1,27 +1,24 @@ package chess.domain.board; -import chess.domain.piece.PieceType; -import chess.domain.piece.Team; +import chess.domain.piece.Piece; import chess.domain.position.Position; public class Tile { private final Position position; - private final PieceType pieceType; - private final Team team; + private final Piece piece; - public Tile(Position position, PieceType pieceType, Team team) { + public Tile(final Position position, final Piece piece) { this.position = position; - this.pieceType = pieceType; - this.team = team; + this.piece = piece; } - public String getPosition() { + public String position() { return this.position.toString(); } - public String getPieceImageUrl() { - return this.pieceType.name().toLowerCase() + public String pieceImageUrl() { + return this.piece.toSymbol() + "_" - + this.team.name().toLowerCase(); + + this.piece.teamName().toLowerCase(); } } diff --git a/src/main/java/chess/domain/piece/Piece.java b/src/main/java/chess/domain/piece/Piece.java index a09e9aacb87..2565556e243 100644 --- a/src/main/java/chess/domain/piece/Piece.java +++ b/src/main/java/chess/domain/piece/Piece.java @@ -33,6 +33,10 @@ public String toSymbol() { return this.team.symbolize(this.pieceType.getSymbol()); } + public String teamName() { + return this.team.name(); + } + public Team getTeam() { return this.team; } diff --git a/src/main/resources/templates/css/game.css b/src/main/resources/templates/css/game.css index 92ceed69db6..29259ee53bc 100644 --- a/src/main/resources/templates/css/game.css +++ b/src/main/resources/templates/css/game.css @@ -6,43 +6,47 @@ } #chess-board { - width: 600px; + width: 600px; } #chess-board div { - margin: 0; - padding: 0; - width: 70px; - height: 70px; - float: left; - border: 1px solid; + margin: 0; + padding: 0; + width: 70px; + height: 70px; + float: left; + border: 1px solid; } .black { - background-color: #D08B48; + background-color: #d08b48; } .white { - background-color: #FECE9E; + background-color: #fece9e; } #start { - position: relative; - width: 80%; - height: 100%; - left: 30px; + position: relative; + width: 80%; + height: 100%; + left: 30px; } #start-button { - width: 80px; - height: 50px; - font-family: BMHANNAPro; - border: solid 1px; - border-radius: 5px; - font-size: 20px; + width: 80px; + height: 50px; + font-family: BMHANNAPro; + border: solid 1px; + border-radius: 5px; + font-size: 20px; } #start-button:hover { - background-color: black; - color: white; -} \ No newline at end of file + background-color: black; + color: white; +} + +img { + width: 40px; +} diff --git a/src/main/resources/templates/game.html b/src/main/resources/templates/game.html index bf07b5e4845..49b1b34f46c 100644 --- a/src/main/resources/templates/game.html +++ b/src/main/resources/templates/game.html @@ -1,46 +1,59 @@ - - + 체스 + + + + - - -
    - {{#pieces}} - {{/pieces}} -
    - +
    - - - \ No newline at end of file + + diff --git a/src/main/resources/templates/image/piece/bishop_black.png b/src/main/resources/templates/image/piece/B_black.png similarity index 100% rename from src/main/resources/templates/image/piece/bishop_black.png rename to src/main/resources/templates/image/piece/B_black.png diff --git a/src/main/resources/templates/image/piece/king_black.png b/src/main/resources/templates/image/piece/K_black.png similarity index 100% rename from src/main/resources/templates/image/piece/king_black.png rename to src/main/resources/templates/image/piece/K_black.png diff --git a/src/main/resources/templates/image/piece/knight_black.png b/src/main/resources/templates/image/piece/N_black.png similarity index 100% rename from src/main/resources/templates/image/piece/knight_black.png rename to src/main/resources/templates/image/piece/N_black.png diff --git a/src/main/resources/templates/image/piece/pawn_black.png b/src/main/resources/templates/image/piece/P_black.png similarity index 100% rename from src/main/resources/templates/image/piece/pawn_black.png rename to src/main/resources/templates/image/piece/P_black.png diff --git a/src/main/resources/templates/image/piece/queen_black.png b/src/main/resources/templates/image/piece/Q_black.png similarity index 100% rename from src/main/resources/templates/image/piece/queen_black.png rename to src/main/resources/templates/image/piece/Q_black.png diff --git a/src/main/resources/templates/image/piece/rook_black.png b/src/main/resources/templates/image/piece/R_black.png similarity index 100% rename from src/main/resources/templates/image/piece/rook_black.png rename to src/main/resources/templates/image/piece/R_black.png diff --git a/src/main/resources/templates/image/piece/bishop_white.png b/src/main/resources/templates/image/piece/b_white.png similarity index 100% rename from src/main/resources/templates/image/piece/bishop_white.png rename to src/main/resources/templates/image/piece/b_white.png diff --git a/src/main/resources/templates/image/piece/king_white.png b/src/main/resources/templates/image/piece/k_white.png similarity index 100% rename from src/main/resources/templates/image/piece/king_white.png rename to src/main/resources/templates/image/piece/k_white.png diff --git a/src/main/resources/templates/image/piece/knight_white.png b/src/main/resources/templates/image/piece/n_white.png similarity index 100% rename from src/main/resources/templates/image/piece/knight_white.png rename to src/main/resources/templates/image/piece/n_white.png diff --git a/src/main/resources/templates/image/piece/pawn_white.png b/src/main/resources/templates/image/piece/p_white.png similarity index 100% rename from src/main/resources/templates/image/piece/pawn_white.png rename to src/main/resources/templates/image/piece/p_white.png diff --git a/src/main/resources/templates/image/piece/queen_white.png b/src/main/resources/templates/image/piece/q_white.png similarity index 100% rename from src/main/resources/templates/image/piece/queen_white.png rename to src/main/resources/templates/image/piece/q_white.png diff --git a/src/main/resources/templates/image/piece/rook_white.png b/src/main/resources/templates/image/piece/r_white.png similarity index 100% rename from src/main/resources/templates/image/piece/rook_white.png rename to src/main/resources/templates/image/piece/r_white.png diff --git a/src/main/resources/templates/index.html b/src/main/resources/templates/index.html index a954e896a97..979c847707b 100644 --- a/src/main/resources/templates/index.html +++ b/src/main/resources/templates/index.html @@ -1,42 +1,48 @@ + + + 체스 + + - - - -
    -
    -
    -
    - -
    -
    - + + - \ No newline at end of file + +
    +
    +
    + +
    +
    + + diff --git a/src/main/resources/templates/temp.html b/src/main/resources/templates/temp.html new file mode 100644 index 00000000000..acc34627ffe --- /dev/null +++ b/src/main/resources/templates/temp.html @@ -0,0 +1,89 @@ + + + + + 체스 + + + + +
    + {{#tiles}} +
    +
    +
    +
    +
    +
    +
    +
    + +
    +
    +
    +
    +
    +
    +
    +
    + +
    +
    +
    +
    +
    +
    +
    +
    + +
    +
    +
    +
    +
    +
    +
    +
    + +
    +
    +
    +
    +
    +
    +
    +
    + +
    +
    +
    +
    +
    +
    +
    +
    + +
    +
    +
    +
    +
    +
    +
    +
    + +
    +
    +
    +
    +
    +
    +
    +
    + {{/tiles}} +
    +
    + +
    + + diff --git a/src/main/resources/templates/test.html b/src/main/resources/templates/test.html new file mode 100644 index 00000000000..01ce714c764 --- /dev/null +++ b/src/main/resources/templates/test.html @@ -0,0 +1,21 @@ + + + + + 체스 + + + + +
    + {{#tiles}} +
    + +
    + {{/tiles}} +
    +
    + +
    + + From 46d168ec49fbe0e3386020fbb8dab2290a883dc3 Mon Sep 17 00:00:00 2001 From: giantim Date: Thu, 2 Apr 2020 15:22:14 +0900 Subject: [PATCH 32/75] =?UTF-8?q?feat:=20=EB=B3=B4=EB=93=9C=20=EC=9C=84?= =?UTF-8?q?=EC=97=90=20=EB=A7=90=20=EC=B6=9C=EB=A0=A5?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../java/chess/WebUIChessApplication.java | 5 +- .../java/chess/controller/dto/TileDto.java | 19 +++- src/main/java/chess/domain/ChessRunner.java | 23 ++++- src/main/java/chess/domain/board/Board.java | 1 - .../java/chess/domain/position/Position.java | 13 +++ src/main/resources/templates/css/game.css | 3 +- src/main/resources/templates/game.html | 73 +++++---------- src/main/resources/templates/index.html | 27 +++--- src/main/resources/templates/temp.html | 89 ------------------- src/main/resources/templates/test.html | 21 ----- .../java/chess/domain/ChessRunnerTest.java | 8 ++ .../chess/domain/position/PositionTest.java | 8 ++ 12 files changed, 104 insertions(+), 186 deletions(-) delete mode 100644 src/main/resources/templates/temp.html delete mode 100644 src/main/resources/templates/test.html diff --git a/src/main/java/chess/WebUIChessApplication.java b/src/main/java/chess/WebUIChessApplication.java index fdefc77041b..11b25cd0731 100644 --- a/src/main/java/chess/WebUIChessApplication.java +++ b/src/main/java/chess/WebUIChessApplication.java @@ -1,7 +1,6 @@ package chess; import chess.controller.WebChessController; -import chess.controller.dto.BoardDto; import chess.controller.dto.TileDto; import spark.ModelAndView; import spark.template.handlebars.HandlebarsTemplateEngine; @@ -20,7 +19,7 @@ public static void main(String[] args) { get("/", (req, res) -> { Map model = new HashMap<>(); - return render(model, "index.html"); + return render(model, "start.html"); }); post("/game", (req, res) -> { @@ -28,7 +27,7 @@ public static void main(String[] args) { Map model = new HashMap<>(); model.put("tiles", tileDtos); - return render(model, "test.html"); + return render(model, "game.html"); }); } diff --git a/src/main/java/chess/controller/dto/TileDto.java b/src/main/java/chess/controller/dto/TileDto.java index 8074eab511d..119569a0fe9 100644 --- a/src/main/java/chess/controller/dto/TileDto.java +++ b/src/main/java/chess/controller/dto/TileDto.java @@ -2,18 +2,31 @@ public class TileDto { private final String position; - private final String pieceImageUrl; + private String pieceImageUrl; + private String team; - public TileDto(final String position, final String pieceImageUrl) { + public TileDto(final String position) { this.position = position; + this.pieceImageUrl = ""; + } + + public void setPieceImageUrl(String pieceImageUrl) { this.pieceImageUrl = pieceImageUrl; } + public void setTeam(String team) { + this.team = team; + } + public String getPosition() { return position; } + public String getTeam() { + return this.team; + } + public String getPieceImageUrl() { - return pieceImageUrl; + return this.pieceImageUrl; } } diff --git a/src/main/java/chess/domain/ChessRunner.java b/src/main/java/chess/domain/ChessRunner.java index 426956d8bbf..00f720a400d 100644 --- a/src/main/java/chess/domain/ChessRunner.java +++ b/src/main/java/chess/domain/ChessRunner.java @@ -3,6 +3,7 @@ import chess.controller.dto.TileDto; import chess.domain.board.Board; import chess.domain.board.BoardScore; +import chess.domain.board.Tile; import chess.domain.piece.Piece; import chess.domain.piece.Team; import chess.domain.position.Position; @@ -110,10 +111,28 @@ public String getWinner() { } public List tileDtos() { - List tileDtos = this.board.tiles().stream() - .map(tile -> new TileDto(tile.position(), tile.pieceImageUrl())) + List tileDtos = Position.getPositions().stream() + .map(TileDto::new) .collect(Collectors.toList()); + List indexes = Position.getPositionsIndex(); + for (int i = 0; i < indexes.size(); i++) { + if (indexes.get(i) % 2 == 0) { + tileDtos.get(i).setTeam("white"); + } else { + tileDtos.get(i).setTeam("black"); + } + } + + List tiles = this.board.tiles(); + for (Tile tile : tiles) { + TileDto tileDto = tileDtos.stream() + .filter(td -> td.getPosition().equals(tile.position())) + .findFirst() + .orElseThrow(IllegalArgumentException::new); + tileDto.setPieceImageUrl(tile.pieceImageUrl()); + } + return Collections.unmodifiableList(tileDtos); } } diff --git a/src/main/java/chess/domain/board/Board.java b/src/main/java/chess/domain/board/Board.java index fece1bd979b..01375f91091 100644 --- a/src/main/java/chess/domain/board/Board.java +++ b/src/main/java/chess/domain/board/Board.java @@ -1,7 +1,6 @@ package chess.domain.board; import chess.domain.piece.Piece; -import chess.domain.piece.PieceType; import chess.domain.piece.Team; import chess.domain.position.File; import chess.domain.position.Position; diff --git a/src/main/java/chess/domain/position/Position.java b/src/main/java/chess/domain/position/Position.java index f0794eb275e..427e238dbbf 100644 --- a/src/main/java/chess/domain/position/Position.java +++ b/src/main/java/chess/domain/position/Position.java @@ -67,6 +67,19 @@ public static List getPositions() { return Collections.unmodifiableList(parseResult); } + public static List getPositionsIndex() { + List indexes = positions.stream() + .map(Position::index) + .collect(Collectors.toList()); + + return Collections.unmodifiableList(indexes); + } + + private int index() { + return ((this.rank.getSymbol() - 8) * -1) + + (this.file.getNumber() - 1); + } + public int getFile() { return this.file.getNumber(); } diff --git a/src/main/resources/templates/css/game.css b/src/main/resources/templates/css/game.css index 29259ee53bc..41b92ea0c1e 100644 --- a/src/main/resources/templates/css/game.css +++ b/src/main/resources/templates/css/game.css @@ -16,6 +16,7 @@ height: 70px; float: left; border: 1px solid; + text-align: center; } .black { @@ -48,5 +49,5 @@ } img { - width: 40px; + width: 40px; } diff --git a/src/main/resources/templates/game.html b/src/main/resources/templates/game.html index 49b1b34f46c..7ad786f18de 100644 --- a/src/main/resources/templates/game.html +++ b/src/main/resources/templates/game.html @@ -1,59 +1,26 @@ - - - 체스 - - - - - - - -
    - +
    + {{#tiles}} +
    + {{#if pieceImageUrl}} + + {{/if}}
    - - + {{/tiles}} +
    + +
    + +
    + + \ No newline at end of file diff --git a/src/main/resources/templates/index.html b/src/main/resources/templates/index.html index 979c847707b..66a10f5ae3b 100644 --- a/src/main/resources/templates/index.html +++ b/src/main/resources/templates/index.html @@ -1,9 +1,9 @@ - - + + 체스 - + - + - -
    -
    -
    + +
    +
    + - -
    - + +
    + diff --git a/src/main/resources/templates/temp.html b/src/main/resources/templates/temp.html deleted file mode 100644 index acc34627ffe..00000000000 --- a/src/main/resources/templates/temp.html +++ /dev/null @@ -1,89 +0,0 @@ - - - - - 체스 - - - - -
    - {{#tiles}} -
    -
    -
    -
    -
    -
    -
    -
    - -
    -
    -
    -
    -
    -
    -
    -
    - -
    -
    -
    -
    -
    -
    -
    -
    - -
    -
    -
    -
    -
    -
    -
    -
    - -
    -
    -
    -
    -
    -
    -
    -
    - -
    -
    -
    -
    -
    -
    -
    -
    - -
    -
    -
    -
    -
    -
    -
    -
    - -
    -
    -
    -
    -
    -
    -
    -
    - {{/tiles}} -
    -
    - -
    - - diff --git a/src/main/resources/templates/test.html b/src/main/resources/templates/test.html deleted file mode 100644 index 01ce714c764..00000000000 --- a/src/main/resources/templates/test.html +++ /dev/null @@ -1,21 +0,0 @@ - - - - - 체스 - - - - -
    - {{#tiles}} -
    - -
    - {{/tiles}} -
    -
    - -
    - - diff --git a/src/test/java/chess/domain/ChessRunnerTest.java b/src/test/java/chess/domain/ChessRunnerTest.java index 2bc1178c4c6..9e98f97242c 100644 --- a/src/test/java/chess/domain/ChessRunnerTest.java +++ b/src/test/java/chess/domain/ChessRunnerTest.java @@ -1,9 +1,12 @@ package chess.domain; +import chess.controller.dto.TileDto; import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.DisplayName; import org.junit.jupiter.api.Test; +import java.util.List; + import static org.assertj.core.api.Assertions.assertThat; import static org.assertj.core.api.Assertions.assertThatThrownBy; @@ -74,4 +77,9 @@ void getWinnerTest() { chessRunner.getWinner(); }).isInstanceOf(AssertionError.class); } + + @Test + void tileDtosTest() { + List tileDtos = chessRunner.tileDtos(); + } } \ No newline at end of file diff --git a/src/test/java/chess/domain/position/PositionTest.java b/src/test/java/chess/domain/position/PositionTest.java index 890c88097cf..7702841d7ea 100644 --- a/src/test/java/chess/domain/position/PositionTest.java +++ b/src/test/java/chess/domain/position/PositionTest.java @@ -4,6 +4,8 @@ import org.junit.jupiter.api.DisplayName; import org.junit.jupiter.api.Test; +import java.util.List; + public class PositionTest { @DisplayName("입력한 값으로 position 변경하는 기능") @Test @@ -12,4 +14,10 @@ void moveTest() { Assertions.assertThat(position).isEqualTo(Position.of("b2")); } + +// @Test +// void getPositionsTest() { +// List positions = Position.getPositions(); +// +// } } From 89f7a6a34a5c91a2fd28689cc142d9faf6be4b0e Mon Sep 17 00:00:00 2001 From: giantim Date: Thu, 2 Apr 2020 18:09:19 +0900 Subject: [PATCH 33/75] =?UTF-8?q?feat:=20=EC=9B=B9=EC=97=90=EC=84=9C=20?= =?UTF-8?q?=EC=83=81=ED=83=9C=20=EC=B6=9C=EB=A0=A5=20/=20=EC=A2=85?= =?UTF-8?q?=EB=A3=8C=20=EA=B8=B0=EB=8A=A5=20=EA=B5=AC=ED=98=84?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../java/chess/WebUIChessApplication.java | 43 ++++++++++++++++++- .../chess/controller/WebChessController.java | 16 ++++++- .../java/chess/controller/dto/StatusDto.java | 13 ++++++ src/main/resources/templates/css/game.css | 37 ++++++++++++++-- src/main/resources/templates/game.html | 29 ++++++++++++- src/main/resources/templates/index.html | 1 + .../chess/domain/position/PositionTest.java | 2 - 7 files changed, 130 insertions(+), 11 deletions(-) create mode 100644 src/main/java/chess/controller/dto/StatusDto.java diff --git a/src/main/java/chess/WebUIChessApplication.java b/src/main/java/chess/WebUIChessApplication.java index 11b25cd0731..a4f6e3633f7 100644 --- a/src/main/java/chess/WebUIChessApplication.java +++ b/src/main/java/chess/WebUIChessApplication.java @@ -1,6 +1,8 @@ package chess; import chess.controller.WebChessController; +import chess.controller.dto.BoardScoreDto; +import chess.controller.dto.TeamDto; import chess.controller.dto.TileDto; import spark.ModelAndView; import spark.template.handlebars.HandlebarsTemplateEngine; @@ -23,12 +25,51 @@ public static void main(String[] args) { }); post("/game", (req, res) -> { - List tileDtos = webChessController.start(); + webChessController.start(); + List tileDtos = webChessController.getTiles(); + TeamDto teamDto = webChessController.getCurrentTeam(); + + Map model = new HashMap<>(); + model.put("tiles", tileDtos); + model.put("currentTeam", teamDto); + + return render(model, "game.html"); + }); + + post("/move", (req, res) -> { + String source = req.queryParams("source"); + String target = req.queryParams("target"); + webChessController.move(source, target); + + List tileDtos = webChessController.getTiles(); + TeamDto teamDto = webChessController.getCurrentTeam(); + + Map model = new HashMap<>(); + model.put("tiles", tileDtos); + model.put("currentTeam", teamDto); + + return render(model, "game.html"); + }); + + post("/status", (req, res) -> { + List tileDtos = webChessController.getTiles(); + TeamDto teamDto = webChessController.getCurrentTeam(); + BoardScoreDto boardScoreDto = webChessController.getBoardScore(); + String message = teamDto.getTeamName() + "의 점수는 " + boardScoreDto.getBoardScore() + "입니다."; + Map model = new HashMap<>(); model.put("tiles", tileDtos); + model.put("currentTeam", teamDto); + model.put("message", message); return render(model, "game.html"); }); + + post("/end", (req, res) -> { + Map model = new HashMap<>(); + + return render(model, "index.html"); + }); } private static String render(Map model, String templatePath) { diff --git a/src/main/java/chess/controller/WebChessController.java b/src/main/java/chess/controller/WebChessController.java index 3224ce3e396..04f29b9d4cc 100644 --- a/src/main/java/chess/controller/WebChessController.java +++ b/src/main/java/chess/controller/WebChessController.java @@ -1,6 +1,7 @@ package chess.controller; import chess.controller.dto.BoardScoreDto; +import chess.controller.dto.TeamDto; import chess.controller.dto.TileDto; import chess.domain.ChessRunner; @@ -9,9 +10,8 @@ public class WebChessController { private ChessRunner chessRunner; - public List start() { + public void start() { chessRunner = new ChessRunner(); - return chessRunner.tileDtos(); } public void move(String source, String target) { @@ -21,4 +21,16 @@ public void move(String source, String target) { public BoardScoreDto status() { return new BoardScoreDto(chessRunner.calculateScore()); } + + public TeamDto getCurrentTeam() { + return new TeamDto(this.chessRunner.getCurrentTeam()); + } + + public List getTiles() { + return this.chessRunner.tileDtos(); + } + + public BoardScoreDto getBoardScore() { + return new BoardScoreDto(this.chessRunner.calculateScore()); + } } diff --git a/src/main/java/chess/controller/dto/StatusDto.java b/src/main/java/chess/controller/dto/StatusDto.java new file mode 100644 index 00000000000..5ec329c52e1 --- /dev/null +++ b/src/main/java/chess/controller/dto/StatusDto.java @@ -0,0 +1,13 @@ +package chess.controller.dto; + +public class StatusDto { + private final String status; + + public StatusDto(String status) { + this.status = status; + } + + public String getStatus() { + return this.status; + } +} diff --git a/src/main/resources/templates/css/game.css b/src/main/resources/templates/css/game.css index 41b92ea0c1e..e6b16b6ab74 100644 --- a/src/main/resources/templates/css/game.css +++ b/src/main/resources/templates/css/game.css @@ -27,14 +27,16 @@ background-color: #fece9e; } -#start { +#content { position: relative; width: 80%; height: 100%; left: 30px; } -#start-button { +#status-button, +#end-button, +#move-button { width: 80px; height: 50px; font-family: BMHANNAPro; @@ -43,11 +45,38 @@ font-size: 20px; } -#start-button:hover { +#status-button:hover, +#end-button:hover, +#move-button:hover { background-color: black; color: white; } img { - width: 40px; + width: 50px; } + +#source-label, +#target-label { + font-family: BMHANNAPro; + font-size:30px; +} + +#source, +#target { + font-family: BMHANNAPro; + size:50; +} + +#currentTeam { + font-family: BMHANNAPro; + font-size: 30px; +} + +#message { + width: 500px; + height: 40px; + resize: none; + font-family: BMHANNAPro; + font-size: 30px; +} \ No newline at end of file diff --git a/src/main/resources/templates/game.html b/src/main/resources/templates/game.html index 7ad786f18de..4ba1c9146eb 100644 --- a/src/main/resources/templates/game.html +++ b/src/main/resources/templates/game.html @@ -19,8 +19,33 @@ {{/tiles}}
    -
    - +
    + {{#currentTeam}} +

    현재 차례는 {{teamName}} 입니다

    + {{/currentTeam}} +
    +
    +

    + + +

    +

    + + +

    + +
    +
    + +
    +
    + +
    +
    +
    + +
    + \ No newline at end of file diff --git a/src/main/resources/templates/index.html b/src/main/resources/templates/index.html index 66a10f5ae3b..b2000ad59c4 100644 --- a/src/main/resources/templates/index.html +++ b/src/main/resources/templates/index.html @@ -35,6 +35,7 @@ } } + diff --git a/src/test/java/chess/domain/position/PositionTest.java b/src/test/java/chess/domain/position/PositionTest.java index 7702841d7ea..c56ba303ebd 100644 --- a/src/test/java/chess/domain/position/PositionTest.java +++ b/src/test/java/chess/domain/position/PositionTest.java @@ -4,8 +4,6 @@ import org.junit.jupiter.api.DisplayName; import org.junit.jupiter.api.Test; -import java.util.List; - public class PositionTest { @DisplayName("입력한 값으로 position 변경하는 기능") @Test From 9f2711eedad07bb45663713b791f1e793d82cf8d Mon Sep 17 00:00:00 2001 From: giantim Date: Fri, 3 Apr 2020 13:40:58 +0900 Subject: [PATCH 34/75] =?UTF-8?q?refactor:=20=EC=9D=B4=EB=8F=99=EC=9D=84?= =?UTF-8?q?=20=EB=AA=BB=ED=95=98=EB=8A=94=20=EB=B2=84=EA=B7=B8=20=EC=88=98?= =?UTF-8?q?=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../chess/controller/ChessController.java | 11 ++++++++++- src/main/java/chess/domain/ChessRunner.java | 15 ++++++++++++--- src/main/java/chess/domain/board/Board.java | 9 ++++----- .../java/chess/domain/board/BoardTest.java | 19 +++++++++---------- 4 files changed, 35 insertions(+), 19 deletions(-) diff --git a/src/main/java/chess/controller/ChessController.java b/src/main/java/chess/controller/ChessController.java index f5bb64d8294..6cefa41bd88 100644 --- a/src/main/java/chess/controller/ChessController.java +++ b/src/main/java/chess/controller/ChessController.java @@ -13,7 +13,7 @@ public class ChessController { private static OutputView outputView = new ConsoleOutputView(); public static void start() { - Command command = Command.of(inputView.askChessRun()); + Command command = getCommand(); if (command.isStart()) { ChessRunner chessRunner = new ChessRunner(); GameController gameController = command.getGameController(); @@ -23,6 +23,15 @@ public static void start() { } } + private static Command getCommand() { + try { + return Command.of(inputView.askChessRun()); + } catch (IllegalArgumentException e) { + System.out.println(e.getMessage()); + return getCommand(); + } + } + private static void runChessGame(Command command, ChessRunner chessRunner) { do { command = validateExecute(command, chessRunner); diff --git a/src/main/java/chess/domain/ChessRunner.java b/src/main/java/chess/domain/ChessRunner.java index 4652a0e677b..a886c58ebfe 100644 --- a/src/main/java/chess/domain/ChessRunner.java +++ b/src/main/java/chess/domain/ChessRunner.java @@ -23,7 +23,7 @@ public ChessRunner() { public void update(String source, String target) { Position sourcePosition = Position.of(source); Position targetPosition = Position.of(target); - Piece sourcePiece = this.board.getPiece(sourcePosition); + Piece sourcePiece = getSourcePiece(sourcePosition); checkCorrectTurn(sourcePiece); checkUpdateBoard(sourcePosition, targetPosition, sourcePiece); @@ -32,6 +32,15 @@ public void update(String source, String target) { changeTeam(); } + private Piece getSourcePiece(Position source) { + Optional sourcePiece = this.board.getPiece(source); + if (!sourcePiece.isPresent()) { + throw new IllegalArgumentException("비어있는 위치를 선택했습니다."); + } + + return sourcePiece.get(); + } + private void checkCorrectTurn(Piece sourcePiece) { if (sourcePiece.isEnemy(this.currentTeam)) { throw new IllegalArgumentException("현재 차례가 아닙니다."); @@ -72,8 +81,8 @@ private boolean isEmptyPath(final Position sourcePosition, final Position target } private boolean isMovableTarget(final Piece sourcePiece, final Position targetPosition) { - Piece targetPiece = this.board.getPiece(targetPosition); - return sourcePiece.isEnemy(targetPiece); + Optional targetPiece = this.board.getPiece(targetPosition); + return targetPiece.map(sourcePiece::isEnemy).orElse(true); } private void updateBoard(Position sourcePosition, Position targetPosition) { diff --git a/src/main/java/chess/domain/board/Board.java b/src/main/java/chess/domain/board/Board.java index 13ef182755a..dd387f3ffb4 100644 --- a/src/main/java/chess/domain/board/Board.java +++ b/src/main/java/chess/domain/board/Board.java @@ -74,12 +74,11 @@ public boolean isEmpty(final Position position) { return !this.board.containsKey(position); } - public Piece getPiece(final Position position) { - if (!this.board.containsKey(position)) { - throw new IllegalArgumentException("비어있는 위치를 선택하였습니다."); + public Optional getPiece(final Position position) { + if (this.board.containsKey(position)) { + return Optional.of(this.board.get(position)); } - - return this.board.get(position); + return Optional.empty(); } public Map parse() { diff --git a/src/test/java/chess/domain/board/BoardTest.java b/src/test/java/chess/domain/board/BoardTest.java index c1cb9c4df07..9e9bfc6cf6c 100644 --- a/src/test/java/chess/domain/board/BoardTest.java +++ b/src/test/java/chess/domain/board/BoardTest.java @@ -20,9 +20,9 @@ void updateAtEmptyBoard() { board.updateBoard(source, target); Assertions.assertThatThrownBy(() -> { - board.getPiece(source); - }).isInstanceOf(IllegalArgumentException.class); - Assertions.assertThat(board.getPiece(target)).isInstanceOf(Piece.class); + board.getPiece(source).get(); + }).isInstanceOf(NoSuchElementException.class); + Assertions.assertThat(board.getPiece(target).get()).isInstanceOf(Piece.class); } @DisplayName("상대 편으로 말 이동") @@ -39,10 +39,9 @@ void updateAtEnemy() { board.updateBoard(source, target); Assertions.assertThatThrownBy(() -> { - board.getPiece(source); - }).isInstanceOf(IllegalArgumentException.class); - Assertions.assertThat(board.getPiece(target)).isNotNull(); - Assertions.assertThat(board.getPiece(target)).isInstanceOf(Piece.class); + board.getPiece(source).get(); + }).isInstanceOf(NoSuchElementException.class); + Assertions.assertThat(board.getPiece(target).get()).isInstanceOf(Piece.class); } @DisplayName("승자 팀을 판단") @@ -84,10 +83,10 @@ void isEmptyTest() { void getPieceTest() { Board board = new Board(); - Assertions.assertThat(board.getPiece(Position.of("a2"))).isInstanceOf(Piece.class); + Assertions.assertThat(board.getPiece(Position.of("a2")).get()).isInstanceOf(Piece.class); Assertions.assertThatThrownBy(() -> { - board.getPiece(Position.of("a3")); - }).isInstanceOf(IllegalArgumentException.class); + board.getPiece(Position.of("a3")).get(); + }).isInstanceOf(NoSuchElementException.class); } @DisplayName("같은 세로줄에 폰이 없을 때 점수 계산") From 28cbe8dba3a492f52c7ff39327c0845f9566d047 Mon Sep 17 00:00:00 2001 From: giantim Date: Fri, 3 Apr 2020 19:47:53 +0900 Subject: [PATCH 35/75] =?UTF-8?q?refactor:=20=EC=9B=B9=EC=97=90=EC=84=9C?= =?UTF-8?q?=20=EC=9D=B4=EB=8F=99=20=EA=B8=B0=EB=8A=A5=20=EA=B5=AC=ED=98=84?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/main/java/chess/WebUIChessApplication.java | 4 +++- .../java/chess/controller/WebChessController.java | 11 +++++++++-- .../java/chess/controller/dto/MoveResultDto.java | 13 +++++++++++++ 3 files changed, 25 insertions(+), 3 deletions(-) create mode 100644 src/main/java/chess/controller/dto/MoveResultDto.java diff --git a/src/main/java/chess/WebUIChessApplication.java b/src/main/java/chess/WebUIChessApplication.java index a4f6e3633f7..02a929cfd91 100644 --- a/src/main/java/chess/WebUIChessApplication.java +++ b/src/main/java/chess/WebUIChessApplication.java @@ -2,6 +2,7 @@ import chess.controller.WebChessController; import chess.controller.dto.BoardScoreDto; +import chess.controller.dto.MoveResultDto; import chess.controller.dto.TeamDto; import chess.controller.dto.TileDto; import spark.ModelAndView; @@ -39,14 +40,15 @@ public static void main(String[] args) { post("/move", (req, res) -> { String source = req.queryParams("source"); String target = req.queryParams("target"); - webChessController.move(source, target); + MoveResultDto moveResultDto = webChessController.move(source, target); List tileDtos = webChessController.getTiles(); TeamDto teamDto = webChessController.getCurrentTeam(); Map model = new HashMap<>(); model.put("tiles", tileDtos); model.put("currentTeam", teamDto); + model.put("message", moveResultDto); return render(model, "game.html"); }); diff --git a/src/main/java/chess/controller/WebChessController.java b/src/main/java/chess/controller/WebChessController.java index 04f29b9d4cc..cc1fbbe1a46 100644 --- a/src/main/java/chess/controller/WebChessController.java +++ b/src/main/java/chess/controller/WebChessController.java @@ -1,6 +1,7 @@ package chess.controller; import chess.controller.dto.BoardScoreDto; +import chess.controller.dto.MoveResultDto; import chess.controller.dto.TeamDto; import chess.controller.dto.TileDto; import chess.domain.ChessRunner; @@ -14,8 +15,14 @@ public void start() { chessRunner = new ChessRunner(); } - public void move(String source, String target) { - chessRunner.update(source, target); + public MoveResultDto move(String source, String target) { + try { + chessRunner.update(source, target); + String moveResult = source + " -> " + target; + return new MoveResultDto(moveResult); + } catch (IllegalArgumentException e) { + return new MoveResultDto(e.getMessage()); + } } public BoardScoreDto status() { diff --git a/src/main/java/chess/controller/dto/MoveResultDto.java b/src/main/java/chess/controller/dto/MoveResultDto.java new file mode 100644 index 00000000000..f12446d1811 --- /dev/null +++ b/src/main/java/chess/controller/dto/MoveResultDto.java @@ -0,0 +1,13 @@ +package chess.controller.dto; + +public class MoveResultDto { + private final String result; + + public MoveResultDto(String result) { + this.result = result; + } + + public String getResult() { + return result; + } +} From e0628cbdfb6bddd0f44f2d6a2f0b36a316af2327 Mon Sep 17 00:00:00 2001 From: giantim Date: Sat, 4 Apr 2020 21:25:39 +0900 Subject: [PATCH 36/75] =?UTF-8?q?refactor:=20=EC=97=90=EB=9F=AC=20?= =?UTF-8?q?=EB=A1=9C=EA=B7=B8,=20=EC=9D=B4=EB=8F=99=20=EA=B2=BD=EB=A1=9C?= =?UTF-8?q?=20=EC=B6=9C=EB=A0=A5=20=EB=B2=84=EA=B7=B8=20=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../java/chess/WebUIChessApplication.java | 3 +- .../chess/controller/WebChessController.java | 19 ++--- .../chess/controller/dto/MoveResultDto.java | 16 +++-- .../java/chess/controller/dto/StatusDto.java | 10 +-- src/main/resources/templates/css/game.css | 72 +++++++++---------- src/main/resources/templates/css/index.css | 4 +- src/main/resources/templates/game.html | 61 ++++++++-------- src/main/resources/templates/index.html | 50 ++++++------- 8 files changed, 120 insertions(+), 115 deletions(-) diff --git a/src/main/java/chess/WebUIChessApplication.java b/src/main/java/chess/WebUIChessApplication.java index 02a929cfd91..e1f345c4c5c 100644 --- a/src/main/java/chess/WebUIChessApplication.java +++ b/src/main/java/chess/WebUIChessApplication.java @@ -48,7 +48,8 @@ public static void main(String[] args) { Map model = new HashMap<>(); model.put("tiles", tileDtos); model.put("currentTeam", teamDto); - model.put("message", moveResultDto); + model.put("message", moveResultDto.getMessage()); + model.put("style", moveResultDto.getStyle()); return render(model, "game.html"); }); diff --git a/src/main/java/chess/controller/WebChessController.java b/src/main/java/chess/controller/WebChessController.java index cc1fbbe1a46..aad1af2e3d0 100644 --- a/src/main/java/chess/controller/WebChessController.java +++ b/src/main/java/chess/controller/WebChessController.java @@ -12,21 +12,24 @@ public class WebChessController { private ChessRunner chessRunner; public void start() { - chessRunner = new ChessRunner(); + this.chessRunner = new ChessRunner(); } - public MoveResultDto move(String source, String target) { + public MoveResultDto move(final String source, final String target) { try { - chessRunner.update(source, target); - String moveResult = source + " -> " + target; - return new MoveResultDto(moveResult); + this.chessRunner.update(source, target); + String moveResult = moveResult(this.chessRunner, source, target); + return new MoveResultDto(moveResult, "color:black;"); } catch (IllegalArgumentException e) { - return new MoveResultDto(e.getMessage()); + return new MoveResultDto(e.getMessage(), "color:red;"); } } - public BoardScoreDto status() { - return new BoardScoreDto(chessRunner.calculateScore()); + private String moveResult(final ChessRunner chessRunner, final String source, final String target) { + if (!chessRunner.isEndChess()) { + return source + " -> " + target; + } + return chessRunner.getWinner() + " 가 이겼습니다."; } public TeamDto getCurrentTeam() { diff --git a/src/main/java/chess/controller/dto/MoveResultDto.java b/src/main/java/chess/controller/dto/MoveResultDto.java index f12446d1811..50125ea3c2d 100644 --- a/src/main/java/chess/controller/dto/MoveResultDto.java +++ b/src/main/java/chess/controller/dto/MoveResultDto.java @@ -1,13 +1,19 @@ package chess.controller.dto; public class MoveResultDto { - private final String result; + private final String message; + private final String style; - public MoveResultDto(String result) { - this.result = result; + public MoveResultDto(String message, String style) { + this.message = message; + this.style = style; } - public String getResult() { - return result; + public String getMessage() { + return message; + } + + public String getStyle() { + return this.style; } } diff --git a/src/main/java/chess/controller/dto/StatusDto.java b/src/main/java/chess/controller/dto/StatusDto.java index 5ec329c52e1..7faf356b190 100644 --- a/src/main/java/chess/controller/dto/StatusDto.java +++ b/src/main/java/chess/controller/dto/StatusDto.java @@ -1,13 +1,13 @@ package chess.controller.dto; public class StatusDto { - private final String status; + private final String message; - public StatusDto(String status) { - this.status = status; + public StatusDto(String message) { + this.message = message; } - public String getStatus() { - return this.status; + public String getMessage() { + return this.message; } } diff --git a/src/main/resources/templates/css/game.css b/src/main/resources/templates/css/game.css index e6b16b6ab74..5d424cc8f95 100644 --- a/src/main/resources/templates/css/game.css +++ b/src/main/resources/templates/css/game.css @@ -1,82 +1,82 @@ @charset "utf-8"; @font-face { - font-family: "BMHANNAPro"; - src: url(../ttf/BMHANNAPro.ttf); + font-family: "BMHANNAPro"; + src: url(../ttf/BMHANNAPro.ttf); } #chess-board { - width: 600px; + width: 600px; } #chess-board div { - margin: 0; - padding: 0; - width: 70px; - height: 70px; - float: left; - border: 1px solid; - text-align: center; + margin: 0; + padding: 0; + width: 70px; + height: 70px; + float: left; + border: 1px solid; + text-align: center; } .black { - background-color: #d08b48; + background-color: #d08b48; } .white { - background-color: #fece9e; + background-color: #fece9e; } #content { - position: relative; - width: 80%; - height: 100%; - left: 30px; + position: relative; + width: 80%; + height: 100%; + left: 30px; } #status-button, #end-button, #move-button { - width: 80px; - height: 50px; - font-family: BMHANNAPro; - border: solid 1px; - border-radius: 5px; - font-size: 20px; + width: 80px; + height: 50px; + font-family: BMHANNAPro; + border: solid 1px; + border-radius: 5px; + font-size: 20px; } #status-button:hover, #end-button:hover, #move-button:hover { - background-color: black; - color: white; + background-color: black; + color: white; } img { - width: 50px; + width: 50px; } #source-label, #target-label { - font-family: BMHANNAPro; - font-size:30px; + font-family: BMHANNAPro; + font-size: 30px; } #source, #target { - font-family: BMHANNAPro; - size:50; + font-family: BMHANNAPro; + size: 50; } #currentTeam { - font-family: BMHANNAPro; - font-size: 30px; + font-family: BMHANNAPro; + font-size: 30px; } #message { - width: 500px; - height: 40px; - resize: none; - font-family: BMHANNAPro; - font-size: 30px; + width: 500px; + height: 40px; + resize: none; + font-family: BMHANNAPro; + font-size: 30px; } \ No newline at end of file diff --git a/src/main/resources/templates/css/index.css b/src/main/resources/templates/css/index.css index 92ceed69db6..377c311a7f0 100644 --- a/src/main/resources/templates/css/index.css +++ b/src/main/resources/templates/css/index.css @@ -1,8 +1,8 @@ @charset "utf-8"; @font-face { - font-family: "BMHANNAPro"; - src: url(../ttf/BMHANNAPro.ttf); + font-family: "BMHANNAPro"; + src: url(../ttf/BMHANNAPro.ttf); } #chess-board { diff --git a/src/main/resources/templates/game.html b/src/main/resources/templates/game.html index 4ba1c9146eb..3f7621d20d8 100644 --- a/src/main/resources/templates/game.html +++ b/src/main/resources/templates/game.html @@ -1,51 +1,46 @@ - - - 체스 - + + 체스 + - -
    +
    {{#tiles}}
    - {{#if pieceImageUrl}} - - {{/if}} + {{#if pieceImageUrl}} + + {{/if}}
    {{/tiles}} -
    +
    -
    - {{#currentTeam}} -

    현재 차례는 {{teamName}} 입니다

    - {{/currentTeam}} -
    +
    +

    현재 차례는 {{currentTeam.teamName}} 입니다

    +
    -

    - - -

    -

    - - -

    - +

    + + +

    +

    + + +

    +
    -
    - -
    +
    + +
    - +
    -
    +
    - +
    -
    +
    - - \ No newline at end of file + diff --git a/src/main/resources/templates/index.html b/src/main/resources/templates/index.html index b2000ad59c4..5a93a51495d 100644 --- a/src/main/resources/templates/index.html +++ b/src/main/resources/templates/index.html @@ -5,35 +5,35 @@ 체스 From 51b12f0a0bebf0358bbdb315865e1acbd5adea83 Mon Sep 17 00:00:00 2001 From: giantim Date: Sun, 5 Apr 2020 12:38:02 +0900 Subject: [PATCH 37/75] =?UTF-8?q?refactor:=20=ED=94=84=EB=A1=9C=EA=B7=B8?= =?UTF-8?q?=EB=9E=A8=20=EC=8B=A4=ED=96=89=20=EC=8B=9C=20=EC=9E=AC=EA=B7=80?= =?UTF-8?q?=20=EB=A1=9C=EC=A7=81=20=EC=A0=9C=EA=B1=B0=20/=20=ED=85=8C?= =?UTF-8?q?=EC=8A=A4=ED=8A=B8=20=EB=A9=94=EC=84=9C=EB=93=9C=EB=A5=BC=20?= =?UTF-8?q?=EC=9E=91=EC=9D=80=20=EB=8B=A8=EC=9C=84=20=ED=85=8C=EC=8A=A4?= =?UTF-8?q?=ED=8A=B8=EB=A1=9C=20=EB=B6=84=EB=A6=AC=20/=20=EC=8A=B9?= =?UTF-8?q?=EC=9E=90=EA=B0=80=20=EA=B2=B0=EC=A0=95=EB=90=98=EC=A7=80=20?= =?UTF-8?q?=EC=95=8A=EC=95=98=EC=9D=84=20=EB=95=8C=20=EB=8D=98=EC=A7=80?= =?UTF-8?q?=EB=8A=94=20=EC=98=88=EC=99=B8=20=EC=A0=9C=EA=B1=B0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../chess/controller/ChessController.java | 46 +++++-- src/main/java/chess/controller/Command.java | 12 +- src/main/java/chess/domain/ChessRunner.java | 3 +- .../java/chess/view/ConsoleInputView.java | 9 -- .../java/chess/view/ConsoleOutputView.java | 8 ++ src/main/java/chess/view/InputView.java | 2 - src/main/java/chess/view/OutputView.java | 2 + .../java/chess/domain/ChessRunnerTest.java | 7 +- .../java/chess/domain/piece/PawnTest.java | 114 +++++++++++++++--- 9 files changed, 152 insertions(+), 51 deletions(-) diff --git a/src/main/java/chess/controller/ChessController.java b/src/main/java/chess/controller/ChessController.java index 6cefa41bd88..c5124a28527 100644 --- a/src/main/java/chess/controller/ChessController.java +++ b/src/main/java/chess/controller/ChessController.java @@ -8,12 +8,15 @@ import chess.view.OutputView; import org.apache.commons.lang3.StringUtils; +import java.util.Optional; + public class ChessController { private static InputView inputView = new ConsoleInputView(); private static OutputView outputView = new ConsoleOutputView(); public static void start() { - Command command = getCommand(); + outputView.printGameRule(); + Command command = getGameCommand(); if (command.isStart()) { ChessRunner chessRunner = new ChessRunner(); GameController gameController = command.getGameController(); @@ -23,13 +26,22 @@ public static void start() { } } - private static Command getCommand() { - try { - return Command.of(inputView.askChessRun()); - } catch (IllegalArgumentException e) { - System.out.println(e.getMessage()); - return getCommand(); + private static Command getGameCommand() { + Optional command = Optional.empty(); + + do { + command = Command.of(inputView.askGameCommand()); + } while (isEmptyCommand(command)); + return command.get(); + } + + private static boolean isEmptyCommand(Optional command) { + if (command.isPresent()) { + return false; } + + System.out.println("잘못된 명령어를 입력하였습니다."); + return true; } private static void runChessGame(Command command, ChessRunner chessRunner) { @@ -41,16 +53,26 @@ private static void runChessGame(Command command, ChessRunner chessRunner) { private static Command validateExecute(Command command, ChessRunner chessRunner) { try { - String commands = inputView.askGameCommand(); - command = Command.of(commands); - GameController gameController = command.getGameController(); - gameController.execute(chessRunner, commands); - } catch (IllegalArgumentException e) { + command = executeByCommand(command, chessRunner); + } catch (IllegalArgumentException | ArrayIndexOutOfBoundsException e) { System.out.println(e.getMessage()); } return command; } + private static Command executeByCommand(Command command, ChessRunner chessRunner) { + String input = inputView.askGameCommand(); + Optional inputCommand = Command.of(input); + + while (isEmptyCommand(inputCommand)) { + input = inputView.askGameCommand(); + inputCommand = Command.of(input); + } + command = inputCommand.get(); + command.execute(chessRunner, input); + return command; + } + private static void printWinner(ChessRunner chessRunner) { if (chessRunner.isEndChess()) { TeamDto teamDto = new TeamDto(chessRunner.getWinner()); diff --git a/src/main/java/chess/controller/Command.java b/src/main/java/chess/controller/Command.java index c140263d451..aa1d5abe7ba 100644 --- a/src/main/java/chess/controller/Command.java +++ b/src/main/java/chess/controller/Command.java @@ -1,6 +1,9 @@ package chess.controller; +import chess.domain.ChessRunner; + import java.util.Arrays; +import java.util.Optional; public enum Command { START("start", new StartController()), @@ -16,11 +19,10 @@ public enum Command { this.gameController = gameController; } - public static Command of(final String command) { + public static Optional of(final String command) { return Arrays.stream(values()) .filter(c -> command.contains(c.command)) - .findFirst() - .orElseThrow(() -> new IllegalArgumentException("잘못된 명령어를 입력하였습니다.")); + .findFirst(); } public boolean isStart() { @@ -34,4 +36,8 @@ public GameController getGameController() { public boolean isEnd() { return this == END; } + + public void execute(ChessRunner chessRunner, String commands) { + this.gameController.execute(chessRunner, commands); + } } diff --git a/src/main/java/chess/domain/ChessRunner.java b/src/main/java/chess/domain/ChessRunner.java index a886c58ebfe..f9a0870ab78 100644 --- a/src/main/java/chess/domain/ChessRunner.java +++ b/src/main/java/chess/domain/ChessRunner.java @@ -6,6 +6,7 @@ import chess.domain.piece.Team; import chess.domain.position.Position; import chess.domain.strategy.direction.Direction; +import org.apache.commons.lang3.StringUtils; import java.util.List; import java.util.Map; @@ -112,6 +113,6 @@ public String getCurrentTeam() { public String getWinner() { Optional winner = this.board.getWinner(); - return winner.map(Enum::name).orElseThrow(AssertionError::new); + return winner.map(Enum::name).orElse(StringUtils.EMPTY); } } diff --git a/src/main/java/chess/view/ConsoleInputView.java b/src/main/java/chess/view/ConsoleInputView.java index 0649abe99fb..527c5ea93b0 100644 --- a/src/main/java/chess/view/ConsoleInputView.java +++ b/src/main/java/chess/view/ConsoleInputView.java @@ -5,15 +5,6 @@ public class ConsoleInputView implements InputView { private static final Scanner SCANNER = new Scanner(System.in); - @Override - public String askChessRun() { - System.out.println("> 체스 게임을 시작합니다."); - System.out.println("> 게임 시작 : start"); - System.out.println("> 게임 종료 : end"); - System.out.println("> 게임 이동 : move source위치 target위치 - 예. move b2 b3"); - return SCANNER.nextLine(); - } - @Override public String askGameCommand() { return SCANNER.nextLine(); diff --git a/src/main/java/chess/view/ConsoleOutputView.java b/src/main/java/chess/view/ConsoleOutputView.java index b85b029b013..a34e4153e51 100644 --- a/src/main/java/chess/view/ConsoleOutputView.java +++ b/src/main/java/chess/view/ConsoleOutputView.java @@ -7,6 +7,14 @@ public class ConsoleOutputView implements OutputView { private static final String EMPTY_SQUARE = "."; private static final int MAX_BOARD_SIZE = 8; + @Override + public void printGameRule() { + System.out.println("> 체스 게임을 시작합니다."); + System.out.println("> 게임 시작 : start"); + System.out.println("> 게임 종료 : end"); + System.out.println("> 게임 이동 : move source위치 target위치 - 예. move b2 b3"); + } + @Override public void printBoard(final List positions, final Map board) { for (int i = 1; i <= positions.size(); i++) { diff --git a/src/main/java/chess/view/InputView.java b/src/main/java/chess/view/InputView.java index d3a8f06a520..f96f36786e5 100644 --- a/src/main/java/chess/view/InputView.java +++ b/src/main/java/chess/view/InputView.java @@ -1,7 +1,5 @@ package chess.view; public interface InputView { - String askChessRun(); - String askGameCommand(); } diff --git a/src/main/java/chess/view/OutputView.java b/src/main/java/chess/view/OutputView.java index 155d5eaca09..29016029f8e 100644 --- a/src/main/java/chess/view/OutputView.java +++ b/src/main/java/chess/view/OutputView.java @@ -9,4 +9,6 @@ public interface OutputView { void printStatus(double calculateScore, String teamName); void printWinner(String teamName); + + void printGameRule(); } diff --git a/src/test/java/chess/domain/ChessRunnerTest.java b/src/test/java/chess/domain/ChessRunnerTest.java index 2bc1178c4c6..03e5efad96d 100644 --- a/src/test/java/chess/domain/ChessRunnerTest.java +++ b/src/test/java/chess/domain/ChessRunnerTest.java @@ -1,5 +1,6 @@ package chess.domain; +import org.apache.commons.lang3.StringUtils; import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.DisplayName; import org.junit.jupiter.api.Test; @@ -67,11 +68,9 @@ void isEndChessTest() { assertThat(chessRunner.isEndChess()).isFalse(); } - @DisplayName("게임이 종료되지 않았을 때 승자를 출력 시 예외 출력") + @DisplayName("게임이 종료되지 않았을 때 승자를 출력 시 빈 문자열 출력") @Test void getWinnerTest() { - assertThatThrownBy(() -> { - chessRunner.getWinner(); - }).isInstanceOf(AssertionError.class); + assertThat(chessRunner.getWinner()).isEqualTo(StringUtils.EMPTY); } } \ No newline at end of file diff --git a/src/test/java/chess/domain/piece/PawnTest.java b/src/test/java/chess/domain/piece/PawnTest.java index 42222b383f4..1fc14cee2f6 100644 --- a/src/test/java/chess/domain/piece/PawnTest.java +++ b/src/test/java/chess/domain/piece/PawnTest.java @@ -6,49 +6,123 @@ import org.junit.jupiter.api.Test; public class PawnTest { - @DisplayName("흰색 폰이 이동 가능한 곳인지 검사") + @DisplayName("흰색 폰이 시작 위치에서 두 칸 이동") @Test - void whitePawnMovableTest() { + void whitePawnMovableOnInitialPositionTwoTest() { Piece whitePawn = new Pawn(PieceType.PAWN, Team.WHITE); Position initialSource = Position.of("a2"); - Position directOne = Position.of("a3"); Position directTwo = Position.of("a4"); - Position nonMovableInitial = Position.of("a5"); - Position nonInitialSource = Position.of("b3"); - Position diagonalTarget = Position.of("c4"); - Position directTarget = Position.of("b4"); - Position nonMovableTarget = Position.of("b5"); + Assertions.assertThat(whitePawn.movable(initialSource, directTwo)).isTrue(); + } + + @DisplayName("흰색 폰이 시작 위치에서 한 칸 이동") + @Test + void whitePawnMovableOnInitialPositionOneTest() { + Piece whitePawn = new Pawn(PieceType.PAWN, Team.WHITE); + Position initialSource = Position.of("a2"); + Position directOne = Position.of("a3"); Assertions.assertThat(whitePawn.movable(initialSource, directOne)).isTrue(); - Assertions.assertThat(whitePawn.movable(initialSource, directTwo)).isTrue(); + } + + @DisplayName("흰색 폰이 시작 위치에서 갈 수 없는 곳으로 이동") + @Test + void whitePawnNonMovableOnInitialPositionTest() { + Piece whitePawn = new Pawn(PieceType.PAWN, Team.WHITE); + Position initialSource = Position.of("a2"); + Position nonMovableInitial = Position.of("a5"); + Assertions.assertThat(whitePawn.movable(initialSource, nonMovableInitial)).isFalse(); + } + + @DisplayName("흰색 폰이 시작 위치가 아닌 곳에서 대각으로 공격") + @Test + void whitePawnDiagonalMovableTest() { + Piece whitePawn = new Pawn(PieceType.PAWN, Team.WHITE); + Position nonInitialSource = Position.of("b3"); + Position diagonalTarget = Position.of("c4"); Assertions.assertThat(whitePawn.movable(nonInitialSource, diagonalTarget)).isTrue(); + } + + @DisplayName("흰색 폰이 시작 위치가 아닌 곳에서 직진 이동") + @Test + void whitePawnDirectMovableTest() { + Piece whitePawn = new Pawn(PieceType.PAWN, Team.WHITE); + Position nonInitialSource = Position.of("b3"); + Position directTarget = Position.of("b4"); + Assertions.assertThat(whitePawn.movable(nonInitialSource, directTarget)).isTrue(); + } + + @DisplayName("흰색 폰이 시작 위치가 아닌 곳에서 갈수 없는 곳으로 이동") + @Test + void whitePawnNonMovableTest() { + Piece whitePawn = new Pawn(PieceType.PAWN, Team.WHITE); + Position nonInitialSource = Position.of("b3"); + Position nonMovableTarget = Position.of("b5"); + Assertions.assertThat(whitePawn.movable(nonInitialSource, nonMovableTarget)).isFalse(); } - @DisplayName("검은색 폰이 이동 가능한 곳인지 검사") + @DisplayName("검은색 폰이 시작 위치에서 두 칸 이동") @Test - void blackPawnMovableTest() { - Piece blackPawn = new Pawn(PieceType.PAWN, Team.BLACK); + void blackPawnMovableOnInitialPositionTwoTest() { + Piece whitePawn = new Pawn(PieceType.PAWN, Team.BLACK); Position initialSource = Position.of("a7"); - Position directOne = Position.of("a6"); Position directTwo = Position.of("a5"); + + Assertions.assertThat(whitePawn.movable(initialSource, directTwo)).isTrue(); + } + + @DisplayName("검은색 폰이 시작 위치에서 한 칸 이동") + @Test + void blackPawnMovableOnInitialPositionOneTest() { + Piece whitePawn = new Pawn(PieceType.PAWN, Team.BLACK); + Position initialSource = Position.of("a7"); + Position directOne = Position.of("a6"); + + Assertions.assertThat(whitePawn.movable(initialSource, directOne)).isTrue(); + } + + @DisplayName("검은색 폰이 시작 위치에서 갈 수 없는 곳으로 이동") + @Test + void blackPawnNonMovableOnInitialPositionTest() { + Piece whitePawn = new Pawn(PieceType.PAWN, Team.BLACK); + Position initialSource = Position.of("a7"); Position nonMovableInitial = Position.of("a4"); + Assertions.assertThat(whitePawn.movable(initialSource, nonMovableInitial)).isFalse(); + } + + @DisplayName("검은색 폰이 시작 위치가 아닌 곳에서 대각으로 공격") + @Test + void blackPawnDiagonalMovableTest() { + Piece whitePawn = new Pawn(PieceType.PAWN, Team.BLACK); Position nonInitialSource = Position.of("b6"); Position diagonalTarget = Position.of("c5"); + + Assertions.assertThat(whitePawn.movable(nonInitialSource, diagonalTarget)).isTrue(); + } + + @DisplayName("검은색 폰이 시작 위치가 아닌 곳에서 직진 이동") + @Test + void blackPawnDirectMovableTest() { + Piece whitePawn = new Pawn(PieceType.PAWN, Team.BLACK); + Position nonInitialSource = Position.of("b6"); Position directTarget = Position.of("b5"); - Position nonMovableTarget = Position.of("b4"); - Assertions.assertThat(blackPawn.movable(initialSource, directOne)).isTrue(); - Assertions.assertThat(blackPawn.movable(initialSource, directTwo)).isTrue(); - Assertions.assertThat(blackPawn.movable(initialSource, nonMovableInitial)).isFalse(); + Assertions.assertThat(whitePawn.movable(nonInitialSource, directTarget)).isTrue(); + } - Assertions.assertThat(blackPawn.movable(nonInitialSource, diagonalTarget)).isTrue(); - Assertions.assertThat(blackPawn.movable(nonInitialSource, directTarget)).isTrue(); - Assertions.assertThat(blackPawn.movable(nonInitialSource, nonMovableTarget)).isFalse(); + @DisplayName("검은색 폰이 시작 위치가 아닌 곳에서 갈수 없는 곳으로 이동") + @Test + void blackPawnNonMovableTest() { + Piece whitePawn = new Pawn(PieceType.PAWN, Team.BLACK); + Position nonInitialSource = Position.of("b6"); + Position nonMovableTarget = Position.of("b4"); + + Assertions.assertThat(whitePawn.movable(nonInitialSource, nonMovableTarget)).isFalse(); } } From dd4951dbf376c396aca82326f287caaaa07b664b Mon Sep 17 00:00:00 2001 From: giantim Date: Sun, 5 Apr 2020 14:19:40 +0900 Subject: [PATCH 38/75] =?UTF-8?q?refactor:=20=EC=9B=B9=EC=97=90=EC=84=9C?= =?UTF-8?q?=20=EC=A0=90=EC=88=98=20=EC=B6=9C=EB=A0=A5=20=EC=8B=9C=20black,?= =?UTF-8?q?=20white=20=EB=91=98=20=EB=8B=A4=20=EC=B6=9C=EB=A0=A5=20?= =?UTF-8?q?=EB=90=98=EB=8F=84=EB=A1=9D=20=EB=B3=80=EA=B2=BD=20/=20?= =?UTF-8?q?=EC=99=95=EC=9D=84=20=EC=9E=A1=EC=95=84=EC=84=9C=20=EA=B2=8C?= =?UTF-8?q?=EC=9E=84=EC=9D=B4=20=EB=81=9D=EB=82=A0=20=EC=8B=9C=20=EC=A2=85?= =?UTF-8?q?=EB=A3=8C=20=ED=8E=98=EC=9D=B4=EC=A7=80=EB=A1=9C=20=EC=9D=B4?= =?UTF-8?q?=EB=8F=99?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../java/chess/WebUIChessApplication.java | 10 ++++--- .../chess/controller/ChessController.java | 2 +- src/main/java/chess/controller/Command.java | 2 +- .../chess/controller/WebChessController.java | 16 ++++++++---- .../chess/controller/dto/BoardScoreDto.java | 11 +++++++- src/main/java/chess/domain/ChessRunner.java | 26 ++++++++++++++----- src/main/java/chess/domain/piece/Piece.java | 2 +- src/main/resources/templates/css/end.css | 24 +++++++++++++++++ src/main/resources/templates/css/game.css | 2 +- src/main/resources/templates/end.html | 17 ++++++++++++ .../java/chess/domain/ChessRunnerTest.java | 8 ------ 11 files changed, 91 insertions(+), 29 deletions(-) create mode 100644 src/main/resources/templates/css/end.css create mode 100644 src/main/resources/templates/end.html diff --git a/src/main/java/chess/WebUIChessApplication.java b/src/main/java/chess/WebUIChessApplication.java index e1f345c4c5c..2f760d2362a 100644 --- a/src/main/java/chess/WebUIChessApplication.java +++ b/src/main/java/chess/WebUIChessApplication.java @@ -1,7 +1,6 @@ package chess; import chess.controller.WebChessController; -import chess.controller.dto.BoardScoreDto; import chess.controller.dto.MoveResultDto; import chess.controller.dto.TeamDto; import chess.controller.dto.TileDto; @@ -38,6 +37,8 @@ public static void main(String[] args) { }); post("/move", (req, res) -> { + Map model = new HashMap<>(); + String source = req.queryParams("source"); String target = req.queryParams("target"); @@ -45,20 +46,21 @@ public static void main(String[] args) { List tileDtos = webChessController.getTiles(); TeamDto teamDto = webChessController.getCurrentTeam(); - Map model = new HashMap<>(); model.put("tiles", tileDtos); model.put("currentTeam", teamDto); model.put("message", moveResultDto.getMessage()); model.put("style", moveResultDto.getStyle()); + if (webChessController.isEndGame()) { + return render(model, "end.html"); + } return render(model, "game.html"); }); post("/status", (req, res) -> { List tileDtos = webChessController.getTiles(); TeamDto teamDto = webChessController.getCurrentTeam(); - BoardScoreDto boardScoreDto = webChessController.getBoardScore(); - String message = teamDto.getTeamName() + "의 점수는 " + boardScoreDto.getBoardScore() + "입니다."; + String message = webChessController.getScores(); Map model = new HashMap<>(); model.put("tiles", tileDtos); diff --git a/src/main/java/chess/controller/ChessController.java b/src/main/java/chess/controller/ChessController.java index 0f29e42959b..c5124a28527 100644 --- a/src/main/java/chess/controller/ChessController.java +++ b/src/main/java/chess/controller/ChessController.java @@ -59,7 +59,7 @@ private static Command validateExecute(Command command, ChessRunner chessRunner) } return command; } - + private static Command executeByCommand(Command command, ChessRunner chessRunner) { String input = inputView.askGameCommand(); Optional inputCommand = Command.of(input); diff --git a/src/main/java/chess/controller/Command.java b/src/main/java/chess/controller/Command.java index 08053a80a3b..aa1d5abe7ba 100644 --- a/src/main/java/chess/controller/Command.java +++ b/src/main/java/chess/controller/Command.java @@ -18,7 +18,7 @@ public enum Command { this.command = command; this.gameController = gameController; } - + public static Optional of(final String command) { return Arrays.stream(values()) .filter(c -> command.contains(c.command)) diff --git a/src/main/java/chess/controller/WebChessController.java b/src/main/java/chess/controller/WebChessController.java index aad1af2e3d0..4dc7990ee6f 100644 --- a/src/main/java/chess/controller/WebChessController.java +++ b/src/main/java/chess/controller/WebChessController.java @@ -1,12 +1,12 @@ package chess.controller; -import chess.controller.dto.BoardScoreDto; import chess.controller.dto.MoveResultDto; import chess.controller.dto.TeamDto; import chess.controller.dto.TileDto; import chess.domain.ChessRunner; import java.util.List; +import java.util.stream.Collectors; public class WebChessController { private ChessRunner chessRunner; @@ -20,13 +20,13 @@ public MoveResultDto move(final String source, final String target) { this.chessRunner.update(source, target); String moveResult = moveResult(this.chessRunner, source, target); return new MoveResultDto(moveResult, "color:black;"); - } catch (IllegalArgumentException e) { + } catch (IllegalArgumentException | StringIndexOutOfBoundsException e) { return new MoveResultDto(e.getMessage(), "color:red;"); } } private String moveResult(final ChessRunner chessRunner, final String source, final String target) { - if (!chessRunner.isEndChess()) { + if (!this.isEndGame()) { return source + " -> " + target; } return chessRunner.getWinner() + " 가 이겼습니다."; @@ -40,7 +40,13 @@ public List getTiles() { return this.chessRunner.tileDtos(); } - public BoardScoreDto getBoardScore() { - return new BoardScoreDto(this.chessRunner.calculateScore()); + public String getScores() { + return this.chessRunner.calculateScores().stream() + .map(dto -> dto.getTeam() + ": " + dto.getBoardScore()) + .collect(Collectors.joining("\n")); + } + + public boolean isEndGame() { + return this.chessRunner.isEndChess(); } } diff --git a/src/main/java/chess/controller/dto/BoardScoreDto.java b/src/main/java/chess/controller/dto/BoardScoreDto.java index d7e457a2076..3d60af9239f 100644 --- a/src/main/java/chess/controller/dto/BoardScoreDto.java +++ b/src/main/java/chess/controller/dto/BoardScoreDto.java @@ -2,12 +2,21 @@ public class BoardScoreDto { private final double boardScore; + private String team; - public BoardScoreDto(double boardScore) { + public BoardScoreDto(final double boardScore) { this.boardScore = boardScore; } + public void setTeam(final String team) { + this.team = team; + } + public double getBoardScore() { return boardScore; } + + public String getTeam() { + return this.team; + } } diff --git a/src/main/java/chess/domain/ChessRunner.java b/src/main/java/chess/domain/ChessRunner.java index d013608911e..a1578fe1a38 100644 --- a/src/main/java/chess/domain/ChessRunner.java +++ b/src/main/java/chess/domain/ChessRunner.java @@ -1,5 +1,6 @@ package chess.domain; +import chess.controller.dto.BoardScoreDto; import chess.controller.dto.TileDto; import chess.domain.board.Board; import chess.domain.board.BoardScore; @@ -8,13 +9,10 @@ import chess.domain.piece.Team; import chess.domain.position.Position; import chess.domain.strategy.direction.Direction; +import org.apache.commons.lang3.StringUtils; -import java.util.Collections; -import java.util.List; -import java.util.Map; -import java.util.Optional; +import java.util.*; import java.util.stream.Collectors; -import org.apache.commons.lang3.StringUtils; public class ChessRunner { private Board board; @@ -99,8 +97,22 @@ private void changeTeam() { } public double calculateScore() { - BoardScore boardScore = this.board.calculateScore(this.currentTeam); - return boardScore.getBoardScore(); + BoardScore currentTeamScore = this.board.calculateScore(this.currentTeam); + return currentTeamScore.getBoardScore(); + } + + public List calculateScores() { + List scores = new ArrayList<>(); + BoardScoreDto currentTeam = new BoardScoreDto(calculateScore()); + currentTeam.setTeam(this.currentTeam.name()); + scores.add(currentTeam); + + BoardScore oppositeTeamScore = this.board.calculateScore(this.currentTeam.changeTeam()); + BoardScoreDto oppositeTeam = new BoardScoreDto(oppositeTeamScore.getBoardScore()); + oppositeTeam.setTeam(this.currentTeam.changeTeam().name()); + scores.add(oppositeTeam); + + return Collections.unmodifiableList(scores); } public boolean isEndChess() { diff --git a/src/main/java/chess/domain/piece/Piece.java b/src/main/java/chess/domain/piece/Piece.java index dc88798f3da..2565556e243 100644 --- a/src/main/java/chess/domain/piece/Piece.java +++ b/src/main/java/chess/domain/piece/Piece.java @@ -36,7 +36,7 @@ public String toSymbol() { public String teamName() { return this.team.name(); } - + public Team getTeam() { return this.team; } diff --git a/src/main/resources/templates/css/end.css b/src/main/resources/templates/css/end.css new file mode 100644 index 00000000000..2fef2cb16f8 --- /dev/null +++ b/src/main/resources/templates/css/end.css @@ -0,0 +1,24 @@ +@charset "utf-8"; + +@font-face { + font-family: "BMHANNAPro"; + src: url(../ttf/BMHANNAPro.ttf); +} + +h1 { + font-family: BMHANNAPro; +} + +#restart-button { + width: 80px; + height: 50px; + font-family: BMHANNAPro; + border: solid 1px; + border-radius: 5px; + font-size: 20px; +} + +#restart-button:hover { + background-color: black; + color: white; +} \ No newline at end of file diff --git a/src/main/resources/templates/css/game.css b/src/main/resources/templates/css/game.css index 5d424cc8f95..c46f3980ccb 100644 --- a/src/main/resources/templates/css/game.css +++ b/src/main/resources/templates/css/game.css @@ -75,7 +75,7 @@ img { #message { width: 500px; - height: 40px; + height: 100px; resize: none; font-family: BMHANNAPro; font-size: 30px; diff --git a/src/main/resources/templates/end.html b/src/main/resources/templates/end.html new file mode 100644 index 00000000000..2718198851c --- /dev/null +++ b/src/main/resources/templates/end.html @@ -0,0 +1,17 @@ + + + + + 체스 + + + + +
    +

    {{message}}

    +
    +
    + +
    + + diff --git a/src/test/java/chess/domain/ChessRunnerTest.java b/src/test/java/chess/domain/ChessRunnerTest.java index 3c3772afd81..4f36859e50e 100644 --- a/src/test/java/chess/domain/ChessRunnerTest.java +++ b/src/test/java/chess/domain/ChessRunnerTest.java @@ -72,14 +72,6 @@ void isEndChessTest() { } - @DisplayName("게임이 종료되지 않았을 때 승자를 출력 시 예외 출력") - @Test - void getWinnerTest() { - assertThatThrownBy(() -> { - chessRunner.getWinner(); - }).isInstanceOf(AssertionError.class); - } - @Test void tileDtosTest() { List tileDtos = chessRunner.tileDtos(); From 80f682138db6d937aee0405f87eeca0f55839fc0 Mon Sep 17 00:00:00 2001 From: giantim Date: Sun, 5 Apr 2020 14:49:38 +0900 Subject: [PATCH 39/75] =?UTF-8?q?refactor:=20=EC=BD=98=EC=86=94=EC=97=90?= =?UTF-8?q?=EC=84=9C=20status=20=EB=AA=85=EB=A0=B9=20=EC=9E=85=EB=A0=A5=20?= =?UTF-8?q?=EC=8B=9C=20=EC=96=91=20=ED=8C=80=EC=9D=98=20=EC=A0=90=EC=88=98?= =?UTF-8?q?=20=EB=AA=A8=EB=91=90=20=EA=B3=84=EC=82=B0=ED=95=B4=20=EC=B6=9C?= =?UTF-8?q?=EB=A0=A5=20/=20=EC=BB=A8=EB=B2=A4=EC=85=98=20=EC=88=98?= =?UTF-8?q?=EC=A0=95=20/=20=EC=83=81=EC=88=98=20=EC=B6=94=EC=B6=9C?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../java/chess/WebUIChessApplication.java | 8 +++--- .../chess/controller/StatusController.java | 16 ++++++++--- .../chess/controller/WebChessController.java | 27 ++++++++++++------- .../java/chess/controller/dto/TileDto.java | 21 ++++++++++----- src/main/java/chess/domain/ChessRunner.java | 18 ++++++++----- .../java/chess/view/ConsoleOutputView.java | 4 +-- src/main/java/chess/view/OutputView.java | 2 +- src/main/resources/templates/game.html | 2 +- 8 files changed, 62 insertions(+), 36 deletions(-) diff --git a/src/main/java/chess/WebUIChessApplication.java b/src/main/java/chess/WebUIChessApplication.java index 2f760d2362a..de1c347edca 100644 --- a/src/main/java/chess/WebUIChessApplication.java +++ b/src/main/java/chess/WebUIChessApplication.java @@ -15,7 +15,6 @@ public class WebUIChessApplication { public static void main(String[] args) { - staticFiles.location("/templates"); WebChessController webChessController = new WebChessController(); @@ -25,11 +24,12 @@ public static void main(String[] args) { }); post("/game", (req, res) -> { + Map model = new HashMap<>(); + webChessController.start(); List tileDtos = webChessController.getTiles(); TeamDto teamDto = webChessController.getCurrentTeam(); - Map model = new HashMap<>(); model.put("tiles", tileDtos); model.put("currentTeam", teamDto); @@ -58,11 +58,12 @@ public static void main(String[] args) { }); post("/status", (req, res) -> { + Map model = new HashMap<>(); + List tileDtos = webChessController.getTiles(); TeamDto teamDto = webChessController.getCurrentTeam(); String message = webChessController.getScores(); - Map model = new HashMap<>(); model.put("tiles", tileDtos); model.put("currentTeam", teamDto); model.put("message", message); @@ -72,7 +73,6 @@ public static void main(String[] args) { post("/end", (req, res) -> { Map model = new HashMap<>(); - return render(model, "index.html"); }); } diff --git a/src/main/java/chess/controller/StatusController.java b/src/main/java/chess/controller/StatusController.java index 1b950eccbc9..010797003d2 100644 --- a/src/main/java/chess/controller/StatusController.java +++ b/src/main/java/chess/controller/StatusController.java @@ -1,19 +1,27 @@ package chess.controller; import chess.controller.dto.BoardScoreDto; -import chess.controller.dto.TeamDto; import chess.domain.ChessRunner; +import java.util.List; +import java.util.stream.Collectors; + public class StatusController extends GameController { + private static final String DELIMITER = ": "; + private static final String NEW_LINE = "\n"; + public StatusController() { super(); } @Override public void execute(ChessRunner chessRunner, String input) { - BoardScoreDto boardScoreDto = new BoardScoreDto(chessRunner.calculateScore()); - TeamDto teamDto = new TeamDto(chessRunner.getCurrentTeam()); - outputView.printStatus(boardScoreDto.getBoardScore(), teamDto.getTeamName()); + List boardScoreDtos = chessRunner.calculateScores(); + String scores = boardScoreDtos.stream() + .map(dto -> dto.getTeam() + DELIMITER + dto.getBoardScore()) + .collect(Collectors.joining(NEW_LINE)); + + outputView.printStatus(scores); printBoard(chessRunner.getBoardEntities()); } } diff --git a/src/main/java/chess/controller/WebChessController.java b/src/main/java/chess/controller/WebChessController.java index 4dc7990ee6f..a57d6c2c5a9 100644 --- a/src/main/java/chess/controller/WebChessController.java +++ b/src/main/java/chess/controller/WebChessController.java @@ -9,6 +9,13 @@ import java.util.stream.Collectors; public class WebChessController { + private static final String MESSAGE_STYLE_BLACK = "color:black;"; + private static final String MESSAGE_STYLE_RED = "color:red;"; + private static final String DELIMITER = ": "; + private static final String NEW_LINE = "\n"; + private static final String ARROW = " -> "; + private static final String WINNER = " 가 이겼습니다."; + private ChessRunner chessRunner; public void start() { @@ -19,17 +26,21 @@ public MoveResultDto move(final String source, final String target) { try { this.chessRunner.update(source, target); String moveResult = moveResult(this.chessRunner, source, target); - return new MoveResultDto(moveResult, "color:black;"); + return new MoveResultDto(moveResult, MESSAGE_STYLE_BLACK); } catch (IllegalArgumentException | StringIndexOutOfBoundsException e) { - return new MoveResultDto(e.getMessage(), "color:red;"); + return new MoveResultDto(e.getMessage(), MESSAGE_STYLE_RED); } } private String moveResult(final ChessRunner chessRunner, final String source, final String target) { if (!this.isEndGame()) { - return source + " -> " + target; + return source + ARROW + target; } - return chessRunner.getWinner() + " 가 이겼습니다."; + return chessRunner.getWinner() + WINNER; + } + + public boolean isEndGame() { + return this.chessRunner.isEndChess(); } public TeamDto getCurrentTeam() { @@ -42,11 +53,7 @@ public List getTiles() { public String getScores() { return this.chessRunner.calculateScores().stream() - .map(dto -> dto.getTeam() + ": " + dto.getBoardScore()) - .collect(Collectors.joining("\n")); - } - - public boolean isEndGame() { - return this.chessRunner.isEndChess(); + .map(dto -> dto.getTeam() + DELIMITER + dto.getBoardScore()) + .collect(Collectors.joining(NEW_LINE)); } } diff --git a/src/main/java/chess/controller/dto/TileDto.java b/src/main/java/chess/controller/dto/TileDto.java index 119569a0fe9..da3ff3791e7 100644 --- a/src/main/java/chess/controller/dto/TileDto.java +++ b/src/main/java/chess/controller/dto/TileDto.java @@ -1,29 +1,36 @@ package chess.controller.dto; public class TileDto { + private static final String WHITE = "white"; + private static final String BLACK = "black"; + private final String position; private String pieceImageUrl; - private String team; + private String style; public TileDto(final String position) { this.position = position; this.pieceImageUrl = ""; } - public void setPieceImageUrl(String pieceImageUrl) { - this.pieceImageUrl = pieceImageUrl; + public void setStyle(int index) { + if (index % 2 == 0) { + this.style = WHITE; + return; + } + this.style = BLACK; } - public void setTeam(String team) { - this.team = team; + public void setPieceImageUrl(String pieceImageUrl) { + this.pieceImageUrl = pieceImageUrl; } public String getPosition() { return position; } - public String getTeam() { - return this.team; + public String getStyle() { + return this.style; } public String getPieceImageUrl() { diff --git a/src/main/java/chess/domain/ChessRunner.java b/src/main/java/chess/domain/ChessRunner.java index a1578fe1a38..7e00c5ce694 100644 --- a/src/main/java/chess/domain/ChessRunner.java +++ b/src/main/java/chess/domain/ChessRunner.java @@ -137,15 +137,21 @@ public List tileDtos() { .map(TileDto::new) .collect(Collectors.toList()); + setTileDtoTeam(tileDtos); + setTileDtoImage(tileDtos); + + return Collections.unmodifiableList(tileDtos); + } + + private void setTileDtoTeam(List tileDtos) { List indexes = Position.getPositionsIndex(); for (int i = 0; i < indexes.size(); i++) { - if (indexes.get(i) % 2 == 0) { - tileDtos.get(i).setTeam("white"); - } else { - tileDtos.get(i).setTeam("black"); - } + TileDto tileDto = tileDtos.get(i); + tileDto.setStyle(indexes.get(i)); } + } + private void setTileDtoImage(List tileDtos) { List tiles = this.board.tiles(); for (Tile tile : tiles) { TileDto tileDto = tileDtos.stream() @@ -154,7 +160,5 @@ public List tileDtos() { .orElseThrow(IllegalArgumentException::new); tileDto.setPieceImageUrl(tile.pieceImageUrl()); } - - return Collections.unmodifiableList(tileDtos); } } diff --git a/src/main/java/chess/view/ConsoleOutputView.java b/src/main/java/chess/view/ConsoleOutputView.java index a34e4153e51..1468d1646ea 100644 --- a/src/main/java/chess/view/ConsoleOutputView.java +++ b/src/main/java/chess/view/ConsoleOutputView.java @@ -39,8 +39,8 @@ private String printPiece(String piece) { } @Override - public void printStatus(double calculateScore, String teamName) { - System.out.println(String.format("%s 팀의 점수는 %.1f 점입니다.", teamName, calculateScore)); + public void printStatus(String scores) { + System.out.println(scores); } @Override diff --git a/src/main/java/chess/view/OutputView.java b/src/main/java/chess/view/OutputView.java index 29016029f8e..6bc63fb1c4d 100644 --- a/src/main/java/chess/view/OutputView.java +++ b/src/main/java/chess/view/OutputView.java @@ -6,7 +6,7 @@ public interface OutputView { void printBoard(List positions, Map board); - void printStatus(double calculateScore, String teamName); + void printStatus(String scores); void printWinner(String teamName); diff --git a/src/main/resources/templates/game.html b/src/main/resources/templates/game.html index 3f7621d20d8..877b614d861 100644 --- a/src/main/resources/templates/game.html +++ b/src/main/resources/templates/game.html @@ -9,7 +9,7 @@
    {{#tiles}} -
    +
    {{#if pieceImageUrl}} {{/if}} From fec5fe5c160082097c603c38f3d144c44291c3e5 Mon Sep 17 00:00:00 2001 From: giantim Date: Sun, 5 Apr 2020 19:43:52 +0900 Subject: [PATCH 40/75] =?UTF-8?q?feat:=20ChessBoard=20=EC=B6=94=EA=B0=80?= =?UTF-8?q?=20=ED=85=8C=EC=8A=A4=ED=8A=B8?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- build.gradle | 1 + .../java/chess/controller/dao/ChessBoard.java | 28 ++++++++++ .../chess/controller/dao/ChessBoardDAO.java | 55 +++++++++++++++++++ .../controller/dao/ChessBoardDAOTest.java | 30 ++++++++++ 4 files changed, 114 insertions(+) create mode 100644 src/main/java/chess/controller/dao/ChessBoard.java create mode 100644 src/main/java/chess/controller/dao/ChessBoardDAO.java create mode 100644 src/test/java/chess/controller/dao/ChessBoardDAOTest.java diff --git a/build.gradle b/build.gradle index 163d9013778..72d3b126566 100644 --- a/build.gradle +++ b/build.gradle @@ -14,6 +14,7 @@ dependencies { compile('ch.qos.logback:logback-classic:1.2.3') testCompile('org.junit.jupiter:junit-jupiter:5.6.0') testCompile('org.assertj:assertj-core:3.15.0') + compile("mysql:mysql-connector-java:8.0.16") } test { diff --git a/src/main/java/chess/controller/dao/ChessBoard.java b/src/main/java/chess/controller/dao/ChessBoard.java new file mode 100644 index 00000000000..82baaf1e752 --- /dev/null +++ b/src/main/java/chess/controller/dao/ChessBoard.java @@ -0,0 +1,28 @@ +package chess.controller.dao; + +import java.util.Objects; + +public class ChessBoard { + private int chessBoardId; + + public ChessBoard(int chessBoardId) { + this.chessBoardId = chessBoardId; + } + + public int getChessBoardId() { + return chessBoardId; + } + + @Override + public boolean equals(Object o) { + if (this == o) return true; + if (o == null || getClass() != o.getClass()) return false; + ChessBoard user = (ChessBoard) o; + return Objects.equals(chessBoardId, user.chessBoardId); + } + + @Override + public int hashCode() { + return Objects.hash(chessBoardId); + } +} diff --git a/src/main/java/chess/controller/dao/ChessBoardDAO.java b/src/main/java/chess/controller/dao/ChessBoardDAO.java new file mode 100644 index 00000000000..846c1116a51 --- /dev/null +++ b/src/main/java/chess/controller/dao/ChessBoardDAO.java @@ -0,0 +1,55 @@ +package chess.controller.dao; + +import java.sql.Connection; +import java.sql.DriverManager; +import java.sql.PreparedStatement; +import java.sql.SQLException; + +public class ChessBoardDAO { + public Connection getConnection() { + Connection con = null; + String server = "localhost:13306"; // MySQL 서버 주소 + String database = "chess"; // MySQL DATABASE 이름 + String option = "?useSSL=false&serverTimezone=UTC"; + String userName = "root"; // MySQL 서버 아이디 + String password = "root"; // MySQL 서버 비밀번호 + + // 드라이버 로딩 + try { + Class.forName("com.mysql.cj.jdbc.Driver"); + } catch (ClassNotFoundException e) { + System.err.println(" !! JDBC Driver load 오류: " + e.getMessage()); + e.printStackTrace(); + } + + // 드라이버 연결 + try { + con = DriverManager.getConnection("jdbc:mysql://" + server + "/" + database + option, + userName, password); + System.out.println("정상적으로 연결되었습니다."); + } catch (SQLException e) { + System.err.println("연결 오류:" + e.getMessage()); + e.printStackTrace(); + } + + return con; + } + + // 드라이버 연결해제 + public void closeConnection(Connection con) { + try { + if (con != null) + con.close(); + } catch (SQLException e) { + System.err.println("con 오류:" + e.getMessage()); + } + } + + public void addChessBoard() throws SQLException { + String query = "INSERT INTO chessBoard VALUES()"; + Connection con = getConnection(); + PreparedStatement pstmt = con.prepareStatement(query); + pstmt.executeUpdate(); + closeConnection(con); + } +} diff --git a/src/test/java/chess/controller/dao/ChessBoardDAOTest.java b/src/test/java/chess/controller/dao/ChessBoardDAOTest.java new file mode 100644 index 00000000000..156c4cea85e --- /dev/null +++ b/src/test/java/chess/controller/dao/ChessBoardDAOTest.java @@ -0,0 +1,30 @@ +package chess.controller.dao; + +import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; + +import java.sql.Connection; + +public class ChessBoardDAOTest { + private ChessBoardDAO chessBoardDAO; + + @BeforeEach + private void setUp() { + chessBoardDAO = new ChessBoardDAO(); + } + + @DisplayName("데이터베이스 연결 테스트") + @Test + void connectionTest() { + Connection con = chessBoardDAO.getConnection(); + Assertions.assertThat(con).isNotNull(); + } + + @DisplayName("체스 보드 추가 테스트") + @Test + void addChessBoardTest() throws Exception { + chessBoardDAO.addChessBoard(); + } +} From 130853ca61dd22f727d8adf335511f19dcd7f914 Mon Sep 17 00:00:00 2001 From: giantim Date: Sun, 5 Apr 2020 19:54:19 +0900 Subject: [PATCH 41/75] =?UTF-8?q?feat:=20=EA=B0=80=EC=9E=A5=20=EC=B5=9C?= =?UTF-8?q?=EA=B7=BC=EC=97=90=20=EC=B6=94=EA=B0=80=EB=90=9C=20ChessBoard?= =?UTF-8?q?=20=EC=B0=BE=EB=8A=94=20=EA=B8=B0=EB=8A=A5=20=EC=B6=94=EA=B0=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../java/chess/controller/dao/ChessBoardDAO.java | 16 ++++++++++++---- .../chess/controller/dao/ChessBoardDAOTest.java | 9 +++++++++ 2 files changed, 21 insertions(+), 4 deletions(-) diff --git a/src/main/java/chess/controller/dao/ChessBoardDAO.java b/src/main/java/chess/controller/dao/ChessBoardDAO.java index 846c1116a51..f46b7306292 100644 --- a/src/main/java/chess/controller/dao/ChessBoardDAO.java +++ b/src/main/java/chess/controller/dao/ChessBoardDAO.java @@ -1,9 +1,6 @@ package chess.controller.dao; -import java.sql.Connection; -import java.sql.DriverManager; -import java.sql.PreparedStatement; -import java.sql.SQLException; +import java.sql.*; public class ChessBoardDAO { public Connection getConnection() { @@ -52,4 +49,15 @@ public void addChessBoard() throws SQLException { pstmt.executeUpdate(); closeConnection(con); } + + public ChessBoard findRecentChessBoard() throws SQLException{ + String query = "SELECT * FROM chessBoard ORDER BY chessBoardId DESC limit 1"; + Connection con = getConnection(); + PreparedStatement pstmt = con.prepareStatement(query); + ResultSet rs = pstmt.executeQuery(); + + if (!rs.next()) return null; + + return new ChessBoard(rs.getInt("chessBoardId")); + } } diff --git a/src/test/java/chess/controller/dao/ChessBoardDAOTest.java b/src/test/java/chess/controller/dao/ChessBoardDAOTest.java index 156c4cea85e..8c3cb74f113 100644 --- a/src/test/java/chess/controller/dao/ChessBoardDAOTest.java +++ b/src/test/java/chess/controller/dao/ChessBoardDAOTest.java @@ -27,4 +27,13 @@ void connectionTest() { void addChessBoardTest() throws Exception { chessBoardDAO.addChessBoard(); } + + @DisplayName("가장 최근에 추가된 체스 보드 찾기") + @Test + void findRecentChessBoardTest() throws Exception { + ChessBoard chessBoard = chessBoardDAO.findRecentChessBoard(); + + Assertions.assertThat(chessBoard).isNotNull(); + Assertions.assertThat(chessBoard).isInstanceOf(ChessBoard.class); + } } From d435afaae995a8409babb27b8147b57c1b3a41f7 Mon Sep 17 00:00:00 2001 From: giantim Date: Sun, 5 Apr 2020 21:19:06 +0900 Subject: [PATCH 42/75] =?UTF-8?q?feat:=20=EA=B0=80=EC=9E=A5=20=EC=B5=9C?= =?UTF-8?q?=EA=B7=BC=EC=97=90=20=EC=B6=94=EA=B0=80=20=EB=90=9C=20ChessBoar?= =?UTF-8?q?d=20=EC=82=AD=EC=A0=9C=20=EA=B8=B0=EB=8A=A5=20=EA=B5=AC?= =?UTF-8?q?=ED=98=84?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../chess/controller/dao/ChessBoardDAO.java | 24 ++++++++++++++++--- .../controller/dao/ChessBoardDAOTest.java | 14 +++++++++++ 2 files changed, 35 insertions(+), 3 deletions(-) diff --git a/src/main/java/chess/controller/dao/ChessBoardDAO.java b/src/main/java/chess/controller/dao/ChessBoardDAO.java index f46b7306292..96b1112daf1 100644 --- a/src/main/java/chess/controller/dao/ChessBoardDAO.java +++ b/src/main/java/chess/controller/dao/ChessBoardDAO.java @@ -50,14 +50,32 @@ public void addChessBoard() throws SQLException { closeConnection(con); } - public ChessBoard findRecentChessBoard() throws SQLException{ + public ChessBoard findRecentChessBoard() throws SQLException { String query = "SELECT * FROM chessBoard ORDER BY chessBoardId DESC limit 1"; Connection con = getConnection(); PreparedStatement pstmt = con.prepareStatement(query); ResultSet rs = pstmt.executeQuery(); - if (!rs.next()) return null; + if (!rs.next()) { + closeConnection(con); + return null; + } + + ChessBoard chessBoard = new ChessBoard(rs.getInt("chessBoardId")); + closeConnection(con); + return chessBoard; + } + + public void deleteChessBoard(ChessBoard chessBoard) throws SQLException { + if (chessBoard == null) { + return; + } - return new ChessBoard(rs.getInt("chessBoardId")); + String query = "DELETE FROM chessBoard WHERE chessBoardId = ?"; + Connection con = getConnection(); + PreparedStatement pstmt = con.prepareStatement(query); + pstmt.setInt(1, chessBoard.getChessBoardId()); + pstmt.executeUpdate(); + closeConnection(con); } } diff --git a/src/test/java/chess/controller/dao/ChessBoardDAOTest.java b/src/test/java/chess/controller/dao/ChessBoardDAOTest.java index 8c3cb74f113..a70aeec9f9f 100644 --- a/src/test/java/chess/controller/dao/ChessBoardDAOTest.java +++ b/src/test/java/chess/controller/dao/ChessBoardDAOTest.java @@ -2,6 +2,7 @@ import org.assertj.core.api.Assertions; import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.Disabled; import org.junit.jupiter.api.DisplayName; import org.junit.jupiter.api.Test; @@ -10,11 +11,13 @@ public class ChessBoardDAOTest { private ChessBoardDAO chessBoardDAO; + @Disabled @BeforeEach private void setUp() { chessBoardDAO = new ChessBoardDAO(); } + @Disabled @DisplayName("데이터베이스 연결 테스트") @Test void connectionTest() { @@ -22,18 +25,29 @@ void connectionTest() { Assertions.assertThat(con).isNotNull(); } + @Disabled @DisplayName("체스 보드 추가 테스트") @Test void addChessBoardTest() throws Exception { chessBoardDAO.addChessBoard(); } + @Disabled @DisplayName("가장 최근에 추가된 체스 보드 찾기") @Test void findRecentChessBoardTest() throws Exception { + chessBoardDAO.addChessBoard(); ChessBoard chessBoard = chessBoardDAO.findRecentChessBoard(); Assertions.assertThat(chessBoard).isNotNull(); Assertions.assertThat(chessBoard).isInstanceOf(ChessBoard.class); } + + @Disabled + @DisplayName("체스 보드 삭제") + @Test + void deleteChessBoardTest() throws Exception { + ChessBoard chessBoard = chessBoardDAO.findRecentChessBoard(); + chessBoardDAO.deleteChessBoard(chessBoard); + } } From 254c5ed400a3cbd6d24b57b5b148410594c7bf79 Mon Sep 17 00:00:00 2001 From: giantim Date: Sun, 5 Apr 2020 22:53:39 +0900 Subject: [PATCH 43/75] =?UTF-8?q?feat:=20=ED=94=BC=EC=8A=A4=20=EC=A0=95?= =?UTF-8?q?=EB=B3=B4=20=EC=B6=94=EA=B0=80,=20=EC=97=85=EB=8D=B0=EC=9D=B4?= =?UTF-8?q?=ED=8A=B8,=20=EC=82=AD=EC=A0=9C=20=EA=B5=AC=ED=98=84?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../java/chess/controller/dao/ChessBoard.java | 12 ++-- .../chess/controller/dao/ChessBoardDAO.java | 58 ++++--------------- .../controller/dao/ConnectionManager.java | 46 +++++++++++++++ .../java/chess/controller/dao/PieceDAO.java | 49 ++++++++++++++++ .../chess/controller/dao/PieceOnBoard.java | 53 +++++++++++++++++ .../controller/dao/ChessBoardDAOTest.java | 11 ---- .../controller/dao/ConnectionManagerTest.java | 16 +++++ .../chess/controller/dao/PieceDAOTest.java | 57 ++++++++++++++++++ 8 files changed, 240 insertions(+), 62 deletions(-) create mode 100644 src/main/java/chess/controller/dao/ConnectionManager.java create mode 100644 src/main/java/chess/controller/dao/PieceDAO.java create mode 100644 src/main/java/chess/controller/dao/PieceOnBoard.java create mode 100644 src/test/java/chess/controller/dao/ConnectionManagerTest.java create mode 100644 src/test/java/chess/controller/dao/PieceDAOTest.java diff --git a/src/main/java/chess/controller/dao/ChessBoard.java b/src/main/java/chess/controller/dao/ChessBoard.java index 82baaf1e752..bc30989d8b8 100644 --- a/src/main/java/chess/controller/dao/ChessBoard.java +++ b/src/main/java/chess/controller/dao/ChessBoard.java @@ -15,10 +15,14 @@ public int getChessBoardId() { @Override public boolean equals(Object o) { - if (this == o) return true; - if (o == null || getClass() != o.getClass()) return false; - ChessBoard user = (ChessBoard) o; - return Objects.equals(chessBoardId, user.chessBoardId); + if (this == o) { + return true; + } + if (o == null || getClass() != o.getClass()) { + return false; + } + ChessBoard chessBoard = (ChessBoard) o; + return Objects.equals(chessBoardId, chessBoard.chessBoardId); } @Override diff --git a/src/main/java/chess/controller/dao/ChessBoardDAO.java b/src/main/java/chess/controller/dao/ChessBoardDAO.java index 96b1112daf1..4267a23cd7c 100644 --- a/src/main/java/chess/controller/dao/ChessBoardDAO.java +++ b/src/main/java/chess/controller/dao/ChessBoardDAO.java @@ -1,68 +1,32 @@ package chess.controller.dao; -import java.sql.*; +import java.sql.Connection; +import java.sql.PreparedStatement; +import java.sql.ResultSet; +import java.sql.SQLException; public class ChessBoardDAO { - public Connection getConnection() { - Connection con = null; - String server = "localhost:13306"; // MySQL 서버 주소 - String database = "chess"; // MySQL DATABASE 이름 - String option = "?useSSL=false&serverTimezone=UTC"; - String userName = "root"; // MySQL 서버 아이디 - String password = "root"; // MySQL 서버 비밀번호 - - // 드라이버 로딩 - try { - Class.forName("com.mysql.cj.jdbc.Driver"); - } catch (ClassNotFoundException e) { - System.err.println(" !! JDBC Driver load 오류: " + e.getMessage()); - e.printStackTrace(); - } - - // 드라이버 연결 - try { - con = DriverManager.getConnection("jdbc:mysql://" + server + "/" + database + option, - userName, password); - System.out.println("정상적으로 연결되었습니다."); - } catch (SQLException e) { - System.err.println("연결 오류:" + e.getMessage()); - e.printStackTrace(); - } - - return con; - } - - // 드라이버 연결해제 - public void closeConnection(Connection con) { - try { - if (con != null) - con.close(); - } catch (SQLException e) { - System.err.println("con 오류:" + e.getMessage()); - } - } - public void addChessBoard() throws SQLException { String query = "INSERT INTO chessBoard VALUES()"; - Connection con = getConnection(); + Connection con = ConnectionManager.getConnection(); PreparedStatement pstmt = con.prepareStatement(query); pstmt.executeUpdate(); - closeConnection(con); + ConnectionManager.closeConnection(con); } public ChessBoard findRecentChessBoard() throws SQLException { String query = "SELECT * FROM chessBoard ORDER BY chessBoardId DESC limit 1"; - Connection con = getConnection(); + Connection con = ConnectionManager.getConnection(); PreparedStatement pstmt = con.prepareStatement(query); ResultSet rs = pstmt.executeQuery(); if (!rs.next()) { - closeConnection(con); + ConnectionManager.closeConnection(con); return null; } ChessBoard chessBoard = new ChessBoard(rs.getInt("chessBoardId")); - closeConnection(con); + ConnectionManager.closeConnection(con); return chessBoard; } @@ -72,10 +36,10 @@ public void deleteChessBoard(ChessBoard chessBoard) throws SQLException { } String query = "DELETE FROM chessBoard WHERE chessBoardId = ?"; - Connection con = getConnection(); + Connection con = ConnectionManager.getConnection(); PreparedStatement pstmt = con.prepareStatement(query); pstmt.setInt(1, chessBoard.getChessBoardId()); pstmt.executeUpdate(); - closeConnection(con); + ConnectionManager.closeConnection(con); } } diff --git a/src/main/java/chess/controller/dao/ConnectionManager.java b/src/main/java/chess/controller/dao/ConnectionManager.java new file mode 100644 index 00000000000..5c950dbc617 --- /dev/null +++ b/src/main/java/chess/controller/dao/ConnectionManager.java @@ -0,0 +1,46 @@ +package chess.controller.dao; + +import java.sql.Connection; +import java.sql.DriverManager; +import java.sql.SQLException; + +public class ConnectionManager { + private ConnectionManager() { + } + + public static Connection getConnection() { + Connection con = null; + String server = "localhost:13306"; + String database = "chess"; + String option = "?useSSL=false&serverTimezone=UTC"; + String userName = "root"; + String password = "root"; + + try { + Class.forName("com.mysql.cj.jdbc.Driver"); + } catch (ClassNotFoundException e) { + System.err.println(" !! JDBC Driver load 오류: " + e.getMessage()); + e.printStackTrace(); + } + + try { + con = DriverManager.getConnection("jdbc:mysql://" + server + "/" + database + option, + userName, password); + System.out.println("정상적으로 연결되었습니다."); + } catch (SQLException e) { + System.err.println("연결 오류:" + e.getMessage()); + e.printStackTrace(); + } + + return con; + } + + public static void closeConnection(Connection con) { + try { + if (con != null) + con.close(); + } catch (SQLException e) { + System.err.println("con 오류:" + e.getMessage()); + } + } +} diff --git a/src/main/java/chess/controller/dao/PieceDAO.java b/src/main/java/chess/controller/dao/PieceDAO.java new file mode 100644 index 00000000000..4c43e2392b9 --- /dev/null +++ b/src/main/java/chess/controller/dao/PieceDAO.java @@ -0,0 +1,49 @@ +package chess.controller.dao; + +import chess.controller.dto.TileDto; + +import java.sql.Connection; +import java.sql.PreparedStatement; +import java.sql.SQLException; +import java.util.List; + +public class PieceDAO { + public void addPiece(int chessBoardId, List tileDtos) throws SQLException { + Connection con = ConnectionManager.getConnection(); + for (TileDto tileDto : tileDtos) { + String query = "INSERT INTO piece (position, pieceImageUrl, chessBoardId) " + + "VALUES(?, ?, ?)"; + PreparedStatement pstmt = con.prepareStatement(query); + pstmt.setString(1, tileDto.getPosition()); + pstmt.setString(2, tileDto.getPieceImageUrl()); + pstmt.setInt(3, chessBoardId); + pstmt.executeUpdate(); + } + ConnectionManager.closeConnection(con); + } + + public void updatePiece(List pieces) throws SQLException { + Connection con = ConnectionManager.getConnection(); + for (PieceOnBoard pieceOnBoard : pieces) { + String query = "UPDATE piece SET position = ? WHERE pieceId = ?"; + PreparedStatement pstmt = con.prepareStatement(query); + pstmt.setString(1, pieceOnBoard.getPosition()); + pstmt.setInt(2, pieceOnBoard.getPieceId()); + pstmt.executeUpdate(); + } + ConnectionManager.closeConnection(con); + } + + public void deletePiece(PieceOnBoard a2WhitePawn) throws SQLException { + if (a2WhitePawn == null) { + return; + } + + Connection con = ConnectionManager.getConnection(); + String query = "DELETE FROM piece WHERE pieceId = ?"; + PreparedStatement pstmt = con.prepareStatement(query); + pstmt.setInt(1, a2WhitePawn.getPieceId()); + pstmt.executeUpdate(); + ConnectionManager.closeConnection(con); + } +} diff --git a/src/main/java/chess/controller/dao/PieceOnBoard.java b/src/main/java/chess/controller/dao/PieceOnBoard.java new file mode 100644 index 00000000000..aa435866352 --- /dev/null +++ b/src/main/java/chess/controller/dao/PieceOnBoard.java @@ -0,0 +1,53 @@ +package chess.controller.dao; + +import java.util.Objects; + +public class PieceOnBoard { + private int pieceId; + private String position; + private String pieceImageUrl; + private int chessBoardId; + + public PieceOnBoard(int pieceId, String position, String pieceImageUrl, int chessBoardId) { + this.pieceId = pieceId; + this.position = position; + this.pieceImageUrl = pieceImageUrl; + this.chessBoardId = chessBoardId; + } + + public int getPieceId() { + return pieceId; + } + + public String getPosition() { + return position; + } + + public String getPieceImageUrl() { + return this.pieceImageUrl; + } + + public int getChessBoardId() { + return chessBoardId; + } + + @Override + public boolean equals(Object o) { + if (this == o) { + return true; + } + if (o == null || getClass() != o.getClass()) { + return false; + } + PieceOnBoard pieceOnBoard = (PieceOnBoard) o; + return Objects.equals(pieceId, pieceOnBoard.pieceId) + && Objects.equals(position, pieceOnBoard.position) + && Objects.equals(pieceImageUrl, pieceOnBoard.pieceImageUrl) + && Objects.equals(chessBoardId, pieceOnBoard.chessBoardId); + } + + @Override + public int hashCode() { + return Objects.hash(pieceId, position, pieceImageUrl, chessBoardId); + } +} diff --git a/src/test/java/chess/controller/dao/ChessBoardDAOTest.java b/src/test/java/chess/controller/dao/ChessBoardDAOTest.java index a70aeec9f9f..63ada2996ad 100644 --- a/src/test/java/chess/controller/dao/ChessBoardDAOTest.java +++ b/src/test/java/chess/controller/dao/ChessBoardDAOTest.java @@ -6,25 +6,14 @@ import org.junit.jupiter.api.DisplayName; import org.junit.jupiter.api.Test; -import java.sql.Connection; - public class ChessBoardDAOTest { private ChessBoardDAO chessBoardDAO; - @Disabled @BeforeEach private void setUp() { chessBoardDAO = new ChessBoardDAO(); } - @Disabled - @DisplayName("데이터베이스 연결 테스트") - @Test - void connectionTest() { - Connection con = chessBoardDAO.getConnection(); - Assertions.assertThat(con).isNotNull(); - } - @Disabled @DisplayName("체스 보드 추가 테스트") @Test diff --git a/src/test/java/chess/controller/dao/ConnectionManagerTest.java b/src/test/java/chess/controller/dao/ConnectionManagerTest.java new file mode 100644 index 00000000000..a23de70b49d --- /dev/null +++ b/src/test/java/chess/controller/dao/ConnectionManagerTest.java @@ -0,0 +1,16 @@ +package chess.controller.dao; + +import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; + +import java.sql.Connection; + +public class ConnectionManagerTest { + @DisplayName("데이터베이스 연결 테스트") + @Test + void connectionTest() { + Connection con = ConnectionManager.getConnection(); + Assertions.assertThat(con).isNotNull(); + } +} diff --git a/src/test/java/chess/controller/dao/PieceDAOTest.java b/src/test/java/chess/controller/dao/PieceDAOTest.java new file mode 100644 index 00000000000..be676fbdf51 --- /dev/null +++ b/src/test/java/chess/controller/dao/PieceDAOTest.java @@ -0,0 +1,57 @@ +package chess.controller.dao; + +import chess.controller.dto.TileDto; +import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.Disabled; +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; + +import java.util.ArrayList; +import java.util.Arrays; +import java.util.List; + +public class PieceDAOTest { + private PieceDAO pieceDAO; + + @BeforeEach + private void setUp() { + pieceDAO = new PieceDAO(); + } + + @Disabled + @DisplayName("피스 정보 추가") + @Test + void addPieceTest() throws Exception { + TileDto a2WhitePawn = new TileDto("ATWO"); + a2WhitePawn.setPieceImageUrl("p_white"); + TileDto a6BlackPawn = new TileDto("ASIX"); + a6BlackPawn.setPieceImageUrl("P_black"); + List tileDtos = new ArrayList<>(Arrays.asList( + a2WhitePawn, a6BlackPawn + )); + + pieceDAO.addPiece(1, tileDtos); + } + + @Disabled + @DisplayName("피스 정보 업데이트") + @Test + void updatePieceTest() throws Exception { + PieceOnBoard a2WhitePawn = new PieceOnBoard(4, "ATHREE", "p_white", 1); + PieceOnBoard a6BlackPawn = new PieceOnBoard(5, "ASIX", "P_black", 1); + List pieces = new ArrayList<>(Arrays.asList( + a2WhitePawn, a6BlackPawn + )); + + pieceDAO.updatePiece(pieces); + } + + @Disabled + @DisplayName("피스 삭제") + @Test + void deletePieceTest() throws Exception { + PieceOnBoard a2WhitePawn = new PieceOnBoard(4, "ATHREE", "p_white", 1); + + pieceDAO.deletePiece(a2WhitePawn); + } +} From cafcd69aacbe3b0d0d7d53feda82532a8850d402 Mon Sep 17 00:00:00 2001 From: giantim Date: Sun, 5 Apr 2020 23:38:21 +0900 Subject: [PATCH 44/75] =?UTF-8?q?feat:=20=EB=8D=B0=EC=9D=B4=ED=84=B0?= =?UTF-8?q?=EB=B2=A0=EC=9D=B4=EC=8A=A4=EC=97=90=EC=84=9C=20=ED=94=BC?= =?UTF-8?q?=EC=8A=A4=20=EC=A0=95=EB=B3=B4=20=EB=B6=88=EB=9F=AC=EC=98=A4?= =?UTF-8?q?=EA=B8=B0=20-=20(1)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../chess/controller/WebChessController.java | 28 +++++++++++++++++-- .../java/chess/controller/dao/PieceDAO.java | 25 +++++++++++++++++ src/main/java/chess/domain/ChessRunner.java | 18 +++++++++++- src/main/java/chess/domain/board/Board.java | 4 +++ .../chess/domain/board/BoardInitializer.java | 10 +++++++ .../initialize/BishopInitializer.java | 5 ++++ .../initialize/InitializeStrategy.java | 2 ++ .../strategy/initialize/KingInitializer.java | 5 ++++ .../initialize/KnightInitializer.java | 5 ++++ .../strategy/initialize/PawnInitializer.java | 5 ++++ .../strategy/initialize/QueenInitializer.java | 5 ++++ .../strategy/initialize/RookInitializer.java | 5 ++++ .../chess/controller/dao/PieceDAOTest.java | 15 +++++++++- .../java/chess/domain/ChessRunnerTest.java | 2 +- 14 files changed, 128 insertions(+), 6 deletions(-) diff --git a/src/main/java/chess/controller/WebChessController.java b/src/main/java/chess/controller/WebChessController.java index a57d6c2c5a9..c2fd02f1ec1 100644 --- a/src/main/java/chess/controller/WebChessController.java +++ b/src/main/java/chess/controller/WebChessController.java @@ -1,11 +1,17 @@ package chess.controller; +import chess.controller.dao.ChessBoard; +import chess.controller.dao.ChessBoardDAO; +import chess.controller.dao.PieceDAO; +import chess.controller.dao.PieceOnBoard; import chess.controller.dto.MoveResultDto; import chess.controller.dto.TeamDto; import chess.controller.dto.TileDto; import chess.domain.ChessRunner; +import java.util.HashMap; import java.util.List; +import java.util.Map; import java.util.stream.Collectors; public class WebChessController { @@ -17,9 +23,25 @@ public class WebChessController { private static final String WINNER = " 가 이겼습니다."; private ChessRunner chessRunner; + private ChessBoard chessBoard; - public void start() { - this.chessRunner = new ChessRunner(); + public void start() throws Exception { + ChessBoardDAO chessBoardDAO = new ChessBoardDAO(); + PieceDAO pieceDAO = new PieceDAO(); + this.chessBoard = chessBoardDAO.findRecentChessBoard(); + if (this.chessBoard == null) { // 게임을 새로 시작했다면 + this.chessRunner = new ChessRunner(); + chessBoardDAO.addChessBoard(); + this.chessBoard = chessBoardDAO.findRecentChessBoard(); + List tileDtos = this.chessRunner.pieceTileDtos(); + pieceDAO.addPiece(chessBoard.getChessBoardId(), tileDtos); + } else { + List pieces = pieceDAO.findPiece(this.chessBoard.getChessBoardId()); + Map pieceOnBoards = pieces.stream() + .collect(Collectors.toMap(entry -> entry.getPosition(), + entry -> entry.getPieceImageUrl(), (e1, e2) -> e1, HashMap::new)); + this.chessRunner = new ChessRunner(pieceOnBoards); + } } public MoveResultDto move(final String source, final String target) { @@ -48,7 +70,7 @@ public TeamDto getCurrentTeam() { } public List getTiles() { - return this.chessRunner.tileDtos(); + return this.chessRunner.entireTileDtos(); } public String getScores() { diff --git a/src/main/java/chess/controller/dao/PieceDAO.java b/src/main/java/chess/controller/dao/PieceDAO.java index 4c43e2392b9..baef1511eed 100644 --- a/src/main/java/chess/controller/dao/PieceDAO.java +++ b/src/main/java/chess/controller/dao/PieceDAO.java @@ -4,7 +4,10 @@ import java.sql.Connection; import java.sql.PreparedStatement; +import java.sql.ResultSet; import java.sql.SQLException; +import java.util.ArrayList; +import java.util.Collections; import java.util.List; public class PieceDAO { @@ -46,4 +49,26 @@ public void deletePiece(PieceOnBoard a2WhitePawn) throws SQLException { pstmt.executeUpdate(); ConnectionManager.closeConnection(con); } + + public List findPiece(int chessBoardId) throws SQLException { + List pieceOnBoards = new ArrayList<>(); + + Connection con = ConnectionManager.getConnection(); + String query = "SELECT * FROM piece WHERE chessBoardId = ?"; + PreparedStatement pstmt = con.prepareStatement(query); + pstmt.setInt(1, chessBoardId); + ResultSet rs = pstmt.executeQuery(); + + while (rs.next()) { + PieceOnBoard pieceOnBoard = new PieceOnBoard( + rs.getInt("pieceId"), + rs.getString("position"), + rs.getString("pieceImageUrl"), + rs.getInt("chessBoardId") + ); + pieceOnBoards.add(pieceOnBoard); + } + + return Collections.unmodifiableList(pieceOnBoards); + } } diff --git a/src/main/java/chess/domain/ChessRunner.java b/src/main/java/chess/domain/ChessRunner.java index 7e00c5ce694..32551fae5c2 100644 --- a/src/main/java/chess/domain/ChessRunner.java +++ b/src/main/java/chess/domain/ChessRunner.java @@ -23,6 +23,11 @@ public ChessRunner() { this.currentTeam = Team.WHITE; } + public ChessRunner(Map pieceOnBoards) { + this.board = Board.webBoard(pieceOnBoards); + this.currentTeam = Team.WHITE; + } + public void update(String source, String target) { Position sourcePosition = Position.of(source); Position targetPosition = Position.of(target); @@ -132,7 +137,7 @@ public String getWinner() { return winner.map(Enum::name).orElse(StringUtils.EMPTY); } - public List tileDtos() { + public List entireTileDtos() { List tileDtos = Position.getPositions().stream() .map(TileDto::new) .collect(Collectors.toList()); @@ -161,4 +166,15 @@ private void setTileDtoImage(List tileDtos) { tileDto.setPieceImageUrl(tile.pieceImageUrl()); } } + + public List pieceTileDtos() { + List tileDtos = this.board.tiles().stream() + .map((tile) -> { + TileDto tileDto = new TileDto(tile.position()); + tileDto.setPieceImageUrl(tile.pieceImageUrl()); + return tileDto; + }).collect(Collectors.toList()); + + return Collections.unmodifiableList(tileDtos); + } } diff --git a/src/main/java/chess/domain/board/Board.java b/src/main/java/chess/domain/board/Board.java index fced1c3a5cb..158364378c1 100644 --- a/src/main/java/chess/domain/board/Board.java +++ b/src/main/java/chess/domain/board/Board.java @@ -19,6 +19,10 @@ public Board(final Map board) { this.board = board; } + public static Board webBoard(Map pieceOnBoards) { + return new Board(BoardInitializer.webInitialize(pieceOnBoards)); + } + public void updateBoard(final Position sourcePosition, final Position targetPosition) { Piece selectedPiece = this.board.get(sourcePosition); this.board.put(targetPosition, selectedPiece); diff --git a/src/main/java/chess/domain/board/BoardInitializer.java b/src/main/java/chess/domain/board/BoardInitializer.java index 057eb7137b0..404f076af77 100644 --- a/src/main/java/chess/domain/board/BoardInitializer.java +++ b/src/main/java/chess/domain/board/BoardInitializer.java @@ -29,4 +29,14 @@ public static Map initializeAll() { return board; } + + public static Map webInitialize(Map pieceOnBoards) { + Map board = new HashMap<>(); + + for (InitializeStrategy strategy : INITIALIZER) { + board.putAll(strategy.webInitialize(pieceOnBoards)); + } + + return board; + } } diff --git a/src/main/java/chess/domain/strategy/initialize/BishopInitializer.java b/src/main/java/chess/domain/strategy/initialize/BishopInitializer.java index de5017b6892..8650fb5f229 100644 --- a/src/main/java/chess/domain/strategy/initialize/BishopInitializer.java +++ b/src/main/java/chess/domain/strategy/initialize/BishopInitializer.java @@ -39,4 +39,9 @@ public static Map initializeBishops() { public Map initialize() { return InitialBishop.initializeBishops(); } + + @Override + public Map webInitialize(Map pieceOnBoards) { + return null; + } } \ No newline at end of file diff --git a/src/main/java/chess/domain/strategy/initialize/InitializeStrategy.java b/src/main/java/chess/domain/strategy/initialize/InitializeStrategy.java index 18ae42a7b9d..ee4739b4ec2 100644 --- a/src/main/java/chess/domain/strategy/initialize/InitializeStrategy.java +++ b/src/main/java/chess/domain/strategy/initialize/InitializeStrategy.java @@ -7,4 +7,6 @@ public interface InitializeStrategy { Map initialize(); + + Map webInitialize(Map pieceOnBoards); } diff --git a/src/main/java/chess/domain/strategy/initialize/KingInitializer.java b/src/main/java/chess/domain/strategy/initialize/KingInitializer.java index caec8420870..d31ed6a5d56 100644 --- a/src/main/java/chess/domain/strategy/initialize/KingInitializer.java +++ b/src/main/java/chess/domain/strategy/initialize/KingInitializer.java @@ -37,4 +37,9 @@ public static Map initializeKings() { public Map initialize() { return InitialKing.initializeKings(); } + + @Override + public Map webInitialize(Map pieceOnBoards) { + return null; + } } diff --git a/src/main/java/chess/domain/strategy/initialize/KnightInitializer.java b/src/main/java/chess/domain/strategy/initialize/KnightInitializer.java index fa95bb0823d..90ee542c56c 100644 --- a/src/main/java/chess/domain/strategy/initialize/KnightInitializer.java +++ b/src/main/java/chess/domain/strategy/initialize/KnightInitializer.java @@ -39,4 +39,9 @@ public static Map initializeKnights() { public Map initialize() { return InitialKnight.initializeKnights(); } + + @Override + public Map webInitialize(Map pieceOnBoards) { + return null; + } } \ No newline at end of file diff --git a/src/main/java/chess/domain/strategy/initialize/PawnInitializer.java b/src/main/java/chess/domain/strategy/initialize/PawnInitializer.java index 523acea9c0a..a616991ff5d 100644 --- a/src/main/java/chess/domain/strategy/initialize/PawnInitializer.java +++ b/src/main/java/chess/domain/strategy/initialize/PawnInitializer.java @@ -52,4 +52,9 @@ public static Map initialPawns() { public Map initialize() { return InitialPawn.initialPawns(); } + + @Override + public Map webInitialize(Map pieceOnBoards) { + return null; + } } diff --git a/src/main/java/chess/domain/strategy/initialize/QueenInitializer.java b/src/main/java/chess/domain/strategy/initialize/QueenInitializer.java index e23871b6bd9..08d0c80764b 100644 --- a/src/main/java/chess/domain/strategy/initialize/QueenInitializer.java +++ b/src/main/java/chess/domain/strategy/initialize/QueenInitializer.java @@ -37,4 +37,9 @@ public static Map initializeQueens() { public Map initialize() { return InitialQueen.initializeQueens(); } + + @Override + public Map webInitialize(Map pieceOnBoards) { + return null; + } } \ No newline at end of file diff --git a/src/main/java/chess/domain/strategy/initialize/RookInitializer.java b/src/main/java/chess/domain/strategy/initialize/RookInitializer.java index 8b351c3088d..6aec49ca606 100644 --- a/src/main/java/chess/domain/strategy/initialize/RookInitializer.java +++ b/src/main/java/chess/domain/strategy/initialize/RookInitializer.java @@ -39,4 +39,9 @@ public static Map initializeRooks() { public Map initialize() { return InitialRook.initializeRooks(); } + + @Override + public Map webInitialize(Map pieceOnBoards) { + return null; + } } \ No newline at end of file diff --git a/src/test/java/chess/controller/dao/PieceDAOTest.java b/src/test/java/chess/controller/dao/PieceDAOTest.java index be676fbdf51..929a5e8bb0a 100644 --- a/src/test/java/chess/controller/dao/PieceDAOTest.java +++ b/src/test/java/chess/controller/dao/PieceDAOTest.java @@ -1,6 +1,7 @@ package chess.controller.dao; import chess.controller.dto.TileDto; +import org.assertj.core.api.Assertions; import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Disabled; import org.junit.jupiter.api.DisplayName; @@ -30,7 +31,7 @@ void addPieceTest() throws Exception { a2WhitePawn, a6BlackPawn )); - pieceDAO.addPiece(1, tileDtos); + pieceDAO.addPiece(12, tileDtos); } @Disabled @@ -54,4 +55,16 @@ void deletePieceTest() throws Exception { pieceDAO.deletePiece(a2WhitePawn); } + + @Disabled + @DisplayName("저장되어 있는 피스 정보 불러오기") + @Test + void findPieceTest() throws Exception { + List pieceOnBoards = pieceDAO.findPiece(12); + + Assertions.assertThat(pieceOnBoards).containsExactly( + new PieceOnBoard(6, "ATWO", "p_white", 12), + new PieceOnBoard(7, "ASIX", "P_black", 12) + ); + } } diff --git a/src/test/java/chess/domain/ChessRunnerTest.java b/src/test/java/chess/domain/ChessRunnerTest.java index 4f36859e50e..c9be4662f99 100644 --- a/src/test/java/chess/domain/ChessRunnerTest.java +++ b/src/test/java/chess/domain/ChessRunnerTest.java @@ -74,7 +74,7 @@ void isEndChessTest() { @Test void tileDtosTest() { - List tileDtos = chessRunner.tileDtos(); + List tileDtos = chessRunner.entireTileDtos(); } @DisplayName("게임이 종료되지 않았을 때 승자를 출력 시 빈 문자열 출력") From 4ca03076594e7e4fe612bc432afb52055c8ee1a2 Mon Sep 17 00:00:00 2001 From: giantim Date: Mon, 6 Apr 2020 16:13:23 +0900 Subject: [PATCH 45/75] =?UTF-8?q?feat:=20db=20=EC=97=90=EC=84=9C=20?= =?UTF-8?q?=EC=9D=BD=EC=9D=80=20=EA=B0=92=EC=9C=BC=EB=A1=9C=20=EA=B0=81=20?= =?UTF-8?q?=ED=94=BC=EC=8A=A4=20=EC=B4=88=EA=B8=B0=ED=99=94?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../java/chess/domain/piece/PieceType.java | 9 +++++ .../java/chess/domain/position/Position.java | 9 +++++ .../initialize/BishopInitializer.java | 19 ++++++++++- .../strategy/initialize/KingInitializer.java | 24 ++++++++++--- .../initialize/KnightInitializer.java | 24 ++++++++++--- .../strategy/initialize/PawnInitializer.java | 24 ++++++++++--- .../strategy/initialize/QueenInitializer.java | 24 ++++++++++--- .../strategy/initialize/RookInitializer.java | 24 ++++++++++--- .../chess/domain/position/PositionTest.java | 6 ---- .../initialize/BishopInitializerTest.java | 33 ++++++++++++++++++ .../initialize/KingInitializerTest.java | 33 ++++++++++++++++++ .../initialize/KnightInitializerTest.java | 34 +++++++++++++++++++ .../initialize/PawnInitializerTest.java | 34 +++++++++++++++++++ .../initialize/QueenInitializerTest.java | 34 +++++++++++++++++++ .../initialize/RookInitializerTest.java | 34 +++++++++++++++++++ 15 files changed, 333 insertions(+), 32 deletions(-) create mode 100644 src/test/java/chess/domain/strategy/initialize/BishopInitializerTest.java create mode 100644 src/test/java/chess/domain/strategy/initialize/KingInitializerTest.java create mode 100644 src/test/java/chess/domain/strategy/initialize/KnightInitializerTest.java create mode 100644 src/test/java/chess/domain/strategy/initialize/PawnInitializerTest.java create mode 100644 src/test/java/chess/domain/strategy/initialize/QueenInitializerTest.java create mode 100644 src/test/java/chess/domain/strategy/initialize/RookInitializerTest.java diff --git a/src/main/java/chess/domain/piece/PieceType.java b/src/main/java/chess/domain/piece/PieceType.java index 6344a8423de..369ab0c0bcd 100644 --- a/src/main/java/chess/domain/piece/PieceType.java +++ b/src/main/java/chess/domain/piece/PieceType.java @@ -1,5 +1,7 @@ package chess.domain.piece; +import java.util.Arrays; + public enum PieceType { KING("k", 0), QUEEN("q", 9), @@ -16,6 +18,13 @@ public enum PieceType { this.score = score; } + public static PieceType of(String symbol) { + return Arrays.stream(values()) + .filter(pt -> pt.symbol.equals(symbol.toLowerCase())) + .findFirst() + .orElseThrow(IllegalArgumentException::new); + } + public boolean isKing() { return this == KING; } diff --git a/src/main/java/chess/domain/position/Position.java b/src/main/java/chess/domain/position/Position.java index 427e238dbbf..1bfc1e7b409 100644 --- a/src/main/java/chess/domain/position/Position.java +++ b/src/main/java/chess/domain/position/Position.java @@ -52,6 +52,15 @@ public static Position of(final int fileSymbol, final int rankSymbol) { return findPosition(File.of(fileSymbol), Rank.of(rankSymbol)); } + public static Position convert(String value) { + String fileName = value.substring(0, 1); + String rankName = value.substring(1); + File file = File.of(fileName); + Rank rank = Rank.valueOf(rankName); + + return new Position(file, rank); + } + public int calculateFileGap(final Position target) { return this.file.compareTo(target.file); } diff --git a/src/main/java/chess/domain/strategy/initialize/BishopInitializer.java b/src/main/java/chess/domain/strategy/initialize/BishopInitializer.java index 8650fb5f229..ce1972c568f 100644 --- a/src/main/java/chess/domain/strategy/initialize/BishopInitializer.java +++ b/src/main/java/chess/domain/strategy/initialize/BishopInitializer.java @@ -42,6 +42,23 @@ public Map initialize() { @Override public Map webInitialize(Map pieceOnBoards) { - return null; + Map bishops = pieceOnBoards.entrySet().stream() + .filter(entry -> entry.getValue().substring(0, 1).toLowerCase().equals("b")) + .collect(Collectors.toMap(entry -> entry.getKey(), entry -> entry.getValue())); + + Map board = bishops.entrySet().stream() + .collect(Collectors.toMap(entry -> Position.convert(entry.getKey()), + entry -> initializeBishop(entry.getValue()), + (e1, e2) -> e1, HashMap::new)); + + return Collections.unmodifiableMap(board); + } + + private Piece initializeBishop(String key) { + String pieceTypeSymbol = key.substring(0, 1); + String teamName = key.substring(2).toUpperCase(); + PieceType pieceType = PieceType.of(pieceTypeSymbol); + Team team = Team.valueOf(teamName); + return new Bishop(pieceType, team); } } \ No newline at end of file diff --git a/src/main/java/chess/domain/strategy/initialize/KingInitializer.java b/src/main/java/chess/domain/strategy/initialize/KingInitializer.java index d31ed6a5d56..88f6bdd6a7b 100644 --- a/src/main/java/chess/domain/strategy/initialize/KingInitializer.java +++ b/src/main/java/chess/domain/strategy/initialize/KingInitializer.java @@ -1,9 +1,6 @@ package chess.domain.strategy.initialize; -import chess.domain.piece.King; -import chess.domain.piece.Piece; -import chess.domain.piece.PieceType; -import chess.domain.piece.Team; +import chess.domain.piece.*; import chess.domain.position.Position; import java.util.Arrays; @@ -40,6 +37,23 @@ public Map initialize() { @Override public Map webInitialize(Map pieceOnBoards) { - return null; + Map kings = pieceOnBoards.entrySet().stream() + .filter(entry -> entry.getValue().substring(0, 1).toLowerCase().equals("k")) + .collect(Collectors.toMap(entry -> entry.getKey(), entry -> entry.getValue())); + + Map board = kings.entrySet().stream() + .collect(Collectors.toMap(entry -> Position.convert(entry.getKey()), + entry -> initializeKing(entry.getValue()), + (e1, e2) -> e1, HashMap::new)); + + return Collections.unmodifiableMap(board); + } + + private Piece initializeKing(String key) { + String pieceTypeSymbol = key.substring(0, 1); + String teamName = key.substring(2).toUpperCase(); + PieceType pieceType = PieceType.of(pieceTypeSymbol); + Team team = Team.valueOf(teamName); + return new King(pieceType, team); } } diff --git a/src/main/java/chess/domain/strategy/initialize/KnightInitializer.java b/src/main/java/chess/domain/strategy/initialize/KnightInitializer.java index 90ee542c56c..a03d15c7831 100644 --- a/src/main/java/chess/domain/strategy/initialize/KnightInitializer.java +++ b/src/main/java/chess/domain/strategy/initialize/KnightInitializer.java @@ -1,9 +1,6 @@ package chess.domain.strategy.initialize; -import chess.domain.piece.Knight; -import chess.domain.piece.Piece; -import chess.domain.piece.PieceType; -import chess.domain.piece.Team; +import chess.domain.piece.*; import chess.domain.position.Position; import java.util.Arrays; @@ -42,6 +39,23 @@ public Map initialize() { @Override public Map webInitialize(Map pieceOnBoards) { - return null; + Map knights = pieceOnBoards.entrySet().stream() + .filter(entry -> entry.getValue().substring(0, 1).toLowerCase().equals("n")) + .collect(Collectors.toMap(entry -> entry.getKey(), entry -> entry.getValue())); + + Map board = knights.entrySet().stream() + .collect(Collectors.toMap(entry -> Position.convert(entry.getKey()), + entry -> initializeKnight(entry.getValue()), + (e1, e2) -> e1, HashMap::new)); + + return Collections.unmodifiableMap(board); + } + + private Piece initializeKnight(String key) { + String pieceTypeSymbol = key.substring(0, 1); + String teamName = key.substring(2).toUpperCase(); + PieceType pieceType = PieceType.of(pieceTypeSymbol); + Team team = Team.valueOf(teamName); + return new Knight(pieceType, team); } } \ No newline at end of file diff --git a/src/main/java/chess/domain/strategy/initialize/PawnInitializer.java b/src/main/java/chess/domain/strategy/initialize/PawnInitializer.java index a616991ff5d..525ad5efbb6 100644 --- a/src/main/java/chess/domain/strategy/initialize/PawnInitializer.java +++ b/src/main/java/chess/domain/strategy/initialize/PawnInitializer.java @@ -1,9 +1,6 @@ package chess.domain.strategy.initialize; -import chess.domain.piece.Pawn; -import chess.domain.piece.Piece; -import chess.domain.piece.PieceType; -import chess.domain.piece.Team; +import chess.domain.piece.*; import chess.domain.position.Position; import java.util.Arrays; @@ -55,6 +52,23 @@ public Map initialize() { @Override public Map webInitialize(Map pieceOnBoards) { - return null; + Map pawns = pieceOnBoards.entrySet().stream() + .filter(entry -> entry.getValue().substring(0, 1).toLowerCase().equals("p")) + .collect(Collectors.toMap(entry -> entry.getKey(), entry -> entry.getValue())); + + Map board = pawns.entrySet().stream() + .collect(Collectors.toMap(entry -> Position.convert(entry.getKey()), + entry -> initializePawn(entry.getValue()), + (e1, e2) -> e1, HashMap::new)); + + return Collections.unmodifiableMap(board); + } + + private Piece initializePawn(String key) { + String pieceTypeSymbol = key.substring(0, 1); + String teamName = key.substring(2).toUpperCase(); + PieceType pieceType = PieceType.of(pieceTypeSymbol); + Team team = Team.valueOf(teamName); + return new Pawn(pieceType, team); } } diff --git a/src/main/java/chess/domain/strategy/initialize/QueenInitializer.java b/src/main/java/chess/domain/strategy/initialize/QueenInitializer.java index 08d0c80764b..88ab9259007 100644 --- a/src/main/java/chess/domain/strategy/initialize/QueenInitializer.java +++ b/src/main/java/chess/domain/strategy/initialize/QueenInitializer.java @@ -1,9 +1,6 @@ package chess.domain.strategy.initialize; -import chess.domain.piece.Piece; -import chess.domain.piece.PieceType; -import chess.domain.piece.Queen; -import chess.domain.piece.Team; +import chess.domain.piece.*; import chess.domain.position.Position; import java.util.Arrays; @@ -40,6 +37,23 @@ public Map initialize() { @Override public Map webInitialize(Map pieceOnBoards) { - return null; + Map queens = pieceOnBoards.entrySet().stream() + .filter(entry -> entry.getValue().substring(0, 1).toLowerCase().equals("q")) + .collect(Collectors.toMap(entry -> entry.getKey(), entry -> entry.getValue())); + + Map board = queens.entrySet().stream() + .collect(Collectors.toMap(entry -> Position.convert(entry.getKey()), + entry -> initializeQueen(entry.getValue()), + (e1, e2) -> e1, HashMap::new)); + + return Collections.unmodifiableMap(board); + } + + private Piece initializeQueen(String key) { + String pieceTypeSymbol = key.substring(0, 1); + String teamName = key.substring(2).toUpperCase(); + PieceType pieceType = PieceType.of(pieceTypeSymbol); + Team team = Team.valueOf(teamName); + return new Queen(pieceType, team); } } \ No newline at end of file diff --git a/src/main/java/chess/domain/strategy/initialize/RookInitializer.java b/src/main/java/chess/domain/strategy/initialize/RookInitializer.java index 6aec49ca606..def42b8b658 100644 --- a/src/main/java/chess/domain/strategy/initialize/RookInitializer.java +++ b/src/main/java/chess/domain/strategy/initialize/RookInitializer.java @@ -1,9 +1,6 @@ package chess.domain.strategy.initialize; -import chess.domain.piece.Piece; -import chess.domain.piece.PieceType; -import chess.domain.piece.Rook; -import chess.domain.piece.Team; +import chess.domain.piece.*; import chess.domain.position.Position; import java.util.Arrays; @@ -42,6 +39,23 @@ public Map initialize() { @Override public Map webInitialize(Map pieceOnBoards) { - return null; + Map rooks = pieceOnBoards.entrySet().stream() + .filter(entry -> entry.getValue().substring(0, 1).toLowerCase().equals("r")) + .collect(Collectors.toMap(entry -> entry.getKey(), entry -> entry.getValue())); + + Map board = rooks.entrySet().stream() + .collect(Collectors.toMap(entry -> Position.convert(entry.getKey()), + entry -> initializeRook(entry.getValue()), + (e1, e2) -> e1, HashMap::new)); + + return Collections.unmodifiableMap(board); + } + + private Piece initializeRook(String key) { + String pieceTypeSymbol = key.substring(0, 1); + String teamName = key.substring(2).toUpperCase(); + PieceType pieceType = PieceType.of(pieceTypeSymbol); + Team team = Team.valueOf(teamName); + return new Rook(pieceType, team); } } \ No newline at end of file diff --git a/src/test/java/chess/domain/position/PositionTest.java b/src/test/java/chess/domain/position/PositionTest.java index c56ba303ebd..890c88097cf 100644 --- a/src/test/java/chess/domain/position/PositionTest.java +++ b/src/test/java/chess/domain/position/PositionTest.java @@ -12,10 +12,4 @@ void moveTest() { Assertions.assertThat(position).isEqualTo(Position.of("b2")); } - -// @Test -// void getPositionsTest() { -// List positions = Position.getPositions(); -// -// } } diff --git a/src/test/java/chess/domain/strategy/initialize/BishopInitializerTest.java b/src/test/java/chess/domain/strategy/initialize/BishopInitializerTest.java new file mode 100644 index 00000000000..8823e83163d --- /dev/null +++ b/src/test/java/chess/domain/strategy/initialize/BishopInitializerTest.java @@ -0,0 +1,33 @@ +package chess.domain.strategy.initialize; + +import chess.domain.piece.Bishop; +import chess.domain.piece.Piece; +import chess.domain.position.Position; +import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; + +import java.util.HashMap; +import java.util.Map; + +public class BishopInitializerTest { + @DisplayName("db에서 받아온 정보로 비숍 초기화") + @Test + void webInitializeTest() { + Map pieceOnBoard = new HashMap<>(); + pieceOnBoard.put("ATWO", "b_white"); + pieceOnBoard.put("BTWO", "p_white"); + pieceOnBoard.put("FSIX", "P_black"); + pieceOnBoard.put("CEIGHT", "B_black"); + pieceOnBoard.put("DFOUR", "b_white"); + InitializeStrategy bishopInitialize = new BishopInitializer(); + Map board = bishopInitialize.webInitialize(pieceOnBoard); + + Assertions.assertThat(board.keySet()).contains( + Position.of("a2"), Position.of("c8"), Position.of("d4") + ); + for (Piece piece : board.values()) { + Assertions.assertThat(piece).isInstanceOf(Bishop.class); + } + } +} \ No newline at end of file diff --git a/src/test/java/chess/domain/strategy/initialize/KingInitializerTest.java b/src/test/java/chess/domain/strategy/initialize/KingInitializerTest.java new file mode 100644 index 00000000000..cb23c82c415 --- /dev/null +++ b/src/test/java/chess/domain/strategy/initialize/KingInitializerTest.java @@ -0,0 +1,33 @@ +package chess.domain.strategy.initialize; + +import chess.domain.piece.King; +import chess.domain.piece.Piece; +import chess.domain.position.Position; +import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; + +import java.util.HashMap; +import java.util.Map; + +public class KingInitializerTest { + @DisplayName("db에서 받아온 정보로 킹 초기화") + @Test + void webInitializeTest() { + Map pieceOnBoard = new HashMap<>(); + pieceOnBoard.put("ATWO", "k_white"); + pieceOnBoard.put("BTWO", "p_white"); + pieceOnBoard.put("FSIX", "P_black"); + pieceOnBoard.put("CEIGHT", "K_black"); + pieceOnBoard.put("DFOUR", "k_white"); + InitializeStrategy kingInitializer = new KingInitializer(); + Map board = kingInitializer.webInitialize(pieceOnBoard); + + Assertions.assertThat(board.keySet()).contains( + Position.of("a2"), Position.of("c8"), Position.of("d4") + ); + for (Piece piece : board.values()) { + Assertions.assertThat(piece).isInstanceOf(King.class); + } + } +} diff --git a/src/test/java/chess/domain/strategy/initialize/KnightInitializerTest.java b/src/test/java/chess/domain/strategy/initialize/KnightInitializerTest.java new file mode 100644 index 00000000000..23d212b3045 --- /dev/null +++ b/src/test/java/chess/domain/strategy/initialize/KnightInitializerTest.java @@ -0,0 +1,34 @@ +package chess.domain.strategy.initialize; + +import chess.domain.piece.King; +import chess.domain.piece.Knight; +import chess.domain.piece.Piece; +import chess.domain.position.Position; +import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; + +import java.util.HashMap; +import java.util.Map; + +public class KnightInitializerTest { + @DisplayName("db에서 받아온 정보로 킹 초기화") + @Test + void webInitializeTest() { + Map pieceOnBoard = new HashMap<>(); + pieceOnBoard.put("ATWO", "n_white"); + pieceOnBoard.put("BTWO", "p_white"); + pieceOnBoard.put("FSIX", "P_black"); + pieceOnBoard.put("CEIGHT", "N_black"); + pieceOnBoard.put("DFOUR", "n_white"); + InitializeStrategy knightInitializer = new KnightInitializer(); + Map board = knightInitializer.webInitialize(pieceOnBoard); + + Assertions.assertThat(board.keySet()).contains( + Position.of("a2"), Position.of("c8"), Position.of("d4") + ); + for (Piece piece : board.values()) { + Assertions.assertThat(piece).isInstanceOf(Knight.class); + } + } +} diff --git a/src/test/java/chess/domain/strategy/initialize/PawnInitializerTest.java b/src/test/java/chess/domain/strategy/initialize/PawnInitializerTest.java new file mode 100644 index 00000000000..9a44a93243f --- /dev/null +++ b/src/test/java/chess/domain/strategy/initialize/PawnInitializerTest.java @@ -0,0 +1,34 @@ +package chess.domain.strategy.initialize; + +import chess.domain.piece.Knight; +import chess.domain.piece.Pawn; +import chess.domain.piece.Piece; +import chess.domain.position.Position; +import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; + +import java.util.HashMap; +import java.util.Map; + +public class PawnInitializerTest { + @DisplayName("db에서 받아온 정보로 킹 초기화") + @Test + void webInitializeTest() { + Map pieceOnBoard = new HashMap<>(); + pieceOnBoard.put("ATWO", "n_white"); + pieceOnBoard.put("BTWO", "p_white"); + pieceOnBoard.put("FSIX", "P_black"); + pieceOnBoard.put("CEIGHT", "N_black"); + pieceOnBoard.put("DFOUR", "n_white"); + InitializeStrategy pawnInitializer = new PawnInitializer(); + Map board = pawnInitializer.webInitialize(pieceOnBoard); + + Assertions.assertThat(board.keySet()).contains( + Position.of("b2"), Position.of("f6") + ); + for (Piece piece : board.values()) { + Assertions.assertThat(piece).isInstanceOf(Pawn.class); + } + } +} diff --git a/src/test/java/chess/domain/strategy/initialize/QueenInitializerTest.java b/src/test/java/chess/domain/strategy/initialize/QueenInitializerTest.java new file mode 100644 index 00000000000..9b850d43523 --- /dev/null +++ b/src/test/java/chess/domain/strategy/initialize/QueenInitializerTest.java @@ -0,0 +1,34 @@ +package chess.domain.strategy.initialize; + +import chess.domain.piece.Pawn; +import chess.domain.piece.Piece; +import chess.domain.piece.Queen; +import chess.domain.position.Position; +import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; + +import java.util.HashMap; +import java.util.Map; + +public class QueenInitializerTest { + @DisplayName("db에서 받아온 정보로 킹 초기화") + @Test + void webInitializeTest() { + Map pieceOnBoard = new HashMap<>(); + pieceOnBoard.put("ATWO", "q_white"); + pieceOnBoard.put("BTWO", "p_white"); + pieceOnBoard.put("FSIX", "P_black"); + pieceOnBoard.put("CEIGHT", "Q_black"); + pieceOnBoard.put("DFOUR", "q_white"); + InitializeStrategy queenInitializer = new QueenInitializer(); + Map board = queenInitializer.webInitialize(pieceOnBoard); + + Assertions.assertThat(board.keySet()).contains( + Position.of("a2"), Position.of("c8"), Position.of("d4") + ); + for (Piece piece : board.values()) { + Assertions.assertThat(piece).isInstanceOf(Queen.class); + } + } +} diff --git a/src/test/java/chess/domain/strategy/initialize/RookInitializerTest.java b/src/test/java/chess/domain/strategy/initialize/RookInitializerTest.java new file mode 100644 index 00000000000..c6af470abf5 --- /dev/null +++ b/src/test/java/chess/domain/strategy/initialize/RookInitializerTest.java @@ -0,0 +1,34 @@ +package chess.domain.strategy.initialize; + +import chess.domain.piece.Pawn; +import chess.domain.piece.Piece; +import chess.domain.piece.Rook; +import chess.domain.position.Position; +import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; + +import java.util.HashMap; +import java.util.Map; + +public class RookInitializerTest { + @DisplayName("db에서 받아온 정보로 킹 초기화") + @Test + void webInitializeTest() { + Map pieceOnBoard = new HashMap<>(); + pieceOnBoard.put("ATWO", "r_white"); + pieceOnBoard.put("BTWO", "p_white"); + pieceOnBoard.put("FSIX", "P_black"); + pieceOnBoard.put("CEIGHT", "R_black"); + pieceOnBoard.put("DFOUR", "r_white"); + InitializeStrategy rookInitializer = new RookInitializer(); + Map board = rookInitializer.webInitialize(pieceOnBoard); + + Assertions.assertThat(board.keySet()).contains( + Position.of("a2"), Position.of("c8"), Position.of("d4") + ); + for (Piece piece : board.values()) { + Assertions.assertThat(piece).isInstanceOf(Rook.class); + } + } +} From 8990ebbc67736176e5fe1853738711ff70f4c200 Mon Sep 17 00:00:00 2001 From: giantim Date: Mon, 6 Apr 2020 16:57:41 +0900 Subject: [PATCH 46/75] =?UTF-8?q?feat:=20=ED=98=84=EC=9E=AC=20=ED=8C=80=20?= =?UTF-8?q?=EC=A0=95=EB=B3=B4=20=EB=8D=B0=EC=9D=B4=ED=84=B0=EB=B2=A0?= =?UTF-8?q?=EC=9D=B4=EC=8A=A4=EC=97=90=20=EC=A0=80=EC=9E=A5=20=EA=B5=AC?= =?UTF-8?q?=ED=98=84?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../java/chess/WebUIChessApplication.java | 2 +- .../chess/controller/WebChessController.java | 3 +- .../chess/controller/dao/CurrentTeam.java | 13 +++++++ .../chess/controller/dao/CurrentTeamDAO.java | 36 +++++++++++++++++++ .../controller/dao/CurrentTeamDAOTest.java | 36 +++++++++++++++++++ 5 files changed, 88 insertions(+), 2 deletions(-) create mode 100644 src/main/java/chess/controller/dao/CurrentTeam.java create mode 100644 src/main/java/chess/controller/dao/CurrentTeamDAO.java create mode 100644 src/test/java/chess/controller/dao/CurrentTeamDAOTest.java diff --git a/src/main/java/chess/WebUIChessApplication.java b/src/main/java/chess/WebUIChessApplication.java index de1c347edca..b8b407cba15 100644 --- a/src/main/java/chess/WebUIChessApplication.java +++ b/src/main/java/chess/WebUIChessApplication.java @@ -20,7 +20,7 @@ public static void main(String[] args) { get("/", (req, res) -> { Map model = new HashMap<>(); - return render(model, "start.html"); + return render(model, "index.html"); }); post("/game", (req, res) -> { diff --git a/src/main/java/chess/controller/WebChessController.java b/src/main/java/chess/controller/WebChessController.java index c2fd02f1ec1..98fb3db814a 100644 --- a/src/main/java/chess/controller/WebChessController.java +++ b/src/main/java/chess/controller/WebChessController.java @@ -39,7 +39,8 @@ public void start() throws Exception { List pieces = pieceDAO.findPiece(this.chessBoard.getChessBoardId()); Map pieceOnBoards = pieces.stream() .collect(Collectors.toMap(entry -> entry.getPosition(), - entry -> entry.getPieceImageUrl(), (e1, e2) -> e1, HashMap::new)); + entry -> entry.getPieceImageUrl(), + (e1, e2) -> e1, HashMap::new)); this.chessRunner = new ChessRunner(pieceOnBoards); } } diff --git a/src/main/java/chess/controller/dao/CurrentTeam.java b/src/main/java/chess/controller/dao/CurrentTeam.java new file mode 100644 index 00000000000..8c81f47460c --- /dev/null +++ b/src/main/java/chess/controller/dao/CurrentTeam.java @@ -0,0 +1,13 @@ +package chess.controller.dao; + +public class CurrentTeam { + private String currentTeam; + + public CurrentTeam(String currentTeam) { + this.currentTeam = currentTeam; + } + + public String getCurrentTeam() { + return this.currentTeam; + } +} diff --git a/src/main/java/chess/controller/dao/CurrentTeamDAO.java b/src/main/java/chess/controller/dao/CurrentTeamDAO.java new file mode 100644 index 00000000000..1f45e229087 --- /dev/null +++ b/src/main/java/chess/controller/dao/CurrentTeamDAO.java @@ -0,0 +1,36 @@ +package chess.controller.dao; + +import java.sql.Connection; +import java.sql.PreparedStatement; +import java.sql.SQLException; + +public class CurrentTeamDAO { + public void addCurrentTeam(int chessBoardId, String currentTeam) throws SQLException { + Connection con = ConnectionManager.getConnection(); + String query = "INSERT INTO currentTeam (team, chessBoardId) VALUES(?, ?)"; + PreparedStatement pstmt = con.prepareStatement(query); + pstmt.setString(1, currentTeam); + pstmt.setInt(2, chessBoardId); + pstmt.executeUpdate(); + ConnectionManager.closeConnection(con); + } + + public void updateCurrentTeam(int chessBoardId, String currentTeam) throws SQLException { + Connection con = ConnectionManager.getConnection(); + String query = "UPDATE currentTeam SET team = ? WHERE chessBoardId = ?"; + PreparedStatement pstmt = con.prepareStatement(query); + pstmt.setString(1, currentTeam); + pstmt.setInt(2, chessBoardId); + pstmt.executeUpdate(); + ConnectionManager.closeConnection(con); + } + + public void deleteCurrentTeam(int chessBoardId) throws SQLException { + Connection con = ConnectionManager.getConnection(); + String query = "DELETE FROM currentTeam WHERE chessBoardId = ?"; + PreparedStatement pstmt = con.prepareStatement(query); + pstmt.setInt(1, chessBoardId); + pstmt.executeUpdate(); + ConnectionManager.closeConnection(con); + } +} diff --git a/src/test/java/chess/controller/dao/CurrentTeamDAOTest.java b/src/test/java/chess/controller/dao/CurrentTeamDAOTest.java new file mode 100644 index 00000000000..1e4151aa77a --- /dev/null +++ b/src/test/java/chess/controller/dao/CurrentTeamDAOTest.java @@ -0,0 +1,36 @@ +package chess.controller.dao; + +import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.Disabled; +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; + +public class CurrentTeamDAOTest { + private CurrentTeamDAO currentTeamDAO; + + @BeforeEach + private void setUp() { + this.currentTeamDAO = new CurrentTeamDAO(); + } + + @Disabled + @DisplayName("현재 팀 정보 추가") + @Test + void addCurrentTeamTest() throws Exception { + this.currentTeamDAO.addCurrentTeam(2, "white"); + } + + @Disabled + @DisplayName("현재 팀 정보 업데이트") + @Test + void updateCurrentTeamTest() throws Exception { + this.currentTeamDAO.updateCurrentTeam(2, "black"); + } + + @Disabled + @DisplayName("현재 팀 삭제") + @Test + void deleteCurrentTeamTest() throws Exception { + this.currentTeamDAO.deleteCurrentTeam(2); + } +} From 72a35ba3e5b5c55cf5a55a3b8ad504c98e2a9062 Mon Sep 17 00:00:00 2001 From: giantim Date: Mon, 6 Apr 2020 17:36:37 +0900 Subject: [PATCH 47/75] =?UTF-8?q?feat:=20=EA=B2=8C=EC=9E=84=20=EC=8B=9C?= =?UTF-8?q?=EC=9E=91=20=EB=98=90=EB=8A=94=20=EC=B2=B4=EC=8A=A4=20=EA=B2=8C?= =?UTF-8?q?=EC=9E=84=20=EB=B6=88=EB=9F=AC=EC=98=A4=EA=B8=B0=20=EA=B8=B0?= =?UTF-8?q?=EB=8A=A5=20=EA=B5=AC=ED=98=84=20refactor:=20=EC=BB=A8=EB=B2=A4?= =?UTF-8?q?=EC=85=98=20=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../chess/controller/WebChessController.java | 28 +++++++++++-------- .../chess/controller/dao/CurrentTeam.java | 19 +++++++++++++ .../chess/controller/dao/CurrentTeamDAO.java | 17 +++++++++++ src/main/java/chess/domain/ChessRunner.java | 4 +-- .../strategy/initialize/KingInitializer.java | 5 +++- .../initialize/KnightInitializer.java | 5 +++- .../strategy/initialize/PawnInitializer.java | 5 +++- .../strategy/initialize/QueenInitializer.java | 5 +++- .../strategy/initialize/RookInitializer.java | 5 +++- .../controller/dao/CurrentTeamDAOTest.java | 11 ++++++++ .../initialize/KnightInitializerTest.java | 1 - .../initialize/PawnInitializerTest.java | 1 - .../initialize/QueenInitializerTest.java | 1 - .../initialize/RookInitializerTest.java | 1 - 14 files changed, 85 insertions(+), 23 deletions(-) diff --git a/src/main/java/chess/controller/WebChessController.java b/src/main/java/chess/controller/WebChessController.java index 98fb3db814a..9ac0cbf003d 100644 --- a/src/main/java/chess/controller/WebChessController.java +++ b/src/main/java/chess/controller/WebChessController.java @@ -1,9 +1,6 @@ package chess.controller; -import chess.controller.dao.ChessBoard; -import chess.controller.dao.ChessBoardDAO; -import chess.controller.dao.PieceDAO; -import chess.controller.dao.PieceOnBoard; +import chess.controller.dao.*; import chess.controller.dto.MoveResultDto; import chess.controller.dto.TeamDto; import chess.controller.dto.TileDto; @@ -24,25 +21,32 @@ public class WebChessController { private ChessRunner chessRunner; private ChessBoard chessBoard; + private CurrentTeam currentTeam; public void start() throws Exception { ChessBoardDAO chessBoardDAO = new ChessBoardDAO(); + CurrentTeamDAO currentTeamDAO = new CurrentTeamDAO(); PieceDAO pieceDAO = new PieceDAO(); this.chessBoard = chessBoardDAO.findRecentChessBoard(); - if (this.chessBoard == null) { // 게임을 새로 시작했다면 + + if (this.chessBoard == null) { this.chessRunner = new ChessRunner(); chessBoardDAO.addChessBoard(); this.chessBoard = chessBoardDAO.findRecentChessBoard(); + currentTeamDAO.addCurrentTeam(this.chessBoard.getChessBoardId(), this.chessRunner.getCurrentTeam()); + currentTeam = new CurrentTeam(this.chessRunner.getCurrentTeam()); List tileDtos = this.chessRunner.pieceTileDtos(); pieceDAO.addPiece(chessBoard.getChessBoardId(), tileDtos); - } else { - List pieces = pieceDAO.findPiece(this.chessBoard.getChessBoardId()); - Map pieceOnBoards = pieces.stream() - .collect(Collectors.toMap(entry -> entry.getPosition(), - entry -> entry.getPieceImageUrl(), - (e1, e2) -> e1, HashMap::new)); - this.chessRunner = new ChessRunner(pieceOnBoards); + return; } + + List pieces = pieceDAO.findPiece(this.chessBoard.getChessBoardId()); + Map pieceOnBoards = pieces.stream() + .collect(Collectors.toMap(entry -> entry.getPosition(), + entry -> entry.getPieceImageUrl(), + (e1, e2) -> e1, HashMap::new)); + currentTeam = currentTeamDAO.findCurrentTeam(this.chessBoard.getChessBoardId()); + this.chessRunner = new ChessRunner(pieceOnBoards, currentTeam.getCurrentTeam()); } public MoveResultDto move(final String source, final String target) { diff --git a/src/main/java/chess/controller/dao/CurrentTeam.java b/src/main/java/chess/controller/dao/CurrentTeam.java index 8c81f47460c..636376ea6ee 100644 --- a/src/main/java/chess/controller/dao/CurrentTeam.java +++ b/src/main/java/chess/controller/dao/CurrentTeam.java @@ -1,5 +1,7 @@ package chess.controller.dao; +import java.util.Objects; + public class CurrentTeam { private String currentTeam; @@ -10,4 +12,21 @@ public CurrentTeam(String currentTeam) { public String getCurrentTeam() { return this.currentTeam; } + + @Override + public boolean equals(Object o) { + if (this == o) { + return true; + } + if (o == null || getClass() != o.getClass()) { + return false; + } + CurrentTeam currentTeam = (CurrentTeam) o; + return Objects.equals(currentTeam, currentTeam.currentTeam); + } + + @Override + public int hashCode() { + return Objects.hash(currentTeam); + } } diff --git a/src/main/java/chess/controller/dao/CurrentTeamDAO.java b/src/main/java/chess/controller/dao/CurrentTeamDAO.java index 1f45e229087..f5da79b8573 100644 --- a/src/main/java/chess/controller/dao/CurrentTeamDAO.java +++ b/src/main/java/chess/controller/dao/CurrentTeamDAO.java @@ -2,6 +2,7 @@ import java.sql.Connection; import java.sql.PreparedStatement; +import java.sql.ResultSet; import java.sql.SQLException; public class CurrentTeamDAO { @@ -33,4 +34,20 @@ public void deleteCurrentTeam(int chessBoardId) throws SQLException { pstmt.executeUpdate(); ConnectionManager.closeConnection(con); } + + public CurrentTeam findCurrentTeam(int chessBoardId) throws SQLException { + Connection con = ConnectionManager.getConnection(); + String query = "SELECT * FROM currentTeam WHERE chessBoardId = ?"; + PreparedStatement pstmt = con.prepareStatement(query); + pstmt.setInt(1, chessBoardId); + ResultSet rs = pstmt.executeQuery(); + + while (!rs.next()) { + return null; + } + + return new CurrentTeam( + rs.getString("team") + ); + } } diff --git a/src/main/java/chess/domain/ChessRunner.java b/src/main/java/chess/domain/ChessRunner.java index 32551fae5c2..4769484ee03 100644 --- a/src/main/java/chess/domain/ChessRunner.java +++ b/src/main/java/chess/domain/ChessRunner.java @@ -23,9 +23,9 @@ public ChessRunner() { this.currentTeam = Team.WHITE; } - public ChessRunner(Map pieceOnBoards) { + public ChessRunner(Map pieceOnBoards, String currentTeam) { this.board = Board.webBoard(pieceOnBoards); - this.currentTeam = Team.WHITE; + this.currentTeam = Team.valueOf(currentTeam.toUpperCase()); } public void update(String source, String target) { diff --git a/src/main/java/chess/domain/strategy/initialize/KingInitializer.java b/src/main/java/chess/domain/strategy/initialize/KingInitializer.java index 88f6bdd6a7b..9984e0b0c19 100644 --- a/src/main/java/chess/domain/strategy/initialize/KingInitializer.java +++ b/src/main/java/chess/domain/strategy/initialize/KingInitializer.java @@ -1,6 +1,9 @@ package chess.domain.strategy.initialize; -import chess.domain.piece.*; +import chess.domain.piece.King; +import chess.domain.piece.Piece; +import chess.domain.piece.PieceType; +import chess.domain.piece.Team; import chess.domain.position.Position; import java.util.Arrays; diff --git a/src/main/java/chess/domain/strategy/initialize/KnightInitializer.java b/src/main/java/chess/domain/strategy/initialize/KnightInitializer.java index a03d15c7831..f7f913a7c53 100644 --- a/src/main/java/chess/domain/strategy/initialize/KnightInitializer.java +++ b/src/main/java/chess/domain/strategy/initialize/KnightInitializer.java @@ -1,6 +1,9 @@ package chess.domain.strategy.initialize; -import chess.domain.piece.*; +import chess.domain.piece.Knight; +import chess.domain.piece.Piece; +import chess.domain.piece.PieceType; +import chess.domain.piece.Team; import chess.domain.position.Position; import java.util.Arrays; diff --git a/src/main/java/chess/domain/strategy/initialize/PawnInitializer.java b/src/main/java/chess/domain/strategy/initialize/PawnInitializer.java index 525ad5efbb6..38b6e41267d 100644 --- a/src/main/java/chess/domain/strategy/initialize/PawnInitializer.java +++ b/src/main/java/chess/domain/strategy/initialize/PawnInitializer.java @@ -1,6 +1,9 @@ package chess.domain.strategy.initialize; -import chess.domain.piece.*; +import chess.domain.piece.Pawn; +import chess.domain.piece.Piece; +import chess.domain.piece.PieceType; +import chess.domain.piece.Team; import chess.domain.position.Position; import java.util.Arrays; diff --git a/src/main/java/chess/domain/strategy/initialize/QueenInitializer.java b/src/main/java/chess/domain/strategy/initialize/QueenInitializer.java index 88ab9259007..a4000b22806 100644 --- a/src/main/java/chess/domain/strategy/initialize/QueenInitializer.java +++ b/src/main/java/chess/domain/strategy/initialize/QueenInitializer.java @@ -1,6 +1,9 @@ package chess.domain.strategy.initialize; -import chess.domain.piece.*; +import chess.domain.piece.Piece; +import chess.domain.piece.PieceType; +import chess.domain.piece.Queen; +import chess.domain.piece.Team; import chess.domain.position.Position; import java.util.Arrays; diff --git a/src/main/java/chess/domain/strategy/initialize/RookInitializer.java b/src/main/java/chess/domain/strategy/initialize/RookInitializer.java index def42b8b658..75a7ba79db1 100644 --- a/src/main/java/chess/domain/strategy/initialize/RookInitializer.java +++ b/src/main/java/chess/domain/strategy/initialize/RookInitializer.java @@ -1,6 +1,9 @@ package chess.domain.strategy.initialize; -import chess.domain.piece.*; +import chess.domain.piece.Piece; +import chess.domain.piece.PieceType; +import chess.domain.piece.Rook; +import chess.domain.piece.Team; import chess.domain.position.Position; import java.util.Arrays; diff --git a/src/test/java/chess/controller/dao/CurrentTeamDAOTest.java b/src/test/java/chess/controller/dao/CurrentTeamDAOTest.java index 1e4151aa77a..4c903fa5e50 100644 --- a/src/test/java/chess/controller/dao/CurrentTeamDAOTest.java +++ b/src/test/java/chess/controller/dao/CurrentTeamDAOTest.java @@ -1,5 +1,6 @@ package chess.controller.dao; +import org.assertj.core.api.Assertions; import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Disabled; import org.junit.jupiter.api.DisplayName; @@ -33,4 +34,14 @@ void updateCurrentTeamTest() throws Exception { void deleteCurrentTeamTest() throws Exception { this.currentTeamDAO.deleteCurrentTeam(2); } + + @Disabled + @DisplayName("현재 팀 검색") + @Test + void findCurrentTeamTest() throws Exception { + CurrentTeam currentTeam = currentTeamDAO.findCurrentTeam(3); + + Assertions.assertThat(currentTeam).isNotNull(); + Assertions.assertThat(currentTeam.getCurrentTeam()).isEqualTo("white"); + } } diff --git a/src/test/java/chess/domain/strategy/initialize/KnightInitializerTest.java b/src/test/java/chess/domain/strategy/initialize/KnightInitializerTest.java index 23d212b3045..a5cf8744f1e 100644 --- a/src/test/java/chess/domain/strategy/initialize/KnightInitializerTest.java +++ b/src/test/java/chess/domain/strategy/initialize/KnightInitializerTest.java @@ -1,6 +1,5 @@ package chess.domain.strategy.initialize; -import chess.domain.piece.King; import chess.domain.piece.Knight; import chess.domain.piece.Piece; import chess.domain.position.Position; diff --git a/src/test/java/chess/domain/strategy/initialize/PawnInitializerTest.java b/src/test/java/chess/domain/strategy/initialize/PawnInitializerTest.java index 9a44a93243f..b16f6d9be04 100644 --- a/src/test/java/chess/domain/strategy/initialize/PawnInitializerTest.java +++ b/src/test/java/chess/domain/strategy/initialize/PawnInitializerTest.java @@ -1,6 +1,5 @@ package chess.domain.strategy.initialize; -import chess.domain.piece.Knight; import chess.domain.piece.Pawn; import chess.domain.piece.Piece; import chess.domain.position.Position; diff --git a/src/test/java/chess/domain/strategy/initialize/QueenInitializerTest.java b/src/test/java/chess/domain/strategy/initialize/QueenInitializerTest.java index 9b850d43523..ca2cbbb9906 100644 --- a/src/test/java/chess/domain/strategy/initialize/QueenInitializerTest.java +++ b/src/test/java/chess/domain/strategy/initialize/QueenInitializerTest.java @@ -1,6 +1,5 @@ package chess.domain.strategy.initialize; -import chess.domain.piece.Pawn; import chess.domain.piece.Piece; import chess.domain.piece.Queen; import chess.domain.position.Position; diff --git a/src/test/java/chess/domain/strategy/initialize/RookInitializerTest.java b/src/test/java/chess/domain/strategy/initialize/RookInitializerTest.java index c6af470abf5..e9e1d654e9c 100644 --- a/src/test/java/chess/domain/strategy/initialize/RookInitializerTest.java +++ b/src/test/java/chess/domain/strategy/initialize/RookInitializerTest.java @@ -1,6 +1,5 @@ package chess.domain.strategy.initialize; -import chess.domain.piece.Pawn; import chess.domain.piece.Piece; import chess.domain.piece.Rook; import chess.domain.position.Position; From b1ce5b9ee05527ca5fbfbf6fe7af79ec1d7d905e Mon Sep 17 00:00:00 2001 From: giantim Date: Mon, 6 Apr 2020 20:17:11 +0900 Subject: [PATCH 48/75] =?UTF-8?q?feat:=20=EC=9D=B4=EB=8F=99=20=ED=9B=84?= =?UTF-8?q?=EC=9D=98=20=EA=B2=B0=EA=B3=BC=20=EB=8D=B0=EC=9D=B4=ED=84=B0?= =?UTF-8?q?=EB=B2=A0=EC=9D=B4=EC=8A=A4=EC=97=90=20=EC=97=85=EB=8D=B0?= =?UTF-8?q?=EC=9D=B4=ED=8A=B8=20=EA=B5=AC=ED=98=84(=ED=8F=AC=EC=A7=80?= =?UTF-8?q?=EC=85=98=20=EC=9D=B4=EB=A6=84=20=EB=A7=A4=ED=95=91=20=EC=88=98?= =?UTF-8?q?=EC=A0=95=ED=95=84=EC=9A=94)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../chess/controller/WebChessController.java | 35 ++++++++++++++---- .../java/chess/controller/dao/PieceDAO.java | 20 +++++++++++ .../chess/controller/dao/PieceOnBoards.java | 36 +++++++++++++++++++ .../chess/controller/dao/PieceDAOTest.java | 9 +++++ 4 files changed, 93 insertions(+), 7 deletions(-) create mode 100644 src/main/java/chess/controller/dao/PieceOnBoards.java diff --git a/src/main/java/chess/controller/WebChessController.java b/src/main/java/chess/controller/WebChessController.java index 9ac0cbf003d..2d1334f2225 100644 --- a/src/main/java/chess/controller/WebChessController.java +++ b/src/main/java/chess/controller/WebChessController.java @@ -9,6 +9,7 @@ import java.util.HashMap; import java.util.List; import java.util.Map; +import java.util.Optional; import java.util.stream.Collectors; public class WebChessController { @@ -22,6 +23,7 @@ public class WebChessController { private ChessRunner chessRunner; private ChessBoard chessBoard; private CurrentTeam currentTeam; + private PieceOnBoards pieceOnBoards; public void start() throws Exception { ChessBoardDAO chessBoardDAO = new ChessBoardDAO(); @@ -34,24 +36,31 @@ public void start() throws Exception { chessBoardDAO.addChessBoard(); this.chessBoard = chessBoardDAO.findRecentChessBoard(); currentTeamDAO.addCurrentTeam(this.chessBoard.getChessBoardId(), this.chessRunner.getCurrentTeam()); - currentTeam = new CurrentTeam(this.chessRunner.getCurrentTeam()); + this.currentTeam = new CurrentTeam(this.chessRunner.getCurrentTeam()); List tileDtos = this.chessRunner.pieceTileDtos(); - pieceDAO.addPiece(chessBoard.getChessBoardId(), tileDtos); + pieceDAO.addPiece(this.chessBoard.getChessBoardId(), tileDtos); + updatePieceOnBoards(pieceDAO); return; } - List pieces = pieceDAO.findPiece(this.chessBoard.getChessBoardId()); - Map pieceOnBoards = pieces.stream() + updatePieceOnBoards(pieceDAO); + Map pieceOnBoards = this.pieceOnBoards.getPieceOnBoards().stream() .collect(Collectors.toMap(entry -> entry.getPosition(), entry -> entry.getPieceImageUrl(), (e1, e2) -> e1, HashMap::new)); - currentTeam = currentTeamDAO.findCurrentTeam(this.chessBoard.getChessBoardId()); - this.chessRunner = new ChessRunner(pieceOnBoards, currentTeam.getCurrentTeam()); + this.currentTeam = currentTeamDAO.findCurrentTeam(this.chessBoard.getChessBoardId()); + this.chessRunner = new ChessRunner(pieceOnBoards, this.currentTeam.getCurrentTeam()); + } + + private void updatePieceOnBoards(PieceDAO pieceDAO) throws Exception { + List pieces = pieceDAO.findPiece(this.chessBoard.getChessBoardId()); + this.pieceOnBoards = PieceOnBoards.of(pieces); } - public MoveResultDto move(final String source, final String target) { + public MoveResultDto move(final String source, final String target) throws Exception { try { this.chessRunner.update(source, target); + updateChessBoard(source, target); String moveResult = moveResult(this.chessRunner, source, target); return new MoveResultDto(moveResult, MESSAGE_STYLE_BLACK); } catch (IllegalArgumentException | StringIndexOutOfBoundsException e) { @@ -59,6 +68,18 @@ public MoveResultDto move(final String source, final String target) { } } + private void updateChessBoard(final String source, final String target) throws Exception { + PieceOnBoard deletedPiece = null; + PieceDAO pieceDAO = new PieceDAO(); + Optional targetPiece = this.pieceOnBoards.find(target); + if (targetPiece.isPresent()) { + deletedPiece = targetPiece.get(); + pieceDAO.deletePiece(deletedPiece); + } + Optional sourcePiece = this.pieceOnBoards.find(source); + pieceDAO.updatePiece(sourcePiece.get(), target); + } + private String moveResult(final ChessRunner chessRunner, final String source, final String target) { if (!this.isEndGame()) { return source + ARROW + target; diff --git a/src/main/java/chess/controller/dao/PieceDAO.java b/src/main/java/chess/controller/dao/PieceDAO.java index baef1511eed..4c6a8726cb1 100644 --- a/src/main/java/chess/controller/dao/PieceDAO.java +++ b/src/main/java/chess/controller/dao/PieceDAO.java @@ -37,6 +37,16 @@ public void updatePiece(List pieces) throws SQLException { ConnectionManager.closeConnection(con); } + public void updatePiece(PieceOnBoard piece) throws SQLException { + Connection con = ConnectionManager.getConnection(); + String query = "UPDATE piece SET position = ? WHERE pieceId = ?"; + PreparedStatement pstmt = con.prepareStatement(query); + pstmt.setString(1, piece.getPosition()); + pstmt.setInt(2, piece.getPieceId()); + pstmt.executeUpdate(); + ConnectionManager.closeConnection(con); + } + public void deletePiece(PieceOnBoard a2WhitePawn) throws SQLException { if (a2WhitePawn == null) { return; @@ -71,4 +81,14 @@ public List findPiece(int chessBoardId) throws SQLException { return Collections.unmodifiableList(pieceOnBoards); } + + public void updatePiece(PieceOnBoard pieceOnBoard, String targetPosition) throws SQLException { + Connection con = ConnectionManager.getConnection(); + String query = "UPDATE piece SET position = ? WHERE pieceId = ?"; + PreparedStatement pstmt = con.prepareStatement(query); + pstmt.setString(1, targetPosition); + pstmt.setInt(2, pieceOnBoard.getPieceId()); + pstmt.executeUpdate(); + ConnectionManager.closeConnection(con); + } } diff --git a/src/main/java/chess/controller/dao/PieceOnBoards.java b/src/main/java/chess/controller/dao/PieceOnBoards.java new file mode 100644 index 00000000000..0ff3fe6bc5c --- /dev/null +++ b/src/main/java/chess/controller/dao/PieceOnBoards.java @@ -0,0 +1,36 @@ +package chess.controller.dao; + +import chess.domain.position.File; +import chess.domain.position.Rank; + +import java.util.Collections; +import java.util.List; +import java.util.Optional; + +public class PieceOnBoards { + private List pieceOnBoards; + + private PieceOnBoards(List pieceOnBoards) { + this.pieceOnBoards = pieceOnBoards; + } + + public static PieceOnBoards of(List pieceOnBoards) { + return new PieceOnBoards(pieceOnBoards); + } + + public List getPieceOnBoards() { + return Collections.unmodifiableList(this.pieceOnBoards); + } + + public Optional find(String target) { + String file = File.valueOf(target.substring(0, 1).toUpperCase()).name(); + String rank = Rank.of(target.substring(1)).name(); + String position = file + rank; + Optional targetPiece = Optional.ofNullable(this.pieceOnBoards.stream() + .filter(p -> p.getPosition().equals(position)) + .findFirst() + .orElse(null)); + + return targetPiece; + } +} diff --git a/src/test/java/chess/controller/dao/PieceDAOTest.java b/src/test/java/chess/controller/dao/PieceDAOTest.java index 929a5e8bb0a..d0bf6df2565 100644 --- a/src/test/java/chess/controller/dao/PieceDAOTest.java +++ b/src/test/java/chess/controller/dao/PieceDAOTest.java @@ -67,4 +67,13 @@ void findPieceTest() throws Exception { new PieceOnBoard(7, "ASIX", "P_black", 12) ); } + + @Disabled + @DisplayName("피스를 받아서 업데이트") + @Test + void updatePiecePositionTest() throws Exception { + PieceOnBoard pieceOnBoard = new PieceOnBoard(34, "ATHREE", "p_white", 4); + + pieceDAO.updatePiece(pieceOnBoard); + } } From 89c93dbd8f58a1dff5850ec439b6fd3b051fd41a Mon Sep 17 00:00:00 2001 From: giantim Date: Tue, 7 Apr 2020 00:37:07 +0900 Subject: [PATCH 49/75] =?UTF-8?q?feat:=20=EC=9D=B4=EB=8F=99=20=ED=9B=84?= =?UTF-8?q?=EC=97=90=20=EC=A0=95=EB=B3=B4=EB=A5=BC=20=EC=A0=80=EC=9E=A5?= =?UTF-8?q?=ED=95=B4=20=EC=84=9C=EB=B2=84=20=EC=A2=85=EB=A3=8C=20=ED=9B=84?= =?UTF-8?q?=EC=97=90=EB=8F=84=20=EA=B2=8C=EC=9E=84=20=EC=A7=84=ED=96=89=20?= =?UTF-8?q?=EA=B0=80=EB=8A=A5=ED=95=98=EA=B2=8C=20=EA=B5=AC=ED=98=84?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../chess/controller/WebChessController.java | 22 +++++++++------ .../chess/controller/dao/CurrentTeamDAO.java | 8 +++--- .../chess/controller/dao/PieceOnBoards.java | 8 +----- src/main/java/chess/domain/board/Board.java | 2 +- src/main/java/chess/domain/position/File.java | 28 +++++++++++-------- .../java/chess/domain/position/Position.java | 9 +++--- 6 files changed, 40 insertions(+), 37 deletions(-) diff --git a/src/main/java/chess/controller/WebChessController.java b/src/main/java/chess/controller/WebChessController.java index 2d1334f2225..5849a1f33a0 100644 --- a/src/main/java/chess/controller/WebChessController.java +++ b/src/main/java/chess/controller/WebChessController.java @@ -23,7 +23,7 @@ public class WebChessController { private ChessRunner chessRunner; private ChessBoard chessBoard; private CurrentTeam currentTeam; - private PieceOnBoards pieceOnBoards; + private PieceOnBoards originalPieces; public void start() throws Exception { ChessBoardDAO chessBoardDAO = new ChessBoardDAO(); @@ -35,16 +35,16 @@ public void start() throws Exception { this.chessRunner = new ChessRunner(); chessBoardDAO.addChessBoard(); this.chessBoard = chessBoardDAO.findRecentChessBoard(); - currentTeamDAO.addCurrentTeam(this.chessBoard.getChessBoardId(), this.chessRunner.getCurrentTeam()); this.currentTeam = new CurrentTeam(this.chessRunner.getCurrentTeam()); + currentTeamDAO.addCurrentTeam(this.chessBoard.getChessBoardId(), this.currentTeam); List tileDtos = this.chessRunner.pieceTileDtos(); pieceDAO.addPiece(this.chessBoard.getChessBoardId(), tileDtos); - updatePieceOnBoards(pieceDAO); + updateOriginalPieces(pieceDAO); return; } - updatePieceOnBoards(pieceDAO); - Map pieceOnBoards = this.pieceOnBoards.getPieceOnBoards().stream() + updateOriginalPieces(pieceDAO); + Map pieceOnBoards = this.originalPieces.getPieceOnBoards().stream() .collect(Collectors.toMap(entry -> entry.getPosition(), entry -> entry.getPieceImageUrl(), (e1, e2) -> e1, HashMap::new)); @@ -52,9 +52,9 @@ public void start() throws Exception { this.chessRunner = new ChessRunner(pieceOnBoards, this.currentTeam.getCurrentTeam()); } - private void updatePieceOnBoards(PieceDAO pieceDAO) throws Exception { + private void updateOriginalPieces(PieceDAO pieceDAO) throws Exception { List pieces = pieceDAO.findPiece(this.chessBoard.getChessBoardId()); - this.pieceOnBoards = PieceOnBoards.of(pieces); + this.originalPieces = PieceOnBoards.of(pieces); } public MoveResultDto move(final String source, final String target) throws Exception { @@ -71,13 +71,17 @@ public MoveResultDto move(final String source, final String target) throws Excep private void updateChessBoard(final String source, final String target) throws Exception { PieceOnBoard deletedPiece = null; PieceDAO pieceDAO = new PieceDAO(); - Optional targetPiece = this.pieceOnBoards.find(target); + CurrentTeamDAO currentTeamDAO = new CurrentTeamDAO(); + + Optional targetPiece = this.originalPieces.find(target); if (targetPiece.isPresent()) { deletedPiece = targetPiece.get(); pieceDAO.deletePiece(deletedPiece); } - Optional sourcePiece = this.pieceOnBoards.find(source); + Optional sourcePiece = this.originalPieces.find(source); pieceDAO.updatePiece(sourcePiece.get(), target); + this.currentTeam = new CurrentTeam(this.chessRunner.getCurrentTeam()); + currentTeamDAO.updateCurrentTeam(this.chessBoard.getChessBoardId(), this.currentTeam); } private String moveResult(final ChessRunner chessRunner, final String source, final String target) { diff --git a/src/main/java/chess/controller/dao/CurrentTeamDAO.java b/src/main/java/chess/controller/dao/CurrentTeamDAO.java index f5da79b8573..0d6205375ad 100644 --- a/src/main/java/chess/controller/dao/CurrentTeamDAO.java +++ b/src/main/java/chess/controller/dao/CurrentTeamDAO.java @@ -6,21 +6,21 @@ import java.sql.SQLException; public class CurrentTeamDAO { - public void addCurrentTeam(int chessBoardId, String currentTeam) throws SQLException { + public void addCurrentTeam(int chessBoardId, CurrentTeam currentTeam) throws SQLException { Connection con = ConnectionManager.getConnection(); String query = "INSERT INTO currentTeam (team, chessBoardId) VALUES(?, ?)"; PreparedStatement pstmt = con.prepareStatement(query); - pstmt.setString(1, currentTeam); + pstmt.setString(1, currentTeam.getCurrentTeam()); pstmt.setInt(2, chessBoardId); pstmt.executeUpdate(); ConnectionManager.closeConnection(con); } - public void updateCurrentTeam(int chessBoardId, String currentTeam) throws SQLException { + public void updateCurrentTeam(int chessBoardId, CurrentTeam currentTeam) throws SQLException { Connection con = ConnectionManager.getConnection(); String query = "UPDATE currentTeam SET team = ? WHERE chessBoardId = ?"; PreparedStatement pstmt = con.prepareStatement(query); - pstmt.setString(1, currentTeam); + pstmt.setString(1, currentTeam.getCurrentTeam()); pstmt.setInt(2, chessBoardId); pstmt.executeUpdate(); ConnectionManager.closeConnection(con); diff --git a/src/main/java/chess/controller/dao/PieceOnBoards.java b/src/main/java/chess/controller/dao/PieceOnBoards.java index 0ff3fe6bc5c..51a9f35ef21 100644 --- a/src/main/java/chess/controller/dao/PieceOnBoards.java +++ b/src/main/java/chess/controller/dao/PieceOnBoards.java @@ -1,8 +1,5 @@ package chess.controller.dao; -import chess.domain.position.File; -import chess.domain.position.Rank; - import java.util.Collections; import java.util.List; import java.util.Optional; @@ -22,10 +19,7 @@ public List getPieceOnBoards() { return Collections.unmodifiableList(this.pieceOnBoards); } - public Optional find(String target) { - String file = File.valueOf(target.substring(0, 1).toUpperCase()).name(); - String rank = Rank.of(target.substring(1)).name(); - String position = file + rank; + public Optional find(String position) { Optional targetPiece = Optional.ofNullable(this.pieceOnBoards.stream() .filter(p -> p.getPosition().equals(position)) .findFirst() diff --git a/src/main/java/chess/domain/board/Board.java b/src/main/java/chess/domain/board/Board.java index 158364378c1..9ba235c1aa4 100644 --- a/src/main/java/chess/domain/board/Board.java +++ b/src/main/java/chess/domain/board/Board.java @@ -86,7 +86,7 @@ public Optional getPiece(final Position position) { } public Map parse() { - Map parseResult = board.entrySet() + Map parseResult = this.board.entrySet() .stream() .collect(Collectors.toMap(entry -> entry.getKey().toString(), entry -> entry.getValue().toSymbol(), diff --git a/src/main/java/chess/domain/position/File.java b/src/main/java/chess/domain/position/File.java index bb03d1216d0..36b56610761 100644 --- a/src/main/java/chess/domain/position/File.java +++ b/src/main/java/chess/domain/position/File.java @@ -3,26 +3,26 @@ import java.util.Arrays; public enum File { - A('a', 1), - B('b', 2), - C('c', 3), - D('d', 4), - E('e', 5), - F('f', 6), - G('g', 7), - H('h', 8); - - private final char symbol; + A("a", 1), + B("b", 2), + C("c", 3), + D("d", 4), + E("e", 5), + F("f", 6), + G("g", 7), + H("h", 8); + + private final String symbol; private final int number; - File(char symbol, int number) { + File(String symbol, int number) { this.symbol = symbol; this.number = number; } public static File of(final String file) { return Arrays.stream(values()) - .filter(f -> f.symbol == file.toLowerCase().charAt(0)) + .filter(f -> f.symbol.equals(file.toLowerCase())) .findFirst() .orElseThrow(() -> new IllegalArgumentException("잘못된 x 좌표값을 입력하였습니다.")); } @@ -34,6 +34,10 @@ public static File of(final int file) { .orElseThrow(() -> new IllegalArgumentException("잘못된 x 좌표값을 입력하였습니다.")); } + public String getSymbol() { + return this.symbol; + } + public int getNumber() { return number; } diff --git a/src/main/java/chess/domain/position/Position.java b/src/main/java/chess/domain/position/Position.java index 1bfc1e7b409..51e4c19fa2e 100644 --- a/src/main/java/chess/domain/position/Position.java +++ b/src/main/java/chess/domain/position/Position.java @@ -56,7 +56,7 @@ public static Position convert(String value) { String fileName = value.substring(0, 1); String rankName = value.substring(1); File file = File.of(fileName); - Rank rank = Rank.valueOf(rankName); + Rank rank = Rank.of(rankName); return new Position(file, rank); } @@ -99,7 +99,8 @@ public int getRank() { @Override public String toString() { - return file.name() + rank.name(); + return this.file.getSymbol() + + this.rank.getSymbol(); } @Override @@ -107,8 +108,8 @@ public boolean equals(Object o) { if (this == o) return true; if (o == null || getClass() != o.getClass()) return false; Position position = (Position) o; - return file == position.file && - rank == position.rank; + return file == position.file + && rank == position.rank; } @Override From f4efb987d86f0cd12e94060d3c8c4a31328d32ae Mon Sep 17 00:00:00 2001 From: giantim Date: Tue, 7 Apr 2020 01:15:51 +0900 Subject: [PATCH 50/75] =?UTF-8?q?feat:=20end=20=EB=B2=84=ED=8A=BC=20?= =?UTF-8?q?=EB=88=84=EB=A5=BC=20=EC=8B=9C=20=EC=96=91=20=ED=8C=80=EC=9D=98?= =?UTF-8?q?=20=EC=A0=90=EC=88=98=EB=A5=BC=20=EA=B3=84=EC=82=B0=ED=95=B4?= =?UTF-8?q?=EC=84=9C=20=EB=B3=B4=EC=97=AC=EC=A3=BC=EA=B3=A0=20=EC=A2=85?= =?UTF-8?q?=EB=A3=8C=20/=20=ED=95=9C=20=ED=8C=80=EC=9D=B4=20=EB=8B=A4?= =?UTF-8?q?=EB=A5=B8=20=ED=8C=80=EC=9D=98=20=EC=99=95=EC=9D=84=20=EC=9E=A1?= =?UTF-8?q?=EC=95=98=EC=9D=84=20=EB=95=8C=20=EB=8D=B0=EC=9D=B4=ED=84=B0=20?= =?UTF-8?q?=EB=B2=A0=EC=9D=B4=EC=8A=A4=EC=97=90=20=EC=A0=95=EB=B3=B4?= =?UTF-8?q?=EB=A5=BC=20=EC=82=AD=EC=A0=9C=ED=95=98=EA=B3=A0=20=EA=B2=8C?= =?UTF-8?q?=EC=9E=84=20=EC=A2=85=EB=A3=8C?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/main/java/chess/WebUIChessApplication.java | 9 ++++++++- .../java/chess/controller/WebChessController.java | 13 +++++++++++++ src/main/java/chess/controller/dao/PieceDAO.java | 6 +++--- 3 files changed, 24 insertions(+), 4 deletions(-) diff --git a/src/main/java/chess/WebUIChessApplication.java b/src/main/java/chess/WebUIChessApplication.java index b8b407cba15..e085b75ff49 100644 --- a/src/main/java/chess/WebUIChessApplication.java +++ b/src/main/java/chess/WebUIChessApplication.java @@ -52,6 +52,7 @@ public static void main(String[] args) { model.put("style", moveResultDto.getStyle()); if (webChessController.isEndGame()) { + webChessController.deleteChessGame(); return render(model, "end.html"); } return render(model, "game.html"); @@ -73,7 +74,13 @@ public static void main(String[] args) { post("/end", (req, res) -> { Map model = new HashMap<>(); - return render(model, "index.html"); + + webChessController.deleteChessGame(); + String message = webChessController.getScores(); + + model.put("message", message); + + return render(model, "end.html"); }); } diff --git a/src/main/java/chess/controller/WebChessController.java b/src/main/java/chess/controller/WebChessController.java index 5849a1f33a0..17369b7aa50 100644 --- a/src/main/java/chess/controller/WebChessController.java +++ b/src/main/java/chess/controller/WebChessController.java @@ -82,6 +82,7 @@ private void updateChessBoard(final String source, final String target) throws E pieceDAO.updatePiece(sourcePiece.get(), target); this.currentTeam = new CurrentTeam(this.chessRunner.getCurrentTeam()); currentTeamDAO.updateCurrentTeam(this.chessBoard.getChessBoardId(), this.currentTeam); + updateOriginalPieces(pieceDAO); } private String moveResult(final ChessRunner chessRunner, final String source, final String target) { @@ -95,6 +96,18 @@ public boolean isEndGame() { return this.chessRunner.isEndChess(); } + public void deleteChessGame() throws Exception { + ChessBoardDAO chessBoardDAO = new ChessBoardDAO(); + PieceDAO pieceDAO = new PieceDAO(); + CurrentTeamDAO currentTeamDAO = new CurrentTeamDAO(); + + currentTeamDAO.deleteCurrentTeam(this.chessBoard.getChessBoardId()); + for (PieceOnBoard pieceOnBoard : this.originalPieces.getPieceOnBoards()) { + pieceDAO.deletePiece(pieceOnBoard); + } + chessBoardDAO.deleteChessBoard(this.chessBoard); + } + public TeamDto getCurrentTeam() { return new TeamDto(this.chessRunner.getCurrentTeam()); } diff --git a/src/main/java/chess/controller/dao/PieceDAO.java b/src/main/java/chess/controller/dao/PieceDAO.java index 4c6a8726cb1..fe5cbc6f62c 100644 --- a/src/main/java/chess/controller/dao/PieceDAO.java +++ b/src/main/java/chess/controller/dao/PieceDAO.java @@ -47,15 +47,15 @@ public void updatePiece(PieceOnBoard piece) throws SQLException { ConnectionManager.closeConnection(con); } - public void deletePiece(PieceOnBoard a2WhitePawn) throws SQLException { - if (a2WhitePawn == null) { + public void deletePiece(PieceOnBoard piece) throws SQLException { + if (piece == null) { return; } Connection con = ConnectionManager.getConnection(); String query = "DELETE FROM piece WHERE pieceId = ?"; PreparedStatement pstmt = con.prepareStatement(query); - pstmt.setInt(1, a2WhitePawn.getPieceId()); + pstmt.setInt(1, piece.getPieceId()); pstmt.executeUpdate(); ConnectionManager.closeConnection(con); } From fd4d78e1b99e2ad2954729d7b5a5a4f8d7136dd6 Mon Sep 17 00:00:00 2001 From: giantim Date: Tue, 7 Apr 2020 01:42:59 +0900 Subject: [PATCH 51/75] =?UTF-8?q?refactor:=20=EC=9B=B9=EC=9D=98=20?= =?UTF-8?q?=EC=B2=B4=EC=8A=A4=20=EB=B3=B4=EB=93=9C=EC=9D=98=20=EA=B0=81=20?= =?UTF-8?q?=EC=B9=B8=EB=A7=88=EB=8B=A4=20=EC=9C=84=EC=B9=98=20=EA=B0=92=20?= =?UTF-8?q?=ED=91=9C=EC=8B=9C?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/main/resources/templates/css/game.css | 28 +++++++++++++++------- src/main/resources/templates/css/index.css | 7 +++--- src/main/resources/templates/game.html | 1 + src/main/resources/templates/index.html | 15 +++--------- 4 files changed, 27 insertions(+), 24 deletions(-) diff --git a/src/main/resources/templates/css/game.css b/src/main/resources/templates/css/game.css index c46f3980ccb..82182ceac53 100644 --- a/src/main/resources/templates/css/game.css +++ b/src/main/resources/templates/css/game.css @@ -6,17 +6,31 @@ } #chess-board { - width: 600px; + width: 800px; } #chess-board div { margin: 0; padding: 0; - width: 70px; - height: 70px; + width: 90px; + height: 90px; float: left; border: 1px solid; - text-align: center; + font-family: BMHANNAPro; +} + +#chess-board p { + float: left; + margin: 0; +} + +#chess-board img { + width: 50px; + height: 50px; + position: relative; + top: 60%; + left: 40%; + transform: translate(-60%, -40%); } .black { @@ -52,10 +66,6 @@ color: white; } -img { - width: 50px; -} - #source-label, #target-label { font-family: BMHANNAPro; @@ -65,7 +75,7 @@ img { #source, #target { font-family: BMHANNAPro; - size: 50; + size: 50px; } #currentTeam { diff --git a/src/main/resources/templates/css/index.css b/src/main/resources/templates/css/index.css index 377c311a7f0..aff52aae969 100644 --- a/src/main/resources/templates/css/index.css +++ b/src/main/resources/templates/css/index.css @@ -6,16 +6,17 @@ } #chess-board { - width: 600px; + width: 800px; } #chess-board div { margin: 0; padding: 0; - width: 70px; - height: 70px; + width: 90px; + height: 90px; float: left; border: 1px solid; + font-family: BMHANNAPro; } .black { diff --git a/src/main/resources/templates/game.html b/src/main/resources/templates/game.html index 877b614d861..ed370964f40 100644 --- a/src/main/resources/templates/game.html +++ b/src/main/resources/templates/game.html @@ -10,6 +10,7 @@
    {{#tiles}}
    +

    {{position}}

    {{#if pieceImageUrl}} {{/if}} diff --git a/src/main/resources/templates/index.html b/src/main/resources/templates/index.html index 5a93a51495d..f364db7f549 100644 --- a/src/main/resources/templates/index.html +++ b/src/main/resources/templates/index.html @@ -6,17 +6,8 @@ + - -
    -
    -
    - + +
    + + + +
    +
    +
    +
    diff --git a/src/main/resources/templates/table.html b/src/main/resources/templates/table.html index d5aba9f4f14..11fb940a04f 100644 --- a/src/main/resources/templates/table.html +++ b/src/main/resources/templates/table.html @@ -17,8 +17,8 @@ + {{#gameData}} - {{#gameData}}
    {{chessBoardId}} {{whitePlayer}} @@ -27,8 +27,8 @@
    - {{/gameData}} + {{/gameData}} diff --git a/src/test/java/chess/controller/dao/CurrentTeamDAOTest.java b/src/test/java/chess/controller/dao/CurrentTeamDAOTest.java index 4d830db5fa5..0b7c6c7a9c6 100644 --- a/src/test/java/chess/controller/dao/CurrentTeamDAOTest.java +++ b/src/test/java/chess/controller/dao/CurrentTeamDAOTest.java @@ -18,32 +18,37 @@ private void setUp() { @DisplayName("현재 팀 정보 추가") @Test void addCurrentTeamTest() throws Exception { + ChessBoard chessBoard = new ChessBoard(2); CurrentTeam currentTeam = new CurrentTeam("white"); - this.currentTeamDAO.addCurrentTeam(2, currentTeam); + this.currentTeamDAO.addCurrentTeam(chessBoard, currentTeam); } @Disabled @DisplayName("현재 팀 정보 업데이트") @Test void updateCurrentTeamTest() throws Exception { + ChessBoard chessBoard = new ChessBoard(2); CurrentTeam currentTeam = new CurrentTeam("black"); - this.currentTeamDAO.updateCurrentTeam(2, currentTeam); + this.currentTeamDAO.updateCurrentTeam(chessBoard, currentTeam); } @Disabled @DisplayName("현재 팀 삭제") @Test void deleteCurrentTeamTest() throws Exception { - this.currentTeamDAO.deleteCurrentTeam(2); + ChessBoard chessBoard = new ChessBoard(2); + + this.currentTeamDAO.deleteCurrentTeam(chessBoard); } @Disabled @DisplayName("현재 팀 검색") @Test void findCurrentTeamTest() throws Exception { - CurrentTeam currentTeam = currentTeamDAO.findCurrentTeam(3); + ChessBoard chessBoard = new ChessBoard(3); + CurrentTeam currentTeam = currentTeamDAO.findCurrentTeam(chessBoard); Assertions.assertThat(currentTeam).isNotNull(); Assertions.assertThat(currentTeam.getCurrentTeam()).isEqualTo("white"); diff --git a/src/test/java/chess/controller/dao/PieceDAOTest.java b/src/test/java/chess/controller/dao/PieceDAOTest.java index 2e338daeee9..75c7a853256 100644 --- a/src/test/java/chess/controller/dao/PieceDAOTest.java +++ b/src/test/java/chess/controller/dao/PieceDAOTest.java @@ -30,8 +30,9 @@ void addPieceTest() throws Exception { List tileDtos = new ArrayList<>(Arrays.asList( a2WhitePawn, a6BlackPawn )); + ChessBoard chessBoard = new ChessBoard(12); - pieceDAO.addPiece(12, tileDtos); + pieceDAO.addPiece(chessBoard, tileDtos); } @Disabled @@ -47,7 +48,8 @@ void deletePieceTest() throws Exception { @DisplayName("저장되어 있는 피스 정보 불러오기") @Test void findPieceTest() throws Exception { - List pieceOnBoards = pieceDAO.findPiece(12); + ChessBoard chessBoard = new ChessBoard(12); + List pieceOnBoards = pieceDAO.findPiece(chessBoard); Assertions.assertThat(pieceOnBoards).containsExactly( new PieceOnBoard(6, "a2", "p_white", 12), diff --git a/src/test/java/chess/controller/dao/PlayerDAOTest.java b/src/test/java/chess/controller/dao/PlayerDAOTest.java index 22c7622bf1d..23d69d02647 100644 --- a/src/test/java/chess/controller/dao/PlayerDAOTest.java +++ b/src/test/java/chess/controller/dao/PlayerDAOTest.java @@ -6,6 +6,8 @@ import org.junit.jupiter.api.DisplayName; import org.junit.jupiter.api.Test; +import java.util.List; + public class PlayerDAOTest { private PlayerDAO playerDAO; @@ -43,4 +45,15 @@ void deletePlayerTest() throws Exception { this.playerDAO.deletePlayer(chessBoard); } + + @Disabled + @DisplayName("전체 플레이어 정보 찾기") + @Test + void findAllPlayerTest() throws Exception { + List players = this.playerDAO.findAllPlayer(); + Player expected = new Player("pobi", "json"); + expected.setChessBoardId(8); + + Assertions.assertThat(players).contains(expected); + } } From f46bc67c927de452f70994973ebd52e05c181149 Mon Sep 17 00:00:00 2001 From: giantim Date: Tue, 7 Apr 2020 17:43:19 +0900 Subject: [PATCH 56/75] =?UTF-8?q?feat:=20=EA=B2=8C=EC=9E=84=20=EB=AA=A9?= =?UTF-8?q?=EB=A1=9D=EC=97=90=EC=84=9C=20=EB=B6=88=EB=9F=AC=EC=98=A4?= =?UTF-8?q?=EA=B8=B0=20=EA=B8=B0=EB=8A=A5=20=EA=B5=AC=ED=98=84(1)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/main/java/chess/WebUIChessApplication.java | 10 ++++++++++ src/main/resources/templates/game.html | 4 ++++ src/main/resources/templates/table.html | 6 +++--- 3 files changed, 17 insertions(+), 3 deletions(-) diff --git a/src/main/java/chess/WebUIChessApplication.java b/src/main/java/chess/WebUIChessApplication.java index 5fa448301da..2bde3f493e0 100644 --- a/src/main/java/chess/WebUIChessApplication.java +++ b/src/main/java/chess/WebUIChessApplication.java @@ -58,6 +58,16 @@ public static void main(String[] args) { return render(model, "game.html"); }); + post("/continueGame", (req, res) -> { + Map model = new HashMap<>(); + + int chessBoardId = Integer.parseInt(req.queryParams("chess-board-id")); + String whitePlayer = req.queryParams("white-player"); + String blackPlayer = req.queryParams("black-player"); + + return render(model, "game.html"); + }); + post("/move", (req, res) -> { Map model = new HashMap<>(); diff --git a/src/main/resources/templates/game.html b/src/main/resources/templates/game.html index ed370964f40..9d9ccf6ad35 100644 --- a/src/main/resources/templates/game.html +++ b/src/main/resources/templates/game.html @@ -19,6 +19,10 @@
    +

    White: {{player.whitePlayer}}

    +
    +

    Black: {{player.blackPlayer}}

    +

    현재 차례는 {{currentTeam.teamName}} 입니다


    diff --git a/src/main/resources/templates/table.html b/src/main/resources/templates/table.html index 11fb940a04f..5b32fd906aa 100644 --- a/src/main/resources/templates/table.html +++ b/src/main/resources/templates/table.html @@ -20,9 +20,9 @@ {{#gameData}} - {{chessBoardId}} - {{whitePlayer}} - {{blackPlayer}} + {{chessBoardId}} + {{whitePlayer}} + {{blackPlayer}} From 3fef55898db4124060a1e7dbd4d9ddb6baf84cff Mon Sep 17 00:00:00 2001 From: giantim Date: Wed, 8 Apr 2020 11:26:21 +0900 Subject: [PATCH 57/75] =?UTF-8?q?feat:=20=EA=B2=8C=EC=9E=84=20=EB=AA=A9?= =?UTF-8?q?=EB=A1=9D=EC=97=90=EC=84=9C=20=EB=B6=88=EB=9F=AC=EC=98=A4?= =?UTF-8?q?=EA=B8=B0=20=EA=B8=B0=EB=8A=A5=20=EA=B5=AC=ED=98=84(2)=20-=20?= =?UTF-8?q?=EB=8D=B0=EC=9D=B4=ED=84=B0=20=EB=B6=88=EB=9F=AC=EC=98=A4?= =?UTF-8?q?=EA=B8=B0=20=EA=B8=B0=EB=8A=A5=20=EA=B5=AC=ED=98=84?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../java/chess/WebUIChessApplication.java | 10 ++++++++ .../chess/controller/WebChessController.java | 24 +++++++++++++++++++ .../chess/controller/dao/ChessBoardDAO.java | 18 ++++++++++++++ src/main/resources/templates/css/game.css | 6 +++++ src/main/resources/templates/css/table.css | 10 +++++++- src/main/resources/templates/game.html | 1 - src/main/resources/templates/table.html | 12 +++++++--- .../controller/dao/ChessBoardDAOTest.java | 10 ++++++++ 8 files changed, 86 insertions(+), 5 deletions(-) diff --git a/src/main/java/chess/WebUIChessApplication.java b/src/main/java/chess/WebUIChessApplication.java index 2bde3f493e0..3bcefdacb4f 100644 --- a/src/main/java/chess/WebUIChessApplication.java +++ b/src/main/java/chess/WebUIChessApplication.java @@ -54,6 +54,7 @@ public static void main(String[] args) { model.put("tiles", tileDtos); model.put("currentTeam", teamDto); + model.put("player", player); return render(model, "game.html"); }); @@ -65,6 +66,15 @@ public static void main(String[] args) { String whitePlayer = req.queryParams("white-player"); String blackPlayer = req.queryParams("black-player"); + webChessController.continueGame(chessBoardId, whitePlayer, blackPlayer); + List tileDtos = webChessController.getTiles(); + TeamDto teamDto = webChessController.getCurrentTeam(); + Player player = webChessController.getPlayer(); + + model.put("tiles", tileDtos); + model.put("currentTeam", teamDto); + model.put("player", player); + return render(model, "game.html"); }); diff --git a/src/main/java/chess/controller/WebChessController.java b/src/main/java/chess/controller/WebChessController.java index ce9225442a3..75f739e2715 100644 --- a/src/main/java/chess/controller/WebChessController.java +++ b/src/main/java/chess/controller/WebChessController.java @@ -49,6 +49,30 @@ public List players() throws Exception { return Collections.unmodifiableList(playerDAO.findAllPlayer()); } + public Player getPlayer() throws Exception { + PlayerDAO playerDAO = new PlayerDAO(); + + return playerDAO.findPlayer(this.chessBoard); + } + + public void continueGame(int chessBoardId, String whitePlayer, String blackPlayer) throws Exception { + ChessBoardDAO chessBoardDAO = new ChessBoardDAO(); + CurrentTeamDAO currentTeamDAO = new CurrentTeamDAO(); + PieceDAO pieceDAO = new PieceDAO(); + PlayerDAO playerDAO = new PlayerDAO(); + + this.chessBoard = chessBoardDAO.findById(chessBoardId); + + this.currentTeam = currentTeamDAO.findCurrentTeam(this.chessBoard); + + updateOriginalPieces(pieceDAO); + Map pieceOnBoards = this.originalPieces.getPieceOnBoards().stream() + .collect(Collectors.toMap(entry -> entry.getPosition(), + entry -> entry.getPieceImageUrl(), + (e1, e2) -> e1, HashMap::new)); + this.chessRunner = new ChessRunner(pieceOnBoards, this.currentTeam.getCurrentTeam()); + } + public void start() throws Exception { ChessBoardDAO chessBoardDAO = new ChessBoardDAO(); CurrentTeamDAO currentTeamDAO = new CurrentTeamDAO(); diff --git a/src/main/java/chess/controller/dao/ChessBoardDAO.java b/src/main/java/chess/controller/dao/ChessBoardDAO.java index 4267a23cd7c..e3ddf86cb62 100644 --- a/src/main/java/chess/controller/dao/ChessBoardDAO.java +++ b/src/main/java/chess/controller/dao/ChessBoardDAO.java @@ -42,4 +42,22 @@ public void deleteChessBoard(ChessBoard chessBoard) throws SQLException { pstmt.executeUpdate(); ConnectionManager.closeConnection(con); } + + public ChessBoard findById(int chessBoardId) throws SQLException { + Connection con = ConnectionManager.getConnection(); + String query = "SELECT * FROM chessBoard WHERE chessBoardId=?"; + PreparedStatement pstmt = con.prepareStatement(query); + pstmt.setInt(1, chessBoardId); + ResultSet rs = pstmt.executeQuery(); + + while (!rs.next()) { + return null; + } + ChessBoard chessBoard = new ChessBoard( + rs.getInt("chessBoardId") + ); + ConnectionManager.closeConnection(con); + + return chessBoard; + } } diff --git a/src/main/resources/templates/css/game.css b/src/main/resources/templates/css/game.css index 82182ceac53..b1fd81dcf2c 100644 --- a/src/main/resources/templates/css/game.css +++ b/src/main/resources/templates/css/game.css @@ -5,6 +5,12 @@ src: url(../ttf/BMHANNAPro.ttf); } +#white-player, +#black-player { + font-family: BMHANNAPro; + font-size: 30px; +} + #chess-board { width: 800px; } diff --git a/src/main/resources/templates/css/table.css b/src/main/resources/templates/css/table.css index 4467e66149d..16d6176bb37 100644 --- a/src/main/resources/templates/css/table.css +++ b/src/main/resources/templates/css/table.css @@ -18,10 +18,18 @@ th, td { border: 1px solid black; height: 50px; - width: 100px; + width: 50px; text-align: center; } +#index, +#white-player, +#black-player { + width: 200px; + height: 50px; + font-size: 20px; +} + #game-start { width: 100px; height: 50px; diff --git a/src/main/resources/templates/game.html b/src/main/resources/templates/game.html index 9d9ccf6ad35..7a73001597d 100644 --- a/src/main/resources/templates/game.html +++ b/src/main/resources/templates/game.html @@ -20,7 +20,6 @@

    White: {{player.whitePlayer}}

    -

    Black: {{player.blackPlayer}}


    현재 차례는 {{currentTeam.teamName}} 입니다

    diff --git a/src/main/resources/templates/table.html b/src/main/resources/templates/table.html index 5b32fd906aa..b050060bbb1 100644 --- a/src/main/resources/templates/table.html +++ b/src/main/resources/templates/table.html @@ -20,9 +20,15 @@ {{#gameData}} - {{chessBoardId}} - {{whitePlayer}} - {{blackPlayer}} + + + + + + + + + diff --git a/src/test/java/chess/controller/dao/ChessBoardDAOTest.java b/src/test/java/chess/controller/dao/ChessBoardDAOTest.java index 63ada2996ad..d4f76b7f9d1 100644 --- a/src/test/java/chess/controller/dao/ChessBoardDAOTest.java +++ b/src/test/java/chess/controller/dao/ChessBoardDAOTest.java @@ -39,4 +39,14 @@ void deleteChessBoardTest() throws Exception { ChessBoard chessBoard = chessBoardDAO.findRecentChessBoard(); chessBoardDAO.deleteChessBoard(chessBoard); } + + @Disabled + @DisplayName("체스 보드 아이디로 체스 보드 찾기") + @Test + void findByIdTest() throws Exception { + int chessBoardId = 9; + ChessBoard expected = this.chessBoardDAO.findById(chessBoardId); + + Assertions.assertThat(expected.getChessBoardId()).isEqualTo(9); + } } From 2e747b9f57842a16f982bc1b87f148f0f86f2e89 Mon Sep 17 00:00:00 2001 From: giantim Date: Wed, 8 Apr 2020 13:05:37 +0900 Subject: [PATCH 58/75] =?UTF-8?q?feat:=20=EC=A2=85=EB=A3=8C=20=EA=B8=B0?= =?UTF-8?q?=EB=8A=A5=20=EA=B5=AC=ED=98=84=20refactor:=20=EB=94=94=EC=9E=90?= =?UTF-8?q?=EC=9D=B8=20=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../java/chess/WebUIChessApplication.java | 77 ++++++++----------- .../chess/controller/WebChessController.java | 32 +------- src/main/java/chess/domain/board/Tile.java | 2 +- src/main/resources/templates/css/end.css | 4 +- src/main/resources/templates/css/name.css | 8 +- src/main/resources/templates/end.html | 4 +- src/main/resources/templates/name.html | 2 +- 7 files changed, 45 insertions(+), 84 deletions(-) diff --git a/src/main/java/chess/WebUIChessApplication.java b/src/main/java/chess/WebUIChessApplication.java index 3bcefdacb4f..3fb6a524068 100644 --- a/src/main/java/chess/WebUIChessApplication.java +++ b/src/main/java/chess/WebUIChessApplication.java @@ -63,10 +63,8 @@ public static void main(String[] args) { Map model = new HashMap<>(); int chessBoardId = Integer.parseInt(req.queryParams("chess-board-id")); - String whitePlayer = req.queryParams("white-player"); - String blackPlayer = req.queryParams("black-player"); - webChessController.continueGame(chessBoardId, whitePlayer, blackPlayer); + webChessController.continueGame(chessBoardId); List tileDtos = webChessController.getTiles(); TeamDto teamDto = webChessController.getCurrentTeam(); Player player = webChessController.getPlayer(); @@ -75,7 +73,7 @@ public static void main(String[] args) { model.put("currentTeam", teamDto); model.put("player", player); - return render(model, "game.html"); + return render(model, "game.html"); }); post("/move", (req, res) -> { @@ -87,11 +85,13 @@ public static void main(String[] args) { MoveResultDto moveResultDto = webChessController.move(source, target); List tileDtos = webChessController.getTiles(); TeamDto teamDto = webChessController.getCurrentTeam(); + Player player = webChessController.getPlayer(); model.put("tiles", tileDtos); model.put("currentTeam", teamDto); model.put("message", moveResultDto.getMessage()); model.put("style", moveResultDto.getStyle()); + model.put("player", player); if (webChessController.isEndGame()) { webChessController.deleteChessGame(); @@ -100,49 +100,32 @@ public static void main(String[] args) { return render(model, "game.html"); }); -// get("/", (req, res) -> { -// Map model = new HashMap<>(); -// return render(model, "index2.html"); -// }); -// -// post("/game", (req, res) -> { -// Map model = new HashMap<>(); -// -// webChessController.start(); -// List tileDtos = webChessController.getTiles(); -// TeamDto teamDto = webChessController.getCurrentTeam(); -// -// model.put("tiles", tileDtos); -// model.put("currentTeam", teamDto); -// -// return render(model, "game.html"); -// }); -// -// -// post("/status", (req, res) -> { -// Map model = new HashMap<>(); -// -// List tileDtos = webChessController.getTiles(); -// TeamDto teamDto = webChessController.getCurrentTeam(); -// String message = webChessController.getScores(); -// -// model.put("tiles", tileDtos); -// model.put("currentTeam", teamDto); -// model.put("message", message); -// -// return render(model, "game.html"); -// }); -// -// post("/end", (req, res) -> { -// Map model = new HashMap<>(); -// -// webChessController.deleteChessGame(); -// String message = webChessController.getScores(); -// -// model.put("message", message); -// -// return render(model, "end.html"); -// }); + post("/status", (req, res) -> { + Map model = new HashMap<>(); + + List tileDtos = webChessController.getTiles(); + TeamDto teamDto = webChessController.getCurrentTeam(); + String message = webChessController.getScores(); + Player player = webChessController.getPlayer(); + + model.put("tiles", tileDtos); + model.put("currentTeam", teamDto); + model.put("message", message); + model.put("player", player); + + return render(model, "game.html"); + }); + + post("/end", (req, res) -> { + Map model = new HashMap<>(); + + webChessController.deleteChessGame(); + String message = webChessController.getScores(); + + model.put("message", message); + + return render(model, "end.html"); + }); } private static String render(Map model, String templatePath) { diff --git a/src/main/java/chess/controller/WebChessController.java b/src/main/java/chess/controller/WebChessController.java index 75f739e2715..e7b91d87fce 100644 --- a/src/main/java/chess/controller/WebChessController.java +++ b/src/main/java/chess/controller/WebChessController.java @@ -55,11 +55,10 @@ public Player getPlayer() throws Exception { return playerDAO.findPlayer(this.chessBoard); } - public void continueGame(int chessBoardId, String whitePlayer, String blackPlayer) throws Exception { + public void continueGame(int chessBoardId) throws Exception { ChessBoardDAO chessBoardDAO = new ChessBoardDAO(); CurrentTeamDAO currentTeamDAO = new CurrentTeamDAO(); PieceDAO pieceDAO = new PieceDAO(); - PlayerDAO playerDAO = new PlayerDAO(); this.chessBoard = chessBoardDAO.findById(chessBoardId); @@ -73,33 +72,6 @@ public void continueGame(int chessBoardId, String whitePlayer, String blackPlaye this.chessRunner = new ChessRunner(pieceOnBoards, this.currentTeam.getCurrentTeam()); } - public void start() throws Exception { - ChessBoardDAO chessBoardDAO = new ChessBoardDAO(); - CurrentTeamDAO currentTeamDAO = new CurrentTeamDAO(); - PieceDAO pieceDAO = new PieceDAO(); - this.chessBoard = chessBoardDAO.findRecentChessBoard(); - - if (this.chessBoard == null) { - this.chessRunner = new ChessRunner(); - chessBoardDAO.addChessBoard(); - this.chessBoard = chessBoardDAO.findRecentChessBoard(); - this.currentTeam = new CurrentTeam(this.chessRunner.getCurrentTeam()); - currentTeamDAO.addCurrentTeam(this.chessBoard, this.currentTeam); - List tileDtos = this.chessRunner.pieceTileDtos(); - pieceDAO.addPiece(this.chessBoard, tileDtos); - updateOriginalPieces(pieceDAO); - return; - } - - updateOriginalPieces(pieceDAO); - Map pieceOnBoards = this.originalPieces.getPieceOnBoards().stream() - .collect(Collectors.toMap(entry -> entry.getPosition(), - entry -> entry.getPieceImageUrl(), - (e1, e2) -> e1, HashMap::new)); - this.currentTeam = currentTeamDAO.findCurrentTeam(this.chessBoard); - this.chessRunner = new ChessRunner(pieceOnBoards, this.currentTeam.getCurrentTeam()); - } - private void updateOriginalPieces(PieceDAO pieceDAO) throws Exception { List pieces = pieceDAO.findPiece(this.chessBoard); this.originalPieces = PieceOnBoards.of(pieces); @@ -148,11 +120,13 @@ public void deleteChessGame() throws Exception { ChessBoardDAO chessBoardDAO = new ChessBoardDAO(); PieceDAO pieceDAO = new PieceDAO(); CurrentTeamDAO currentTeamDAO = new CurrentTeamDAO(); + PlayerDAO playerDAO = new PlayerDAO(); currentTeamDAO.deleteCurrentTeam(this.chessBoard); for (PieceOnBoard pieceOnBoard : this.originalPieces.getPieceOnBoards()) { pieceDAO.deletePiece(pieceOnBoard); } + playerDAO.deletePlayer(this.chessBoard); chessBoardDAO.deleteChessBoard(this.chessBoard); } diff --git a/src/main/java/chess/domain/board/Tile.java b/src/main/java/chess/domain/board/Tile.java index 5e6aa6fde6f..edca44f63a2 100644 --- a/src/main/java/chess/domain/board/Tile.java +++ b/src/main/java/chess/domain/board/Tile.java @@ -5,7 +5,7 @@ public class Tile { private static final String UNDER_BAR = "_"; - + private final Position position; private final Piece piece; diff --git a/src/main/resources/templates/css/end.css b/src/main/resources/templates/css/end.css index 2fef2cb16f8..3409a052e61 100644 --- a/src/main/resources/templates/css/end.css +++ b/src/main/resources/templates/css/end.css @@ -9,7 +9,7 @@ h1 { font-family: BMHANNAPro; } -#restart-button { +#menu-button { width: 80px; height: 50px; font-family: BMHANNAPro; @@ -18,7 +18,7 @@ h1 { font-size: 20px; } -#restart-button:hover { +#menu-button:hover { background-color: black; color: white; } \ No newline at end of file diff --git a/src/main/resources/templates/css/name.css b/src/main/resources/templates/css/name.css index d9ef25b6ac9..06ec899176d 100644 --- a/src/main/resources/templates/css/name.css +++ b/src/main/resources/templates/css/name.css @@ -5,12 +5,14 @@ src: url(../ttf/BMHANNAPro.ttf); } -div { +#name-label { font-family: BMHANNAPro; + font-size: 30px; } #white-label, -#black-label {; +#black-label { + font-family: BMHANNAPro; font-size: 30px; } @@ -18,9 +20,11 @@ div { #black-team { font-family: BMHANNAPro; font-size: 30px; + width: 200px; } #submit-button { + font-family: BMHANNAPro; width: 80px; height: 50px; border: solid 1px; diff --git a/src/main/resources/templates/end.html b/src/main/resources/templates/end.html index 2718198851c..91282537362 100644 --- a/src/main/resources/templates/end.html +++ b/src/main/resources/templates/end.html @@ -10,8 +10,8 @@

    {{message}}

    - - + + diff --git a/src/main/resources/templates/name.html b/src/main/resources/templates/name.html index 0e3dea0665e..89433a7a6ee 100644 --- a/src/main/resources/templates/name.html +++ b/src/main/resources/templates/name.html @@ -8,7 +8,7 @@
    - 이름을 입력하세요. +

    이름을 입력하세요.

    From 6fe417bad8c0f025d1bb99eb1b57aa735d6fd416 Mon Sep 17 00:00:00 2001 From: giantim Date: Wed, 8 Apr 2020 22:19:34 +0900 Subject: [PATCH 59/75] =?UTF-8?q?refactor:=20DAO=20=EC=9D=98=20=EC=BD=94?= =?UTF-8?q?=EB=93=9C=20=EC=88=98=EC=A0=95=20/=20=EC=97=B0=EA=B2=B0?= =?UTF-8?q?=ED=95=98=EB=8A=94=20DB=20=EB=B3=80=EA=B2=BD?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../chess/controller/WebChessController.java | 2 +- .../java/chess/controller/dao/ChessBoardDAO.java | 16 +++++++--------- .../chess/controller/dao/ConnectionManager.java | 2 +- .../chess/controller/dao/CurrentTeamDAO.java | 7 ++++--- src/main/java/chess/controller/dao/PieceDAO.java | 1 - .../java/chess/controller/dao/PieceOnBoards.java | 2 +- .../java/chess/controller/dao/PlayerDAO.java | 1 - 7 files changed, 14 insertions(+), 17 deletions(-) diff --git a/src/main/java/chess/controller/WebChessController.java b/src/main/java/chess/controller/WebChessController.java index e7b91d87fce..95f19a90c2f 100644 --- a/src/main/java/chess/controller/WebChessController.java +++ b/src/main/java/chess/controller/WebChessController.java @@ -74,7 +74,7 @@ public void continueGame(int chessBoardId) throws Exception { private void updateOriginalPieces(PieceDAO pieceDAO) throws Exception { List pieces = pieceDAO.findPiece(this.chessBoard); - this.originalPieces = PieceOnBoards.of(pieces); + this.originalPieces = PieceOnBoards.create(pieces); } public MoveResultDto move(final String source, final String target) throws Exception { diff --git a/src/main/java/chess/controller/dao/ChessBoardDAO.java b/src/main/java/chess/controller/dao/ChessBoardDAO.java index e3ddf86cb62..4a3d244bc55 100644 --- a/src/main/java/chess/controller/dao/ChessBoardDAO.java +++ b/src/main/java/chess/controller/dao/ChessBoardDAO.java @@ -1,22 +1,19 @@ package chess.controller.dao; -import java.sql.Connection; -import java.sql.PreparedStatement; -import java.sql.ResultSet; -import java.sql.SQLException; +import java.sql.*; public class ChessBoardDAO { public void addChessBoard() throws SQLException { - String query = "INSERT INTO chessBoard VALUES()"; Connection con = ConnectionManager.getConnection(); + String query = "INSERT INTO chessBoard VALUES()"; PreparedStatement pstmt = con.prepareStatement(query); pstmt.executeUpdate(); ConnectionManager.closeConnection(con); } public ChessBoard findRecentChessBoard() throws SQLException { - String query = "SELECT * FROM chessBoard ORDER BY chessBoardId DESC limit 1"; Connection con = ConnectionManager.getConnection(); + String query = "SELECT * FROM chessBoard ORDER BY chessBoardId DESC limit 1"; PreparedStatement pstmt = con.prepareStatement(query); ResultSet rs = pstmt.executeQuery(); @@ -25,7 +22,9 @@ public ChessBoard findRecentChessBoard() throws SQLException { return null; } - ChessBoard chessBoard = new ChessBoard(rs.getInt("chessBoardId")); + ChessBoard chessBoard = new ChessBoard( + rs.getInt("chessBoardId") + ); ConnectionManager.closeConnection(con); return chessBoard; } @@ -35,8 +34,8 @@ public void deleteChessBoard(ChessBoard chessBoard) throws SQLException { return; } - String query = "DELETE FROM chessBoard WHERE chessBoardId = ?"; Connection con = ConnectionManager.getConnection(); + String query = "DELETE FROM chessBoard WHERE chessBoardId = ?"; PreparedStatement pstmt = con.prepareStatement(query); pstmt.setInt(1, chessBoard.getChessBoardId()); pstmt.executeUpdate(); @@ -57,7 +56,6 @@ public ChessBoard findById(int chessBoardId) throws SQLException { rs.getInt("chessBoardId") ); ConnectionManager.closeConnection(con); - return chessBoard; } } diff --git a/src/main/java/chess/controller/dao/ConnectionManager.java b/src/main/java/chess/controller/dao/ConnectionManager.java index 5c950dbc617..c4c9531c893 100644 --- a/src/main/java/chess/controller/dao/ConnectionManager.java +++ b/src/main/java/chess/controller/dao/ConnectionManager.java @@ -11,7 +11,7 @@ private ConnectionManager() { public static Connection getConnection() { Connection con = null; String server = "localhost:13306"; - String database = "chess"; + String database = "webChess"; String option = "?useSSL=false&serverTimezone=UTC"; String userName = "root"; String password = "root"; diff --git a/src/main/java/chess/controller/dao/CurrentTeamDAO.java b/src/main/java/chess/controller/dao/CurrentTeamDAO.java index b4cd6e3c277..8648f55e820 100644 --- a/src/main/java/chess/controller/dao/CurrentTeamDAO.java +++ b/src/main/java/chess/controller/dao/CurrentTeamDAO.java @@ -37,7 +37,7 @@ public void deleteCurrentTeam(ChessBoard chessBoard) throws SQLException { public CurrentTeam findCurrentTeam(ChessBoard chessBoard) throws SQLException { Connection con = ConnectionManager.getConnection(); - String query = "SELECT * FROM currentTeam WHERE chessBoardId = ?"; + String query = "SELECT team FROM currentTeam WHERE chessBoardId = ?"; PreparedStatement pstmt = con.prepareStatement(query); pstmt.setInt(1, chessBoard.getChessBoardId()); ResultSet rs = pstmt.executeQuery(); @@ -45,9 +45,10 @@ public CurrentTeam findCurrentTeam(ChessBoard chessBoard) throws SQLException { while (!rs.next()) { return null; } - - return new CurrentTeam( + CurrentTeam currentTeam = new CurrentTeam( rs.getString("team") ); + ConnectionManager.closeConnection(con); + return currentTeam; } } diff --git a/src/main/java/chess/controller/dao/PieceDAO.java b/src/main/java/chess/controller/dao/PieceDAO.java index ef34e9d63dc..5effa6596b9 100644 --- a/src/main/java/chess/controller/dao/PieceDAO.java +++ b/src/main/java/chess/controller/dao/PieceDAO.java @@ -56,7 +56,6 @@ public List findPiece(ChessBoard chessBoard) throws SQLException { ); pieceOnBoards.add(pieceOnBoard); } - return Collections.unmodifiableList(pieceOnBoards); } diff --git a/src/main/java/chess/controller/dao/PieceOnBoards.java b/src/main/java/chess/controller/dao/PieceOnBoards.java index 51a9f35ef21..4232a5c8169 100644 --- a/src/main/java/chess/controller/dao/PieceOnBoards.java +++ b/src/main/java/chess/controller/dao/PieceOnBoards.java @@ -11,7 +11,7 @@ private PieceOnBoards(List pieceOnBoards) { this.pieceOnBoards = pieceOnBoards; } - public static PieceOnBoards of(List pieceOnBoards) { + public static PieceOnBoards create(List pieceOnBoards) { return new PieceOnBoards(pieceOnBoards); } diff --git a/src/main/java/chess/controller/dao/PlayerDAO.java b/src/main/java/chess/controller/dao/PlayerDAO.java index 454aa271f0d..e2aadf532f4 100644 --- a/src/main/java/chess/controller/dao/PlayerDAO.java +++ b/src/main/java/chess/controller/dao/PlayerDAO.java @@ -62,7 +62,6 @@ public List findAllPlayer() throws SQLException { player.setChessBoardId(rs.getInt("chessBoardId")); players.add(player); } - return players; } } From 23b2f34b0255baf0536a5d777e0956a50b0c876e Mon Sep 17 00:00:00 2001 From: giantim Date: Thu, 9 Apr 2020 20:18:09 +0900 Subject: [PATCH 60/75] =?UTF-8?q?refactor:=20Service=20Layer=20=EC=B6=94?= =?UTF-8?q?=EA=B0=80=20/=20DAO,=20DTO=20=ED=8C=A8=ED=82=A4=EC=A7=80=20?= =?UTF-8?q?=EC=9D=B4=EB=8F=99?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../java/chess/WebUIChessApplication.java | 26 +++++++-------- .../chess/controller/ChessController.java | 4 +-- .../java/chess/controller/GameController.java | 8 ++--- .../chess/controller/StatusController.java | 4 +-- .../chess/controller/WebChessController.java | 22 ++++++------- .../{controller => }/dao/ChessBoard.java | 2 +- .../{controller => }/dao/ChessBoardDAO.java | 7 ++-- .../dao/ConnectionManager.java | 2 +- .../{controller => }/dao/CurrentTeam.java | 2 +- .../{controller => }/dao/CurrentTeamDAO.java | 2 +- .../chess/{controller => }/dao/PieceDAO.java | 8 ++--- .../{controller => }/dao/PieceOnBoard.java | 2 +- .../{controller => }/dao/PieceOnBoards.java | 2 +- .../chess/{controller => }/dao/Player.java | 2 +- .../chess/{controller => }/dao/PlayerDAO.java | 2 +- src/main/java/chess/domain/ChessRunner.java | 32 +++++++++---------- .../dto/BoardDto.java => dto/BoardDTO.java} | 6 ++-- .../BoardScoreDTO.java} | 6 ++-- .../MoveResultDTO.java} | 6 ++-- .../PositionDto.java => dto/PositionDTO.java} | 6 ++-- .../dto/StatusDto.java => dto/StatusDTO.java} | 6 ++-- .../dto/TeamDto.java => dto/TeamDTO.java} | 6 ++-- .../dto/TileDto.java => dto/TileDTO.java} | 6 ++-- src/main/java/chess/service/ChessService.java | 4 +++ .../dao/ChessBoardDAOTest.java | 2 +- .../dao/ConnectionManagerTest.java | 2 +- .../dao/CurrentTeamDAOTest.java | 2 +- .../{controller => }/dao/PieceDAOTest.java | 10 +++--- .../{controller => }/dao/PlayerDAOTest.java | 2 +- .../java/chess/domain/ChessRunnerTest.java | 4 +-- 30 files changed, 101 insertions(+), 94 deletions(-) rename src/main/java/chess/{controller => }/dao/ChessBoard.java (95%) rename src/main/java/chess/{controller => }/dao/ChessBoardDAO.java (93%) rename src/main/java/chess/{controller => }/dao/ConnectionManager.java (97%) rename src/main/java/chess/{controller => }/dao/CurrentTeam.java (95%) rename src/main/java/chess/{controller => }/dao/CurrentTeamDAO.java (98%) rename src/main/java/chess/{controller => }/dao/PieceDAO.java (93%) rename src/main/java/chess/{controller => }/dao/PieceOnBoard.java (97%) rename src/main/java/chess/{controller => }/dao/PieceOnBoards.java (96%) rename src/main/java/chess/{controller => }/dao/Player.java (97%) rename src/main/java/chess/{controller => }/dao/PlayerDAO.java (98%) rename src/main/java/chess/{controller/dto/BoardDto.java => dto/BoardDTO.java} (68%) rename src/main/java/chess/{controller/dto/BoardScoreDto.java => dto/BoardScoreDTO.java} (74%) rename src/main/java/chess/{controller/dto/MoveResultDto.java => dto/MoveResultDTO.java} (69%) rename src/main/java/chess/{controller/dto/PositionDto.java => dto/PositionDTO.java} (68%) rename src/main/java/chess/{controller/dto/StatusDto.java => dto/StatusDTO.java} (60%) rename src/main/java/chess/{controller/dto/TeamDto.java => dto/TeamDTO.java} (59%) rename src/main/java/chess/{controller/dto/TileDto.java => dto/TileDTO.java} (88%) create mode 100644 src/main/java/chess/service/ChessService.java rename src/test/java/chess/{controller => }/dao/ChessBoardDAOTest.java (98%) rename src/test/java/chess/{controller => }/dao/ConnectionManagerTest.java (92%) rename src/test/java/chess/{controller => }/dao/CurrentTeamDAOTest.java (98%) rename src/test/java/chess/{controller => }/dao/PieceDAOTest.java (88%) rename src/test/java/chess/{controller => }/dao/PlayerDAOTest.java (98%) diff --git a/src/main/java/chess/WebUIChessApplication.java b/src/main/java/chess/WebUIChessApplication.java index 3fb6a524068..4a915166fdc 100644 --- a/src/main/java/chess/WebUIChessApplication.java +++ b/src/main/java/chess/WebUIChessApplication.java @@ -1,10 +1,10 @@ package chess; import chess.controller.WebChessController; -import chess.controller.dao.Player; -import chess.controller.dto.MoveResultDto; -import chess.controller.dto.TeamDto; -import chess.controller.dto.TileDto; +import chess.dao.Player; +import chess.dto.MoveResultDTO; +import chess.dto.TeamDTO; +import chess.dto.TileDTO; import spark.ModelAndView; import spark.template.handlebars.HandlebarsTemplateEngine; @@ -49,8 +49,8 @@ public static void main(String[] args) { Player player = new Player(whitePlayer, blackPlayer); webChessController.newGame(player); - List tileDtos = webChessController.getTiles(); - TeamDto teamDto = webChessController.getCurrentTeam(); + List tileDtos = webChessController.getTiles(); + TeamDTO teamDto = webChessController.getCurrentTeam(); model.put("tiles", tileDtos); model.put("currentTeam", teamDto); @@ -65,8 +65,8 @@ public static void main(String[] args) { int chessBoardId = Integer.parseInt(req.queryParams("chess-board-id")); webChessController.continueGame(chessBoardId); - List tileDtos = webChessController.getTiles(); - TeamDto teamDto = webChessController.getCurrentTeam(); + List tileDtos = webChessController.getTiles(); + TeamDTO teamDto = webChessController.getCurrentTeam(); Player player = webChessController.getPlayer(); model.put("tiles", tileDtos); @@ -82,9 +82,9 @@ public static void main(String[] args) { String source = req.queryParams("source"); String target = req.queryParams("target"); - MoveResultDto moveResultDto = webChessController.move(source, target); - List tileDtos = webChessController.getTiles(); - TeamDto teamDto = webChessController.getCurrentTeam(); + MoveResultDTO moveResultDto = webChessController.move(source, target); + List tileDtos = webChessController.getTiles(); + TeamDTO teamDto = webChessController.getCurrentTeam(); Player player = webChessController.getPlayer(); model.put("tiles", tileDtos); @@ -103,8 +103,8 @@ public static void main(String[] args) { post("/status", (req, res) -> { Map model = new HashMap<>(); - List tileDtos = webChessController.getTiles(); - TeamDto teamDto = webChessController.getCurrentTeam(); + List tileDtos = webChessController.getTiles(); + TeamDTO teamDto = webChessController.getCurrentTeam(); String message = webChessController.getScores(); Player player = webChessController.getPlayer(); diff --git a/src/main/java/chess/controller/ChessController.java b/src/main/java/chess/controller/ChessController.java index c5124a28527..e1c211e1ff1 100644 --- a/src/main/java/chess/controller/ChessController.java +++ b/src/main/java/chess/controller/ChessController.java @@ -1,7 +1,7 @@ package chess.controller; -import chess.controller.dto.TeamDto; import chess.domain.ChessRunner; +import chess.dto.TeamDTO; import chess.view.ConsoleInputView; import chess.view.ConsoleOutputView; import chess.view.InputView; @@ -75,7 +75,7 @@ private static Command executeByCommand(Command command, ChessRunner chessRunner private static void printWinner(ChessRunner chessRunner) { if (chessRunner.isEndChess()) { - TeamDto teamDto = new TeamDto(chessRunner.getWinner()); + TeamDTO teamDto = new TeamDTO(chessRunner.getWinner()); outputView.printWinner(teamDto.getTeamName()); } } diff --git a/src/main/java/chess/controller/GameController.java b/src/main/java/chess/controller/GameController.java index ce494b93043..69f9679c117 100644 --- a/src/main/java/chess/controller/GameController.java +++ b/src/main/java/chess/controller/GameController.java @@ -1,9 +1,9 @@ package chess.controller; -import chess.controller.dto.BoardDto; -import chess.controller.dto.PositionDto; import chess.domain.ChessRunner; import chess.domain.position.Position; +import chess.dto.BoardDTO; +import chess.dto.PositionDTO; import chess.view.ConsoleOutputView; import chess.view.OutputView; @@ -17,8 +17,8 @@ public GameController() { } protected void printBoard(final Map board) { - BoardDto boardDto = new BoardDto(board); - PositionDto positionDto = new PositionDto(Position.getPositions()); + BoardDTO boardDto = new BoardDTO(board); + PositionDTO positionDto = new PositionDTO(Position.getPositions()); this.outputView.printBoard(positionDto.getPositions(), boardDto.get()); } diff --git a/src/main/java/chess/controller/StatusController.java b/src/main/java/chess/controller/StatusController.java index 010797003d2..e59a311ab72 100644 --- a/src/main/java/chess/controller/StatusController.java +++ b/src/main/java/chess/controller/StatusController.java @@ -1,7 +1,7 @@ package chess.controller; -import chess.controller.dto.BoardScoreDto; import chess.domain.ChessRunner; +import chess.dto.BoardScoreDTO; import java.util.List; import java.util.stream.Collectors; @@ -16,7 +16,7 @@ public StatusController() { @Override public void execute(ChessRunner chessRunner, String input) { - List boardScoreDtos = chessRunner.calculateScores(); + List boardScoreDtos = chessRunner.calculateScores(); String scores = boardScoreDtos.stream() .map(dto -> dto.getTeam() + DELIMITER + dto.getBoardScore()) .collect(Collectors.joining(NEW_LINE)); diff --git a/src/main/java/chess/controller/WebChessController.java b/src/main/java/chess/controller/WebChessController.java index 95f19a90c2f..4487caab0ba 100644 --- a/src/main/java/chess/controller/WebChessController.java +++ b/src/main/java/chess/controller/WebChessController.java @@ -1,10 +1,10 @@ package chess.controller; -import chess.controller.dao.*; -import chess.controller.dto.MoveResultDto; -import chess.controller.dto.TeamDto; -import chess.controller.dto.TileDto; +import chess.dao.*; import chess.domain.ChessRunner; +import chess.dto.MoveResultDTO; +import chess.dto.TeamDTO; +import chess.dto.TileDTO; import java.util.*; import java.util.stream.Collectors; @@ -36,7 +36,7 @@ public void newGame(Player player) throws Exception { this.currentTeam = new CurrentTeam(this.chessRunner.getCurrentTeam()); currentTeamDAO.addCurrentTeam(this.chessBoard, this.currentTeam); - List tileDtos = this.chessRunner.pieceTileDtos(); + List tileDtos = this.chessRunner.pieceTileDtos(); pieceDAO.addPiece(this.chessBoard, tileDtos); updateOriginalPieces(pieceDAO); @@ -77,14 +77,14 @@ private void updateOriginalPieces(PieceDAO pieceDAO) throws Exception { this.originalPieces = PieceOnBoards.create(pieces); } - public MoveResultDto move(final String source, final String target) throws Exception { + public MoveResultDTO move(final String source, final String target) throws Exception { try { this.chessRunner.update(source, target); updateChessBoard(source, target); String moveResult = moveResult(this.chessRunner, source, target); - return new MoveResultDto(moveResult, MESSAGE_STYLE_BLACK); + return new MoveResultDTO(moveResult, MESSAGE_STYLE_BLACK); } catch (IllegalArgumentException | StringIndexOutOfBoundsException e) { - return new MoveResultDto(e.getMessage(), MESSAGE_STYLE_RED); + return new MoveResultDTO(e.getMessage(), MESSAGE_STYLE_RED); } } @@ -130,11 +130,11 @@ public void deleteChessGame() throws Exception { chessBoardDAO.deleteChessBoard(this.chessBoard); } - public TeamDto getCurrentTeam() { - return new TeamDto(this.chessRunner.getCurrentTeam()); + public TeamDTO getCurrentTeam() { + return new TeamDTO(this.chessRunner.getCurrentTeam()); } - public List getTiles() { + public List getTiles() { return this.chessRunner.entireTileDtos(); } diff --git a/src/main/java/chess/controller/dao/ChessBoard.java b/src/main/java/chess/dao/ChessBoard.java similarity index 95% rename from src/main/java/chess/controller/dao/ChessBoard.java rename to src/main/java/chess/dao/ChessBoard.java index bc30989d8b8..66706ae7964 100644 --- a/src/main/java/chess/controller/dao/ChessBoard.java +++ b/src/main/java/chess/dao/ChessBoard.java @@ -1,4 +1,4 @@ -package chess.controller.dao; +package chess.dao; import java.util.Objects; diff --git a/src/main/java/chess/controller/dao/ChessBoardDAO.java b/src/main/java/chess/dao/ChessBoardDAO.java similarity index 93% rename from src/main/java/chess/controller/dao/ChessBoardDAO.java rename to src/main/java/chess/dao/ChessBoardDAO.java index 4a3d244bc55..53b55ef1cba 100644 --- a/src/main/java/chess/controller/dao/ChessBoardDAO.java +++ b/src/main/java/chess/dao/ChessBoardDAO.java @@ -1,6 +1,9 @@ -package chess.controller.dao; +package chess.dao; -import java.sql.*; +import java.sql.Connection; +import java.sql.PreparedStatement; +import java.sql.ResultSet; +import java.sql.SQLException; public class ChessBoardDAO { public void addChessBoard() throws SQLException { diff --git a/src/main/java/chess/controller/dao/ConnectionManager.java b/src/main/java/chess/dao/ConnectionManager.java similarity index 97% rename from src/main/java/chess/controller/dao/ConnectionManager.java rename to src/main/java/chess/dao/ConnectionManager.java index c4c9531c893..14329a60c0e 100644 --- a/src/main/java/chess/controller/dao/ConnectionManager.java +++ b/src/main/java/chess/dao/ConnectionManager.java @@ -1,4 +1,4 @@ -package chess.controller.dao; +package chess.dao; import java.sql.Connection; import java.sql.DriverManager; diff --git a/src/main/java/chess/controller/dao/CurrentTeam.java b/src/main/java/chess/dao/CurrentTeam.java similarity index 95% rename from src/main/java/chess/controller/dao/CurrentTeam.java rename to src/main/java/chess/dao/CurrentTeam.java index 636376ea6ee..164f465c7dd 100644 --- a/src/main/java/chess/controller/dao/CurrentTeam.java +++ b/src/main/java/chess/dao/CurrentTeam.java @@ -1,4 +1,4 @@ -package chess.controller.dao; +package chess.dao; import java.util.Objects; diff --git a/src/main/java/chess/controller/dao/CurrentTeamDAO.java b/src/main/java/chess/dao/CurrentTeamDAO.java similarity index 98% rename from src/main/java/chess/controller/dao/CurrentTeamDAO.java rename to src/main/java/chess/dao/CurrentTeamDAO.java index 8648f55e820..7949e7dc6fe 100644 --- a/src/main/java/chess/controller/dao/CurrentTeamDAO.java +++ b/src/main/java/chess/dao/CurrentTeamDAO.java @@ -1,4 +1,4 @@ -package chess.controller.dao; +package chess.dao; import java.sql.Connection; import java.sql.PreparedStatement; diff --git a/src/main/java/chess/controller/dao/PieceDAO.java b/src/main/java/chess/dao/PieceDAO.java similarity index 93% rename from src/main/java/chess/controller/dao/PieceDAO.java rename to src/main/java/chess/dao/PieceDAO.java index 5effa6596b9..c8ccb012281 100644 --- a/src/main/java/chess/controller/dao/PieceDAO.java +++ b/src/main/java/chess/dao/PieceDAO.java @@ -1,6 +1,6 @@ -package chess.controller.dao; +package chess.dao; -import chess.controller.dto.TileDto; +import chess.dto.TileDTO; import java.sql.Connection; import java.sql.PreparedStatement; @@ -11,9 +11,9 @@ import java.util.List; public class PieceDAO { - public void addPiece(ChessBoard chessBoard, List tileDtos) throws SQLException { + public void addPiece(ChessBoard chessBoard, List tileDtos) throws SQLException { Connection con = ConnectionManager.getConnection(); - for (TileDto tileDto : tileDtos) { + for (TileDTO tileDto : tileDtos) { String query = "INSERT INTO piece (position, pieceImageUrl, chessBoardId) " + "VALUES(?, ?, ?)"; PreparedStatement pstmt = con.prepareStatement(query); diff --git a/src/main/java/chess/controller/dao/PieceOnBoard.java b/src/main/java/chess/dao/PieceOnBoard.java similarity index 97% rename from src/main/java/chess/controller/dao/PieceOnBoard.java rename to src/main/java/chess/dao/PieceOnBoard.java index aa435866352..81de99ba852 100644 --- a/src/main/java/chess/controller/dao/PieceOnBoard.java +++ b/src/main/java/chess/dao/PieceOnBoard.java @@ -1,4 +1,4 @@ -package chess.controller.dao; +package chess.dao; import java.util.Objects; diff --git a/src/main/java/chess/controller/dao/PieceOnBoards.java b/src/main/java/chess/dao/PieceOnBoards.java similarity index 96% rename from src/main/java/chess/controller/dao/PieceOnBoards.java rename to src/main/java/chess/dao/PieceOnBoards.java index 4232a5c8169..e53bf70bd5e 100644 --- a/src/main/java/chess/controller/dao/PieceOnBoards.java +++ b/src/main/java/chess/dao/PieceOnBoards.java @@ -1,4 +1,4 @@ -package chess.controller.dao; +package chess.dao; import java.util.Collections; import java.util.List; diff --git a/src/main/java/chess/controller/dao/Player.java b/src/main/java/chess/dao/Player.java similarity index 97% rename from src/main/java/chess/controller/dao/Player.java rename to src/main/java/chess/dao/Player.java index 2a5b4388a8e..8cab261a013 100644 --- a/src/main/java/chess/controller/dao/Player.java +++ b/src/main/java/chess/dao/Player.java @@ -1,4 +1,4 @@ -package chess.controller.dao; +package chess.dao; import java.util.Objects; diff --git a/src/main/java/chess/controller/dao/PlayerDAO.java b/src/main/java/chess/dao/PlayerDAO.java similarity index 98% rename from src/main/java/chess/controller/dao/PlayerDAO.java rename to src/main/java/chess/dao/PlayerDAO.java index e2aadf532f4..7c3708adda4 100644 --- a/src/main/java/chess/controller/dao/PlayerDAO.java +++ b/src/main/java/chess/dao/PlayerDAO.java @@ -1,4 +1,4 @@ -package chess.controller.dao; +package chess.dao; import java.sql.Connection; import java.sql.PreparedStatement; diff --git a/src/main/java/chess/domain/ChessRunner.java b/src/main/java/chess/domain/ChessRunner.java index 4769484ee03..03fc7d342ac 100644 --- a/src/main/java/chess/domain/ChessRunner.java +++ b/src/main/java/chess/domain/ChessRunner.java @@ -1,7 +1,5 @@ package chess.domain; -import chess.controller.dto.BoardScoreDto; -import chess.controller.dto.TileDto; import chess.domain.board.Board; import chess.domain.board.BoardScore; import chess.domain.board.Tile; @@ -9,6 +7,8 @@ import chess.domain.piece.Team; import chess.domain.position.Position; import chess.domain.strategy.direction.Direction; +import chess.dto.BoardScoreDTO; +import chess.dto.TileDTO; import org.apache.commons.lang3.StringUtils; import java.util.*; @@ -106,14 +106,14 @@ public double calculateScore() { return currentTeamScore.getBoardScore(); } - public List calculateScores() { - List scores = new ArrayList<>(); - BoardScoreDto currentTeam = new BoardScoreDto(calculateScore()); + public List calculateScores() { + List scores = new ArrayList<>(); + BoardScoreDTO currentTeam = new BoardScoreDTO(calculateScore()); currentTeam.setTeam(this.currentTeam.name()); scores.add(currentTeam); BoardScore oppositeTeamScore = this.board.calculateScore(this.currentTeam.changeTeam()); - BoardScoreDto oppositeTeam = new BoardScoreDto(oppositeTeamScore.getBoardScore()); + BoardScoreDTO oppositeTeam = new BoardScoreDTO(oppositeTeamScore.getBoardScore()); oppositeTeam.setTeam(this.currentTeam.changeTeam().name()); scores.add(oppositeTeam); @@ -137,9 +137,9 @@ public String getWinner() { return winner.map(Enum::name).orElse(StringUtils.EMPTY); } - public List entireTileDtos() { - List tileDtos = Position.getPositions().stream() - .map(TileDto::new) + public List entireTileDtos() { + List tileDtos = Position.getPositions().stream() + .map(TileDTO::new) .collect(Collectors.toList()); setTileDtoTeam(tileDtos); @@ -148,18 +148,18 @@ public List entireTileDtos() { return Collections.unmodifiableList(tileDtos); } - private void setTileDtoTeam(List tileDtos) { + private void setTileDtoTeam(List tileDtos) { List indexes = Position.getPositionsIndex(); for (int i = 0; i < indexes.size(); i++) { - TileDto tileDto = tileDtos.get(i); + TileDTO tileDto = tileDtos.get(i); tileDto.setStyle(indexes.get(i)); } } - private void setTileDtoImage(List tileDtos) { + private void setTileDtoImage(List tileDtos) { List tiles = this.board.tiles(); for (Tile tile : tiles) { - TileDto tileDto = tileDtos.stream() + TileDTO tileDto = tileDtos.stream() .filter(td -> td.getPosition().equals(tile.position())) .findFirst() .orElseThrow(IllegalArgumentException::new); @@ -167,10 +167,10 @@ private void setTileDtoImage(List tileDtos) { } } - public List pieceTileDtos() { - List tileDtos = this.board.tiles().stream() + public List pieceTileDtos() { + List tileDtos = this.board.tiles().stream() .map((tile) -> { - TileDto tileDto = new TileDto(tile.position()); + TileDTO tileDto = new TileDTO(tile.position()); tileDto.setPieceImageUrl(tile.pieceImageUrl()); return tileDto; }).collect(Collectors.toList()); diff --git a/src/main/java/chess/controller/dto/BoardDto.java b/src/main/java/chess/dto/BoardDTO.java similarity index 68% rename from src/main/java/chess/controller/dto/BoardDto.java rename to src/main/java/chess/dto/BoardDTO.java index cbc17ea78b5..6aa1388ed32 100644 --- a/src/main/java/chess/controller/dto/BoardDto.java +++ b/src/main/java/chess/dto/BoardDTO.java @@ -1,12 +1,12 @@ -package chess.controller.dto; +package chess.dto; import java.util.Collections; import java.util.Map; -public class BoardDto { +public class BoardDTO { private final Map board; - public BoardDto(final Map board) { + public BoardDTO(final Map board) { this.board = board; } diff --git a/src/main/java/chess/controller/dto/BoardScoreDto.java b/src/main/java/chess/dto/BoardScoreDTO.java similarity index 74% rename from src/main/java/chess/controller/dto/BoardScoreDto.java rename to src/main/java/chess/dto/BoardScoreDTO.java index 3d60af9239f..53e38e88734 100644 --- a/src/main/java/chess/controller/dto/BoardScoreDto.java +++ b/src/main/java/chess/dto/BoardScoreDTO.java @@ -1,10 +1,10 @@ -package chess.controller.dto; +package chess.dto; -public class BoardScoreDto { +public class BoardScoreDTO { private final double boardScore; private String team; - public BoardScoreDto(final double boardScore) { + public BoardScoreDTO(final double boardScore) { this.boardScore = boardScore; } diff --git a/src/main/java/chess/controller/dto/MoveResultDto.java b/src/main/java/chess/dto/MoveResultDTO.java similarity index 69% rename from src/main/java/chess/controller/dto/MoveResultDto.java rename to src/main/java/chess/dto/MoveResultDTO.java index 50125ea3c2d..0014aa64e03 100644 --- a/src/main/java/chess/controller/dto/MoveResultDto.java +++ b/src/main/java/chess/dto/MoveResultDTO.java @@ -1,10 +1,10 @@ -package chess.controller.dto; +package chess.dto; -public class MoveResultDto { +public class MoveResultDTO { private final String message; private final String style; - public MoveResultDto(String message, String style) { + public MoveResultDTO(String message, String style) { this.message = message; this.style = style; } diff --git a/src/main/java/chess/controller/dto/PositionDto.java b/src/main/java/chess/dto/PositionDTO.java similarity index 68% rename from src/main/java/chess/controller/dto/PositionDto.java rename to src/main/java/chess/dto/PositionDTO.java index 4083a2f2444..02d50262597 100644 --- a/src/main/java/chess/controller/dto/PositionDto.java +++ b/src/main/java/chess/dto/PositionDTO.java @@ -1,12 +1,12 @@ -package chess.controller.dto; +package chess.dto; import java.util.Collections; import java.util.List; -public class PositionDto { +public class PositionDTO { private final List positions; - public PositionDto(final List positions) { + public PositionDTO(final List positions) { this.positions = positions; } diff --git a/src/main/java/chess/controller/dto/StatusDto.java b/src/main/java/chess/dto/StatusDTO.java similarity index 60% rename from src/main/java/chess/controller/dto/StatusDto.java rename to src/main/java/chess/dto/StatusDTO.java index 7faf356b190..3f7280298d1 100644 --- a/src/main/java/chess/controller/dto/StatusDto.java +++ b/src/main/java/chess/dto/StatusDTO.java @@ -1,9 +1,9 @@ -package chess.controller.dto; +package chess.dto; -public class StatusDto { +public class StatusDTO { private final String message; - public StatusDto(String message) { + public StatusDTO(String message) { this.message = message; } diff --git a/src/main/java/chess/controller/dto/TeamDto.java b/src/main/java/chess/dto/TeamDTO.java similarity index 59% rename from src/main/java/chess/controller/dto/TeamDto.java rename to src/main/java/chess/dto/TeamDTO.java index 073908e98f8..4359c286172 100644 --- a/src/main/java/chess/controller/dto/TeamDto.java +++ b/src/main/java/chess/dto/TeamDTO.java @@ -1,9 +1,9 @@ -package chess.controller.dto; +package chess.dto; -public class TeamDto { +public class TeamDTO { private final String teamName; - public TeamDto(final String teamName) { + public TeamDTO(final String teamName) { this.teamName = teamName; } diff --git a/src/main/java/chess/controller/dto/TileDto.java b/src/main/java/chess/dto/TileDTO.java similarity index 88% rename from src/main/java/chess/controller/dto/TileDto.java rename to src/main/java/chess/dto/TileDTO.java index da3ff3791e7..92d62e07681 100644 --- a/src/main/java/chess/controller/dto/TileDto.java +++ b/src/main/java/chess/dto/TileDTO.java @@ -1,6 +1,6 @@ -package chess.controller.dto; +package chess.dto; -public class TileDto { +public class TileDTO { private static final String WHITE = "white"; private static final String BLACK = "black"; @@ -8,7 +8,7 @@ public class TileDto { private String pieceImageUrl; private String style; - public TileDto(final String position) { + public TileDTO(final String position) { this.position = position; this.pieceImageUrl = ""; } diff --git a/src/main/java/chess/service/ChessService.java b/src/main/java/chess/service/ChessService.java new file mode 100644 index 00000000000..866bd27814a --- /dev/null +++ b/src/main/java/chess/service/ChessService.java @@ -0,0 +1,4 @@ +package chess.service; + +public class ChessService { +} diff --git a/src/test/java/chess/controller/dao/ChessBoardDAOTest.java b/src/test/java/chess/dao/ChessBoardDAOTest.java similarity index 98% rename from src/test/java/chess/controller/dao/ChessBoardDAOTest.java rename to src/test/java/chess/dao/ChessBoardDAOTest.java index d4f76b7f9d1..8455367a3b2 100644 --- a/src/test/java/chess/controller/dao/ChessBoardDAOTest.java +++ b/src/test/java/chess/dao/ChessBoardDAOTest.java @@ -1,4 +1,4 @@ -package chess.controller.dao; +package chess.dao; import org.assertj.core.api.Assertions; import org.junit.jupiter.api.BeforeEach; diff --git a/src/test/java/chess/controller/dao/ConnectionManagerTest.java b/src/test/java/chess/dao/ConnectionManagerTest.java similarity index 92% rename from src/test/java/chess/controller/dao/ConnectionManagerTest.java rename to src/test/java/chess/dao/ConnectionManagerTest.java index a23de70b49d..ed0f6941be8 100644 --- a/src/test/java/chess/controller/dao/ConnectionManagerTest.java +++ b/src/test/java/chess/dao/ConnectionManagerTest.java @@ -1,4 +1,4 @@ -package chess.controller.dao; +package chess.dao; import org.assertj.core.api.Assertions; import org.junit.jupiter.api.DisplayName; diff --git a/src/test/java/chess/controller/dao/CurrentTeamDAOTest.java b/src/test/java/chess/dao/CurrentTeamDAOTest.java similarity index 98% rename from src/test/java/chess/controller/dao/CurrentTeamDAOTest.java rename to src/test/java/chess/dao/CurrentTeamDAOTest.java index 0b7c6c7a9c6..c00732d7712 100644 --- a/src/test/java/chess/controller/dao/CurrentTeamDAOTest.java +++ b/src/test/java/chess/dao/CurrentTeamDAOTest.java @@ -1,4 +1,4 @@ -package chess.controller.dao; +package chess.dao; import org.assertj.core.api.Assertions; import org.junit.jupiter.api.BeforeEach; diff --git a/src/test/java/chess/controller/dao/PieceDAOTest.java b/src/test/java/chess/dao/PieceDAOTest.java similarity index 88% rename from src/test/java/chess/controller/dao/PieceDAOTest.java rename to src/test/java/chess/dao/PieceDAOTest.java index 75c7a853256..c35fbc21462 100644 --- a/src/test/java/chess/controller/dao/PieceDAOTest.java +++ b/src/test/java/chess/dao/PieceDAOTest.java @@ -1,6 +1,6 @@ -package chess.controller.dao; +package chess.dao; -import chess.controller.dto.TileDto; +import chess.dto.TileDTO; import org.assertj.core.api.Assertions; import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Disabled; @@ -23,11 +23,11 @@ private void setUp() { @DisplayName("피스 정보 추가") @Test void addPieceTest() throws Exception { - TileDto a2WhitePawn = new TileDto("a2"); + TileDTO a2WhitePawn = new TileDTO("a2"); a2WhitePawn.setPieceImageUrl("p_white"); - TileDto a6BlackPawn = new TileDto("a6"); + TileDTO a6BlackPawn = new TileDTO("a6"); a6BlackPawn.setPieceImageUrl("P_black"); - List tileDtos = new ArrayList<>(Arrays.asList( + List tileDtos = new ArrayList<>(Arrays.asList( a2WhitePawn, a6BlackPawn )); ChessBoard chessBoard = new ChessBoard(12); diff --git a/src/test/java/chess/controller/dao/PlayerDAOTest.java b/src/test/java/chess/dao/PlayerDAOTest.java similarity index 98% rename from src/test/java/chess/controller/dao/PlayerDAOTest.java rename to src/test/java/chess/dao/PlayerDAOTest.java index 23d69d02647..c2746780ea1 100644 --- a/src/test/java/chess/controller/dao/PlayerDAOTest.java +++ b/src/test/java/chess/dao/PlayerDAOTest.java @@ -1,4 +1,4 @@ -package chess.controller.dao; +package chess.dao; import org.assertj.core.api.Assertions; import org.junit.jupiter.api.BeforeEach; diff --git a/src/test/java/chess/domain/ChessRunnerTest.java b/src/test/java/chess/domain/ChessRunnerTest.java index c9be4662f99..87a5a6ec03c 100644 --- a/src/test/java/chess/domain/ChessRunnerTest.java +++ b/src/test/java/chess/domain/ChessRunnerTest.java @@ -1,6 +1,6 @@ package chess.domain; -import chess.controller.dto.TileDto; +import chess.dto.TileDTO; import org.apache.commons.lang3.StringUtils; import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.DisplayName; @@ -74,7 +74,7 @@ void isEndChessTest() { @Test void tileDtosTest() { - List tileDtos = chessRunner.entireTileDtos(); + List tileDtos = chessRunner.entireTileDtos(); } @DisplayName("게임이 종료되지 않았을 때 승자를 출력 시 빈 문자열 출력") From 44888f84f3345c742fca6dee8e34cb3a638e65c3 Mon Sep 17 00:00:00 2001 From: giantim Date: Thu, 9 Apr 2020 21:53:30 +0900 Subject: [PATCH 61/75] =?UTF-8?q?refactor:=20DAO=20=EC=97=90=20try-with-re?= =?UTF-8?q?sources=20=EC=A0=81=EC=9A=A9?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/main/java/chess/dao/ChessBoard.java | 4 +- src/main/java/chess/dao/ChessBoardDAO.java | 79 +++++++++------- .../java/chess/dao/ConnectionManager.java | 10 +- src/main/java/chess/dao/CurrentTeam.java | 4 +- src/main/java/chess/dao/CurrentTeamDAO.java | 72 +++++++------- src/main/java/chess/dao/PieceDAO.java | 89 ++++++++++-------- src/main/java/chess/dao/Player.java | 7 +- src/main/java/chess/dao/PlayerDAO.java | 93 +++++++++++-------- .../java/chess/dao/ChessBoardDAOTest.java | 12 +-- .../java/chess/dao/CurrentTeamDAOTest.java | 22 ++--- src/test/java/chess/dao/PieceDAOTest.java | 26 +++--- src/test/java/chess/dao/PlayerDAOTest.java | 14 +-- 12 files changed, 238 insertions(+), 194 deletions(-) diff --git a/src/main/java/chess/dao/ChessBoard.java b/src/main/java/chess/dao/ChessBoard.java index 66706ae7964..7e8a4b3beaa 100644 --- a/src/main/java/chess/dao/ChessBoard.java +++ b/src/main/java/chess/dao/ChessBoard.java @@ -22,11 +22,11 @@ public boolean equals(Object o) { return false; } ChessBoard chessBoard = (ChessBoard) o; - return Objects.equals(chessBoardId, chessBoard.chessBoardId); + return Objects.equals(this.chessBoardId, chessBoard.chessBoardId); } @Override public int hashCode() { - return Objects.hash(chessBoardId); + return Objects.hash(this.chessBoardId); } } diff --git a/src/main/java/chess/dao/ChessBoardDAO.java b/src/main/java/chess/dao/ChessBoardDAO.java index 53b55ef1cba..5fd6298c1e3 100644 --- a/src/main/java/chess/dao/ChessBoardDAO.java +++ b/src/main/java/chess/dao/ChessBoardDAO.java @@ -6,59 +6,68 @@ import java.sql.SQLException; public class ChessBoardDAO { - public void addChessBoard() throws SQLException { - Connection con = ConnectionManager.getConnection(); + public void addChessBoard() { String query = "INSERT INTO chessBoard VALUES()"; - PreparedStatement pstmt = con.prepareStatement(query); - pstmt.executeUpdate(); - ConnectionManager.closeConnection(con); + try (Connection con = ConnectionManager.getConnection(); + PreparedStatement pstmt = con.prepareStatement(query)) { + pstmt.executeUpdate(); + } catch (SQLException e) { + e.printStackTrace(); + } } - public ChessBoard findRecentChessBoard() throws SQLException { - Connection con = ConnectionManager.getConnection(); + public ChessBoard findRecentChessBoard() { String query = "SELECT * FROM chessBoard ORDER BY chessBoardId DESC limit 1"; - PreparedStatement pstmt = con.prepareStatement(query); - ResultSet rs = pstmt.executeQuery(); + try (Connection con = ConnectionManager.getConnection(); + PreparedStatement pstmt = con.prepareStatement(query); + ResultSet rs = pstmt.executeQuery()) { + if (!rs.next()) { + return null; + } - if (!rs.next()) { - ConnectionManager.closeConnection(con); + ChessBoard chessBoard = new ChessBoard( + rs.getInt("chessBoardId") + ); + ConnectionManager.closeResultSet(rs); + return chessBoard; + } catch (SQLException e) { + e.printStackTrace(); return null; } - - ChessBoard chessBoard = new ChessBoard( - rs.getInt("chessBoardId") - ); - ConnectionManager.closeConnection(con); - return chessBoard; } - public void deleteChessBoard(ChessBoard chessBoard) throws SQLException { + public void deleteChessBoard(ChessBoard chessBoard) { if (chessBoard == null) { return; } - - Connection con = ConnectionManager.getConnection(); String query = "DELETE FROM chessBoard WHERE chessBoardId = ?"; - PreparedStatement pstmt = con.prepareStatement(query); - pstmt.setInt(1, chessBoard.getChessBoardId()); - pstmt.executeUpdate(); - ConnectionManager.closeConnection(con); + try (Connection con = ConnectionManager.getConnection(); + PreparedStatement pstmt = con.prepareStatement(query);) { + pstmt.setInt(1, chessBoard.getChessBoardId()); + pstmt.executeUpdate(); + } catch (SQLException e) { + e.printStackTrace(); + } } - public ChessBoard findById(int chessBoardId) throws SQLException { - Connection con = ConnectionManager.getConnection(); + public ChessBoard findById(int chessBoardId) { String query = "SELECT * FROM chessBoard WHERE chessBoardId=?"; - PreparedStatement pstmt = con.prepareStatement(query); - pstmt.setInt(1, chessBoardId); - ResultSet rs = pstmt.executeQuery(); + try (Connection con = ConnectionManager.getConnection(); + PreparedStatement pstmt = con.prepareStatement(query)) { + pstmt.setInt(1, chessBoardId); + ResultSet rs = pstmt.executeQuery(); + while (!rs.next()) { + return null; + } - while (!rs.next()) { + ChessBoard chessBoard = new ChessBoard( + rs.getInt("chessBoardId") + ); + ConnectionManager.closeResultSet(rs); + return chessBoard; + } catch (SQLException e) { + e.printStackTrace(); return null; } - ChessBoard chessBoard = new ChessBoard( - rs.getInt("chessBoardId") - ); - ConnectionManager.closeConnection(con); - return chessBoard; } } diff --git a/src/main/java/chess/dao/ConnectionManager.java b/src/main/java/chess/dao/ConnectionManager.java index 14329a60c0e..e44eb4b7aee 100644 --- a/src/main/java/chess/dao/ConnectionManager.java +++ b/src/main/java/chess/dao/ConnectionManager.java @@ -2,6 +2,7 @@ import java.sql.Connection; import java.sql.DriverManager; +import java.sql.ResultSet; import java.sql.SQLException; public class ConnectionManager { @@ -35,12 +36,13 @@ public static Connection getConnection() { return con; } - public static void closeConnection(Connection con) { + public static void closeResultSet(ResultSet rs) { try { - if (con != null) - con.close(); + if (rs != null) { + rs.close(); + } } catch (SQLException e) { - System.err.println("con 오류:" + e.getMessage()); + System.err.println("rs 오류:" + e.getMessage()); } } } diff --git a/src/main/java/chess/dao/CurrentTeam.java b/src/main/java/chess/dao/CurrentTeam.java index 164f465c7dd..20623db291e 100644 --- a/src/main/java/chess/dao/CurrentTeam.java +++ b/src/main/java/chess/dao/CurrentTeam.java @@ -22,11 +22,11 @@ public boolean equals(Object o) { return false; } CurrentTeam currentTeam = (CurrentTeam) o; - return Objects.equals(currentTeam, currentTeam.currentTeam); + return Objects.equals(this.currentTeam, currentTeam.currentTeam); } @Override public int hashCode() { - return Objects.hash(currentTeam); + return Objects.hash(this.currentTeam); } } diff --git a/src/main/java/chess/dao/CurrentTeamDAO.java b/src/main/java/chess/dao/CurrentTeamDAO.java index 7949e7dc6fe..6037a0fdd5c 100644 --- a/src/main/java/chess/dao/CurrentTeamDAO.java +++ b/src/main/java/chess/dao/CurrentTeamDAO.java @@ -6,49 +6,59 @@ import java.sql.SQLException; public class CurrentTeamDAO { - public void addCurrentTeam(ChessBoard chessBoard, CurrentTeam currentTeam) throws SQLException { - Connection con = ConnectionManager.getConnection(); + public void addCurrentTeam(ChessBoard chessBoard, CurrentTeam currentTeam) { String query = "INSERT INTO currentTeam (team, chessBoardId) VALUES(?, ?)"; - PreparedStatement pstmt = con.prepareStatement(query); - pstmt.setString(1, currentTeam.getCurrentTeam()); - pstmt.setInt(2, chessBoard.getChessBoardId()); - pstmt.executeUpdate(); - ConnectionManager.closeConnection(con); + try (Connection con = ConnectionManager.getConnection(); + PreparedStatement pstmt = con.prepareStatement(query)) { + pstmt.setString(1, currentTeam.getCurrentTeam()); + pstmt.setInt(2, chessBoard.getChessBoardId()); + pstmt.executeUpdate(); + } catch (SQLException e) { + e.printStackTrace(); + } } - public void updateCurrentTeam(ChessBoard chessBoard, CurrentTeam currentTeam) throws SQLException { - Connection con = ConnectionManager.getConnection(); + public void updateCurrentTeam(ChessBoard chessBoard, CurrentTeam currentTeam) { String query = "UPDATE currentTeam SET team = ? WHERE chessBoardId = ?"; - PreparedStatement pstmt = con.prepareStatement(query); - pstmt.setString(1, currentTeam.getCurrentTeam()); - pstmt.setInt(2, chessBoard.getChessBoardId()); - pstmt.executeUpdate(); - ConnectionManager.closeConnection(con); + try (Connection con = ConnectionManager.getConnection(); + PreparedStatement pstmt = con.prepareStatement(query)) { + pstmt.setString(1, currentTeam.getCurrentTeam()); + pstmt.setInt(2, chessBoard.getChessBoardId()); + pstmt.executeUpdate(); + } catch (SQLException e) { + e.printStackTrace(); + } } - public void deleteCurrentTeam(ChessBoard chessBoard) throws SQLException { - Connection con = ConnectionManager.getConnection(); + public void deleteCurrentTeam(ChessBoard chessBoard) { String query = "DELETE FROM currentTeam WHERE chessBoardId = ?"; - PreparedStatement pstmt = con.prepareStatement(query); - pstmt.setInt(1, chessBoard.getChessBoardId()); - pstmt.executeUpdate(); - ConnectionManager.closeConnection(con); + try (Connection con = ConnectionManager.getConnection(); + PreparedStatement pstmt = con.prepareStatement(query)) { + pstmt.setInt(1, chessBoard.getChessBoardId()); + pstmt.executeUpdate(); + } catch (SQLException e) { + e.printStackTrace(); + } } - public CurrentTeam findCurrentTeam(ChessBoard chessBoard) throws SQLException { - Connection con = ConnectionManager.getConnection(); + public CurrentTeam findCurrentTeam(ChessBoard chessBoard) { String query = "SELECT team FROM currentTeam WHERE chessBoardId = ?"; - PreparedStatement pstmt = con.prepareStatement(query); - pstmt.setInt(1, chessBoard.getChessBoardId()); - ResultSet rs = pstmt.executeQuery(); + try (Connection con = ConnectionManager.getConnection(); + PreparedStatement pstmt = con.prepareStatement(query)) { + pstmt.setInt(1, chessBoard.getChessBoardId()); + ResultSet rs = pstmt.executeQuery(); + while (!rs.next()) { + return null; + } - while (!rs.next()) { + CurrentTeam currentTeam = new CurrentTeam( + rs.getString("team") + ); + ConnectionManager.closeResultSet(rs); + return currentTeam; + } catch (SQLException e) { + e.printStackTrace(); return null; } - CurrentTeam currentTeam = new CurrentTeam( - rs.getString("team") - ); - ConnectionManager.closeConnection(con); - return currentTeam; } } diff --git a/src/main/java/chess/dao/PieceDAO.java b/src/main/java/chess/dao/PieceDAO.java index c8ccb012281..63bbc711101 100644 --- a/src/main/java/chess/dao/PieceDAO.java +++ b/src/main/java/chess/dao/PieceDAO.java @@ -11,61 +11,70 @@ import java.util.List; public class PieceDAO { - public void addPiece(ChessBoard chessBoard, List tileDtos) throws SQLException { - Connection con = ConnectionManager.getConnection(); - for (TileDTO tileDto : tileDtos) { - String query = "INSERT INTO piece (position, pieceImageUrl, chessBoardId) " - + "VALUES(?, ?, ?)"; - PreparedStatement pstmt = con.prepareStatement(query); - pstmt.setString(1, tileDto.getPosition()); - pstmt.setString(2, tileDto.getPieceImageUrl()); - pstmt.setInt(3, chessBoard.getChessBoardId()); - pstmt.executeUpdate(); + public void addPiece(ChessBoard chessBoard, List tileDtos) { + try (Connection con = ConnectionManager.getConnection();) { + for (TileDTO tileDto : tileDtos) { + String query = "INSERT INTO piece (position, pieceImageUrl, chessBoardId) " + + "VALUES(?, ?, ?)"; + PreparedStatement pstmt = con.prepareStatement(query); + pstmt.setString(1, tileDto.getPosition()); + pstmt.setString(2, tileDto.getPieceImageUrl()); + pstmt.setInt(3, chessBoard.getChessBoardId()); + pstmt.executeUpdate(); + } + } catch (SQLException e) { + e.printStackTrace(); } - ConnectionManager.closeConnection(con); } - public void deletePiece(PieceOnBoard piece) throws SQLException { + public void deletePiece(PieceOnBoard piece) { if (piece == null) { return; } - - Connection con = ConnectionManager.getConnection(); String query = "DELETE FROM piece WHERE pieceId = ?"; - PreparedStatement pstmt = con.prepareStatement(query); - pstmt.setInt(1, piece.getPieceId()); - pstmt.executeUpdate(); - ConnectionManager.closeConnection(con); + try (Connection con = ConnectionManager.getConnection(); + PreparedStatement pstmt = con.prepareStatement(query)) { + pstmt.setInt(1, piece.getPieceId()); + pstmt.executeUpdate(); + } catch (SQLException e) { + e.printStackTrace(); + } } - public List findPiece(ChessBoard chessBoard) throws SQLException { + public List findPiece(ChessBoard chessBoard) { List pieceOnBoards = new ArrayList<>(); - - Connection con = ConnectionManager.getConnection(); String query = "SELECT * FROM piece WHERE chessBoardId = ?"; - PreparedStatement pstmt = con.prepareStatement(query); - pstmt.setInt(1, chessBoard.getChessBoardId()); - ResultSet rs = pstmt.executeQuery(); + try (Connection con = ConnectionManager.getConnection(); + PreparedStatement pstmt = con.prepareStatement(query);) { + pstmt.setInt(1, chessBoard.getChessBoardId()); + ResultSet rs = pstmt.executeQuery(); - while (rs.next()) { - PieceOnBoard pieceOnBoard = new PieceOnBoard( - rs.getInt("pieceId"), - rs.getString("position"), - rs.getString("pieceImageUrl"), - rs.getInt("chessBoardId") - ); - pieceOnBoards.add(pieceOnBoard); + while (rs.next()) { + PieceOnBoard pieceOnBoard = new PieceOnBoard( + rs.getInt("pieceId"), + rs.getString("position"), + rs.getString("pieceImageUrl"), + rs.getInt("chessBoardId") + ); + pieceOnBoards.add(pieceOnBoard); + } + ConnectionManager.closeResultSet(rs); + return Collections.unmodifiableList(pieceOnBoards); + } catch (SQLException e) { + e.printStackTrace(); + return null; } - return Collections.unmodifiableList(pieceOnBoards); } - public void updatePiece(PieceOnBoard pieceOnBoard, String targetPosition) throws SQLException { - Connection con = ConnectionManager.getConnection(); + public void updatePiece(PieceOnBoard pieceOnBoard, String targetPosition) { String query = "UPDATE piece SET position = ? WHERE pieceId = ?"; - PreparedStatement pstmt = con.prepareStatement(query); - pstmt.setString(1, targetPosition); - pstmt.setInt(2, pieceOnBoard.getPieceId()); - pstmt.executeUpdate(); - ConnectionManager.closeConnection(con); + try (Connection con = ConnectionManager.getConnection(); + PreparedStatement pstmt = con.prepareStatement(query)) { + pstmt.setString(1, targetPosition); + pstmt.setInt(2, pieceOnBoard.getPieceId()); + pstmt.executeUpdate(); + } catch (SQLException e) { + e.printStackTrace(); + } } } diff --git a/src/main/java/chess/dao/Player.java b/src/main/java/chess/dao/Player.java index 8cab261a013..b3da9e39acd 100644 --- a/src/main/java/chess/dao/Player.java +++ b/src/main/java/chess/dao/Player.java @@ -37,12 +37,13 @@ public boolean equals(Object o) { return false; } Player player = (Player) o; - return Objects.equals(whitePlayer, player.whitePlayer) - && Objects.equals(blackPlayer, player.blackPlayer); + return Objects.equals(this.whitePlayer, player.whitePlayer) + && Objects.equals(this.blackPlayer, player.blackPlayer) + && Objects.equals(this.chessBoardId, player.chessBoardId); } @Override public int hashCode() { - return Objects.hash(whitePlayer, blackPlayer); + return Objects.hash(this.whitePlayer, this.blackPlayer, this.chessBoardId); } } diff --git a/src/main/java/chess/dao/PlayerDAO.java b/src/main/java/chess/dao/PlayerDAO.java index 7c3708adda4..dd612fb40c5 100644 --- a/src/main/java/chess/dao/PlayerDAO.java +++ b/src/main/java/chess/dao/PlayerDAO.java @@ -8,60 +8,73 @@ import java.util.List; public class PlayerDAO { - public void addPlayer(ChessBoard chessBoard, Player player) throws SQLException { - Connection con = ConnectionManager.getConnection(); + public void addPlayer(ChessBoard chessBoard, Player player) { String query = "INSERT INTO player (whitePlayer, blackPlayer, chessBoardId) VALUES(?, ?, ?)"; - PreparedStatement pstmt = con.prepareStatement(query); - pstmt.setString(1, player.getWhitePlayer()); - pstmt.setString(2, player.getBlackPlayer()); - pstmt.setInt(3, chessBoard.getChessBoardId()); - pstmt.executeUpdate(); - ConnectionManager.closeConnection(con); + try (Connection con = ConnectionManager.getConnection(); + PreparedStatement pstmt = con.prepareStatement(query)) { + pstmt.setString(1, player.getWhitePlayer()); + pstmt.setString(2, player.getBlackPlayer()); + pstmt.setInt(3, chessBoard.getChessBoardId()); + pstmt.executeUpdate(); + } catch (SQLException e) { + e.printStackTrace(); + } } - public Player findPlayer(ChessBoard chessBoard) throws SQLException { - Connection con = ConnectionManager.getConnection(); + public Player findPlayer(ChessBoard chessBoard) { String query = "SELECT whitePlayer, blackPlayer FROM player WHERE chessBoardId=?"; - PreparedStatement pstmt = con.prepareStatement(query); - pstmt.setInt(1, chessBoard.getChessBoardId()); - ResultSet rs = pstmt.executeQuery(); + try (Connection con = ConnectionManager.getConnection(); + PreparedStatement pstmt = con.prepareStatement(query)) { + pstmt.setInt(1, chessBoard.getChessBoardId()); + ResultSet rs = pstmt.executeQuery(); + + while (!rs.next()) { + return null; + } - while (!rs.next()) { + Player player = new Player( + rs.getString("whitePlayer"), + rs.getString("blackPlayer") + ); + ConnectionManager.closeResultSet(rs); + return player; + } catch (SQLException e) { + e.printStackTrace(); return null; } - - Player player = new Player( - rs.getString("whitePlayer"), - rs.getString("blackPlayer") - ); - ConnectionManager.closeConnection(con); - return player; } - public void deletePlayer(ChessBoard chessBoard) throws SQLException { - Connection con = ConnectionManager.getConnection(); + public void deletePlayer(ChessBoard chessBoard) { String query = "DELETE FROM player WHERE chessBoardId=?"; - PreparedStatement pstmt = con.prepareStatement(query); - pstmt.setInt(1, chessBoard.getChessBoardId()); - pstmt.executeUpdate(); - ConnectionManager.closeConnection(con); + try (Connection con = ConnectionManager.getConnection(); + PreparedStatement pstmt = con.prepareStatement(query)) { + pstmt.setInt(1, chessBoard.getChessBoardId()); + pstmt.executeUpdate(); + } catch (SQLException e) { + e.printStackTrace(); + } } - public List findAllPlayer() throws SQLException { - Connection con = ConnectionManager.getConnection(); + public List findAllPlayer() { String query = "SELECT whitePlayer, blackPlayer, chessBoardId FROM player"; - PreparedStatement pstmt = con.prepareStatement(query); - ResultSet rs = pstmt.executeQuery(); - List players = new ArrayList<>(); + try (Connection con = ConnectionManager.getConnection(); + PreparedStatement pstmt = con.prepareStatement(query)) { + ResultSet rs = pstmt.executeQuery(); + List players = new ArrayList<>(); - while (rs.next()) { - Player player = new Player( - rs.getString("whitePlayer"), - rs.getString("blackPlayer") - ); - player.setChessBoardId(rs.getInt("chessBoardId")); - players.add(player); + while (rs.next()) { + Player player = new Player( + rs.getString("whitePlayer"), + rs.getString("blackPlayer") + ); + player.setChessBoardId(rs.getInt("chessBoardId")); + players.add(player); + } + ConnectionManager.closeResultSet(rs); + return players; + } catch (SQLException e) { + e.printStackTrace(); + return null; } - return players; } } diff --git a/src/test/java/chess/dao/ChessBoardDAOTest.java b/src/test/java/chess/dao/ChessBoardDAOTest.java index 8455367a3b2..01b2b6e2501 100644 --- a/src/test/java/chess/dao/ChessBoardDAOTest.java +++ b/src/test/java/chess/dao/ChessBoardDAOTest.java @@ -17,14 +17,14 @@ private void setUp() { @Disabled @DisplayName("체스 보드 추가 테스트") @Test - void addChessBoardTest() throws Exception { + void addChessBoardTest() { chessBoardDAO.addChessBoard(); } @Disabled @DisplayName("가장 최근에 추가된 체스 보드 찾기") @Test - void findRecentChessBoardTest() throws Exception { + void findRecentChessBoardTest() { chessBoardDAO.addChessBoard(); ChessBoard chessBoard = chessBoardDAO.findRecentChessBoard(); @@ -35,7 +35,7 @@ void findRecentChessBoardTest() throws Exception { @Disabled @DisplayName("체스 보드 삭제") @Test - void deleteChessBoardTest() throws Exception { + void deleteChessBoardTest() { ChessBoard chessBoard = chessBoardDAO.findRecentChessBoard(); chessBoardDAO.deleteChessBoard(chessBoard); } @@ -43,10 +43,10 @@ void deleteChessBoardTest() throws Exception { @Disabled @DisplayName("체스 보드 아이디로 체스 보드 찾기") @Test - void findByIdTest() throws Exception { - int chessBoardId = 9; + void findByIdTest() { + int chessBoardId = 1; ChessBoard expected = this.chessBoardDAO.findById(chessBoardId); - Assertions.assertThat(expected.getChessBoardId()).isEqualTo(9); + Assertions.assertThat(expected.getChessBoardId()).isEqualTo(1); } } diff --git a/src/test/java/chess/dao/CurrentTeamDAOTest.java b/src/test/java/chess/dao/CurrentTeamDAOTest.java index c00732d7712..b5c52c5139e 100644 --- a/src/test/java/chess/dao/CurrentTeamDAOTest.java +++ b/src/test/java/chess/dao/CurrentTeamDAOTest.java @@ -17,9 +17,9 @@ private void setUp() { @Disabled @DisplayName("현재 팀 정보 추가") @Test - void addCurrentTeamTest() throws Exception { - ChessBoard chessBoard = new ChessBoard(2); - CurrentTeam currentTeam = new CurrentTeam("white"); + void addCurrentTeamTest() { + ChessBoard chessBoard = new ChessBoard(1); + CurrentTeam currentTeam = new CurrentTeam("black"); this.currentTeamDAO.addCurrentTeam(chessBoard, currentTeam); } @@ -27,9 +27,9 @@ void addCurrentTeamTest() throws Exception { @Disabled @DisplayName("현재 팀 정보 업데이트") @Test - void updateCurrentTeamTest() throws Exception { - ChessBoard chessBoard = new ChessBoard(2); - CurrentTeam currentTeam = new CurrentTeam("black"); + void updateCurrentTeamTest() { + ChessBoard chessBoard = new ChessBoard(1); + CurrentTeam currentTeam = new CurrentTeam("WHITE"); this.currentTeamDAO.updateCurrentTeam(chessBoard, currentTeam); } @@ -37,8 +37,8 @@ void updateCurrentTeamTest() throws Exception { @Disabled @DisplayName("현재 팀 삭제") @Test - void deleteCurrentTeamTest() throws Exception { - ChessBoard chessBoard = new ChessBoard(2); + void deleteCurrentTeamTest() { + ChessBoard chessBoard = new ChessBoard(1); this.currentTeamDAO.deleteCurrentTeam(chessBoard); } @@ -46,11 +46,11 @@ void deleteCurrentTeamTest() throws Exception { @Disabled @DisplayName("현재 팀 검색") @Test - void findCurrentTeamTest() throws Exception { - ChessBoard chessBoard = new ChessBoard(3); + void findCurrentTeamTest() { + ChessBoard chessBoard = new ChessBoard(1); CurrentTeam currentTeam = currentTeamDAO.findCurrentTeam(chessBoard); Assertions.assertThat(currentTeam).isNotNull(); - Assertions.assertThat(currentTeam.getCurrentTeam()).isEqualTo("white"); + Assertions.assertThat(currentTeam.getCurrentTeam()).isEqualTo("WHITE"); } } diff --git a/src/test/java/chess/dao/PieceDAOTest.java b/src/test/java/chess/dao/PieceDAOTest.java index c35fbc21462..ed2b0ba84a8 100644 --- a/src/test/java/chess/dao/PieceDAOTest.java +++ b/src/test/java/chess/dao/PieceDAOTest.java @@ -22,7 +22,7 @@ private void setUp() { @Disabled @DisplayName("피스 정보 추가") @Test - void addPieceTest() throws Exception { + void addPieceTest() { TileDTO a2WhitePawn = new TileDTO("a2"); a2WhitePawn.setPieceImageUrl("p_white"); TileDTO a6BlackPawn = new TileDTO("a6"); @@ -30,7 +30,7 @@ void addPieceTest() throws Exception { List tileDtos = new ArrayList<>(Arrays.asList( a2WhitePawn, a6BlackPawn )); - ChessBoard chessBoard = new ChessBoard(12); + ChessBoard chessBoard = new ChessBoard(1); pieceDAO.addPiece(chessBoard, tileDtos); } @@ -38,8 +38,8 @@ void addPieceTest() throws Exception { @Disabled @DisplayName("피스 삭제") @Test - void deletePieceTest() throws Exception { - PieceOnBoard a2WhitePawn = new PieceOnBoard(4, "a3", "p_white", 1); + void deletePieceTest() { + PieceOnBoard a2WhitePawn = new PieceOnBoard(29, "a1", "r_white", 1); pieceDAO.deletePiece(a2WhitePawn); } @@ -47,23 +47,23 @@ void deletePieceTest() throws Exception { @Disabled @DisplayName("저장되어 있는 피스 정보 불러오기") @Test - void findPieceTest() throws Exception { - ChessBoard chessBoard = new ChessBoard(12); + void findPieceTest() { + ChessBoard chessBoard = new ChessBoard(1); List pieceOnBoards = pieceDAO.findPiece(chessBoard); - Assertions.assertThat(pieceOnBoards).containsExactly( - new PieceOnBoard(6, "a2", "p_white", 12), - new PieceOnBoard(7, "a6", "P_black", 12) + Assertions.assertThat(pieceOnBoards).contains( + new PieceOnBoard(33, "a2", "p_white", 1), + new PieceOnBoard(26, "a6", "P_black", 1) ); } @Disabled @DisplayName("피스 정보 업데이트") @Test - void updatePieceTest() throws Exception { - PieceOnBoard pieceOnBoard = new PieceOnBoard(141, "a1", - "r_white", 17); + void updatePieceTest() { + PieceOnBoard pieceOnBoard = new PieceOnBoard(33, "a2", + "p_white", 1); - pieceDAO.updatePiece(pieceOnBoard, "a2"); + pieceDAO.updatePiece(pieceOnBoard, "a3"); } } diff --git a/src/test/java/chess/dao/PlayerDAOTest.java b/src/test/java/chess/dao/PlayerDAOTest.java index c2746780ea1..ac677d04543 100644 --- a/src/test/java/chess/dao/PlayerDAOTest.java +++ b/src/test/java/chess/dao/PlayerDAOTest.java @@ -19,8 +19,8 @@ private void setUp() { @Disabled @DisplayName("게임이 시작할 때 플레이어가 저장되는지 테스트") @Test - void addPlayerTest() throws Exception { - ChessBoard chessBoard = new ChessBoard(5); + void addPlayerTest() { + ChessBoard chessBoard = new ChessBoard(4); Player player = new Player("pobi", "json"); this.playerDAO.addPlayer(chessBoard, player); @@ -29,8 +29,8 @@ void addPlayerTest() throws Exception { @Disabled @DisplayName("체스 아이디에 맞는 플레이어 정보 찾기") @Test - void findPlayerTest() throws Exception { - ChessBoard chessBoard = new ChessBoard(5); + void findPlayerTest() { + ChessBoard chessBoard = new ChessBoard(4); Player player = this.playerDAO.findPlayer(chessBoard); Assertions.assertThat(player.getWhitePlayer()).isEqualTo("pobi"); @@ -41,7 +41,7 @@ void findPlayerTest() throws Exception { @DisplayName("게임이 끝나고 플레이어 정보 삭제") @Test void deletePlayerTest() throws Exception { - ChessBoard chessBoard = new ChessBoard(5); + ChessBoard chessBoard = new ChessBoard(4); this.playerDAO.deletePlayer(chessBoard); } @@ -51,8 +51,8 @@ void deletePlayerTest() throws Exception { @Test void findAllPlayerTest() throws Exception { List players = this.playerDAO.findAllPlayer(); - Player expected = new Player("pobi", "json"); - expected.setChessBoardId(8); + Player expected = new Player("lavine", "lavine2"); + expected.setChessBoardId(1); Assertions.assertThat(players).contains(expected); } From c21faed40fed24ed249a8eb3e7dbe9574e54f963 Mon Sep 17 00:00:00 2001 From: giantim Date: Thu, 9 Apr 2020 22:10:22 +0900 Subject: [PATCH 62/75] =?UTF-8?q?refactor:=20service=20layer=20=EC=B6=94?= =?UTF-8?q?=EA=B0=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/main/java/chess/service/ChessService.java | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/src/main/java/chess/service/ChessService.java b/src/main/java/chess/service/ChessService.java index 866bd27814a..9f77aaf89ba 100644 --- a/src/main/java/chess/service/ChessService.java +++ b/src/main/java/chess/service/ChessService.java @@ -1,4 +1,13 @@ package chess.service; +import chess.dao.ChessBoardDAO; +import chess.dao.CurrentTeamDAO; +import chess.dao.PieceDAO; +import chess.dao.PlayerDAO; + public class ChessService { + private final ChessBoardDAO chessBoardDAO = new ChessBoardDAO(); + private final CurrentTeamDAO currentTeamDAO = new CurrentTeamDAO(); + private final PieceDAO pieceDAO = new PieceDAO(); + private final PlayerDAO playerDAO = new PlayerDAO(); } From 65e1171b6add5f13eb3f10f05942c895a51634fc Mon Sep 17 00:00:00 2001 From: giantim Date: Mon, 13 Apr 2020 14:40:51 +0900 Subject: [PATCH 63/75] =?UTF-8?q?refactor:=20controller=20=EC=97=90=20dao?= =?UTF-8?q?=20=EB=A5=BC=20=EC=9D=B4=EC=9A=A9=ED=95=98=EB=8A=94=20=EC=97=AD?= =?UTF-8?q?=ED=95=A0=20=EC=A0=9C=EA=B1=B0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../java/chess/WebUIChessApplication.java | 234 +++++++++--------- .../chess/controller/WebChessController.java | 137 +++++++++- src/main/java/chess/domain/ChessRunner.java | 49 ++-- src/main/java/chess/domain/board/Board.java | 8 +- src/main/java/chess/domain/board/Tile.java | 26 -- src/main/java/chess/dto/StatusDTO.java | 13 - src/main/java/chess/dto/TileDTO.java | 18 +- src/main/java/chess/service/ChessService.java | 15 +- 8 files changed, 300 insertions(+), 200 deletions(-) delete mode 100644 src/main/java/chess/domain/board/Tile.java delete mode 100644 src/main/java/chess/dto/StatusDTO.java diff --git a/src/main/java/chess/WebUIChessApplication.java b/src/main/java/chess/WebUIChessApplication.java index 4a915166fdc..a1d6b4bfb03 100644 --- a/src/main/java/chess/WebUIChessApplication.java +++ b/src/main/java/chess/WebUIChessApplication.java @@ -1,134 +1,124 @@ package chess; import chess.controller.WebChessController; -import chess.dao.Player; -import chess.dto.MoveResultDTO; -import chess.dto.TeamDTO; -import chess.dto.TileDTO; -import spark.ModelAndView; -import spark.template.handlebars.HandlebarsTemplateEngine; -import java.util.HashMap; -import java.util.List; -import java.util.Map; - -import static spark.Spark.*; +import static spark.Spark.staticFiles; public class WebUIChessApplication { public static void main(String[] args) { staticFiles.location("/templates"); WebChessController webChessController = new WebChessController(); - - get("/", (req, res) -> { - Map model = new HashMap<>(); - - return render(model, "index.html"); - }); - - post("/name", (req, res) -> { - Map model = new HashMap<>(); - - return render(model, "name.html"); - }); - - post("/load", (req, res) -> { - Map model = new HashMap<>(); - - List players = webChessController.players(); - - model.put("gameData", players); - - return render(model, "table.html"); - }); - - post("/newGame", (req, res) -> { - Map model = new HashMap<>(); - - String whitePlayer = req.queryParams("white-player"); - String blackPlayer = req.queryParams("black-player"); - - Player player = new Player(whitePlayer, blackPlayer); - webChessController.newGame(player); - List tileDtos = webChessController.getTiles(); - TeamDTO teamDto = webChessController.getCurrentTeam(); - - model.put("tiles", tileDtos); - model.put("currentTeam", teamDto); - model.put("player", player); - - return render(model, "game.html"); - }); - - post("/continueGame", (req, res) -> { - Map model = new HashMap<>(); - - int chessBoardId = Integer.parseInt(req.queryParams("chess-board-id")); - - webChessController.continueGame(chessBoardId); - List tileDtos = webChessController.getTiles(); - TeamDTO teamDto = webChessController.getCurrentTeam(); - Player player = webChessController.getPlayer(); - - model.put("tiles", tileDtos); - model.put("currentTeam", teamDto); - model.put("player", player); - - return render(model, "game.html"); - }); - - post("/move", (req, res) -> { - Map model = new HashMap<>(); - - String source = req.queryParams("source"); - String target = req.queryParams("target"); - - MoveResultDTO moveResultDto = webChessController.move(source, target); - List tileDtos = webChessController.getTiles(); - TeamDTO teamDto = webChessController.getCurrentTeam(); - Player player = webChessController.getPlayer(); - - model.put("tiles", tileDtos); - model.put("currentTeam", teamDto); - model.put("message", moveResultDto.getMessage()); - model.put("style", moveResultDto.getStyle()); - model.put("player", player); - - if (webChessController.isEndGame()) { - webChessController.deleteChessGame(); - return render(model, "end.html"); - } - return render(model, "game.html"); - }); - - post("/status", (req, res) -> { - Map model = new HashMap<>(); - - List tileDtos = webChessController.getTiles(); - TeamDTO teamDto = webChessController.getCurrentTeam(); - String message = webChessController.getScores(); - Player player = webChessController.getPlayer(); - - model.put("tiles", tileDtos); - model.put("currentTeam", teamDto); - model.put("message", message); - model.put("player", player); - - return render(model, "game.html"); - }); - - post("/end", (req, res) -> { - Map model = new HashMap<>(); - - webChessController.deleteChessGame(); - String message = webChessController.getScores(); - - model.put("message", message); - - return render(model, "end.html"); - }); + webChessController.playChess(); +// get("/", (req, res) -> { +// Map model = new HashMap<>(); +// +// return render(model, "index.html"); +// }); +// +// post("/name", (req, res) -> { +// Map model = new HashMap<>(); +// +// return render(model, "name.html"); +// }); +// +// post("/load", (req, res) -> { +// Map model = new HashMap<>(); +// +// List players = webChessController.players(); +// +// model.put("gameData", players); +// +// return render(model, "table.html"); +// }); +// +// post("/newGame", (req, res) -> { +// Map model = new HashMap<>(); +// +// String whitePlayer = req.queryParams("white-player"); +// String blackPlayer = req.queryParams("black-player"); +// +// Player player = new Player(whitePlayer, blackPlayer); +// webChessController.newGame(player); +// List tileDtos = webChessController.getTiles(); +// TeamDTO teamDto = webChessController.getCurrentTeam(); +// +// model.put("tiles", tileDtos); +// model.put("currentTeam", teamDto); +// model.put("player", player); +// +// return render(model, "game.html"); +// }); +// +// post("/continueGame", (req, res) -> { +// Map model = new HashMap<>(); +// +// int chessBoardId = Integer.parseInt(req.queryParams("chess-board-id")); +// +// webChessController.continueGame(chessBoardId); +// List tileDtos = webChessController.getTiles(); +// TeamDTO teamDto = webChessController.getCurrentTeam(); +// Player player = webChessController.getPlayer(); +// +// model.put("tiles", tileDtos); +// model.put("currentTeam", teamDto); +// model.put("player", player); +// +// return render(model, "game.html"); +// }); +// +// post("/move", (req, res) -> { +// Map model = new HashMap<>(); +// +// String source = req.queryParams("source"); +// String target = req.queryParams("target"); +// +// MoveResultDTO moveResultDto = webChessController.move(source, target); +// List tileDtos = webChessController.getTiles(); +// TeamDTO teamDto = webChessController.getCurrentTeam(); +// Player player = webChessController.getPlayer(); +// +// model.put("tiles", tileDtos); +// model.put("currentTeam", teamDto); +// model.put("message", moveResultDto.getMessage()); +// model.put("style", moveResultDto.getStyle()); +// model.put("player", player); +// +// if (webChessController.isEndGame()) { +// webChessController.deleteChessGame(); +// return render(model, "end.html"); +// } +// return render(model, "game.html"); +// }); +// +// post("/status", (req, res) -> { +// Map model = new HashMap<>(); +// +// List tileDtos = webChessController.getTiles(); +// TeamDTO teamDto = webChessController.getCurrentTeam(); +// String message = webChessController.getScores(); +// Player player = webChessController.getPlayer(); +// +// model.put("tiles", tileDtos); +// model.put("currentTeam", teamDto); +// model.put("message", message); +// model.put("player", player); +// +// return render(model, "game.html"); +// }); +// +// post("/end", (req, res) -> { +// Map model = new HashMap<>(); +// +// webChessController.deleteChessGame(); +// String message = webChessController.getScores(); +// +// model.put("message", message); +// +// return render(model, "end.html"); +// }); } - private static String render(Map model, String templatePath) { - return new HandlebarsTemplateEngine().render(new ModelAndView(model, templatePath)); - } +// private static String render(Map model, String templatePath) { +// return new HandlebarsTemplateEngine().render(new ModelAndView(model, templatePath)); +// } } diff --git a/src/main/java/chess/controller/WebChessController.java b/src/main/java/chess/controller/WebChessController.java index 4487caab0ba..86ef6ba265b 100644 --- a/src/main/java/chess/controller/WebChessController.java +++ b/src/main/java/chess/controller/WebChessController.java @@ -5,10 +5,19 @@ import chess.dto.MoveResultDTO; import chess.dto.TeamDTO; import chess.dto.TileDTO; +import chess.service.ChessService; +import spark.ModelAndView; +import spark.template.handlebars.HandlebarsTemplateEngine; -import java.util.*; +import java.util.HashMap; +import java.util.List; +import java.util.Map; +import java.util.Optional; import java.util.stream.Collectors; +import static spark.Spark.get; +import static spark.Spark.post; + public class WebChessController { private static final String MESSAGE_STYLE_BLACK = "color:black;"; private static final String MESSAGE_STYLE_RED = "color:red;"; @@ -22,6 +31,118 @@ public class WebChessController { private CurrentTeam currentTeam; private PieceOnBoards originalPieces; + private ChessService chessService; + + public void playChess() { + get("/", (req, res) -> { + Map model = new HashMap<>(); + + return render(model, "index.html"); + }); + + post("/name", (req, res) -> { + Map model = new HashMap<>(); + + return render(model, "name.html"); + }); + + post("/load", (req, res) -> { + Map model = new HashMap<>(); + + List players = this.chessService.players(); + + model.put("gameData", players); + + return render(model, "table.html"); + }); + + post("/newGame", (req, res) -> { + Map model = new HashMap<>(); + + String whitePlayer = req.queryParams("white-player"); + String blackPlayer = req.queryParams("black-player"); + + Player player = new Player(whitePlayer, blackPlayer); + newGame(player); + List tileDtos = getTiles(); + TeamDTO teamDto = getCurrentTeam(); + + model.put("tiles", tileDtos); + model.put("currentTeam", teamDto); + model.put("player", player); + + return render(model, "game.html"); + }); +// +// post("/continueGame", (req, res) -> { +// Map model = new HashMap<>(); +// +// int chessBoardId = Integer.parseInt(req.queryParams("chess-board-id")); +// +// webChessController.continueGame(chessBoardId); +// List tileDtos = webChessController.getTiles(); +// TeamDTO teamDto = webChessController.getCurrentTeam(); +// Player player = webChessController.getPlayer(); +// +// model.put("tiles", tileDtos); +// model.put("currentTeam", teamDto); +// model.put("player", player); +// +// return render(model, "game.html"); +// }); +// +// post("/move", (req, res) -> { +// Map model = new HashMap<>(); +// +// String source = req.queryParams("source"); +// String target = req.queryParams("target"); +// +// MoveResultDTO moveResultDto = webChessController.move(source, target); +// List tileDtos = webChessController.getTiles(); +// TeamDTO teamDto = webChessController.getCurrentTeam(); +// Player player = webChessController.getPlayer(); +// +// model.put("tiles", tileDtos); +// model.put("currentTeam", teamDto); +// model.put("message", moveResultDto.getMessage()); +// model.put("style", moveResultDto.getStyle()); +// model.put("player", player); +// +// if (webChessController.isEndGame()) { +// webChessController.deleteChessGame(); +// return render(model, "end.html"); +// } +// return render(model, "game.html"); +// }); +// +// post("/status", (req, res) -> { +// Map model = new HashMap<>(); +// +// List tileDtos = webChessController.getTiles(); +// TeamDTO teamDto = webChessController.getCurrentTeam(); +// String message = webChessController.getScores(); +// Player player = webChessController.getPlayer(); +// +// model.put("tiles", tileDtos); +// model.put("currentTeam", teamDto); +// model.put("message", message); +// model.put("player", player); +// +// return render(model, "game.html"); +// }); +// +// post("/end", (req, res) -> { +// Map model = new HashMap<>(); +// +// webChessController.deleteChessGame(); +// String message = webChessController.getScores(); +// +// model.put("message", message); +// +// return render(model, "end.html"); +// }); + } + public void newGame(Player player) throws Exception { ChessBoardDAO chessBoardDAO = new ChessBoardDAO(); CurrentTeamDAO currentTeamDAO = new CurrentTeamDAO(); @@ -43,11 +164,11 @@ public void newGame(Player player) throws Exception { playerDAO.addPlayer(this.chessBoard, player); } - public List players() throws Exception { - PlayerDAO playerDAO = new PlayerDAO(); - - return Collections.unmodifiableList(playerDAO.findAllPlayer()); - } +// public List players() throws Exception { +// PlayerDAO playerDAO = new PlayerDAO(); +// +// return Collections.unmodifiableList(playerDAO.findAllPlayer()); +// } public Player getPlayer() throws Exception { PlayerDAO playerDAO = new PlayerDAO(); @@ -143,4 +264,8 @@ public String getScores() { .map(dto -> dto.getTeam() + DELIMITER + dto.getBoardScore()) .collect(Collectors.joining(NEW_LINE)); } + + private static String render(Map model, String templatePath) { + return new HandlebarsTemplateEngine().render(new ModelAndView(model, templatePath)); + } } diff --git a/src/main/java/chess/domain/ChessRunner.java b/src/main/java/chess/domain/ChessRunner.java index 03fc7d342ac..94780cd6204 100644 --- a/src/main/java/chess/domain/ChessRunner.java +++ b/src/main/java/chess/domain/ChessRunner.java @@ -2,7 +2,6 @@ import chess.domain.board.Board; import chess.domain.board.BoardScore; -import chess.domain.board.Tile; import chess.domain.piece.Piece; import chess.domain.piece.Team; import chess.domain.position.Position; @@ -142,13 +141,13 @@ public List entireTileDtos() { .map(TileDTO::new) .collect(Collectors.toList()); - setTileDtoTeam(tileDtos); + setTileDtoStyle(tileDtos); setTileDtoImage(tileDtos); return Collections.unmodifiableList(tileDtos); } - private void setTileDtoTeam(List tileDtos) { + private void setTileDtoStyle(List tileDtos) { List indexes = Position.getPositionsIndex(); for (int i = 0; i < indexes.size(); i++) { TileDTO tileDto = tileDtos.get(i); @@ -156,25 +155,37 @@ private void setTileDtoTeam(List tileDtos) { } } + private void setTileDtoPiece(List tileDtos) { +// Map board = this.board.getBoard(); +// for (Map.Entry entry : board.entrySet()) { +// tileDtos.stream() +// .filter(td -> td.getPosition().equals(entry.getKey())) +// .findFirst() +// .orElseThrow(IllegalArgumentException::new) +// . +// } + } + private void setTileDtoImage(List tileDtos) { - List tiles = this.board.tiles(); - for (Tile tile : tiles) { - TileDTO tileDto = tileDtos.stream() - .filter(td -> td.getPosition().equals(tile.position())) - .findFirst() - .orElseThrow(IllegalArgumentException::new); - tileDto.setPieceImageUrl(tile.pieceImageUrl()); - } +// List tiles = this.board.tiles(); +// for (Tile tile : tiles) { +// TileDTO tileDto = tileDtos.stream() +// .filter(td -> td.getPosition().equals(tile.position())) +// .findFirst() +// .orElseThrow(IllegalArgumentException::new); +// tileDto.setPieceImageUrl(tile.pieceImageUrl()); +// } } public List pieceTileDtos() { - List tileDtos = this.board.tiles().stream() - .map((tile) -> { - TileDTO tileDto = new TileDTO(tile.position()); - tileDto.setPieceImageUrl(tile.pieceImageUrl()); - return tileDto; - }).collect(Collectors.toList()); - - return Collections.unmodifiableList(tileDtos); +// List tileDtos = this.board.tiles().stream() +// .map((tile) -> { +// TileDTO tileDto = new TileDTO(tile.position()); +// tileDto.setPieceImageUrl(tile.pieceImageUrl()); +// return tileDto; +// }).collect(Collectors.toList()); +// +// return Collections.unmodifiableList(tileDtos); + return null; } } diff --git a/src/main/java/chess/domain/board/Board.java b/src/main/java/chess/domain/board/Board.java index 9ba235c1aa4..5f0cb54664b 100644 --- a/src/main/java/chess/domain/board/Board.java +++ b/src/main/java/chess/domain/board/Board.java @@ -95,11 +95,7 @@ public Map parse() { return Collections.unmodifiableMap(parseResult); } - public List tiles() { - List tiles = this.board.entrySet().stream() - .map((entry) -> new Tile(entry.getKey(), entry.getValue())) - .collect(Collectors.toList()); - - return Collections.unmodifiableList(tiles); + public Map getBoard() { + return Collections.unmodifiableMap(this.board); } } \ No newline at end of file diff --git a/src/main/java/chess/domain/board/Tile.java b/src/main/java/chess/domain/board/Tile.java deleted file mode 100644 index edca44f63a2..00000000000 --- a/src/main/java/chess/domain/board/Tile.java +++ /dev/null @@ -1,26 +0,0 @@ -package chess.domain.board; - -import chess.domain.piece.Piece; -import chess.domain.position.Position; - -public class Tile { - private static final String UNDER_BAR = "_"; - - private final Position position; - private final Piece piece; - - public Tile(final Position position, final Piece piece) { - this.position = position; - this.piece = piece; - } - - public String position() { - return this.position.toString(); - } - - public String pieceImageUrl() { - return this.piece.toSymbol() - + UNDER_BAR - + this.piece.teamName().toLowerCase(); - } -} diff --git a/src/main/java/chess/dto/StatusDTO.java b/src/main/java/chess/dto/StatusDTO.java deleted file mode 100644 index 3f7280298d1..00000000000 --- a/src/main/java/chess/dto/StatusDTO.java +++ /dev/null @@ -1,13 +0,0 @@ -package chess.dto; - -public class StatusDTO { - private final String message; - - public StatusDTO(String message) { - this.message = message; - } - - public String getMessage() { - return this.message; - } -} diff --git a/src/main/java/chess/dto/TileDTO.java b/src/main/java/chess/dto/TileDTO.java index 92d62e07681..195386bfd00 100644 --- a/src/main/java/chess/dto/TileDTO.java +++ b/src/main/java/chess/dto/TileDTO.java @@ -1,10 +1,12 @@ package chess.dto; public class TileDTO { - private static final String WHITE = "white"; - private static final String BLACK = "black"; + private static final String STYLE_WHITE = "white"; + private static final String STYLE_BLACK = "black"; private final String position; + private String team; + private String piece; private String pieceImageUrl; private String style; @@ -15,10 +17,18 @@ public TileDTO(final String position) { public void setStyle(int index) { if (index % 2 == 0) { - this.style = WHITE; + this.style = STYLE_WHITE; return; } - this.style = BLACK; + this.style = STYLE_BLACK; + } + + public void setTeam(String team) { + this.team = team; + } + + public void setPiece(String piece) { + this.piece = piece; } public void setPieceImageUrl(String pieceImageUrl) { diff --git a/src/main/java/chess/service/ChessService.java b/src/main/java/chess/service/ChessService.java index 9f77aaf89ba..62e0acbacd7 100644 --- a/src/main/java/chess/service/ChessService.java +++ b/src/main/java/chess/service/ChessService.java @@ -1,13 +1,20 @@ package chess.service; -import chess.dao.ChessBoardDAO; -import chess.dao.CurrentTeamDAO; -import chess.dao.PieceDAO; -import chess.dao.PlayerDAO; +import chess.dao.*; +import chess.domain.ChessRunner; + +import java.util.Collections; +import java.util.List; public class ChessService { private final ChessBoardDAO chessBoardDAO = new ChessBoardDAO(); private final CurrentTeamDAO currentTeamDAO = new CurrentTeamDAO(); private final PieceDAO pieceDAO = new PieceDAO(); private final PlayerDAO playerDAO = new PlayerDAO(); + + private ChessRunner chessRunner; + + public List players() { + return Collections.unmodifiableList(this.playerDAO.findAllPlayer()); + } } From a358f99c6c015b4af6605176eab5df523e861a88 Mon Sep 17 00:00:00 2001 From: giantim Date: Mon, 13 Apr 2020 15:08:36 +0900 Subject: [PATCH 64/75] =?UTF-8?q?refactor:=20piece=20->=20pieceOnBoard=20?= =?UTF-8?q?=EB=AA=A8=EB=8D=B8=EB=A1=9C=20=EB=B3=80=EA=B2=BD?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../chess/controller/WebChessController.java | 36 +++++----- src/main/java/chess/dao/PieceOnBoard.java | 21 ++++-- .../{PieceDAO.java => PieceOnBoardDAO.java} | 36 +++++----- src/main/java/chess/dto/TileDTO.java | 14 +++- src/main/java/chess/service/ChessService.java | 2 +- src/test/java/chess/dao/PieceDAOTest.java | 69 ------------------- .../java/chess/dao/PieceOnBoardDAOTest.java | 65 +++++++++++++++++ 7 files changed, 127 insertions(+), 116 deletions(-) rename src/main/java/chess/dao/{PieceDAO.java => PieceOnBoardDAO.java} (65%) delete mode 100644 src/test/java/chess/dao/PieceDAOTest.java create mode 100644 src/test/java/chess/dao/PieceOnBoardDAOTest.java diff --git a/src/main/java/chess/controller/WebChessController.java b/src/main/java/chess/controller/WebChessController.java index 86ef6ba265b..d1c7ec16e06 100644 --- a/src/main/java/chess/controller/WebChessController.java +++ b/src/main/java/chess/controller/WebChessController.java @@ -146,7 +146,7 @@ public void playChess() { public void newGame(Player player) throws Exception { ChessBoardDAO chessBoardDAO = new ChessBoardDAO(); CurrentTeamDAO currentTeamDAO = new CurrentTeamDAO(); - PieceDAO pieceDAO = new PieceDAO(); + PieceOnBoardDAO pieceOnBoardDAO = new PieceOnBoardDAO(); PlayerDAO playerDAO = new PlayerDAO(); this.chessRunner = new ChessRunner(); @@ -158,8 +158,8 @@ public void newGame(Player player) throws Exception { currentTeamDAO.addCurrentTeam(this.chessBoard, this.currentTeam); List tileDtos = this.chessRunner.pieceTileDtos(); - pieceDAO.addPiece(this.chessBoard, tileDtos); - updateOriginalPieces(pieceDAO); +// pieceOnBoardDAO.addPiece(this.chessBoard, tileDtos); + updateOriginalPieces(pieceOnBoardDAO); playerDAO.addPlayer(this.chessBoard, player); } @@ -179,22 +179,22 @@ public Player getPlayer() throws Exception { public void continueGame(int chessBoardId) throws Exception { ChessBoardDAO chessBoardDAO = new ChessBoardDAO(); CurrentTeamDAO currentTeamDAO = new CurrentTeamDAO(); - PieceDAO pieceDAO = new PieceDAO(); + PieceOnBoardDAO pieceOnBoardDAO = new PieceOnBoardDAO(); this.chessBoard = chessBoardDAO.findById(chessBoardId); this.currentTeam = currentTeamDAO.findCurrentTeam(this.chessBoard); - updateOriginalPieces(pieceDAO); - Map pieceOnBoards = this.originalPieces.getPieceOnBoards().stream() - .collect(Collectors.toMap(entry -> entry.getPosition(), - entry -> entry.getPieceImageUrl(), - (e1, e2) -> e1, HashMap::new)); - this.chessRunner = new ChessRunner(pieceOnBoards, this.currentTeam.getCurrentTeam()); + updateOriginalPieces(pieceOnBoardDAO); +// Map pieceOnBoards = this.originalPieces.getPieceOnBoards().stream() +// .collect(Collectors.toMap(entry -> entry.getPosition(), +// entry -> entry.getPieceImageUrl(), +// (e1, e2) -> e1, HashMap::new)); +// this.chessRunner = new ChessRunner(pieceOnBoards, this.currentTeam.getCurrentTeam()); } - private void updateOriginalPieces(PieceDAO pieceDAO) throws Exception { - List pieces = pieceDAO.findPiece(this.chessBoard); + private void updateOriginalPieces(PieceOnBoardDAO pieceOnBoardDAO) throws Exception { + List pieces = pieceOnBoardDAO.findPiece(this.chessBoard); this.originalPieces = PieceOnBoards.create(pieces); } @@ -211,19 +211,19 @@ public MoveResultDTO move(final String source, final String target) throws Excep private void updateChessBoard(final String source, final String target) throws Exception { PieceOnBoard deletedPiece = null; - PieceDAO pieceDAO = new PieceDAO(); + PieceOnBoardDAO pieceOnBoardDAO = new PieceOnBoardDAO(); CurrentTeamDAO currentTeamDAO = new CurrentTeamDAO(); Optional targetPiece = this.originalPieces.find(target); if (targetPiece.isPresent()) { deletedPiece = targetPiece.get(); - pieceDAO.deletePiece(deletedPiece); + pieceOnBoardDAO.deletePiece(deletedPiece); } Optional sourcePiece = this.originalPieces.find(source); - pieceDAO.updatePiece(sourcePiece.get(), target); + pieceOnBoardDAO.updatePiece(sourcePiece.get(), target); this.currentTeam = new CurrentTeam(this.chessRunner.getCurrentTeam()); currentTeamDAO.updateCurrentTeam(this.chessBoard, this.currentTeam); - updateOriginalPieces(pieceDAO); + updateOriginalPieces(pieceOnBoardDAO); } private String moveResult(final ChessRunner chessRunner, final String source, final String target) { @@ -239,13 +239,13 @@ public boolean isEndGame() { public void deleteChessGame() throws Exception { ChessBoardDAO chessBoardDAO = new ChessBoardDAO(); - PieceDAO pieceDAO = new PieceDAO(); + PieceOnBoardDAO pieceOnBoardDAO = new PieceOnBoardDAO(); CurrentTeamDAO currentTeamDAO = new CurrentTeamDAO(); PlayerDAO playerDAO = new PlayerDAO(); currentTeamDAO.deleteCurrentTeam(this.chessBoard); for (PieceOnBoard pieceOnBoard : this.originalPieces.getPieceOnBoards()) { - pieceDAO.deletePiece(pieceOnBoard); + pieceOnBoardDAO.deletePiece(pieceOnBoard); } playerDAO.deletePlayer(this.chessBoard); chessBoardDAO.deleteChessBoard(this.chessBoard); diff --git a/src/main/java/chess/dao/PieceOnBoard.java b/src/main/java/chess/dao/PieceOnBoard.java index 81de99ba852..9cae1424afa 100644 --- a/src/main/java/chess/dao/PieceOnBoard.java +++ b/src/main/java/chess/dao/PieceOnBoard.java @@ -5,13 +5,15 @@ public class PieceOnBoard { private int pieceId; private String position; - private String pieceImageUrl; + private String pieceType; + private String team; private int chessBoardId; - public PieceOnBoard(int pieceId, String position, String pieceImageUrl, int chessBoardId) { + public PieceOnBoard(int pieceId, String position, String pieceType, String team, int chessBoardId) { this.pieceId = pieceId; this.position = position; - this.pieceImageUrl = pieceImageUrl; + this.pieceType = pieceType; + this.team = team; this.chessBoardId = chessBoardId; } @@ -23,8 +25,12 @@ public String getPosition() { return position; } - public String getPieceImageUrl() { - return this.pieceImageUrl; + public String getPieceType() { + return this.pieceType; + } + + public String getTeam() { + return this.team; } public int getChessBoardId() { @@ -42,12 +48,13 @@ public boolean equals(Object o) { PieceOnBoard pieceOnBoard = (PieceOnBoard) o; return Objects.equals(pieceId, pieceOnBoard.pieceId) && Objects.equals(position, pieceOnBoard.position) - && Objects.equals(pieceImageUrl, pieceOnBoard.pieceImageUrl) + && Objects.equals(pieceType, pieceOnBoard.pieceType) + && Objects.equals(team, pieceOnBoard.team) && Objects.equals(chessBoardId, pieceOnBoard.chessBoardId); } @Override public int hashCode() { - return Objects.hash(pieceId, position, pieceImageUrl, chessBoardId); + return Objects.hash(pieceId, position, pieceType, team, chessBoardId); } } diff --git a/src/main/java/chess/dao/PieceDAO.java b/src/main/java/chess/dao/PieceOnBoardDAO.java similarity index 65% rename from src/main/java/chess/dao/PieceDAO.java rename to src/main/java/chess/dao/PieceOnBoardDAO.java index 63bbc711101..81a5903dd0a 100644 --- a/src/main/java/chess/dao/PieceDAO.java +++ b/src/main/java/chess/dao/PieceOnBoardDAO.java @@ -1,7 +1,5 @@ package chess.dao; -import chess.dto.TileDTO; - import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; @@ -10,16 +8,17 @@ import java.util.Collections; import java.util.List; -public class PieceDAO { - public void addPiece(ChessBoard chessBoard, List tileDtos) { - try (Connection con = ConnectionManager.getConnection();) { - for (TileDTO tileDto : tileDtos) { - String query = "INSERT INTO piece (position, pieceImageUrl, chessBoardId) " - + "VALUES(?, ?, ?)"; +public class PieceOnBoardDAO { + public void addPiece(ChessBoard chessBoard, List pieceOnBoards) { + try (Connection con = ConnectionManager.getConnection()) { + for (PieceOnBoard pieceOnBoard : pieceOnBoards) { + String query = "INSERT INTO pieceOnBoard (position, pieceType, team, chessBoardId) " + + "VALUES(?, ?, ?, ?)"; PreparedStatement pstmt = con.prepareStatement(query); - pstmt.setString(1, tileDto.getPosition()); - pstmt.setString(2, tileDto.getPieceImageUrl()); - pstmt.setInt(3, chessBoard.getChessBoardId()); + pstmt.setString(1, pieceOnBoard.getPosition()); + pstmt.setString(2, pieceOnBoard.getPieceType()); + pstmt.setString(3, pieceOnBoard.getTeam()); + pstmt.setInt(4, chessBoard.getChessBoardId()); pstmt.executeUpdate(); } } catch (SQLException e) { @@ -27,14 +26,14 @@ public void addPiece(ChessBoard chessBoard, List tileDtos) { } } - public void deletePiece(PieceOnBoard piece) { - if (piece == null) { + public void deletePiece(PieceOnBoard pieceOnBoard) { + if (pieceOnBoard == null) { return; } - String query = "DELETE FROM piece WHERE pieceId = ?"; + String query = "DELETE FROM pieceOnBoard WHERE pieceId = ?"; try (Connection con = ConnectionManager.getConnection(); PreparedStatement pstmt = con.prepareStatement(query)) { - pstmt.setInt(1, piece.getPieceId()); + pstmt.setInt(1, pieceOnBoard.getPieceId()); pstmt.executeUpdate(); } catch (SQLException e) { e.printStackTrace(); @@ -43,7 +42,7 @@ public void deletePiece(PieceOnBoard piece) { public List findPiece(ChessBoard chessBoard) { List pieceOnBoards = new ArrayList<>(); - String query = "SELECT * FROM piece WHERE chessBoardId = ?"; + String query = "SELECT * FROM pieceOnBoard WHERE chessBoardId = ?"; try (Connection con = ConnectionManager.getConnection(); PreparedStatement pstmt = con.prepareStatement(query);) { pstmt.setInt(1, chessBoard.getChessBoardId()); @@ -53,7 +52,8 @@ public List findPiece(ChessBoard chessBoard) { PieceOnBoard pieceOnBoard = new PieceOnBoard( rs.getInt("pieceId"), rs.getString("position"), - rs.getString("pieceImageUrl"), + rs.getString("pieceType"), + rs.getString("team"), rs.getInt("chessBoardId") ); pieceOnBoards.add(pieceOnBoard); @@ -67,7 +67,7 @@ public List findPiece(ChessBoard chessBoard) { } public void updatePiece(PieceOnBoard pieceOnBoard, String targetPosition) { - String query = "UPDATE piece SET position = ? WHERE pieceId = ?"; + String query = "UPDATE pieceOnBoard SET position = ? WHERE pieceId = ?"; try (Connection con = ConnectionManager.getConnection(); PreparedStatement pstmt = con.prepareStatement(query)) { pstmt.setString(1, targetPosition); diff --git a/src/main/java/chess/dto/TileDTO.java b/src/main/java/chess/dto/TileDTO.java index 195386bfd00..c3c94f0e005 100644 --- a/src/main/java/chess/dto/TileDTO.java +++ b/src/main/java/chess/dto/TileDTO.java @@ -6,7 +6,7 @@ public class TileDTO { private final String position; private String team; - private String piece; + private String pieceType; private String pieceImageUrl; private String style; @@ -27,8 +27,8 @@ public void setTeam(String team) { this.team = team; } - public void setPiece(String piece) { - this.piece = piece; + public void setPieceType(String pieceType) { + this.pieceType = pieceType; } public void setPieceImageUrl(String pieceImageUrl) { @@ -46,4 +46,12 @@ public String getStyle() { public String getPieceImageUrl() { return this.pieceImageUrl; } + + public String getPieceType() { + return this.pieceType; + } + + public String getTeam() { + return this.team; + } } diff --git a/src/main/java/chess/service/ChessService.java b/src/main/java/chess/service/ChessService.java index 62e0acbacd7..f9f81d0b246 100644 --- a/src/main/java/chess/service/ChessService.java +++ b/src/main/java/chess/service/ChessService.java @@ -9,7 +9,7 @@ public class ChessService { private final ChessBoardDAO chessBoardDAO = new ChessBoardDAO(); private final CurrentTeamDAO currentTeamDAO = new CurrentTeamDAO(); - private final PieceDAO pieceDAO = new PieceDAO(); + private final PieceOnBoardDAO pieceOnBoardDAO = new PieceOnBoardDAO(); private final PlayerDAO playerDAO = new PlayerDAO(); private ChessRunner chessRunner; diff --git a/src/test/java/chess/dao/PieceDAOTest.java b/src/test/java/chess/dao/PieceDAOTest.java deleted file mode 100644 index ed2b0ba84a8..00000000000 --- a/src/test/java/chess/dao/PieceDAOTest.java +++ /dev/null @@ -1,69 +0,0 @@ -package chess.dao; - -import chess.dto.TileDTO; -import org.assertj.core.api.Assertions; -import org.junit.jupiter.api.BeforeEach; -import org.junit.jupiter.api.Disabled; -import org.junit.jupiter.api.DisplayName; -import org.junit.jupiter.api.Test; - -import java.util.ArrayList; -import java.util.Arrays; -import java.util.List; - -public class PieceDAOTest { - private PieceDAO pieceDAO; - - @BeforeEach - private void setUp() { - pieceDAO = new PieceDAO(); - } - - @Disabled - @DisplayName("피스 정보 추가") - @Test - void addPieceTest() { - TileDTO a2WhitePawn = new TileDTO("a2"); - a2WhitePawn.setPieceImageUrl("p_white"); - TileDTO a6BlackPawn = new TileDTO("a6"); - a6BlackPawn.setPieceImageUrl("P_black"); - List tileDtos = new ArrayList<>(Arrays.asList( - a2WhitePawn, a6BlackPawn - )); - ChessBoard chessBoard = new ChessBoard(1); - - pieceDAO.addPiece(chessBoard, tileDtos); - } - - @Disabled - @DisplayName("피스 삭제") - @Test - void deletePieceTest() { - PieceOnBoard a2WhitePawn = new PieceOnBoard(29, "a1", "r_white", 1); - - pieceDAO.deletePiece(a2WhitePawn); - } - - @Disabled - @DisplayName("저장되어 있는 피스 정보 불러오기") - @Test - void findPieceTest() { - ChessBoard chessBoard = new ChessBoard(1); - List pieceOnBoards = pieceDAO.findPiece(chessBoard); - - Assertions.assertThat(pieceOnBoards).contains( - new PieceOnBoard(33, "a2", "p_white", 1), - new PieceOnBoard(26, "a6", "P_black", 1) - ); - } - - @Disabled - @DisplayName("피스 정보 업데이트") - @Test - void updatePieceTest() { - PieceOnBoard pieceOnBoard = new PieceOnBoard(33, "a2", - "p_white", 1); - - pieceDAO.updatePiece(pieceOnBoard, "a3"); - } -} diff --git a/src/test/java/chess/dao/PieceOnBoardDAOTest.java b/src/test/java/chess/dao/PieceOnBoardDAOTest.java new file mode 100644 index 00000000000..bf941fb6849 --- /dev/null +++ b/src/test/java/chess/dao/PieceOnBoardDAOTest.java @@ -0,0 +1,65 @@ +package chess.dao; + +import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.Disabled; +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; + +import java.util.ArrayList; +import java.util.List; + +public class PieceOnBoardDAOTest { + private PieceOnBoardDAO pieceOnBoardDAO; + + @BeforeEach + private void setUp() { + pieceOnBoardDAO = new PieceOnBoardDAO(); + } + + @Disabled + @DisplayName("피스 정보 추가") + @Test + void addPieceTest() { + List pieceOnBoards = new ArrayList<>(); + pieceOnBoards.add(new PieceOnBoard(0, "a2", "PAWN", "WHITE", 5)); + pieceOnBoards.add(new PieceOnBoard(0, "a1", "ROOK", "WHITE", 5)); + pieceOnBoards.add(new PieceOnBoard(0, "a7", "PAWN", "BLACK", 5)); + ChessBoard chessBoard = new ChessBoard(5); + + pieceOnBoardDAO.addPiece(chessBoard, pieceOnBoards); + } + + @Disabled + @DisplayName("피스 삭제") + @Test + void deletePieceTest() { + PieceOnBoard a2WhitePawn = new PieceOnBoard(35, "a1", "ROOK", + "WHITE", 5); + + pieceOnBoardDAO.deletePiece(a2WhitePawn); + } + + @Disabled + @DisplayName("저장되어 있는 피스 정보 불러오기") + @Test + void findPieceTest() { + ChessBoard chessBoard = new ChessBoard(5); + List pieceOnBoards = pieceOnBoardDAO.findPiece(chessBoard); + + Assertions.assertThat(pieceOnBoards).contains( + new PieceOnBoard(34, "a2", "PAWN", "WHITE", 5), + new PieceOnBoard(36, "a7", "PAWN", "BLACK", 5) + ); + } + + @Disabled + @DisplayName("피스 정보 업데이트") + @Test + void updatePieceTest() { + PieceOnBoard pieceOnBoard = new PieceOnBoard(34, "a2", "PAWN", + "WHITE", 5); + + pieceOnBoardDAO.updatePiece(pieceOnBoard, "a3"); + } +} From d1bbe305fc8d5d76635f21b9c9301a3459dacbb5 Mon Sep 17 00:00:00 2001 From: giantim Date: Mon, 13 Apr 2020 15:55:07 +0900 Subject: [PATCH 65/75] =?UTF-8?q?refactor:=20=EC=8B=A0=EA=B7=9C=20?= =?UTF-8?q?=EA=B2=8C=EC=9E=84=20=EC=8B=9C=EC=9E=91=20=EA=B8=B0=EB=8A=A5=20?= =?UTF-8?q?=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../chess/controller/WebChessController.java | 31 +++-------- src/main/java/chess/dao/PieceOnBoard.java | 4 ++ src/main/java/chess/domain/ChessRunner.java | 50 +++++++----------- src/main/java/chess/dto/TileDTO.java | 31 +++-------- src/main/java/chess/service/ChessService.java | 34 ++++++++++++ .../image/piece/{B_black.png => Bblack.png} | Bin .../image/piece/{K_black.png => Kblack.png} | Bin .../image/piece/{N_black.png => Nblack.png} | Bin .../image/piece/{P_black.png => Pblack.png} | Bin .../image/piece/{Q_black.png => Qblack.png} | Bin .../image/piece/{R_black.png => Rblack.png} | Bin .../image/piece/{b_white.png => bwhite.png} | Bin .../image/piece/{k_white.png => kwhite.png} | Bin .../image/piece/{n_white.png => nwhite.png} | Bin .../image/piece/{p_white.png => pwhite.png} | Bin .../image/piece/{q_white.png => qwhite.png} | Bin .../image/piece/{r_white.png => rwhite.png} | Bin 17 files changed, 70 insertions(+), 80 deletions(-) rename src/main/resources/templates/image/piece/{B_black.png => Bblack.png} (100%) rename src/main/resources/templates/image/piece/{K_black.png => Kblack.png} (100%) rename src/main/resources/templates/image/piece/{N_black.png => Nblack.png} (100%) rename src/main/resources/templates/image/piece/{P_black.png => Pblack.png} (100%) rename src/main/resources/templates/image/piece/{Q_black.png => Qblack.png} (100%) rename src/main/resources/templates/image/piece/{R_black.png => Rblack.png} (100%) rename src/main/resources/templates/image/piece/{b_white.png => bwhite.png} (100%) rename src/main/resources/templates/image/piece/{k_white.png => kwhite.png} (100%) rename src/main/resources/templates/image/piece/{n_white.png => nwhite.png} (100%) rename src/main/resources/templates/image/piece/{p_white.png => pwhite.png} (100%) rename src/main/resources/templates/image/piece/{q_white.png => qwhite.png} (100%) rename src/main/resources/templates/image/piece/{r_white.png => rwhite.png} (100%) diff --git a/src/main/java/chess/controller/WebChessController.java b/src/main/java/chess/controller/WebChessController.java index d1c7ec16e06..24d5b1cdd96 100644 --- a/src/main/java/chess/controller/WebChessController.java +++ b/src/main/java/chess/controller/WebChessController.java @@ -34,6 +34,8 @@ public class WebChessController { private ChessService chessService; public void playChess() { + this.chessService = new ChessService(); + get("/", (req, res) -> { Map model = new HashMap<>(); @@ -63,9 +65,9 @@ public void playChess() { String blackPlayer = req.queryParams("black-player"); Player player = new Player(whitePlayer, blackPlayer); - newGame(player); - List tileDtos = getTiles(); - TeamDTO teamDto = getCurrentTeam(); + this.chessService.newGame(player); + List tileDtos = this.chessService.getTiles(); + TeamDTO teamDto = this.chessService.getCurrentTeam(); model.put("tiles", tileDtos); model.put("currentTeam", teamDto); @@ -143,34 +145,13 @@ public void playChess() { // }); } - public void newGame(Player player) throws Exception { - ChessBoardDAO chessBoardDAO = new ChessBoardDAO(); - CurrentTeamDAO currentTeamDAO = new CurrentTeamDAO(); - PieceOnBoardDAO pieceOnBoardDAO = new PieceOnBoardDAO(); - PlayerDAO playerDAO = new PlayerDAO(); - - this.chessRunner = new ChessRunner(); - - chessBoardDAO.addChessBoard(); - this.chessBoard = chessBoardDAO.findRecentChessBoard(); - - this.currentTeam = new CurrentTeam(this.chessRunner.getCurrentTeam()); - currentTeamDAO.addCurrentTeam(this.chessBoard, this.currentTeam); - - List tileDtos = this.chessRunner.pieceTileDtos(); -// pieceOnBoardDAO.addPiece(this.chessBoard, tileDtos); - updateOriginalPieces(pieceOnBoardDAO); - - playerDAO.addPlayer(this.chessBoard, player); - } - // public List players() throws Exception { // PlayerDAO playerDAO = new PlayerDAO(); // // return Collections.unmodifiableList(playerDAO.findAllPlayer()); // } - public Player getPlayer() throws Exception { + public Player getPlayer() { PlayerDAO playerDAO = new PlayerDAO(); return playerDAO.findPlayer(this.chessBoard); diff --git a/src/main/java/chess/dao/PieceOnBoard.java b/src/main/java/chess/dao/PieceOnBoard.java index 9cae1424afa..afd2e7fbf5e 100644 --- a/src/main/java/chess/dao/PieceOnBoard.java +++ b/src/main/java/chess/dao/PieceOnBoard.java @@ -9,6 +9,10 @@ public class PieceOnBoard { private String team; private int chessBoardId; + public PieceOnBoard(String position, String pieceType, String team, int chessBoardId) { + this(0, position, pieceType, team, chessBoardId); + } + public PieceOnBoard(int pieceId, String position, String pieceType, String team, int chessBoardId) { this.pieceId = pieceId; this.position = position; diff --git a/src/main/java/chess/domain/ChessRunner.java b/src/main/java/chess/domain/ChessRunner.java index 94780cd6204..2367ed36b9c 100644 --- a/src/main/java/chess/domain/ChessRunner.java +++ b/src/main/java/chess/domain/ChessRunner.java @@ -1,5 +1,6 @@ package chess.domain; +import chess.dao.PieceOnBoard; import chess.domain.board.Board; import chess.domain.board.BoardScore; import chess.domain.piece.Piece; @@ -155,37 +156,26 @@ private void setTileDtoStyle(List tileDtos) { } } - private void setTileDtoPiece(List tileDtos) { -// Map board = this.board.getBoard(); -// for (Map.Entry entry : board.entrySet()) { -// tileDtos.stream() -// .filter(td -> td.getPosition().equals(entry.getKey())) -// .findFirst() -// .orElseThrow(IllegalArgumentException::new) -// . -// } + private void setTileDtoImage(List tileDtos) { + Map board = this.board.getBoard(); + for (Map.Entry entry : board.entrySet()) { + tileDtos.stream() + .filter(td -> td.getPosition().equals(entry.getKey().toString())) + .findFirst() + .orElseThrow(IllegalArgumentException::new) + .setPieceImageUrl(entry.getValue().toSymbol() + entry.getValue().teamName().toLowerCase()); + } } - private void setTileDtoImage(List tileDtos) { -// List tiles = this.board.tiles(); -// for (Tile tile : tiles) { -// TileDTO tileDto = tileDtos.stream() -// .filter(td -> td.getPosition().equals(tile.position())) -// .findFirst() -// .orElseThrow(IllegalArgumentException::new); -// tileDto.setPieceImageUrl(tile.pieceImageUrl()); -// } - } - - public List pieceTileDtos() { -// List tileDtos = this.board.tiles().stream() -// .map((tile) -> { -// TileDTO tileDto = new TileDTO(tile.position()); -// tileDto.setPieceImageUrl(tile.pieceImageUrl()); -// return tileDto; -// }).collect(Collectors.toList()); -// -// return Collections.unmodifiableList(tileDtos); - return null; + public List getPieceOnBoards(int chessBoardId) { + List pieces = this.board.getBoard().entrySet().stream() + .map((entry) -> { + String position = entry.getKey().toString(); + String pieceType = entry.getValue().toSymbol(); + String team = entry.getValue().teamName(); + return new PieceOnBoard(position, pieceType, team, chessBoardId); + }).collect(Collectors.toList()); + + return Collections.unmodifiableList(pieces); } } diff --git a/src/main/java/chess/dto/TileDTO.java b/src/main/java/chess/dto/TileDTO.java index c3c94f0e005..64906871d7c 100644 --- a/src/main/java/chess/dto/TileDTO.java +++ b/src/main/java/chess/dto/TileDTO.java @@ -5,14 +5,15 @@ public class TileDTO { private static final String STYLE_BLACK = "black"; private final String position; - private String team; - private String pieceType; private String pieceImageUrl; private String style; public TileDTO(final String position) { this.position = position; - this.pieceImageUrl = ""; + } + + public void setPieceImageUrl(String pieceImageUrl) { + this.pieceImageUrl = pieceImageUrl; } public void setStyle(int index) { @@ -23,35 +24,15 @@ public void setStyle(int index) { this.style = STYLE_BLACK; } - public void setTeam(String team) { - this.team = team; - } - - public void setPieceType(String pieceType) { - this.pieceType = pieceType; - } - - public void setPieceImageUrl(String pieceImageUrl) { - this.pieceImageUrl = pieceImageUrl; - } - public String getPosition() { return position; } - public String getStyle() { - return this.style; - } - public String getPieceImageUrl() { return this.pieceImageUrl; } - public String getPieceType() { - return this.pieceType; - } - - public String getTeam() { - return this.team; + public String getStyle() { + return this.style; } } diff --git a/src/main/java/chess/service/ChessService.java b/src/main/java/chess/service/ChessService.java index f9f81d0b246..6fce595f77c 100644 --- a/src/main/java/chess/service/ChessService.java +++ b/src/main/java/chess/service/ChessService.java @@ -2,6 +2,8 @@ import chess.dao.*; import chess.domain.ChessRunner; +import chess.dto.TeamDTO; +import chess.dto.TileDTO; import java.util.Collections; import java.util.List; @@ -13,8 +15,40 @@ public class ChessService { private final PlayerDAO playerDAO = new PlayerDAO(); private ChessRunner chessRunner; + private ChessBoard chessBoard; + private CurrentTeam currentTeam; + private PieceOnBoards originalPieces; public List players() { return Collections.unmodifiableList(this.playerDAO.findAllPlayer()); } + + public void newGame(Player player) { + this.chessRunner = new ChessRunner(); + + chessBoardDAO.addChessBoard(); + this.chessBoard = chessBoardDAO.findRecentChessBoard(); + + this.currentTeam = new CurrentTeam(this.chessRunner.getCurrentTeam()); + currentTeamDAO.addCurrentTeam(this.chessBoard, this.currentTeam); + + List pieces = this.chessRunner.getPieceOnBoards(this.chessBoard.getChessBoardId()); + pieceOnBoardDAO.addPiece(this.chessBoard, pieces); + updateOriginalPieces(pieceOnBoardDAO); + + playerDAO.addPlayer(this.chessBoard, player); + } + + private void updateOriginalPieces(PieceOnBoardDAO pieceOnBoardDAO) { + List pieces = pieceOnBoardDAO.findPiece(this.chessBoard); + this.originalPieces = PieceOnBoards.create(pieces); + } + + public List getTiles() { + return this.chessRunner.entireTileDtos(); + } + + public TeamDTO getCurrentTeam() { + return new TeamDTO(this.chessRunner.getCurrentTeam()); + } } diff --git a/src/main/resources/templates/image/piece/B_black.png b/src/main/resources/templates/image/piece/Bblack.png similarity index 100% rename from src/main/resources/templates/image/piece/B_black.png rename to src/main/resources/templates/image/piece/Bblack.png diff --git a/src/main/resources/templates/image/piece/K_black.png b/src/main/resources/templates/image/piece/Kblack.png similarity index 100% rename from src/main/resources/templates/image/piece/K_black.png rename to src/main/resources/templates/image/piece/Kblack.png diff --git a/src/main/resources/templates/image/piece/N_black.png b/src/main/resources/templates/image/piece/Nblack.png similarity index 100% rename from src/main/resources/templates/image/piece/N_black.png rename to src/main/resources/templates/image/piece/Nblack.png diff --git a/src/main/resources/templates/image/piece/P_black.png b/src/main/resources/templates/image/piece/Pblack.png similarity index 100% rename from src/main/resources/templates/image/piece/P_black.png rename to src/main/resources/templates/image/piece/Pblack.png diff --git a/src/main/resources/templates/image/piece/Q_black.png b/src/main/resources/templates/image/piece/Qblack.png similarity index 100% rename from src/main/resources/templates/image/piece/Q_black.png rename to src/main/resources/templates/image/piece/Qblack.png diff --git a/src/main/resources/templates/image/piece/R_black.png b/src/main/resources/templates/image/piece/Rblack.png similarity index 100% rename from src/main/resources/templates/image/piece/R_black.png rename to src/main/resources/templates/image/piece/Rblack.png diff --git a/src/main/resources/templates/image/piece/b_white.png b/src/main/resources/templates/image/piece/bwhite.png similarity index 100% rename from src/main/resources/templates/image/piece/b_white.png rename to src/main/resources/templates/image/piece/bwhite.png diff --git a/src/main/resources/templates/image/piece/k_white.png b/src/main/resources/templates/image/piece/kwhite.png similarity index 100% rename from src/main/resources/templates/image/piece/k_white.png rename to src/main/resources/templates/image/piece/kwhite.png diff --git a/src/main/resources/templates/image/piece/n_white.png b/src/main/resources/templates/image/piece/nwhite.png similarity index 100% rename from src/main/resources/templates/image/piece/n_white.png rename to src/main/resources/templates/image/piece/nwhite.png diff --git a/src/main/resources/templates/image/piece/p_white.png b/src/main/resources/templates/image/piece/pwhite.png similarity index 100% rename from src/main/resources/templates/image/piece/p_white.png rename to src/main/resources/templates/image/piece/pwhite.png diff --git a/src/main/resources/templates/image/piece/q_white.png b/src/main/resources/templates/image/piece/qwhite.png similarity index 100% rename from src/main/resources/templates/image/piece/q_white.png rename to src/main/resources/templates/image/piece/qwhite.png diff --git a/src/main/resources/templates/image/piece/r_white.png b/src/main/resources/templates/image/piece/rwhite.png similarity index 100% rename from src/main/resources/templates/image/piece/r_white.png rename to src/main/resources/templates/image/piece/rwhite.png From 953009389cbe494439b15cb498970db57399b336 Mon Sep 17 00:00:00 2001 From: giantim Date: Mon, 13 Apr 2020 16:23:46 +0900 Subject: [PATCH 66/75] =?UTF-8?q?refactor:=20controller=20=EC=9D=98=20?= =?UTF-8?q?=EA=B8=B0=EB=8A=A5=EC=9D=84=20Service=20layer=20=EB=A1=9C=20?= =?UTF-8?q?=EB=B6=84=EB=A6=AC?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../java/chess/WebUIChessApplication.java | 111 --------- .../chess/controller/WebChessController.java | 222 +++++------------- src/main/java/chess/domain/ChessRunner.java | 2 +- .../chess/domain/board/BoardInitializer.java | 2 +- .../initialize/BishopInitializer.java | 8 +- .../initialize/InitializeStrategy.java | 2 +- .../strategy/initialize/KingInitializer.java | 9 +- .../initialize/KnightInitializer.java | 9 +- .../strategy/initialize/PawnInitializer.java | 9 +- .../strategy/initialize/QueenInitializer.java | 9 +- .../strategy/initialize/RookInitializer.java | 9 +- src/main/java/chess/service/ChessService.java | 81 ++++++- .../initialize/BishopInitializerTest.java | 12 +- .../initialize/KingInitializerTest.java | 12 +- .../initialize/KnightInitializerTest.java | 12 +- .../initialize/PawnInitializerTest.java | 12 +- .../initialize/QueenInitializerTest.java | 12 +- .../initialize/RookInitializerTest.java | 12 +- 18 files changed, 206 insertions(+), 339 deletions(-) diff --git a/src/main/java/chess/WebUIChessApplication.java b/src/main/java/chess/WebUIChessApplication.java index a1d6b4bfb03..7110a9f73f3 100644 --- a/src/main/java/chess/WebUIChessApplication.java +++ b/src/main/java/chess/WebUIChessApplication.java @@ -9,116 +9,5 @@ public static void main(String[] args) { staticFiles.location("/templates"); WebChessController webChessController = new WebChessController(); webChessController.playChess(); -// get("/", (req, res) -> { -// Map model = new HashMap<>(); -// -// return render(model, "index.html"); -// }); -// -// post("/name", (req, res) -> { -// Map model = new HashMap<>(); -// -// return render(model, "name.html"); -// }); -// -// post("/load", (req, res) -> { -// Map model = new HashMap<>(); -// -// List players = webChessController.players(); -// -// model.put("gameData", players); -// -// return render(model, "table.html"); -// }); -// -// post("/newGame", (req, res) -> { -// Map model = new HashMap<>(); -// -// String whitePlayer = req.queryParams("white-player"); -// String blackPlayer = req.queryParams("black-player"); -// -// Player player = new Player(whitePlayer, blackPlayer); -// webChessController.newGame(player); -// List tileDtos = webChessController.getTiles(); -// TeamDTO teamDto = webChessController.getCurrentTeam(); -// -// model.put("tiles", tileDtos); -// model.put("currentTeam", teamDto); -// model.put("player", player); -// -// return render(model, "game.html"); -// }); -// -// post("/continueGame", (req, res) -> { -// Map model = new HashMap<>(); -// -// int chessBoardId = Integer.parseInt(req.queryParams("chess-board-id")); -// -// webChessController.continueGame(chessBoardId); -// List tileDtos = webChessController.getTiles(); -// TeamDTO teamDto = webChessController.getCurrentTeam(); -// Player player = webChessController.getPlayer(); -// -// model.put("tiles", tileDtos); -// model.put("currentTeam", teamDto); -// model.put("player", player); -// -// return render(model, "game.html"); -// }); -// -// post("/move", (req, res) -> { -// Map model = new HashMap<>(); -// -// String source = req.queryParams("source"); -// String target = req.queryParams("target"); -// -// MoveResultDTO moveResultDto = webChessController.move(source, target); -// List tileDtos = webChessController.getTiles(); -// TeamDTO teamDto = webChessController.getCurrentTeam(); -// Player player = webChessController.getPlayer(); -// -// model.put("tiles", tileDtos); -// model.put("currentTeam", teamDto); -// model.put("message", moveResultDto.getMessage()); -// model.put("style", moveResultDto.getStyle()); -// model.put("player", player); -// -// if (webChessController.isEndGame()) { -// webChessController.deleteChessGame(); -// return render(model, "end.html"); -// } -// return render(model, "game.html"); -// }); -// -// post("/status", (req, res) -> { -// Map model = new HashMap<>(); -// -// List tileDtos = webChessController.getTiles(); -// TeamDTO teamDto = webChessController.getCurrentTeam(); -// String message = webChessController.getScores(); -// Player player = webChessController.getPlayer(); -// -// model.put("tiles", tileDtos); -// model.put("currentTeam", teamDto); -// model.put("message", message); -// model.put("player", player); -// -// return render(model, "game.html"); -// }); -// -// post("/end", (req, res) -> { -// Map model = new HashMap<>(); -// -// webChessController.deleteChessGame(); -// String message = webChessController.getScores(); -// -// model.put("message", message); -// -// return render(model, "end.html"); -// }); } - -// private static String render(Map model, String templatePath) { -// return new HandlebarsTemplateEngine().render(new ModelAndView(model, templatePath)); -// } } diff --git a/src/main/java/chess/controller/WebChessController.java b/src/main/java/chess/controller/WebChessController.java index 24d5b1cdd96..9d1a27548a0 100644 --- a/src/main/java/chess/controller/WebChessController.java +++ b/src/main/java/chess/controller/WebChessController.java @@ -1,7 +1,6 @@ package chess.controller; -import chess.dao.*; -import chess.domain.ChessRunner; +import chess.dao.Player; import chess.dto.MoveResultDTO; import chess.dto.TeamDTO; import chess.dto.TileDTO; @@ -12,25 +11,11 @@ import java.util.HashMap; import java.util.List; import java.util.Map; -import java.util.Optional; -import java.util.stream.Collectors; import static spark.Spark.get; import static spark.Spark.post; public class WebChessController { - private static final String MESSAGE_STYLE_BLACK = "color:black;"; - private static final String MESSAGE_STYLE_RED = "color:red;"; - private static final String DELIMITER = ": "; - private static final String NEW_LINE = "\n"; - private static final String ARROW = " -> "; - private static final String WINNER = " 가 이겼습니다."; - - private ChessRunner chessRunner; - private ChessBoard chessBoard; - private CurrentTeam currentTeam; - private PieceOnBoards originalPieces; - private ChessService chessService; public void playChess() { @@ -75,175 +60,74 @@ public void playChess() { return render(model, "game.html"); }); -// -// post("/continueGame", (req, res) -> { -// Map model = new HashMap<>(); -// -// int chessBoardId = Integer.parseInt(req.queryParams("chess-board-id")); -// -// webChessController.continueGame(chessBoardId); -// List tileDtos = webChessController.getTiles(); -// TeamDTO teamDto = webChessController.getCurrentTeam(); -// Player player = webChessController.getPlayer(); -// -// model.put("tiles", tileDtos); -// model.put("currentTeam", teamDto); -// model.put("player", player); -// -// return render(model, "game.html"); -// }); -// -// post("/move", (req, res) -> { -// Map model = new HashMap<>(); -// -// String source = req.queryParams("source"); -// String target = req.queryParams("target"); -// -// MoveResultDTO moveResultDto = webChessController.move(source, target); -// List tileDtos = webChessController.getTiles(); -// TeamDTO teamDto = webChessController.getCurrentTeam(); -// Player player = webChessController.getPlayer(); -// -// model.put("tiles", tileDtos); -// model.put("currentTeam", teamDto); -// model.put("message", moveResultDto.getMessage()); -// model.put("style", moveResultDto.getStyle()); -// model.put("player", player); -// -// if (webChessController.isEndGame()) { -// webChessController.deleteChessGame(); -// return render(model, "end.html"); -// } -// return render(model, "game.html"); -// }); -// -// post("/status", (req, res) -> { -// Map model = new HashMap<>(); -// -// List tileDtos = webChessController.getTiles(); -// TeamDTO teamDto = webChessController.getCurrentTeam(); -// String message = webChessController.getScores(); -// Player player = webChessController.getPlayer(); -// -// model.put("tiles", tileDtos); -// model.put("currentTeam", teamDto); -// model.put("message", message); -// model.put("player", player); -// -// return render(model, "game.html"); -// }); -// -// post("/end", (req, res) -> { -// Map model = new HashMap<>(); -// -// webChessController.deleteChessGame(); -// String message = webChessController.getScores(); -// -// model.put("message", message); -// -// return render(model, "end.html"); -// }); - } -// public List players() throws Exception { -// PlayerDAO playerDAO = new PlayerDAO(); -// -// return Collections.unmodifiableList(playerDAO.findAllPlayer()); -// } + post("/continueGame", (req, res) -> { + Map model = new HashMap<>(); - public Player getPlayer() { - PlayerDAO playerDAO = new PlayerDAO(); + int chessBoardId = Integer.parseInt(req.queryParams("chess-board-id")); - return playerDAO.findPlayer(this.chessBoard); - } + this.chessService.continueGame(chessBoardId); + List tileDtos = this.chessService.getTiles(); + TeamDTO teamDto = this.chessService.getCurrentTeam(); + Player player = this.chessService.getPlayer(); - public void continueGame(int chessBoardId) throws Exception { - ChessBoardDAO chessBoardDAO = new ChessBoardDAO(); - CurrentTeamDAO currentTeamDAO = new CurrentTeamDAO(); - PieceOnBoardDAO pieceOnBoardDAO = new PieceOnBoardDAO(); + model.put("tiles", tileDtos); + model.put("currentTeam", teamDto); + model.put("player", player); - this.chessBoard = chessBoardDAO.findById(chessBoardId); + return render(model, "game.html"); + }); - this.currentTeam = currentTeamDAO.findCurrentTeam(this.chessBoard); + post("/move", (req, res) -> { + Map model = new HashMap<>(); - updateOriginalPieces(pieceOnBoardDAO); -// Map pieceOnBoards = this.originalPieces.getPieceOnBoards().stream() -// .collect(Collectors.toMap(entry -> entry.getPosition(), -// entry -> entry.getPieceImageUrl(), -// (e1, e2) -> e1, HashMap::new)); -// this.chessRunner = new ChessRunner(pieceOnBoards, this.currentTeam.getCurrentTeam()); - } + String source = req.queryParams("source"); + String target = req.queryParams("target"); - private void updateOriginalPieces(PieceOnBoardDAO pieceOnBoardDAO) throws Exception { - List pieces = pieceOnBoardDAO.findPiece(this.chessBoard); - this.originalPieces = PieceOnBoards.create(pieces); - } + MoveResultDTO moveResultDto = this.chessService.move(source, target); + List tileDtos = this.chessService.getTiles(); + TeamDTO teamDto = this.chessService.getCurrentTeam(); + Player player = this.chessService.getPlayer(); - public MoveResultDTO move(final String source, final String target) throws Exception { - try { - this.chessRunner.update(source, target); - updateChessBoard(source, target); - String moveResult = moveResult(this.chessRunner, source, target); - return new MoveResultDTO(moveResult, MESSAGE_STYLE_BLACK); - } catch (IllegalArgumentException | StringIndexOutOfBoundsException e) { - return new MoveResultDTO(e.getMessage(), MESSAGE_STYLE_RED); - } - } + model.put("tiles", tileDtos); + model.put("currentTeam", teamDto); + model.put("message", moveResultDto.getMessage()); + model.put("style", moveResultDto.getStyle()); + model.put("player", player); - private void updateChessBoard(final String source, final String target) throws Exception { - PieceOnBoard deletedPiece = null; - PieceOnBoardDAO pieceOnBoardDAO = new PieceOnBoardDAO(); - CurrentTeamDAO currentTeamDAO = new CurrentTeamDAO(); - - Optional targetPiece = this.originalPieces.find(target); - if (targetPiece.isPresent()) { - deletedPiece = targetPiece.get(); - pieceOnBoardDAO.deletePiece(deletedPiece); - } - Optional sourcePiece = this.originalPieces.find(source); - pieceOnBoardDAO.updatePiece(sourcePiece.get(), target); - this.currentTeam = new CurrentTeam(this.chessRunner.getCurrentTeam()); - currentTeamDAO.updateCurrentTeam(this.chessBoard, this.currentTeam); - updateOriginalPieces(pieceOnBoardDAO); - } + if (this.chessService.isEndGame()) { + this.chessService.deleteChessGame(); + return render(model, "end.html"); + } + return render(model, "game.html"); + }); - private String moveResult(final ChessRunner chessRunner, final String source, final String target) { - if (!this.isEndGame()) { - return source + ARROW + target; - } - return chessRunner.getWinner() + WINNER; - } + post("/status", (req, res) -> { + Map model = new HashMap<>(); - public boolean isEndGame() { - return this.chessRunner.isEndChess(); - } + List tileDtos = this.chessService.getTiles(); + TeamDTO teamDto = this.chessService.getCurrentTeam(); + String message = this.chessService.getScores(); + Player player = this.chessService.getPlayer(); - public void deleteChessGame() throws Exception { - ChessBoardDAO chessBoardDAO = new ChessBoardDAO(); - PieceOnBoardDAO pieceOnBoardDAO = new PieceOnBoardDAO(); - CurrentTeamDAO currentTeamDAO = new CurrentTeamDAO(); - PlayerDAO playerDAO = new PlayerDAO(); - - currentTeamDAO.deleteCurrentTeam(this.chessBoard); - for (PieceOnBoard pieceOnBoard : this.originalPieces.getPieceOnBoards()) { - pieceOnBoardDAO.deletePiece(pieceOnBoard); - } - playerDAO.deletePlayer(this.chessBoard); - chessBoardDAO.deleteChessBoard(this.chessBoard); - } + model.put("tiles", tileDtos); + model.put("currentTeam", teamDto); + model.put("message", message); + model.put("player", player); - public TeamDTO getCurrentTeam() { - return new TeamDTO(this.chessRunner.getCurrentTeam()); - } + return render(model, "game.html"); + }); - public List getTiles() { - return this.chessRunner.entireTileDtos(); - } + post("/end", (req, res) -> { + Map model = new HashMap<>(); + + this.chessService.deleteChessGame(); + String message = this.chessService.getScores(); - public String getScores() { - return this.chessRunner.calculateScores().stream() - .map(dto -> dto.getTeam() + DELIMITER + dto.getBoardScore()) - .collect(Collectors.joining(NEW_LINE)); + model.put("message", message); + + return render(model, "end.html"); + }); } private static String render(Map model, String templatePath) { diff --git a/src/main/java/chess/domain/ChessRunner.java b/src/main/java/chess/domain/ChessRunner.java index 2367ed36b9c..4dc06cef352 100644 --- a/src/main/java/chess/domain/ChessRunner.java +++ b/src/main/java/chess/domain/ChessRunner.java @@ -25,7 +25,7 @@ public ChessRunner() { public ChessRunner(Map pieceOnBoards, String currentTeam) { this.board = Board.webBoard(pieceOnBoards); - this.currentTeam = Team.valueOf(currentTeam.toUpperCase()); + this.currentTeam = Team.valueOf(currentTeam); } public void update(String source, String target) { diff --git a/src/main/java/chess/domain/board/BoardInitializer.java b/src/main/java/chess/domain/board/BoardInitializer.java index 404f076af77..29042bb9ec0 100644 --- a/src/main/java/chess/domain/board/BoardInitializer.java +++ b/src/main/java/chess/domain/board/BoardInitializer.java @@ -34,7 +34,7 @@ public static Map webInitialize(Map pieceOnBoar Map board = new HashMap<>(); for (InitializeStrategy strategy : INITIALIZER) { - board.putAll(strategy.webInitialize(pieceOnBoards)); + board.putAll(strategy.initialize(pieceOnBoards)); } return board; diff --git a/src/main/java/chess/domain/strategy/initialize/BishopInitializer.java b/src/main/java/chess/domain/strategy/initialize/BishopInitializer.java index ce1972c568f..eff66e13a4f 100644 --- a/src/main/java/chess/domain/strategy/initialize/BishopInitializer.java +++ b/src/main/java/chess/domain/strategy/initialize/BishopInitializer.java @@ -13,6 +13,8 @@ import java.util.stream.Collectors; public final class BishopInitializer implements InitializeStrategy { + private static final String BISHOP_SYMBOL = "b"; + private enum InitialBishop { BLACK_LEFT(Position.of("c8"), new Bishop(PieceType.BISHOP, Team.BLACK)), BLACK_RIGHT(Position.of("f8"), new Bishop(PieceType.BISHOP, Team.BLACK)), @@ -41,9 +43,9 @@ public Map initialize() { } @Override - public Map webInitialize(Map pieceOnBoards) { + public Map initialize(Map pieceOnBoards) { Map bishops = pieceOnBoards.entrySet().stream() - .filter(entry -> entry.getValue().substring(0, 1).toLowerCase().equals("b")) + .filter(entry -> entry.getValue().substring(0, 1).toLowerCase().equals(BISHOP_SYMBOL)) .collect(Collectors.toMap(entry -> entry.getKey(), entry -> entry.getValue())); Map board = bishops.entrySet().stream() @@ -56,7 +58,7 @@ public Map webInitialize(Map pieceOnBoards) { private Piece initializeBishop(String key) { String pieceTypeSymbol = key.substring(0, 1); - String teamName = key.substring(2).toUpperCase(); + String teamName = key.substring(1).toUpperCase(); PieceType pieceType = PieceType.of(pieceTypeSymbol); Team team = Team.valueOf(teamName); return new Bishop(pieceType, team); diff --git a/src/main/java/chess/domain/strategy/initialize/InitializeStrategy.java b/src/main/java/chess/domain/strategy/initialize/InitializeStrategy.java index ee4739b4ec2..4c01c871bec 100644 --- a/src/main/java/chess/domain/strategy/initialize/InitializeStrategy.java +++ b/src/main/java/chess/domain/strategy/initialize/InitializeStrategy.java @@ -8,5 +8,5 @@ public interface InitializeStrategy { Map initialize(); - Map webInitialize(Map pieceOnBoards); + Map initialize(Map pieceOnBoards); } diff --git a/src/main/java/chess/domain/strategy/initialize/KingInitializer.java b/src/main/java/chess/domain/strategy/initialize/KingInitializer.java index 9984e0b0c19..66140a2aaaa 100644 --- a/src/main/java/chess/domain/strategy/initialize/KingInitializer.java +++ b/src/main/java/chess/domain/strategy/initialize/KingInitializer.java @@ -13,6 +13,9 @@ import java.util.stream.Collectors; public final class KingInitializer implements InitializeStrategy { + + private static final String KING_SYMBOL = "k"; + private enum InitialKing { BLACK_KING(Position.of("e8"), new King(PieceType.KING, Team.BLACK)), WHITE_KING(Position.of("e1"), new King(PieceType.KING, Team.WHITE)); @@ -39,9 +42,9 @@ public Map initialize() { } @Override - public Map webInitialize(Map pieceOnBoards) { + public Map initialize(Map pieceOnBoards) { Map kings = pieceOnBoards.entrySet().stream() - .filter(entry -> entry.getValue().substring(0, 1).toLowerCase().equals("k")) + .filter(entry -> entry.getValue().substring(0, 1).toLowerCase().equals(KING_SYMBOL)) .collect(Collectors.toMap(entry -> entry.getKey(), entry -> entry.getValue())); Map board = kings.entrySet().stream() @@ -54,7 +57,7 @@ public Map webInitialize(Map pieceOnBoards) { private Piece initializeKing(String key) { String pieceTypeSymbol = key.substring(0, 1); - String teamName = key.substring(2).toUpperCase(); + String teamName = key.substring(1).toUpperCase(); PieceType pieceType = PieceType.of(pieceTypeSymbol); Team team = Team.valueOf(teamName); return new King(pieceType, team); diff --git a/src/main/java/chess/domain/strategy/initialize/KnightInitializer.java b/src/main/java/chess/domain/strategy/initialize/KnightInitializer.java index f7f913a7c53..81d845fe897 100644 --- a/src/main/java/chess/domain/strategy/initialize/KnightInitializer.java +++ b/src/main/java/chess/domain/strategy/initialize/KnightInitializer.java @@ -13,6 +13,9 @@ import java.util.stream.Collectors; public final class KnightInitializer implements InitializeStrategy { + + private static final String KNIGHT_SYMBOL = "n"; + private enum InitialKnight { BLACK_LEFT(Position.of("b8"), new Knight(PieceType.KNIGHT, Team.BLACK)), BLACK_RIGHT(Position.of("g8"), new Knight(PieceType.KNIGHT, Team.BLACK)), @@ -41,9 +44,9 @@ public Map initialize() { } @Override - public Map webInitialize(Map pieceOnBoards) { + public Map initialize(Map pieceOnBoards) { Map knights = pieceOnBoards.entrySet().stream() - .filter(entry -> entry.getValue().substring(0, 1).toLowerCase().equals("n")) + .filter(entry -> entry.getValue().substring(0, 1).toLowerCase().equals(KNIGHT_SYMBOL)) .collect(Collectors.toMap(entry -> entry.getKey(), entry -> entry.getValue())); Map board = knights.entrySet().stream() @@ -56,7 +59,7 @@ public Map webInitialize(Map pieceOnBoards) { private Piece initializeKnight(String key) { String pieceTypeSymbol = key.substring(0, 1); - String teamName = key.substring(2).toUpperCase(); + String teamName = key.substring(1).toUpperCase(); PieceType pieceType = PieceType.of(pieceTypeSymbol); Team team = Team.valueOf(teamName); return new Knight(pieceType, team); diff --git a/src/main/java/chess/domain/strategy/initialize/PawnInitializer.java b/src/main/java/chess/domain/strategy/initialize/PawnInitializer.java index 38b6e41267d..9feb6c9dcce 100644 --- a/src/main/java/chess/domain/strategy/initialize/PawnInitializer.java +++ b/src/main/java/chess/domain/strategy/initialize/PawnInitializer.java @@ -13,6 +13,9 @@ import java.util.stream.Collectors; public final class PawnInitializer implements InitializeStrategy { + + private static final String PAWN_SYMBOL = "p"; + private enum InitialPawn { BLACK_A7(Position.of("a7"), new Pawn(PieceType.PAWN, Team.BLACK)), BLACK_B7(Position.of("b7"), new Pawn(PieceType.PAWN, Team.BLACK)), @@ -54,9 +57,9 @@ public Map initialize() { } @Override - public Map webInitialize(Map pieceOnBoards) { + public Map initialize(Map pieceOnBoards) { Map pawns = pieceOnBoards.entrySet().stream() - .filter(entry -> entry.getValue().substring(0, 1).toLowerCase().equals("p")) + .filter(entry -> entry.getValue().substring(0, 1).toLowerCase().equals(PAWN_SYMBOL)) .collect(Collectors.toMap(entry -> entry.getKey(), entry -> entry.getValue())); Map board = pawns.entrySet().stream() @@ -69,7 +72,7 @@ public Map webInitialize(Map pieceOnBoards) { private Piece initializePawn(String key) { String pieceTypeSymbol = key.substring(0, 1); - String teamName = key.substring(2).toUpperCase(); + String teamName = key.substring(1).toUpperCase(); PieceType pieceType = PieceType.of(pieceTypeSymbol); Team team = Team.valueOf(teamName); return new Pawn(pieceType, team); diff --git a/src/main/java/chess/domain/strategy/initialize/QueenInitializer.java b/src/main/java/chess/domain/strategy/initialize/QueenInitializer.java index a4000b22806..2fe595af854 100644 --- a/src/main/java/chess/domain/strategy/initialize/QueenInitializer.java +++ b/src/main/java/chess/domain/strategy/initialize/QueenInitializer.java @@ -13,6 +13,9 @@ import java.util.stream.Collectors; public final class QueenInitializer implements InitializeStrategy { + + private static final String QUEEN_SYMBOL = "q"; + private enum InitialQueen { BLACK_QUEEN(Position.of("d8"), new Queen(PieceType.QUEEN, Team.BLACK)), WHITE_QUEEN(Position.of("d1"), new Queen(PieceType.QUEEN, Team.WHITE)); @@ -39,9 +42,9 @@ public Map initialize() { } @Override - public Map webInitialize(Map pieceOnBoards) { + public Map initialize(Map pieceOnBoards) { Map queens = pieceOnBoards.entrySet().stream() - .filter(entry -> entry.getValue().substring(0, 1).toLowerCase().equals("q")) + .filter(entry -> entry.getValue().substring(0, 1).toLowerCase().equals(QUEEN_SYMBOL)) .collect(Collectors.toMap(entry -> entry.getKey(), entry -> entry.getValue())); Map board = queens.entrySet().stream() @@ -54,7 +57,7 @@ public Map webInitialize(Map pieceOnBoards) { private Piece initializeQueen(String key) { String pieceTypeSymbol = key.substring(0, 1); - String teamName = key.substring(2).toUpperCase(); + String teamName = key.substring(1).toUpperCase(); PieceType pieceType = PieceType.of(pieceTypeSymbol); Team team = Team.valueOf(teamName); return new Queen(pieceType, team); diff --git a/src/main/java/chess/domain/strategy/initialize/RookInitializer.java b/src/main/java/chess/domain/strategy/initialize/RookInitializer.java index 75a7ba79db1..9761be57e94 100644 --- a/src/main/java/chess/domain/strategy/initialize/RookInitializer.java +++ b/src/main/java/chess/domain/strategy/initialize/RookInitializer.java @@ -13,6 +13,9 @@ import java.util.stream.Collectors; public final class RookInitializer implements InitializeStrategy { + + private static final String ROOK_SYMBOL = "r"; + private enum InitialRook { BLACK_LEFT(Position.of("a8"), new Rook(PieceType.ROOK, Team.BLACK)), BLACK_RIGHT(Position.of("h8"), new Rook(PieceType.ROOK, Team.BLACK)), @@ -41,9 +44,9 @@ public Map initialize() { } @Override - public Map webInitialize(Map pieceOnBoards) { + public Map initialize(Map pieceOnBoards) { Map rooks = pieceOnBoards.entrySet().stream() - .filter(entry -> entry.getValue().substring(0, 1).toLowerCase().equals("r")) + .filter(entry -> entry.getValue().substring(0, 1).toLowerCase().equals(ROOK_SYMBOL)) .collect(Collectors.toMap(entry -> entry.getKey(), entry -> entry.getValue())); Map board = rooks.entrySet().stream() @@ -56,7 +59,7 @@ public Map webInitialize(Map pieceOnBoards) { private Piece initializeRook(String key) { String pieceTypeSymbol = key.substring(0, 1); - String teamName = key.substring(2).toUpperCase(); + String teamName = key.substring(1).toUpperCase(); PieceType pieceType = PieceType.of(pieceTypeSymbol); Team team = Team.valueOf(teamName); return new Rook(pieceType, team); diff --git a/src/main/java/chess/service/ChessService.java b/src/main/java/chess/service/ChessService.java index 6fce595f77c..bc970c1cf74 100644 --- a/src/main/java/chess/service/ChessService.java +++ b/src/main/java/chess/service/ChessService.java @@ -2,13 +2,21 @@ import chess.dao.*; import chess.domain.ChessRunner; +import chess.dto.MoveResultDTO; import chess.dto.TeamDTO; import chess.dto.TileDTO; -import java.util.Collections; -import java.util.List; +import java.util.*; +import java.util.stream.Collectors; public class ChessService { + private static final String MESSAGE_STYLE_BLACK = "color:black;"; + private static final String MESSAGE_STYLE_RED = "color:red;"; + private static final String ARROW = " -> "; + private static final String WINNER = " 가 이겼습니다."; + private static final String DELIMITER = ": "; + private static final String NEW_LINE = "\n"; + private final ChessBoardDAO chessBoardDAO = new ChessBoardDAO(); private final CurrentTeamDAO currentTeamDAO = new CurrentTeamDAO(); private final PieceOnBoardDAO pieceOnBoardDAO = new PieceOnBoardDAO(); @@ -44,6 +52,19 @@ private void updateOriginalPieces(PieceOnBoardDAO pieceOnBoardDAO) { this.originalPieces = PieceOnBoards.create(pieces); } + public void continueGame(int chessBoardId) { + this.chessBoard = chessBoardDAO.findById(chessBoardId); + + this.currentTeam = currentTeamDAO.findCurrentTeam(this.chessBoard); + + updateOriginalPieces(pieceOnBoardDAO); + Map pieceOnBoards = this.originalPieces.getPieceOnBoards().stream() + .collect(Collectors.toMap(entry -> entry.getPosition(), + entry -> entry.getPieceType() + entry.getTeam(), + (e1, e2) -> e1, HashMap::new)); + this.chessRunner = new ChessRunner(pieceOnBoards, this.currentTeam.getCurrentTeam()); + } + public List getTiles() { return this.chessRunner.entireTileDtos(); } @@ -51,4 +72,60 @@ public List getTiles() { public TeamDTO getCurrentTeam() { return new TeamDTO(this.chessRunner.getCurrentTeam()); } + + public Player getPlayer() { + return this.playerDAO.findPlayer(this.chessBoard); + } + + public MoveResultDTO move(String source, String target) { + try { + this.chessRunner.update(source, target); + updateChessBoard(source, target); + String moveResult = moveResult(this.chessRunner, source, target); + return new MoveResultDTO(moveResult, MESSAGE_STYLE_BLACK); + } catch (IllegalArgumentException | StringIndexOutOfBoundsException e) { + return new MoveResultDTO(e.getMessage(), MESSAGE_STYLE_RED); + } + } + + private void updateChessBoard(String source, String target) { + PieceOnBoard deletedPiece = null; + + Optional targetPiece = this.originalPieces.find(target); + if (targetPiece.isPresent()) { + deletedPiece = targetPiece.get(); + this.pieceOnBoardDAO.deletePiece(deletedPiece); + } + Optional sourcePiece = this.originalPieces.find(source); + this.pieceOnBoardDAO.updatePiece(sourcePiece.get(), target); + this.currentTeam = new CurrentTeam(this.chessRunner.getCurrentTeam()); + this.currentTeamDAO.updateCurrentTeam(this.chessBoard, this.currentTeam); + updateOriginalPieces(this.pieceOnBoardDAO); + } + + private String moveResult(final ChessRunner chessRunner, final String source, final String target) { + if (!this.isEndGame()) { + return source + ARROW + target; + } + return chessRunner.getWinner() + WINNER; + } + + public boolean isEndGame() { + return this.chessRunner.isEndChess(); + } + + public void deleteChessGame() { + this.currentTeamDAO.deleteCurrentTeam(this.chessBoard); + for (PieceOnBoard pieceOnBoard : this.originalPieces.getPieceOnBoards()) { + this.pieceOnBoardDAO.deletePiece(pieceOnBoard); + } + this.playerDAO.deletePlayer(this.chessBoard); + this.chessBoardDAO.deleteChessBoard(this.chessBoard); + } + + public String getScores() { + return this.chessRunner.calculateScores().stream() + .map(dto -> dto.getTeam() + DELIMITER + dto.getBoardScore()) + .collect(Collectors.joining(NEW_LINE)); + } } diff --git a/src/test/java/chess/domain/strategy/initialize/BishopInitializerTest.java b/src/test/java/chess/domain/strategy/initialize/BishopInitializerTest.java index f2108b3dda2..d661772dcfc 100644 --- a/src/test/java/chess/domain/strategy/initialize/BishopInitializerTest.java +++ b/src/test/java/chess/domain/strategy/initialize/BishopInitializerTest.java @@ -15,13 +15,13 @@ public class BishopInitializerTest { @Test void webInitializeTest() { Map pieceOnBoard = new HashMap<>(); - pieceOnBoard.put("a2", "b_white"); - pieceOnBoard.put("b2", "p_white"); - pieceOnBoard.put("f6", "P_black"); - pieceOnBoard.put("c8", "B_black"); - pieceOnBoard.put("d4", "b_white"); + pieceOnBoard.put("a2", "bwhite"); + pieceOnBoard.put("b2", "pwhite"); + pieceOnBoard.put("f6", "Pblack"); + pieceOnBoard.put("c8", "Bblack"); + pieceOnBoard.put("d4", "bwhite"); InitializeStrategy bishopInitialize = new BishopInitializer(); - Map board = bishopInitialize.webInitialize(pieceOnBoard); + Map board = bishopInitialize.initialize(pieceOnBoard); Assertions.assertThat(board.keySet()).contains( Position.of("a2"), Position.of("c8"), Position.of("d4") diff --git a/src/test/java/chess/domain/strategy/initialize/KingInitializerTest.java b/src/test/java/chess/domain/strategy/initialize/KingInitializerTest.java index 995facb9f0a..c78eae6df63 100644 --- a/src/test/java/chess/domain/strategy/initialize/KingInitializerTest.java +++ b/src/test/java/chess/domain/strategy/initialize/KingInitializerTest.java @@ -15,13 +15,13 @@ public class KingInitializerTest { @Test void webInitializeTest() { Map pieceOnBoard = new HashMap<>(); - pieceOnBoard.put("a2", "k_white"); - pieceOnBoard.put("b2", "p_white"); - pieceOnBoard.put("f6", "P_black"); - pieceOnBoard.put("c8", "K_black"); - pieceOnBoard.put("d4", "k_white"); + pieceOnBoard.put("a2", "kwhite"); + pieceOnBoard.put("b2", "pwhite"); + pieceOnBoard.put("f6", "Pblack"); + pieceOnBoard.put("c8", "Kblack"); + pieceOnBoard.put("d4", "kwhite"); InitializeStrategy kingInitializer = new KingInitializer(); - Map board = kingInitializer.webInitialize(pieceOnBoard); + Map board = kingInitializer.initialize(pieceOnBoard); Assertions.assertThat(board.keySet()).contains( Position.of("a2"), Position.of("c8"), Position.of("d4") diff --git a/src/test/java/chess/domain/strategy/initialize/KnightInitializerTest.java b/src/test/java/chess/domain/strategy/initialize/KnightInitializerTest.java index 05b4e74a5fb..32e67a8a00e 100644 --- a/src/test/java/chess/domain/strategy/initialize/KnightInitializerTest.java +++ b/src/test/java/chess/domain/strategy/initialize/KnightInitializerTest.java @@ -15,13 +15,13 @@ public class KnightInitializerTest { @Test void webInitializeTest() { Map pieceOnBoard = new HashMap<>(); - pieceOnBoard.put("a2", "n_white"); - pieceOnBoard.put("b2", "p_white"); - pieceOnBoard.put("f6", "P_black"); - pieceOnBoard.put("c8", "N_black"); - pieceOnBoard.put("d4", "n_white"); + pieceOnBoard.put("a2", "nwhite"); + pieceOnBoard.put("b2", "pwhite"); + pieceOnBoard.put("f6", "Pblack"); + pieceOnBoard.put("c8", "Nblack"); + pieceOnBoard.put("d4", "nwhite"); InitializeStrategy knightInitializer = new KnightInitializer(); - Map board = knightInitializer.webInitialize(pieceOnBoard); + Map board = knightInitializer.initialize(pieceOnBoard); Assertions.assertThat(board.keySet()).contains( Position.of("a2"), Position.of("c8"), Position.of("d4") diff --git a/src/test/java/chess/domain/strategy/initialize/PawnInitializerTest.java b/src/test/java/chess/domain/strategy/initialize/PawnInitializerTest.java index f56ab962f2c..935e49c8c74 100644 --- a/src/test/java/chess/domain/strategy/initialize/PawnInitializerTest.java +++ b/src/test/java/chess/domain/strategy/initialize/PawnInitializerTest.java @@ -15,13 +15,13 @@ public class PawnInitializerTest { @Test void webInitializeTest() { Map pieceOnBoard = new HashMap<>(); - pieceOnBoard.put("a2", "n_white"); - pieceOnBoard.put("b2", "p_white"); - pieceOnBoard.put("f6", "P_black"); - pieceOnBoard.put("c8", "N_black"); - pieceOnBoard.put("d4", "n_white"); + pieceOnBoard.put("a2", "nwhite"); + pieceOnBoard.put("b2", "pwhite"); + pieceOnBoard.put("f6", "Pblack"); + pieceOnBoard.put("c8", "Nblack"); + pieceOnBoard.put("d4", "nwhite"); InitializeStrategy pawnInitializer = new PawnInitializer(); - Map board = pawnInitializer.webInitialize(pieceOnBoard); + Map board = pawnInitializer.initialize(pieceOnBoard); Assertions.assertThat(board.keySet()).contains( Position.of("b2"), Position.of("f6") diff --git a/src/test/java/chess/domain/strategy/initialize/QueenInitializerTest.java b/src/test/java/chess/domain/strategy/initialize/QueenInitializerTest.java index c814d4d3d51..3d5fa5023e0 100644 --- a/src/test/java/chess/domain/strategy/initialize/QueenInitializerTest.java +++ b/src/test/java/chess/domain/strategy/initialize/QueenInitializerTest.java @@ -15,13 +15,13 @@ public class QueenInitializerTest { @Test void webInitializeTest() { Map pieceOnBoard = new HashMap<>(); - pieceOnBoard.put("a2", "q_white"); - pieceOnBoard.put("b2", "p_white"); - pieceOnBoard.put("f6", "P_black"); - pieceOnBoard.put("c8", "Q_black"); - pieceOnBoard.put("d4", "q_white"); + pieceOnBoard.put("a2", "qwhite"); + pieceOnBoard.put("b2", "pwhite"); + pieceOnBoard.put("f6", "Pblack"); + pieceOnBoard.put("c8", "Qblack"); + pieceOnBoard.put("d4", "qwhite"); InitializeStrategy queenInitializer = new QueenInitializer(); - Map board = queenInitializer.webInitialize(pieceOnBoard); + Map board = queenInitializer.initialize(pieceOnBoard); Assertions.assertThat(board.keySet()).contains( Position.of("a2"), Position.of("c8"), Position.of("d4") diff --git a/src/test/java/chess/domain/strategy/initialize/RookInitializerTest.java b/src/test/java/chess/domain/strategy/initialize/RookInitializerTest.java index 20d017a4469..32082654d22 100644 --- a/src/test/java/chess/domain/strategy/initialize/RookInitializerTest.java +++ b/src/test/java/chess/domain/strategy/initialize/RookInitializerTest.java @@ -15,13 +15,13 @@ public class RookInitializerTest { @Test void webInitializeTest() { Map pieceOnBoard = new HashMap<>(); - pieceOnBoard.put("a2", "r_white"); - pieceOnBoard.put("b2", "p_white"); - pieceOnBoard.put("f6", "P_black"); - pieceOnBoard.put("c8", "R_black"); - pieceOnBoard.put("d4", "r_white"); + pieceOnBoard.put("a2", "rwhite"); + pieceOnBoard.put("b2", "pwhite"); + pieceOnBoard.put("f6", "Pblack"); + pieceOnBoard.put("c8", "Rblack"); + pieceOnBoard.put("d4", "rwhite"); InitializeStrategy rookInitializer = new RookInitializer(); - Map board = rookInitializer.webInitialize(pieceOnBoard); + Map board = rookInitializer.initialize(pieceOnBoard); Assertions.assertThat(board.keySet()).contains( Position.of("a2"), Position.of("c8"), Position.of("d4") From a3629ac9eb8341954b15fbb8655294f51c539042 Mon Sep 17 00:00:00 2001 From: giantim Date: Mon, 13 Apr 2020 17:28:04 +0900 Subject: [PATCH 67/75] =?UTF-8?q?refactor:=20Optional=20=EA=B0=9D=EC=B2=B4?= =?UTF-8?q?=EC=9D=98=20null=20=EA=B2=80=EC=82=AC=20=EB=A1=9C=EC=A7=81=20?= =?UTF-8?q?=EC=B6=94=EA=B0=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/main/java/chess/dao/PieceOnBoards.java | 4 +- src/main/java/chess/service/ChessService.java | 45 ++++++++++--------- 2 files changed, 27 insertions(+), 22 deletions(-) diff --git a/src/main/java/chess/dao/PieceOnBoards.java b/src/main/java/chess/dao/PieceOnBoards.java index e53bf70bd5e..a21f61d0b18 100644 --- a/src/main/java/chess/dao/PieceOnBoards.java +++ b/src/main/java/chess/dao/PieceOnBoards.java @@ -20,11 +20,11 @@ public List getPieceOnBoards() { } public Optional find(String position) { - Optional targetPiece = Optional.ofNullable(this.pieceOnBoards.stream() + Optional piece = Optional.ofNullable(this.pieceOnBoards.stream() .filter(p -> p.getPosition().equals(position)) .findFirst() .orElse(null)); - return targetPiece; + return piece; } } diff --git a/src/main/java/chess/service/ChessService.java b/src/main/java/chess/service/ChessService.java index bc970c1cf74..2f9de3fb1e6 100644 --- a/src/main/java/chess/service/ChessService.java +++ b/src/main/java/chess/service/ChessService.java @@ -65,18 +65,6 @@ public void continueGame(int chessBoardId) { this.chessRunner = new ChessRunner(pieceOnBoards, this.currentTeam.getCurrentTeam()); } - public List getTiles() { - return this.chessRunner.entireTileDtos(); - } - - public TeamDTO getCurrentTeam() { - return new TeamDTO(this.chessRunner.getCurrentTeam()); - } - - public Player getPlayer() { - return this.playerDAO.findPlayer(this.chessBoard); - } - public MoveResultDTO move(String source, String target) { try { this.chessRunner.update(source, target); @@ -89,20 +77,25 @@ public MoveResultDTO move(String source, String target) { } private void updateChessBoard(String source, String target) { - PieceOnBoard deletedPiece = null; + PieceOnBoard piece = null; - Optional targetPiece = this.originalPieces.find(target); - if (targetPiece.isPresent()) { - deletedPiece = targetPiece.get(); - this.pieceOnBoardDAO.deletePiece(deletedPiece); - } - Optional sourcePiece = this.originalPieces.find(source); - this.pieceOnBoardDAO.updatePiece(sourcePiece.get(), target); + piece = getPieceOnBoard(target, piece); + this.pieceOnBoardDAO.deletePiece(piece); + piece = getPieceOnBoard(source, piece); + this.pieceOnBoardDAO.updatePiece(piece, target); this.currentTeam = new CurrentTeam(this.chessRunner.getCurrentTeam()); this.currentTeamDAO.updateCurrentTeam(this.chessBoard, this.currentTeam); updateOriginalPieces(this.pieceOnBoardDAO); } + private PieceOnBoard getPieceOnBoard(String position, PieceOnBoard piece) { + Optional pieceOnBoard = this.originalPieces.find(position); + if (pieceOnBoard.isPresent()) { + piece = pieceOnBoard.get(); + } + return piece; + } + private String moveResult(final ChessRunner chessRunner, final String source, final String target) { if (!this.isEndGame()) { return source + ARROW + target; @@ -128,4 +121,16 @@ public String getScores() { .map(dto -> dto.getTeam() + DELIMITER + dto.getBoardScore()) .collect(Collectors.joining(NEW_LINE)); } + + public List getTiles() { + return this.chessRunner.entireTileDtos(); + } + + public TeamDTO getCurrentTeam() { + return new TeamDTO(this.chessRunner.getCurrentTeam()); + } + + public Player getPlayer() { + return this.playerDAO.findPlayer(this.chessBoard); + } } From 7cdbc884c267d86e0142e13e74a46b5b20f0fb84 Mon Sep 17 00:00:00 2001 From: giantim Date: Mon, 13 Apr 2020 17:29:53 +0900 Subject: [PATCH 68/75] =?UTF-8?q?refactor:=20=EB=A9=94=EC=84=9C=EB=93=9C?= =?UTF-8?q?=20=EC=9C=84=EC=B9=98=20=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/main/java/chess/dao/PieceOnBoards.java | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/src/main/java/chess/dao/PieceOnBoards.java b/src/main/java/chess/dao/PieceOnBoards.java index a21f61d0b18..40997d713b7 100644 --- a/src/main/java/chess/dao/PieceOnBoards.java +++ b/src/main/java/chess/dao/PieceOnBoards.java @@ -15,10 +15,6 @@ public static PieceOnBoards create(List pieceOnBoards) { return new PieceOnBoards(pieceOnBoards); } - public List getPieceOnBoards() { - return Collections.unmodifiableList(this.pieceOnBoards); - } - public Optional find(String position) { Optional piece = Optional.ofNullable(this.pieceOnBoards.stream() .filter(p -> p.getPosition().equals(position)) @@ -27,4 +23,8 @@ public Optional find(String position) { return piece; } + + public List getPieceOnBoards() { + return Collections.unmodifiableList(this.pieceOnBoards); + } } From e145ae0ab7c4a0060b25e3819dd2f4ba52314158 Mon Sep 17 00:00:00 2001 From: giantim Date: Thu, 16 Apr 2020 14:35:25 +0900 Subject: [PATCH 69/75] =?UTF-8?q?refactor:=20ResultSet,=20PreparedStatemen?= =?UTF-8?q?t=20=EB=8B=AB=EB=8A=94=20=EA=B5=AC=EB=AC=B8=20=EC=B6=94?= =?UTF-8?q?=EA=B0=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/main/java/chess/dao/ChessBoardDAO.java | 2 +- src/main/java/chess/dao/ConnectionManager.java | 15 +++++++++++---- src/main/java/chess/dao/PieceOnBoardDAO.java | 1 + 3 files changed, 13 insertions(+), 5 deletions(-) diff --git a/src/main/java/chess/dao/ChessBoardDAO.java b/src/main/java/chess/dao/ChessBoardDAO.java index 5fd6298c1e3..dccf8e9c625 100644 --- a/src/main/java/chess/dao/ChessBoardDAO.java +++ b/src/main/java/chess/dao/ChessBoardDAO.java @@ -42,7 +42,7 @@ public void deleteChessBoard(ChessBoard chessBoard) { } String query = "DELETE FROM chessBoard WHERE chessBoardId = ?"; try (Connection con = ConnectionManager.getConnection(); - PreparedStatement pstmt = con.prepareStatement(query);) { + PreparedStatement pstmt = con.prepareStatement(query)) { pstmt.setInt(1, chessBoard.getChessBoardId()); pstmt.executeUpdate(); } catch (SQLException e) { diff --git a/src/main/java/chess/dao/ConnectionManager.java b/src/main/java/chess/dao/ConnectionManager.java index e44eb4b7aee..7a97817f75c 100644 --- a/src/main/java/chess/dao/ConnectionManager.java +++ b/src/main/java/chess/dao/ConnectionManager.java @@ -1,9 +1,6 @@ package chess.dao; -import java.sql.Connection; -import java.sql.DriverManager; -import java.sql.ResultSet; -import java.sql.SQLException; +import java.sql.*; public class ConnectionManager { private ConnectionManager() { @@ -45,4 +42,14 @@ public static void closeResultSet(ResultSet rs) { System.err.println("rs 오류:" + e.getMessage()); } } + + public static void closePreparedStatement(PreparedStatement pstmt) { + try { + if (pstmt != null) { + pstmt.close(); + } + } catch (SQLException e) { + System.out.println("pstmt 오류: " + e.getMessage()); + } + } } diff --git a/src/main/java/chess/dao/PieceOnBoardDAO.java b/src/main/java/chess/dao/PieceOnBoardDAO.java index 81a5903dd0a..1ac2deb42aa 100644 --- a/src/main/java/chess/dao/PieceOnBoardDAO.java +++ b/src/main/java/chess/dao/PieceOnBoardDAO.java @@ -20,6 +20,7 @@ public void addPiece(ChessBoard chessBoard, List pieceOnBoards) { pstmt.setString(3, pieceOnBoard.getTeam()); pstmt.setInt(4, chessBoard.getChessBoardId()); pstmt.executeUpdate(); + ConnectionManager.closePreparedStatement(pstmt); } } catch (SQLException e) { e.printStackTrace(); From 3a7ba785f86213c905e21f5fe3652a0f8f61ca6a Mon Sep 17 00:00:00 2001 From: giantim Date: Thu, 16 Apr 2020 15:48:28 +0900 Subject: [PATCH 70/75] =?UTF-8?q?refactor:=20=EC=B2=B4=EC=8A=A4=20?= =?UTF-8?q?=EA=B2=8C=EC=9E=84=20=ED=99=94=EB=A9=B4=EC=97=90=20=ED=98=84?= =?UTF-8?q?=EC=9E=AC=20=EC=A7=84=ED=96=89=EC=A4=91=EC=9D=B8=20=EA=B2=8C?= =?UTF-8?q?=EC=9E=84=20id=20=EC=B6=9C=EB=A0=A5=ED=95=98=EA=B2=8C=20?= =?UTF-8?q?=EB=B3=80=EA=B2=BD?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../chess/controller/WebChessController.java | 3 +++ src/main/java/chess/service/ChessService.java | 4 ++++ src/main/resources/templates/css/game.css | 7 +++++++ src/main/resources/templates/game.html | 16 +++++++++++----- 4 files changed, 25 insertions(+), 5 deletions(-) diff --git a/src/main/java/chess/controller/WebChessController.java b/src/main/java/chess/controller/WebChessController.java index 9d1a27548a0..5a3c70fc62a 100644 --- a/src/main/java/chess/controller/WebChessController.java +++ b/src/main/java/chess/controller/WebChessController.java @@ -1,5 +1,6 @@ package chess.controller; +import chess.dao.ChessBoard; import chess.dao.Player; import chess.dto.MoveResultDTO; import chess.dto.TeamDTO; @@ -53,10 +54,12 @@ public void playChess() { this.chessService.newGame(player); List tileDtos = this.chessService.getTiles(); TeamDTO teamDto = this.chessService.getCurrentTeam(); + ChessBoard chessBoard = this.chessService.getChessBoard(); model.put("tiles", tileDtos); model.put("currentTeam", teamDto); model.put("player", player); + model.put("chessBoard", chessBoard); return render(model, "game.html"); }); diff --git a/src/main/java/chess/service/ChessService.java b/src/main/java/chess/service/ChessService.java index 2f9de3fb1e6..11139fbab64 100644 --- a/src/main/java/chess/service/ChessService.java +++ b/src/main/java/chess/service/ChessService.java @@ -133,4 +133,8 @@ public TeamDTO getCurrentTeam() { public Player getPlayer() { return this.playerDAO.findPlayer(this.chessBoard); } + + public ChessBoard getChessBoard() { + return this.chessBoardDAO.findRecentChessBoard(); + } } diff --git a/src/main/resources/templates/css/game.css b/src/main/resources/templates/css/game.css index b1fd81dcf2c..69890303422 100644 --- a/src/main/resources/templates/css/game.css +++ b/src/main/resources/templates/css/game.css @@ -5,12 +5,19 @@ src: url(../ttf/BMHANNAPro.ttf); } +#chess-board-id-label, +#chess-board-id, #white-player, #black-player { font-family: BMHANNAPro; font-size: 30px; } +#chess-board-id { + width: 200px; + height: 50px; +} + #chess-board { width: 800px; } diff --git a/src/main/resources/templates/game.html b/src/main/resources/templates/game.html index 7a73001597d..c981ec59918 100644 --- a/src/main/resources/templates/game.html +++ b/src/main/resources/templates/game.html @@ -19,12 +19,18 @@

    -

    White: {{player.whitePlayer}}

    -

    Black: {{player.blackPlayer}}

    -
    -

    현재 차례는 {{currentTeam.teamName}} 입니다

    -
    +

    + +

    +

    White: {{player.whitePlayer}}

    +

    Black: {{player.blackPlayer}}

    +
    +

    현재 차례는 {{currentTeam.teamName}} 입니다

    +

    From 5d5d8c531910fc09abd4d74b0c1cc745d2efc5cd Mon Sep 17 00:00:00 2001 From: giantim Date: Thu, 16 Apr 2020 16:43:42 +0900 Subject: [PATCH 71/75] =?UTF-8?q?refactor:=20=EC=84=9C=EB=B9=84=EC=8A=A4?= =?UTF-8?q?=20=EB=82=B4=EC=9D=98=20=EC=83=81=ED=83=9C=EB=A5=BC=20=EA=B0=96?= =?UTF-8?q?=EB=8A=94=20=EA=B0=9D=EC=B2=B4=EC=9D=98=20=EC=83=9D=EB=AA=85?= =?UTF-8?q?=EC=A3=BC=EA=B8=B0=EB=A5=BC=20=EB=A9=94=EC=84=9C=EB=93=9C=20?= =?UTF-8?q?=EB=8B=A8=EC=9C=84=EB=A1=9C=20=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../chess/controller/WebChessController.java | 25 ++++-- src/main/java/chess/service/ChessService.java | 79 +++++++++---------- src/main/resources/templates/css/game.css | 4 +- src/main/resources/templates/game.html | 8 +- 4 files changed, 64 insertions(+), 52 deletions(-) diff --git a/src/main/java/chess/controller/WebChessController.java b/src/main/java/chess/controller/WebChessController.java index 5a3c70fc62a..1df7956597c 100644 --- a/src/main/java/chess/controller/WebChessController.java +++ b/src/main/java/chess/controller/WebChessController.java @@ -54,7 +54,7 @@ public void playChess() { this.chessService.newGame(player); List tileDtos = this.chessService.getTiles(); TeamDTO teamDto = this.chessService.getCurrentTeam(); - ChessBoard chessBoard = this.chessService.getChessBoard(); + ChessBoard chessBoard = this.chessService.getRecentChessBoard(); model.put("tiles", tileDtos); model.put("currentTeam", teamDto); @@ -72,11 +72,13 @@ public void playChess() { this.chessService.continueGame(chessBoardId); List tileDtos = this.chessService.getTiles(); TeamDTO teamDto = this.chessService.getCurrentTeam(); - Player player = this.chessService.getPlayer(); + Player player = this.chessService.getPlayer(chessBoardId); + ChessBoard chessBoard = new ChessBoard(chessBoardId); model.put("tiles", tileDtos); model.put("currentTeam", teamDto); model.put("player", player); + model.put("chessBoard", chessBoard); return render(model, "game.html"); }); @@ -84,22 +86,25 @@ public void playChess() { post("/move", (req, res) -> { Map model = new HashMap<>(); + int chessBoardId = Integer.parseInt(req.queryParams("chess-board-id")); String source = req.queryParams("source"); String target = req.queryParams("target"); - MoveResultDTO moveResultDto = this.chessService.move(source, target); + MoveResultDTO moveResultDto = this.chessService.move(chessBoardId, source, target); List tileDtos = this.chessService.getTiles(); TeamDTO teamDto = this.chessService.getCurrentTeam(); - Player player = this.chessService.getPlayer(); + Player player = this.chessService.getPlayer(chessBoardId); + ChessBoard chessBoard = new ChessBoard(chessBoardId); model.put("tiles", tileDtos); model.put("currentTeam", teamDto); model.put("message", moveResultDto.getMessage()); model.put("style", moveResultDto.getStyle()); model.put("player", player); + model.put("chessBoard", chessBoard); if (this.chessService.isEndGame()) { - this.chessService.deleteChessGame(); + this.chessService.deleteChessGame(chessBoardId); return render(model, "end.html"); } return render(model, "game.html"); @@ -108,15 +113,19 @@ public void playChess() { post("/status", (req, res) -> { Map model = new HashMap<>(); + int chessBoardId = Integer.parseInt(req.queryParams("chess-board-id-status")); + List tileDtos = this.chessService.getTiles(); TeamDTO teamDto = this.chessService.getCurrentTeam(); String message = this.chessService.getScores(); - Player player = this.chessService.getPlayer(); + Player player = this.chessService.getPlayer(chessBoardId); + ChessBoard chessBoard = new ChessBoard(chessBoardId); model.put("tiles", tileDtos); model.put("currentTeam", teamDto); model.put("message", message); model.put("player", player); + model.put("chessBoard", chessBoard); return render(model, "game.html"); }); @@ -124,7 +133,9 @@ public void playChess() { post("/end", (req, res) -> { Map model = new HashMap<>(); - this.chessService.deleteChessGame(); + int chessBoardId = Integer.parseInt(req.queryParams("chess-board-id-end")); + + this.chessService.deleteChessGame(chessBoardId); String message = this.chessService.getScores(); model.put("message", message); diff --git a/src/main/java/chess/service/ChessService.java b/src/main/java/chess/service/ChessService.java index 11139fbab64..9915e433934 100644 --- a/src/main/java/chess/service/ChessService.java +++ b/src/main/java/chess/service/ChessService.java @@ -23,9 +23,6 @@ public class ChessService { private final PlayerDAO playerDAO = new PlayerDAO(); private ChessRunner chessRunner; - private ChessBoard chessBoard; - private CurrentTeam currentTeam; - private PieceOnBoards originalPieces; public List players() { return Collections.unmodifiableList(this.playerDAO.findAllPlayer()); @@ -34,41 +31,33 @@ public List players() { public void newGame(Player player) { this.chessRunner = new ChessRunner(); - chessBoardDAO.addChessBoard(); - this.chessBoard = chessBoardDAO.findRecentChessBoard(); + this.chessBoardDAO.addChessBoard(); + ChessBoard chessBoard = this.chessBoardDAO.findRecentChessBoard(); - this.currentTeam = new CurrentTeam(this.chessRunner.getCurrentTeam()); - currentTeamDAO.addCurrentTeam(this.chessBoard, this.currentTeam); + CurrentTeam currentTeam = new CurrentTeam(this.chessRunner.getCurrentTeam()); + this.currentTeamDAO.addCurrentTeam(chessBoard, currentTeam); - List pieces = this.chessRunner.getPieceOnBoards(this.chessBoard.getChessBoardId()); - pieceOnBoardDAO.addPiece(this.chessBoard, pieces); - updateOriginalPieces(pieceOnBoardDAO); + List pieces = this.chessRunner.getPieceOnBoards(chessBoard.getChessBoardId()); + this.pieceOnBoardDAO.addPiece(chessBoard, pieces); - playerDAO.addPlayer(this.chessBoard, player); - } - - private void updateOriginalPieces(PieceOnBoardDAO pieceOnBoardDAO) { - List pieces = pieceOnBoardDAO.findPiece(this.chessBoard); - this.originalPieces = PieceOnBoards.create(pieces); + this.playerDAO.addPlayer(chessBoard, player); } public void continueGame(int chessBoardId) { - this.chessBoard = chessBoardDAO.findById(chessBoardId); + ChessBoard chessBoard = this.chessBoardDAO.findById(chessBoardId); + CurrentTeam currentTeam = this.currentTeamDAO.findCurrentTeam(chessBoard); - this.currentTeam = currentTeamDAO.findCurrentTeam(this.chessBoard); - - updateOriginalPieces(pieceOnBoardDAO); - Map pieceOnBoards = this.originalPieces.getPieceOnBoards().stream() - .collect(Collectors.toMap(entry -> entry.getPosition(), - entry -> entry.getPieceType() + entry.getTeam(), + List pieces = this.pieceOnBoardDAO.findPiece(chessBoard); + Map pieceOnBoards = pieces.stream() + .collect(Collectors.toMap(p -> p.getPosition(), p -> p.getPieceType() + p.getTeam(), (e1, e2) -> e1, HashMap::new)); - this.chessRunner = new ChessRunner(pieceOnBoards, this.currentTeam.getCurrentTeam()); + this.chessRunner = new ChessRunner(pieceOnBoards, currentTeam.getCurrentTeam()); } - public MoveResultDTO move(String source, String target) { + public MoveResultDTO move(int chessBoardId, String source, String target) { try { this.chessRunner.update(source, target); - updateChessBoard(source, target); + updateChessBoard(chessBoardId, source, target); String moveResult = moveResult(this.chessRunner, source, target); return new MoveResultDTO(moveResult, MESSAGE_STYLE_BLACK); } catch (IllegalArgumentException | StringIndexOutOfBoundsException e) { @@ -76,20 +65,22 @@ public MoveResultDTO move(String source, String target) { } } - private void updateChessBoard(String source, String target) { + private void updateChessBoard(int chessBoardId, String source, String target) { PieceOnBoard piece = null; + ChessBoard chessBoard = this.chessBoardDAO.findById(chessBoardId); - piece = getPieceOnBoard(target, piece); + piece = getPieceOnBoard(chessBoard, target, piece); this.pieceOnBoardDAO.deletePiece(piece); - piece = getPieceOnBoard(source, piece); + piece = getPieceOnBoard(chessBoard, source, piece); this.pieceOnBoardDAO.updatePiece(piece, target); - this.currentTeam = new CurrentTeam(this.chessRunner.getCurrentTeam()); - this.currentTeamDAO.updateCurrentTeam(this.chessBoard, this.currentTeam); - updateOriginalPieces(this.pieceOnBoardDAO); + CurrentTeam currentTeam = new CurrentTeam(this.chessRunner.getCurrentTeam()); + this.currentTeamDAO.updateCurrentTeam(chessBoard, currentTeam); } - private PieceOnBoard getPieceOnBoard(String position, PieceOnBoard piece) { - Optional pieceOnBoard = this.originalPieces.find(position); + private PieceOnBoard getPieceOnBoard(ChessBoard chessBoard, String position, PieceOnBoard piece) { + List pieces = this.pieceOnBoardDAO.findPiece(chessBoard); + PieceOnBoards originalPieces = PieceOnBoards.create(pieces); + Optional pieceOnBoard = originalPieces.find(position); if (pieceOnBoard.isPresent()) { piece = pieceOnBoard.get(); } @@ -107,13 +98,16 @@ public boolean isEndGame() { return this.chessRunner.isEndChess(); } - public void deleteChessGame() { - this.currentTeamDAO.deleteCurrentTeam(this.chessBoard); - for (PieceOnBoard pieceOnBoard : this.originalPieces.getPieceOnBoards()) { + public void deleteChessGame(int chessBoardId) { + ChessBoard chessBoard = this.chessBoardDAO.findById(chessBoardId); + List pieces = this.pieceOnBoardDAO.findPiece(chessBoard); + + this.currentTeamDAO.deleteCurrentTeam(chessBoard); + for (PieceOnBoard pieceOnBoard : pieces) { this.pieceOnBoardDAO.deletePiece(pieceOnBoard); } - this.playerDAO.deletePlayer(this.chessBoard); - this.chessBoardDAO.deleteChessBoard(this.chessBoard); + this.playerDAO.deletePlayer(chessBoard); + this.chessBoardDAO.deleteChessBoard(chessBoard); } public String getScores() { @@ -130,11 +124,12 @@ public TeamDTO getCurrentTeam() { return new TeamDTO(this.chessRunner.getCurrentTeam()); } - public Player getPlayer() { - return this.playerDAO.findPlayer(this.chessBoard); + public Player getPlayer(int chessBoardId) { + ChessBoard chessBoard = this.chessBoardDAO.findById(chessBoardId); + return this.playerDAO.findPlayer(chessBoard); } - public ChessBoard getChessBoard() { + public ChessBoard getRecentChessBoard() { return this.chessBoardDAO.findRecentChessBoard(); } } diff --git a/src/main/resources/templates/css/game.css b/src/main/resources/templates/css/game.css index 69890303422..ef46430e303 100644 --- a/src/main/resources/templates/css/game.css +++ b/src/main/resources/templates/css/game.css @@ -88,7 +88,9 @@ #source, #target { font-family: BMHANNAPro; - size: 50px; + width: 200px; + height: 30px; + font-size: 30px; } #currentTeam { diff --git a/src/main/resources/templates/game.html b/src/main/resources/templates/game.html index c981ec59918..3f2c53f9c80 100644 --- a/src/main/resources/templates/game.html +++ b/src/main/resources/templates/game.html @@ -42,14 +42,18 @@
    - -

    + +
    +

    +
    From df0e3ed8099570812b1baf1cdee5122562e76818 Mon Sep 17 00:00:00 2001 From: giantim Date: Thu, 16 Apr 2020 20:43:29 +0900 Subject: [PATCH 72/75] =?UTF-8?q?refactor:=20DAO=20=EA=B0=80=20=EB=8F=84?= =?UTF-8?q?=EB=A9=94=EC=9D=B8=20=EC=9E=90=EB=A3=8C=20=EA=B5=AC=EC=A1=B0?= =?UTF-8?q?=EB=A5=BC=20=EC=82=AC=EC=9A=A9=ED=95=98=EB=8F=84=EB=A1=9D=20?= =?UTF-8?q?=EB=B3=80=EA=B2=BD?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/main/java/chess/dao/CurrentTeam.java | 8 +++-- src/main/java/chess/dao/CurrentTeamDAO.java | 4 ++- src/main/java/chess/dao/PieceOnBoard.java | 22 ++++++++------ src/main/java/chess/dao/PieceOnBoardDAO.java | 10 +++++-- src/main/java/chess/domain/ChessRunner.java | 10 +++++-- src/main/java/chess/service/ChessService.java | 5 ++-- .../java/chess/dao/CurrentTeamDAOTest.java | 13 ++++---- .../java/chess/dao/PieceOnBoardDAOTest.java | 30 ++++++++++++------- 8 files changed, 64 insertions(+), 38 deletions(-) diff --git a/src/main/java/chess/dao/CurrentTeam.java b/src/main/java/chess/dao/CurrentTeam.java index 20623db291e..0bd44b49ad1 100644 --- a/src/main/java/chess/dao/CurrentTeam.java +++ b/src/main/java/chess/dao/CurrentTeam.java @@ -1,16 +1,18 @@ package chess.dao; +import chess.domain.piece.Team; + import java.util.Objects; public class CurrentTeam { - private String currentTeam; + private Team currentTeam; - public CurrentTeam(String currentTeam) { + public CurrentTeam(Team currentTeam) { this.currentTeam = currentTeam; } public String getCurrentTeam() { - return this.currentTeam; + return this.currentTeam.name(); } @Override diff --git a/src/main/java/chess/dao/CurrentTeamDAO.java b/src/main/java/chess/dao/CurrentTeamDAO.java index 6037a0fdd5c..43e69320909 100644 --- a/src/main/java/chess/dao/CurrentTeamDAO.java +++ b/src/main/java/chess/dao/CurrentTeamDAO.java @@ -1,5 +1,7 @@ package chess.dao; +import chess.domain.piece.Team; + import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; @@ -52,7 +54,7 @@ public CurrentTeam findCurrentTeam(ChessBoard chessBoard) { } CurrentTeam currentTeam = new CurrentTeam( - rs.getString("team") + Team.valueOf(rs.getString("team")) ); ConnectionManager.closeResultSet(rs); return currentTeam; diff --git a/src/main/java/chess/dao/PieceOnBoard.java b/src/main/java/chess/dao/PieceOnBoard.java index afd2e7fbf5e..c770d91f077 100644 --- a/src/main/java/chess/dao/PieceOnBoard.java +++ b/src/main/java/chess/dao/PieceOnBoard.java @@ -1,19 +1,23 @@ package chess.dao; +import chess.domain.piece.PieceType; +import chess.domain.piece.Team; +import chess.domain.position.Position; + import java.util.Objects; public class PieceOnBoard { private int pieceId; - private String position; - private String pieceType; - private String team; + private Position position; + private PieceType pieceType; + private Team team; private int chessBoardId; - public PieceOnBoard(String position, String pieceType, String team, int chessBoardId) { + public PieceOnBoard(Position position, PieceType pieceType, Team team, int chessBoardId) { this(0, position, pieceType, team, chessBoardId); } - public PieceOnBoard(int pieceId, String position, String pieceType, String team, int chessBoardId) { + public PieceOnBoard(int pieceId, Position position, PieceType pieceType, Team team, int chessBoardId) { this.pieceId = pieceId; this.position = position; this.pieceType = pieceType; @@ -22,19 +26,19 @@ public PieceOnBoard(int pieceId, String position, String pieceType, String team, } public int getPieceId() { - return pieceId; + return this.pieceId; } public String getPosition() { - return position; + return this.position.toString(); } public String getPieceType() { - return this.pieceType; + return this.pieceType.getSymbol(); } public String getTeam() { - return this.team; + return this.team.name(); } public int getChessBoardId() { diff --git a/src/main/java/chess/dao/PieceOnBoardDAO.java b/src/main/java/chess/dao/PieceOnBoardDAO.java index 1ac2deb42aa..547642a7363 100644 --- a/src/main/java/chess/dao/PieceOnBoardDAO.java +++ b/src/main/java/chess/dao/PieceOnBoardDAO.java @@ -1,5 +1,9 @@ package chess.dao; +import chess.domain.piece.PieceType; +import chess.domain.piece.Team; +import chess.domain.position.Position; + import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; @@ -52,9 +56,9 @@ public List findPiece(ChessBoard chessBoard) { while (rs.next()) { PieceOnBoard pieceOnBoard = new PieceOnBoard( rs.getInt("pieceId"), - rs.getString("position"), - rs.getString("pieceType"), - rs.getString("team"), + Position.of(rs.getString("position")), + PieceType.of(rs.getString("pieceType")), + Team.valueOf(rs.getString("team")), rs.getInt("chessBoardId") ); pieceOnBoards.add(pieceOnBoard); diff --git a/src/main/java/chess/domain/ChessRunner.java b/src/main/java/chess/domain/ChessRunner.java index 4dc06cef352..9e592b1da91 100644 --- a/src/main/java/chess/domain/ChessRunner.java +++ b/src/main/java/chess/domain/ChessRunner.java @@ -4,6 +4,7 @@ import chess.domain.board.Board; import chess.domain.board.BoardScore; import chess.domain.piece.Piece; +import chess.domain.piece.PieceType; import chess.domain.piece.Team; import chess.domain.position.Position; import chess.domain.strategy.direction.Direction; @@ -170,9 +171,12 @@ private void setTileDtoImage(List tileDtos) { public List getPieceOnBoards(int chessBoardId) { List pieces = this.board.getBoard().entrySet().stream() .map((entry) -> { - String position = entry.getKey().toString(); - String pieceType = entry.getValue().toSymbol(); - String team = entry.getValue().teamName(); + Position position = Position.of(entry.getKey().toString()); + PieceType pieceType = PieceType.of(entry.getValue().toSymbol()); + Team team = Team.valueOf(entry.getValue().teamName()); +// String position = entry.getKey().toString(); +// String pieceType = entry.getValue().toSymbol(); +// String team = entry.getValue().teamName(); return new PieceOnBoard(position, pieceType, team, chessBoardId); }).collect(Collectors.toList()); diff --git a/src/main/java/chess/service/ChessService.java b/src/main/java/chess/service/ChessService.java index 9915e433934..ac2e9c03e7c 100644 --- a/src/main/java/chess/service/ChessService.java +++ b/src/main/java/chess/service/ChessService.java @@ -2,6 +2,7 @@ import chess.dao.*; import chess.domain.ChessRunner; +import chess.domain.piece.Team; import chess.dto.MoveResultDTO; import chess.dto.TeamDTO; import chess.dto.TileDTO; @@ -34,7 +35,7 @@ public void newGame(Player player) { this.chessBoardDAO.addChessBoard(); ChessBoard chessBoard = this.chessBoardDAO.findRecentChessBoard(); - CurrentTeam currentTeam = new CurrentTeam(this.chessRunner.getCurrentTeam()); + CurrentTeam currentTeam = new CurrentTeam(Team.valueOf(this.chessRunner.getCurrentTeam())); this.currentTeamDAO.addCurrentTeam(chessBoard, currentTeam); List pieces = this.chessRunner.getPieceOnBoards(chessBoard.getChessBoardId()); @@ -73,7 +74,7 @@ private void updateChessBoard(int chessBoardId, String source, String target) { this.pieceOnBoardDAO.deletePiece(piece); piece = getPieceOnBoard(chessBoard, source, piece); this.pieceOnBoardDAO.updatePiece(piece, target); - CurrentTeam currentTeam = new CurrentTeam(this.chessRunner.getCurrentTeam()); + CurrentTeam currentTeam = new CurrentTeam(Team.valueOf(this.chessRunner.getCurrentTeam())); this.currentTeamDAO.updateCurrentTeam(chessBoard, currentTeam); } diff --git a/src/test/java/chess/dao/CurrentTeamDAOTest.java b/src/test/java/chess/dao/CurrentTeamDAOTest.java index b5c52c5139e..a7023680758 100644 --- a/src/test/java/chess/dao/CurrentTeamDAOTest.java +++ b/src/test/java/chess/dao/CurrentTeamDAOTest.java @@ -1,5 +1,6 @@ package chess.dao; +import chess.domain.piece.Team; import org.assertj.core.api.Assertions; import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Disabled; @@ -18,8 +19,8 @@ private void setUp() { @DisplayName("현재 팀 정보 추가") @Test void addCurrentTeamTest() { - ChessBoard chessBoard = new ChessBoard(1); - CurrentTeam currentTeam = new CurrentTeam("black"); + ChessBoard chessBoard = new ChessBoard(10); + CurrentTeam currentTeam = new CurrentTeam(Team.valueOf("BLACK")); this.currentTeamDAO.addCurrentTeam(chessBoard, currentTeam); } @@ -28,8 +29,8 @@ void addCurrentTeamTest() { @DisplayName("현재 팀 정보 업데이트") @Test void updateCurrentTeamTest() { - ChessBoard chessBoard = new ChessBoard(1); - CurrentTeam currentTeam = new CurrentTeam("WHITE"); + ChessBoard chessBoard = new ChessBoard(10); + CurrentTeam currentTeam = new CurrentTeam(Team.valueOf("WHITE")); this.currentTeamDAO.updateCurrentTeam(chessBoard, currentTeam); } @@ -38,7 +39,7 @@ void updateCurrentTeamTest() { @DisplayName("현재 팀 삭제") @Test void deleteCurrentTeamTest() { - ChessBoard chessBoard = new ChessBoard(1); + ChessBoard chessBoard = new ChessBoard(10); this.currentTeamDAO.deleteCurrentTeam(chessBoard); } @@ -47,7 +48,7 @@ void deleteCurrentTeamTest() { @DisplayName("현재 팀 검색") @Test void findCurrentTeamTest() { - ChessBoard chessBoard = new ChessBoard(1); + ChessBoard chessBoard = new ChessBoard(10); CurrentTeam currentTeam = currentTeamDAO.findCurrentTeam(chessBoard); Assertions.assertThat(currentTeam).isNotNull(); diff --git a/src/test/java/chess/dao/PieceOnBoardDAOTest.java b/src/test/java/chess/dao/PieceOnBoardDAOTest.java index bf941fb6849..a25a919f688 100644 --- a/src/test/java/chess/dao/PieceOnBoardDAOTest.java +++ b/src/test/java/chess/dao/PieceOnBoardDAOTest.java @@ -1,5 +1,8 @@ package chess.dao; +import chess.domain.piece.PieceType; +import chess.domain.piece.Team; +import chess.domain.position.Position; import org.assertj.core.api.Assertions; import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Disabled; @@ -22,10 +25,13 @@ private void setUp() { @Test void addPieceTest() { List pieceOnBoards = new ArrayList<>(); - pieceOnBoards.add(new PieceOnBoard(0, "a2", "PAWN", "WHITE", 5)); - pieceOnBoards.add(new PieceOnBoard(0, "a1", "ROOK", "WHITE", 5)); - pieceOnBoards.add(new PieceOnBoard(0, "a7", "PAWN", "BLACK", 5)); - ChessBoard chessBoard = new ChessBoard(5); + pieceOnBoards.add(new PieceOnBoard(Position.of("a2"), PieceType.valueOf("PAWN"), + Team.valueOf("WHITE"), 10)); + pieceOnBoards.add(new PieceOnBoard(Position.of("a1"), PieceType.valueOf("ROOK"), + Team.valueOf("WHITE"), 10)); + pieceOnBoards.add(new PieceOnBoard(Position.of("a7"), PieceType.valueOf("PAWN"), + Team.valueOf("BLACK"), 10)); + ChessBoard chessBoard = new ChessBoard(10); pieceOnBoardDAO.addPiece(chessBoard, pieceOnBoards); } @@ -34,8 +40,8 @@ void addPieceTest() { @DisplayName("피스 삭제") @Test void deletePieceTest() { - PieceOnBoard a2WhitePawn = new PieceOnBoard(35, "a1", "ROOK", - "WHITE", 5); + PieceOnBoard a2WhitePawn = new PieceOnBoard(166, Position.of("a1"), PieceType.valueOf("ROOK"), + Team.valueOf("WHITE"), 10); pieceOnBoardDAO.deletePiece(a2WhitePawn); } @@ -44,12 +50,14 @@ void deletePieceTest() { @DisplayName("저장되어 있는 피스 정보 불러오기") @Test void findPieceTest() { - ChessBoard chessBoard = new ChessBoard(5); + ChessBoard chessBoard = new ChessBoard(10); List pieceOnBoards = pieceOnBoardDAO.findPiece(chessBoard); Assertions.assertThat(pieceOnBoards).contains( - new PieceOnBoard(34, "a2", "PAWN", "WHITE", 5), - new PieceOnBoard(36, "a7", "PAWN", "BLACK", 5) + new PieceOnBoard(165, Position.of("a2"), PieceType.valueOf("PAWN"), + Team.valueOf("WHITE"), 10), + new PieceOnBoard(167, Position.of("a7"), PieceType.valueOf("PAWN"), + Team.valueOf("BLACK"), 10) ); } @@ -57,8 +65,8 @@ void findPieceTest() { @DisplayName("피스 정보 업데이트") @Test void updatePieceTest() { - PieceOnBoard pieceOnBoard = new PieceOnBoard(34, "a2", "PAWN", - "WHITE", 5); + PieceOnBoard pieceOnBoard = new PieceOnBoard(165, Position.of("a2"), PieceType.valueOf("PAWN"), + Team.valueOf("WHITE"), 10); pieceOnBoardDAO.updatePiece(pieceOnBoard, "a3"); } From f25d61b811b8c8aff82f83ef881959d1e2a55433 Mon Sep 17 00:00:00 2001 From: giantim Date: Thu, 16 Apr 2020 21:15:08 +0900 Subject: [PATCH 73/75] =?UTF-8?q?refactor:=20TileDTO,=20BoardScoreDTO=20?= =?UTF-8?q?=EC=9D=98=20setter=20=EB=A9=94=EC=84=9C=EB=93=9C=20=EC=82=AD?= =?UTF-8?q?=EC=A0=9C?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/main/java/chess/domain/ChessRunner.java | 49 +++++++-------------- src/main/java/chess/domain/board/Board.java | 12 +++++ src/main/java/chess/dto/BoardScoreDTO.java | 7 +-- src/main/java/chess/dto/TileDTO.java | 17 +++---- 4 files changed, 38 insertions(+), 47 deletions(-) diff --git a/src/main/java/chess/domain/ChessRunner.java b/src/main/java/chess/domain/ChessRunner.java index 9e592b1da91..a0bd1717302 100644 --- a/src/main/java/chess/domain/ChessRunner.java +++ b/src/main/java/chess/domain/ChessRunner.java @@ -14,6 +14,7 @@ import java.util.*; import java.util.stream.Collectors; +import java.util.stream.IntStream; public class ChessRunner { private Board board; @@ -109,13 +110,12 @@ public double calculateScore() { public List calculateScores() { List scores = new ArrayList<>(); - BoardScoreDTO currentTeam = new BoardScoreDTO(calculateScore()); - currentTeam.setTeam(this.currentTeam.name()); + BoardScoreDTO currentTeam = new BoardScoreDTO(calculateScore(), this.currentTeam.name()); scores.add(currentTeam); BoardScore oppositeTeamScore = this.board.calculateScore(this.currentTeam.changeTeam()); - BoardScoreDTO oppositeTeam = new BoardScoreDTO(oppositeTeamScore.getBoardScore()); - oppositeTeam.setTeam(this.currentTeam.changeTeam().name()); + BoardScoreDTO oppositeTeam = new BoardScoreDTO(oppositeTeamScore.getBoardScore(), + this.currentTeam.changeTeam().name()); scores.add(oppositeTeam); return Collections.unmodifiableList(scores); @@ -139,33 +139,21 @@ public String getWinner() { } public List entireTileDtos() { - List tileDtos = Position.getPositions().stream() - .map(TileDTO::new) - .collect(Collectors.toList()); - - setTileDtoStyle(tileDtos); - setTileDtoImage(tileDtos); - - return Collections.unmodifiableList(tileDtos); - } - - private void setTileDtoStyle(List tileDtos) { + List positions = Position.getPositions(); List indexes = Position.getPositionsIndex(); - for (int i = 0; i < indexes.size(); i++) { - TileDTO tileDto = tileDtos.get(i); - tileDto.setStyle(indexes.get(i)); - } - } + List tileDTOS = IntStream.range(0, positions.size()) + .mapToObj((index) -> { + String position = positions.get(index); + int styleIndex = indexes.get(index); + if (this.board.contain(position)) { + Map.Entry entry = this.board.getEntry(position); + String pieceImageUrl = entry.getValue().toSymbol() + entry.getValue().teamName().toLowerCase(); + return new TileDTO(position, pieceImageUrl, styleIndex); + } + return new TileDTO(position, StringUtils.EMPTY, styleIndex); + }).collect(Collectors.toList()); - private void setTileDtoImage(List tileDtos) { - Map board = this.board.getBoard(); - for (Map.Entry entry : board.entrySet()) { - tileDtos.stream() - .filter(td -> td.getPosition().equals(entry.getKey().toString())) - .findFirst() - .orElseThrow(IllegalArgumentException::new) - .setPieceImageUrl(entry.getValue().toSymbol() + entry.getValue().teamName().toLowerCase()); - } + return Collections.unmodifiableList(tileDTOS); } public List getPieceOnBoards(int chessBoardId) { @@ -174,9 +162,6 @@ public List getPieceOnBoards(int chessBoardId) { Position position = Position.of(entry.getKey().toString()); PieceType pieceType = PieceType.of(entry.getValue().toSymbol()); Team team = Team.valueOf(entry.getValue().teamName()); -// String position = entry.getKey().toString(); -// String pieceType = entry.getValue().toSymbol(); -// String team = entry.getValue().teamName(); return new PieceOnBoard(position, pieceType, team, chessBoardId); }).collect(Collectors.toList()); diff --git a/src/main/java/chess/domain/board/Board.java b/src/main/java/chess/domain/board/Board.java index 5f0cb54664b..147f1f6f45c 100644 --- a/src/main/java/chess/domain/board/Board.java +++ b/src/main/java/chess/domain/board/Board.java @@ -95,7 +95,19 @@ public Map parse() { return Collections.unmodifiableMap(parseResult); } + public boolean contain(String position) { + return this.board.containsKey(Position.of(position)); + } + public Map getBoard() { return Collections.unmodifiableMap(this.board); } + + public Map.Entry getEntry(String position) { + Position entryPosition = Position.of(position); + return this.board.entrySet().stream() + .filter(entry -> entry.getKey().equals(entryPosition)) + .findFirst() + .orElseThrow(() -> new IllegalArgumentException("위치가 잘못되었습니다.")); + } } \ No newline at end of file diff --git a/src/main/java/chess/dto/BoardScoreDTO.java b/src/main/java/chess/dto/BoardScoreDTO.java index 53e38e88734..246a8f7b4d4 100644 --- a/src/main/java/chess/dto/BoardScoreDTO.java +++ b/src/main/java/chess/dto/BoardScoreDTO.java @@ -2,13 +2,10 @@ public class BoardScoreDTO { private final double boardScore; - private String team; + private final String team; - public BoardScoreDTO(final double boardScore) { + public BoardScoreDTO(final double boardScore, final String team) { this.boardScore = boardScore; - } - - public void setTeam(final String team) { this.team = team; } diff --git a/src/main/java/chess/dto/TileDTO.java b/src/main/java/chess/dto/TileDTO.java index 64906871d7c..481462b2e96 100644 --- a/src/main/java/chess/dto/TileDTO.java +++ b/src/main/java/chess/dto/TileDTO.java @@ -5,23 +5,20 @@ public class TileDTO { private static final String STYLE_BLACK = "black"; private final String position; - private String pieceImageUrl; - private String style; + private final String pieceImageUrl; + private final String style; - public TileDTO(final String position) { + public TileDTO(final String position, final String pieceImageUrl, final int index) { this.position = position; - } - - public void setPieceImageUrl(String pieceImageUrl) { this.pieceImageUrl = pieceImageUrl; + this.style = setStyle(index); } - public void setStyle(int index) { + private String setStyle(int index) { if (index % 2 == 0) { - this.style = STYLE_WHITE; - return; + return STYLE_WHITE; } - this.style = STYLE_BLACK; + return STYLE_BLACK; } public String getPosition() { From 5170429a438c11c4bdbdc32933ce5707cddc8cff Mon Sep 17 00:00:00 2001 From: giantim Date: Thu, 16 Apr 2020 21:42:21 +0900 Subject: [PATCH 74/75] =?UTF-8?q?refactor:=20SQLException=20=EC=97=90=20?= =?UTF-8?q?=EB=8C=80=ED=95=9C=20Custom=20RuntimeException=20=EC=9D=84=20?= =?UTF-8?q?=EB=A7=8C=EB=93=A4=EC=96=B4=EC=84=9C=20=EC=98=88=EC=99=B8=20?= =?UTF-8?q?=ED=8E=98=EC=9D=B4=EC=A7=80=20=EC=B6=9C=EB=A0=A5?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../chess/controller/WebChessController.java | 153 +++++++++++------- src/main/java/chess/dao/ChessBoardDAO.java | 10 +- .../java/chess/dao/ConnectionManager.java | 10 +- src/main/java/chess/dao/CurrentTeamDAO.java | 9 +- .../java/chess/dao/CustomSQLException.java | 7 + src/main/java/chess/dao/PieceOnBoardDAO.java | 9 +- src/main/java/chess/dao/PlayerDAO.java | 10 +- src/main/resources/templates/css/error.css | 11 ++ src/main/resources/templates/error.html | 15 ++ 9 files changed, 145 insertions(+), 89 deletions(-) create mode 100644 src/main/java/chess/dao/CustomSQLException.java create mode 100644 src/main/resources/templates/css/error.css create mode 100644 src/main/resources/templates/error.html diff --git a/src/main/java/chess/controller/WebChessController.java b/src/main/java/chess/controller/WebChessController.java index 1df7956597c..dbfdda58377 100644 --- a/src/main/java/chess/controller/WebChessController.java +++ b/src/main/java/chess/controller/WebChessController.java @@ -1,6 +1,7 @@ package chess.controller; import chess.dao.ChessBoard; +import chess.dao.CustomSQLException; import chess.dao.Player; import chess.dto.MoveResultDTO; import chess.dto.TeamDTO; @@ -37,11 +38,16 @@ public void playChess() { post("/load", (req, res) -> { Map model = new HashMap<>(); - List players = this.chessService.players(); + try { + List players = this.chessService.players(); - model.put("gameData", players); + model.put("gameData", players); - return render(model, "table.html"); + return render(model, "table.html"); + } catch (CustomSQLException e) { + model.put("errMessage", e.getMessage()); + return render(model, "error.html"); + } }); post("/newGame", (req, res) -> { @@ -50,18 +56,23 @@ public void playChess() { String whitePlayer = req.queryParams("white-player"); String blackPlayer = req.queryParams("black-player"); - Player player = new Player(whitePlayer, blackPlayer); - this.chessService.newGame(player); - List tileDtos = this.chessService.getTiles(); - TeamDTO teamDto = this.chessService.getCurrentTeam(); - ChessBoard chessBoard = this.chessService.getRecentChessBoard(); - - model.put("tiles", tileDtos); - model.put("currentTeam", teamDto); - model.put("player", player); - model.put("chessBoard", chessBoard); - - return render(model, "game.html"); + try { + Player player = new Player(whitePlayer, blackPlayer); + this.chessService.newGame(player); + List tileDtos = this.chessService.getTiles(); + TeamDTO teamDto = this.chessService.getCurrentTeam(); + ChessBoard chessBoard = this.chessService.getRecentChessBoard(); + + model.put("tiles", tileDtos); + model.put("currentTeam", teamDto); + model.put("player", player); + model.put("chessBoard", chessBoard); + + return render(model, "game.html"); + } catch (CustomSQLException e) { + model.put("errMessage", e.getMessage()); + return render(model, "error.html"); + } }); post("/continueGame", (req, res) -> { @@ -69,18 +80,23 @@ public void playChess() { int chessBoardId = Integer.parseInt(req.queryParams("chess-board-id")); - this.chessService.continueGame(chessBoardId); - List tileDtos = this.chessService.getTiles(); - TeamDTO teamDto = this.chessService.getCurrentTeam(); - Player player = this.chessService.getPlayer(chessBoardId); - ChessBoard chessBoard = new ChessBoard(chessBoardId); - - model.put("tiles", tileDtos); - model.put("currentTeam", teamDto); - model.put("player", player); - model.put("chessBoard", chessBoard); - - return render(model, "game.html"); + try { + this.chessService.continueGame(chessBoardId); + List tileDtos = this.chessService.getTiles(); + TeamDTO teamDto = this.chessService.getCurrentTeam(); + Player player = this.chessService.getPlayer(chessBoardId); + ChessBoard chessBoard = new ChessBoard(chessBoardId); + + model.put("tiles", tileDtos); + model.put("currentTeam", teamDto); + model.put("player", player); + model.put("chessBoard", chessBoard); + + return render(model, "game.html"); + } catch (CustomSQLException e) { + model.put("errMessage", e.getMessage()); + return render(model, "error.html"); + } }); post("/move", (req, res) -> { @@ -90,24 +106,29 @@ public void playChess() { String source = req.queryParams("source"); String target = req.queryParams("target"); - MoveResultDTO moveResultDto = this.chessService.move(chessBoardId, source, target); - List tileDtos = this.chessService.getTiles(); - TeamDTO teamDto = this.chessService.getCurrentTeam(); - Player player = this.chessService.getPlayer(chessBoardId); - ChessBoard chessBoard = new ChessBoard(chessBoardId); - - model.put("tiles", tileDtos); - model.put("currentTeam", teamDto); - model.put("message", moveResultDto.getMessage()); - model.put("style", moveResultDto.getStyle()); - model.put("player", player); - model.put("chessBoard", chessBoard); - - if (this.chessService.isEndGame()) { - this.chessService.deleteChessGame(chessBoardId); - return render(model, "end.html"); + try { + MoveResultDTO moveResultDto = this.chessService.move(chessBoardId, source, target); + List tileDtos = this.chessService.getTiles(); + TeamDTO teamDto = this.chessService.getCurrentTeam(); + Player player = this.chessService.getPlayer(chessBoardId); + ChessBoard chessBoard = new ChessBoard(chessBoardId); + + model.put("tiles", tileDtos); + model.put("currentTeam", teamDto); + model.put("message", moveResultDto.getMessage()); + model.put("style", moveResultDto.getStyle()); + model.put("player", player); + model.put("chessBoard", chessBoard); + + if (this.chessService.isEndGame()) { + this.chessService.deleteChessGame(chessBoardId); + return render(model, "end.html"); + } + return render(model, "game.html"); + } catch (CustomSQLException e) { + model.put("errorMessage", e.getMessage()); + return render(model, "error.html"); } - return render(model, "game.html"); }); post("/status", (req, res) -> { @@ -115,19 +136,24 @@ public void playChess() { int chessBoardId = Integer.parseInt(req.queryParams("chess-board-id-status")); - List tileDtos = this.chessService.getTiles(); - TeamDTO teamDto = this.chessService.getCurrentTeam(); - String message = this.chessService.getScores(); - Player player = this.chessService.getPlayer(chessBoardId); - ChessBoard chessBoard = new ChessBoard(chessBoardId); - - model.put("tiles", tileDtos); - model.put("currentTeam", teamDto); - model.put("message", message); - model.put("player", player); - model.put("chessBoard", chessBoard); - - return render(model, "game.html"); + try { + List tileDtos = this.chessService.getTiles(); + TeamDTO teamDto = this.chessService.getCurrentTeam(); + String message = this.chessService.getScores(); + Player player = this.chessService.getPlayer(chessBoardId); + ChessBoard chessBoard = new ChessBoard(chessBoardId); + + model.put("tiles", tileDtos); + model.put("currentTeam", teamDto); + model.put("message", message); + model.put("player", player); + model.put("chessBoard", chessBoard); + + return render(model, "game.html"); + } catch (CustomSQLException e) { + model.put("errorMessage", e.getMessage()); + return render(model, "error.html"); + } }); post("/end", (req, res) -> { @@ -135,12 +161,17 @@ public void playChess() { int chessBoardId = Integer.parseInt(req.queryParams("chess-board-id-end")); - this.chessService.deleteChessGame(chessBoardId); - String message = this.chessService.getScores(); + try { + this.chessService.deleteChessGame(chessBoardId); + String message = this.chessService.getScores(); - model.put("message", message); + model.put("message", message); - return render(model, "end.html"); + return render(model, "end.html"); + } catch (CustomSQLException e) { + model.put("errorMessage", e.getMessage()); + return render(model, "error.html"); + } }); } diff --git a/src/main/java/chess/dao/ChessBoardDAO.java b/src/main/java/chess/dao/ChessBoardDAO.java index dccf8e9c625..69eade5a5e5 100644 --- a/src/main/java/chess/dao/ChessBoardDAO.java +++ b/src/main/java/chess/dao/ChessBoardDAO.java @@ -12,7 +12,7 @@ public void addChessBoard() { PreparedStatement pstmt = con.prepareStatement(query)) { pstmt.executeUpdate(); } catch (SQLException e) { - e.printStackTrace(); + throw new CustomSQLException(e.getMessage(), e); } } @@ -31,8 +31,7 @@ public ChessBoard findRecentChessBoard() { ConnectionManager.closeResultSet(rs); return chessBoard; } catch (SQLException e) { - e.printStackTrace(); - return null; + throw new CustomSQLException(e.getMessage(), e); } } @@ -46,7 +45,7 @@ public void deleteChessBoard(ChessBoard chessBoard) { pstmt.setInt(1, chessBoard.getChessBoardId()); pstmt.executeUpdate(); } catch (SQLException e) { - e.printStackTrace(); + throw new CustomSQLException(e.getMessage(), e); } } @@ -66,8 +65,7 @@ public ChessBoard findById(int chessBoardId) { ConnectionManager.closeResultSet(rs); return chessBoard; } catch (SQLException e) { - e.printStackTrace(); - return null; + throw new CustomSQLException(e.getMessage(), e); } } } diff --git a/src/main/java/chess/dao/ConnectionManager.java b/src/main/java/chess/dao/ConnectionManager.java index 7a97817f75c..4a0678885c1 100644 --- a/src/main/java/chess/dao/ConnectionManager.java +++ b/src/main/java/chess/dao/ConnectionManager.java @@ -17,8 +17,7 @@ public static Connection getConnection() { try { Class.forName("com.mysql.cj.jdbc.Driver"); } catch (ClassNotFoundException e) { - System.err.println(" !! JDBC Driver load 오류: " + e.getMessage()); - e.printStackTrace(); + throw new CustomSQLException(e.getMessage(), e); } try { @@ -26,8 +25,7 @@ public static Connection getConnection() { userName, password); System.out.println("정상적으로 연결되었습니다."); } catch (SQLException e) { - System.err.println("연결 오류:" + e.getMessage()); - e.printStackTrace(); + throw new CustomSQLException(e.getMessage(), e); } return con; @@ -39,7 +37,7 @@ public static void closeResultSet(ResultSet rs) { rs.close(); } } catch (SQLException e) { - System.err.println("rs 오류:" + e.getMessage()); + throw new CustomSQLException(e.getMessage(), e); } } @@ -49,7 +47,7 @@ public static void closePreparedStatement(PreparedStatement pstmt) { pstmt.close(); } } catch (SQLException e) { - System.out.println("pstmt 오류: " + e.getMessage()); + throw new CustomSQLException(e.getMessage(), e); } } } diff --git a/src/main/java/chess/dao/CurrentTeamDAO.java b/src/main/java/chess/dao/CurrentTeamDAO.java index 43e69320909..d69ce3376ec 100644 --- a/src/main/java/chess/dao/CurrentTeamDAO.java +++ b/src/main/java/chess/dao/CurrentTeamDAO.java @@ -16,7 +16,7 @@ public void addCurrentTeam(ChessBoard chessBoard, CurrentTeam currentTeam) { pstmt.setInt(2, chessBoard.getChessBoardId()); pstmt.executeUpdate(); } catch (SQLException e) { - e.printStackTrace(); + throw new CustomSQLException(e.getMessage(), e); } } @@ -28,7 +28,7 @@ public void updateCurrentTeam(ChessBoard chessBoard, CurrentTeam currentTeam) { pstmt.setInt(2, chessBoard.getChessBoardId()); pstmt.executeUpdate(); } catch (SQLException e) { - e.printStackTrace(); + throw new CustomSQLException(e.getMessage(), e); } } @@ -39,7 +39,7 @@ public void deleteCurrentTeam(ChessBoard chessBoard) { pstmt.setInt(1, chessBoard.getChessBoardId()); pstmt.executeUpdate(); } catch (SQLException e) { - e.printStackTrace(); + throw new CustomSQLException(e.getMessage(), e); } } @@ -59,8 +59,7 @@ public CurrentTeam findCurrentTeam(ChessBoard chessBoard) { ConnectionManager.closeResultSet(rs); return currentTeam; } catch (SQLException e) { - e.printStackTrace(); - return null; + throw new CustomSQLException(e.getMessage(), e); } } } diff --git a/src/main/java/chess/dao/CustomSQLException.java b/src/main/java/chess/dao/CustomSQLException.java new file mode 100644 index 00000000000..e0ec907b351 --- /dev/null +++ b/src/main/java/chess/dao/CustomSQLException.java @@ -0,0 +1,7 @@ +package chess.dao; + +public class CustomSQLException extends RuntimeException { + public CustomSQLException(String message, Throwable cause) { + super(message, cause); + } +} diff --git a/src/main/java/chess/dao/PieceOnBoardDAO.java b/src/main/java/chess/dao/PieceOnBoardDAO.java index 547642a7363..2905d528ef9 100644 --- a/src/main/java/chess/dao/PieceOnBoardDAO.java +++ b/src/main/java/chess/dao/PieceOnBoardDAO.java @@ -27,7 +27,7 @@ public void addPiece(ChessBoard chessBoard, List pieceOnBoards) { ConnectionManager.closePreparedStatement(pstmt); } } catch (SQLException e) { - e.printStackTrace(); + throw new CustomSQLException(e.getMessage(), e); } } @@ -41,7 +41,7 @@ public void deletePiece(PieceOnBoard pieceOnBoard) { pstmt.setInt(1, pieceOnBoard.getPieceId()); pstmt.executeUpdate(); } catch (SQLException e) { - e.printStackTrace(); + throw new CustomSQLException(e.getMessage(), e); } } @@ -66,8 +66,7 @@ public List findPiece(ChessBoard chessBoard) { ConnectionManager.closeResultSet(rs); return Collections.unmodifiableList(pieceOnBoards); } catch (SQLException e) { - e.printStackTrace(); - return null; + throw new CustomSQLException(e.getMessage(), e); } } @@ -79,7 +78,7 @@ public void updatePiece(PieceOnBoard pieceOnBoard, String targetPosition) { pstmt.setInt(2, pieceOnBoard.getPieceId()); pstmt.executeUpdate(); } catch (SQLException e) { - e.printStackTrace(); + throw new CustomSQLException(e.getMessage(), e); } } } diff --git a/src/main/java/chess/dao/PlayerDAO.java b/src/main/java/chess/dao/PlayerDAO.java index dd612fb40c5..fb0fae0db41 100644 --- a/src/main/java/chess/dao/PlayerDAO.java +++ b/src/main/java/chess/dao/PlayerDAO.java @@ -17,7 +17,7 @@ public void addPlayer(ChessBoard chessBoard, Player player) { pstmt.setInt(3, chessBoard.getChessBoardId()); pstmt.executeUpdate(); } catch (SQLException e) { - e.printStackTrace(); + throw new CustomSQLException(e.getMessage(), e); } } @@ -39,8 +39,7 @@ public Player findPlayer(ChessBoard chessBoard) { ConnectionManager.closeResultSet(rs); return player; } catch (SQLException e) { - e.printStackTrace(); - return null; + throw new CustomSQLException(e.getMessage(), e); } } @@ -51,7 +50,7 @@ public void deletePlayer(ChessBoard chessBoard) { pstmt.setInt(1, chessBoard.getChessBoardId()); pstmt.executeUpdate(); } catch (SQLException e) { - e.printStackTrace(); + throw new CustomSQLException(e.getMessage(), e); } } @@ -73,8 +72,7 @@ public List findAllPlayer() { ConnectionManager.closeResultSet(rs); return players; } catch (SQLException e) { - e.printStackTrace(); - return null; + throw new CustomSQLException(e.getMessage(), e); } } } diff --git a/src/main/resources/templates/css/error.css b/src/main/resources/templates/css/error.css new file mode 100644 index 00000000000..1bbd87a5d13 --- /dev/null +++ b/src/main/resources/templates/css/error.css @@ -0,0 +1,11 @@ +@charset "utf-8"; + +@font-face { + font-family: "BMHANNAPro"; + src: url(../ttf/BMHANNAPro.ttf); +} + +#result { + font-family: BMHANNAPro; + font-size: 30px; +} \ No newline at end of file diff --git a/src/main/resources/templates/error.html b/src/main/resources/templates/error.html new file mode 100644 index 00000000000..a5364085edf --- /dev/null +++ b/src/main/resources/templates/error.html @@ -0,0 +1,15 @@ + + + + + 체스 + + + + +
    +

    에러 내용: {{errMessage}} +

    +

    + + From e5b625fbc0806e3a795f59a5308a783a8d36c49e Mon Sep 17 00:00:00 2001 From: giantim Date: Sun, 19 Apr 2020 19:47:23 +0900 Subject: [PATCH 75/75] =?UTF-8?q?refactor:=20findFirst=20=EB=A5=BC=20Optio?= =?UTF-8?q?nal=20=EB=A1=9C=20=EB=9E=98=ED=95=91=ED=95=9C=20=EB=B6=80?= =?UTF-8?q?=EB=B6=84=20=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/main/java/chess/dao/PieceOnBoards.java | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/src/main/java/chess/dao/PieceOnBoards.java b/src/main/java/chess/dao/PieceOnBoards.java index 40997d713b7..64ef0e933ab 100644 --- a/src/main/java/chess/dao/PieceOnBoards.java +++ b/src/main/java/chess/dao/PieceOnBoards.java @@ -16,10 +16,9 @@ public static PieceOnBoards create(List pieceOnBoards) { } public Optional find(String position) { - Optional piece = Optional.ofNullable(this.pieceOnBoards.stream() + Optional piece = this.pieceOnBoards.stream() .filter(p -> p.getPosition().equals(position)) - .findFirst() - .orElse(null)); + .findFirst(); return piece; }

Gz<{$b)Hkh9flE&3$ZQpiXR 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%0AGxhE=j4On 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≫hxV9Fs#Cbq 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�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