summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMatthias Schiffer <mschiffer@universe-factory.net>2011-05-05 16:48:17 +0200
committerMatthias Schiffer <mschiffer@universe-factory.net>2011-05-05 16:48:17 +0200
commit7ee737f0d38bd815dc26a81a440148beebb17385 (patch)
tree0cf573d0a930ec710183d15b23d16f75228e1c75
parentf5075789facf8a133f1c225ca9d25a1e0a801f43 (diff)
downloadJRummikub-7ee737f0d38bd815dc26a81a440148beebb17385.tar
JRummikub-7ee737f0d38bd815dc26a81a440148beebb17385.zip
Implement tableDifference (and fix test...)
git-svn-id: svn://sunsvr01.isp.uni-luebeck.de/swproj13/trunk@144 72836036-5685-4462-b002-a69064685172
-rw-r--r--src/jrummikub/control/RoundControl.java24
-rw-r--r--test/jrummikub/control/RoundControlTest.java1
2 files changed, 19 insertions, 6 deletions
diff --git a/src/jrummikub/control/RoundControl.java b/src/jrummikub/control/RoundControl.java
index cce6160..1411337 100644
--- a/src/jrummikub/control/RoundControl.java
+++ b/src/jrummikub/control/RoundControl.java
@@ -1,5 +1,6 @@
package jrummikub.control;
+import java.util.HashSet;
import java.util.Set;
import jrummikub.model.IGameState;
@@ -7,7 +8,9 @@ import jrummikub.model.IHand;
import jrummikub.model.ITable;
import jrummikub.model.Position;
import jrummikub.model.Stone;
+import jrummikub.model.StoneSet;
import jrummikub.util.IListener;
+import jrummikub.util.Pair;
import jrummikub.view.IView;
public class RoundControl {
@@ -52,10 +55,8 @@ public class RoundControl {
for (int i = 0; i < gameState.getPlayerCount(); i++) {
IHand hand = gameState.getPlayer(i).getHand();
for (int j = 0; j < 7; j++) {
- hand.drop(gameState.getGameHeap().drawStone(), new Position(j,
- 0));
- hand.drop(gameState.getGameHeap().drawStone(), new Position(j,
- 1));
+ hand.drop(gameState.getGameHeap().drawStone(), new Position(j, 0));
+ hand.drop(gameState.getGameHeap().drawStone(), new Position(j, 1));
}
}
}
@@ -65,7 +66,20 @@ public class RoundControl {
}
static Set<Stone> tableDifference(ITable oldTable, ITable newTable) {
- return null;
+ Set<Stone> ret = new HashSet<Stone>();
+
+ for (Pair<StoneSet, Position> entry : newTable) {
+ for (Stone stone : entry.getFirst()) {
+ ret.add(stone);
+ }
+ }
+ for (Pair<StoneSet, Position> entry : oldTable) {
+ for (Stone stone : entry.getFirst()) {
+ ret.remove(stone);
+ }
+ }
+
+ return ret;
}
private void resetTable() {
diff --git a/test/jrummikub/control/RoundControlTest.java b/test/jrummikub/control/RoundControlTest.java
index 783eabe..6958819 100644
--- a/test/jrummikub/control/RoundControlTest.java
+++ b/test/jrummikub/control/RoundControlTest.java
@@ -227,7 +227,6 @@ public class RoundControlTest {
newTable.drop(newSet2, new Position(0, 0));
Set<Stone> expectedStones = new HashSet<Stone>();
- expectedStones.add(blueTwo);
expectedStones.add(blueThree);
expectedStones.add(blueFour);