diff options
13 files changed, 142 insertions, 144 deletions
diff --git a/src/main/java/fr/umlv/java/wallj/block/BlockFactory.java b/src/main/java/fr/umlv/java/wallj/block/BlockFactory.java index 6911c88..411696d 100644 --- a/src/main/java/fr/umlv/java/wallj/block/BlockFactory.java +++ b/src/main/java/fr/umlv/java/wallj/block/BlockFactory.java | |||
@@ -9,6 +9,10 @@ import org.jbox2d.common.Vec2; | |||
9 | * @author Pacien TRAN-GIRARD | 9 | * @author Pacien TRAN-GIRARD |
10 | */ | 10 | */ |
11 | public final class BlockFactory { | 11 | public final class BlockFactory { |
12 | private BlockFactory() { | ||
13 | // static class | ||
14 | } | ||
15 | |||
12 | private static Block forType(BlockType t, Vec2 pos) { | 16 | private static Block forType(BlockType t, Vec2 pos) { |
13 | switch (t) { | 17 | switch (t) { |
14 | case WALL: | 18 | case WALL: |
@@ -35,8 +39,4 @@ public final class BlockFactory { | |||
35 | public static Block build(BlockType type, TileVec2 pos) { | 39 | public static Block build(BlockType type, TileVec2 pos) { |
36 | return forType(type, pos.toVec2()); | 40 | return forType(type, pos.toVec2()); |
37 | } | 41 | } |
38 | |||
39 | private BlockFactory() { | ||
40 | // static class | ||
41 | } | ||
42 | } | 42 | } |
diff --git a/src/main/java/fr/umlv/java/wallj/block/SolidDef.java b/src/main/java/fr/umlv/java/wallj/block/SolidDef.java index 6fb7dc3..25ff022 100644 --- a/src/main/java/fr/umlv/java/wallj/block/SolidDef.java +++ b/src/main/java/fr/umlv/java/wallj/block/SolidDef.java | |||
@@ -13,6 +13,10 @@ import org.jbox2d.dynamics.FixtureDef; | |||
13 | * @author Pacien TRAN-GIRARD | 13 | * @author Pacien TRAN-GIRARD |
14 | */ | 14 | */ |
15 | public final class SolidDef { | 15 | public final class SolidDef { |
16 | private SolidDef() { | ||
17 | // static class | ||
18 | } | ||
19 | |||
16 | /** | 20 | /** |
17 | * @param bodyType type of body | 21 | * @param bodyType type of body |
18 | * @param pos initial position of the body | 22 | * @param pos initial position of the body |
@@ -53,8 +57,4 @@ public final class SolidDef { | |||
53 | shape.m_radius = TileVec2.TILE_DIM / 2; | 57 | shape.m_radius = TileVec2.TILE_DIM / 2; |
54 | return shape; | 58 | return shape; |
55 | } | 59 | } |
56 | |||
57 | private SolidDef() { | ||
58 | // static class | ||
59 | } | ||
60 | } | 60 | } |
diff --git a/src/main/java/fr/umlv/java/wallj/board/Board.java b/src/main/java/fr/umlv/java/wallj/board/Board.java index 2e67c53..077dd26 100644 --- a/src/main/java/fr/umlv/java/wallj/board/Board.java +++ b/src/main/java/fr/umlv/java/wallj/board/Board.java | |||
@@ -15,38 +15,6 @@ import java.util.stream.Stream; | |||
15 | */ | 15 | */ |
16 | public final class Board { | 16 | public final class Board { |
17 | 17 | ||
18 | /** | ||
19 | * Board Builder | ||
20 | */ | ||
21 | public static final class Builder { | ||
22 | private final BlockType[][] map; | ||
23 | |||
24 | /** | ||
25 | * @param width width in tiles | ||
26 | * @param height height in tiles | ||
27 | */ | ||
28 | public Builder(int width, int height) { | ||
29 | map = new BlockType[height][width]; | ||
30 | } | ||
31 | |||
32 | /** | ||
33 | * @param pos the tile position vector | ||
34 | * @param type the BlockType to set | ||
35 | * @return the Builder | ||
36 | */ | ||
37 | public Builder setBlockTypeAt(TileVec2 pos, BlockType type) { | ||
38 | map[pos.getRow()][pos.getCol()] = type; | ||
39 | return this; | ||
40 | } | ||
41 | |||
42 | /** | ||
43 | * @return the immutable Board | ||
44 | */ | ||
45 | public Board build() { | ||
46 | return new Board(map); | ||
47 | } | ||
48 | } | ||
49 | |||
50 | private final BlockType[][] map; | 18 | private final BlockType[][] map; |
51 | 19 | ||
52 | private Board(BlockType[][] map) { | 20 | private Board(BlockType[][] map) { |
@@ -103,4 +71,36 @@ public final class Board { | |||
103 | return Arrays.hashCode(map); | 71 | return Arrays.hashCode(map); |
104 | } | 72 | } |
105 | 73 | ||
74 | /** | ||
75 | * Board Builder | ||
76 | */ | ||
77 | public static final class Builder { | ||
78 | private final BlockType[][] map; | ||
79 | |||
80 | /** | ||
81 | * @param width width in tiles | ||
82 | * @param height height in tiles | ||
83 | */ | ||
84 | public Builder(int width, int height) { | ||
85 | map = new BlockType[height][width]; | ||
86 | } | ||
87 | |||
88 | /** | ||
89 | * @param pos the tile position vector | ||
90 | * @param type the BlockType to set | ||
91 | * @return the Builder | ||
92 | */ | ||
93 | public Builder setBlockTypeAt(TileVec2 pos, BlockType type) { | ||
94 | map[pos.getRow()][pos.getCol()] = type; | ||
95 | return this; | ||
96 | } | ||
97 | |||
98 | /** | ||
99 | * @return the immutable Board | ||
100 | */ | ||
101 | public Board build() { | ||
102 | return new Board(map); | ||
103 | } | ||
104 | } | ||
105 | |||
106 | } | 106 | } |
diff --git a/src/main/java/fr/umlv/java/wallj/board/BoardParser.java b/src/main/java/fr/umlv/java/wallj/board/BoardParser.java index 90fd9c2..71bdc51 100644 --- a/src/main/java/fr/umlv/java/wallj/board/BoardParser.java +++ b/src/main/java/fr/umlv/java/wallj/board/BoardParser.java | |||
@@ -15,6 +15,10 @@ import java.util.stream.Collectors; | |||
15 | * @author Pacien TRAN-GIRARD | 15 | * @author Pacien TRAN-GIRARD |
16 | */ | 16 | */ |
17 | public final class BoardParser { | 17 | public final class BoardParser { |
18 | private BoardParser() { | ||
19 | // static class | ||
20 | } | ||
21 | |||
18 | private static Board buildBoard(List<List<BlockType>> map) { | 22 | private static Board buildBoard(List<List<BlockType>> map) { |
19 | if (!Matrix.isShapeValid(map)) throw new IllegalArgumentException("Board must be rectangular."); | 23 | if (!Matrix.isShapeValid(map)) throw new IllegalArgumentException("Board must be rectangular."); |
20 | 24 | ||
@@ -60,8 +64,4 @@ public final class BoardParser { | |||
60 | .map(BoardParser::parseLine) | 64 | .map(BoardParser::parseLine) |
61 | .collect(Collectors.toList())); | 65 | .collect(Collectors.toList())); |
62 | } | 66 | } |
63 | |||
64 | private BoardParser() { | ||
65 | // static class | ||
66 | } | ||
67 | } | 67 | } |
diff --git a/src/main/java/fr/umlv/java/wallj/board/BoardValidator.java b/src/main/java/fr/umlv/java/wallj/board/BoardValidator.java index 011ca8b..d7d3583 100644 --- a/src/main/java/fr/umlv/java/wallj/board/BoardValidator.java +++ b/src/main/java/fr/umlv/java/wallj/board/BoardValidator.java | |||
@@ -13,6 +13,39 @@ import java.util.stream.IntStream; | |||
13 | */ | 13 | */ |
14 | public class BoardValidator { | 14 | public class BoardValidator { |
15 | 15 | ||
16 | private final Board board; | ||
17 | private final ValidationException errors = new ValidationException(); | ||
18 | |||
19 | /** | ||
20 | * @param board the board to validate | ||
21 | */ | ||
22 | public BoardValidator(Board board) { | ||
23 | this.board = board; | ||
24 | } | ||
25 | |||
26 | /** | ||
27 | * Tests the board against a given validator, using the supplied error message if the validation fails. | ||
28 | * | ||
29 | * @param validator a validity test | ||
30 | * @param msg a failure message | ||
31 | * @return the board validator | ||
32 | */ | ||
33 | public BoardValidator validate(Predicate<Board> validator, String msg) { | ||
34 | if (!validator.test(board)) errors.addSuppressed(new ValidationException(msg)); | ||
35 | return this; | ||
36 | } | ||
37 | |||
38 | /** | ||
39 | * @return the validated board | ||
40 | * @throws ValidationException in case of failure | ||
41 | */ | ||
42 | public Board get() throws ValidationException { | ||
43 | if (errors.getSuppressed().length > 0) | ||
44 | throw errors; | ||
45 | else | ||
46 | return board; | ||
47 | } | ||
48 | |||
16 | /** | 49 | /** |
17 | * A validation exception, witness of validation error(s). | 50 | * A validation exception, witness of validation error(s). |
18 | */ | 51 | */ |
@@ -33,6 +66,10 @@ public class BoardValidator { | |||
33 | 66 | ||
34 | <