summaryrefslogtreecommitdiffstats
path: root/core/src/ch/asynk/rustanddust/engine
diff options
context:
space:
mode:
authorJérémy Zurcher <jeremy@asynk.ch>2016-01-11 15:59:06 +0100
committerJérémy Zurcher <jeremy@asynk.ch>2016-01-11 15:59:06 +0100
commitf4b9af0c311bce96ee7b71000b3aa8ab9a2ab556 (patch)
treeaf808f802894e9e746bd17eb17b872d652adabe9 /core/src/ch/asynk/rustanddust/engine
parentb2ba5d9fd27a562f5096e6c5eeacc81752376d73 (diff)
downloadRustAndDust-f4b9af0c311bce96ee7b71000b3aa8ab9a2ab556.zip
RustAndDust-f4b9af0c311bce96ee7b71000b3aa8ab9a2ab556.tar.gz
IterableArray does not extends ArrayList but has it's own implementation
Diffstat (limited to 'core/src/ch/asynk/rustanddust/engine')
-rw-r--r--core/src/ch/asynk/rustanddust/engine/PathBuilder.java19
-rw-r--r--core/src/ch/asynk/rustanddust/engine/util/Collection.java12
-rw-r--r--core/src/ch/asynk/rustanddust/engine/util/IterableArray.java117
3 files changed, 120 insertions, 28 deletions
diff --git a/core/src/ch/asynk/rustanddust/engine/PathBuilder.java b/core/src/ch/asynk/rustanddust/engine/PathBuilder.java
index ecc7634..a663d6a 100644
--- a/core/src/ch/asynk/rustanddust/engine/PathBuilder.java
+++ b/core/src/ch/asynk/rustanddust/engine/PathBuilder.java
@@ -1,9 +1,8 @@
package ch.asynk.rustanddust.engine;
-import java.util.List;
-
import com.badlogic.gdx.utils.Disposable;
+import ch.asynk.rustanddust.engine.util.Collection;
import ch.asynk.rustanddust.engine.util.IterableArray;
import ch.asynk.rustanddust.engine.util.IterableStack;
import ch.asynk.rustanddust.engine.util.IterableSet;
@@ -18,9 +17,9 @@ public class PathBuilder implements Disposable
public int distance;
public Orientation orientation;
private IterableStack<Tile> stack;
- private List<Tile> ctrlTiles;
- private List<Path> paths;
- private List<Path> filteredPaths;
+ private Collection<Tile> ctrlTiles;
+ private Collection<Path> paths;
+ private Collection<Path> filteredPaths;
private IterableSet<Tile> tiles;
public PathBuilder(Board board, int tSize, int stSize, int ftSize, int psSize)
@@ -121,7 +120,7 @@ public class PathBuilder implements Disposable
public int chooseBest()
{
- List<Path> ps = getPaths();
+ Collection<Path> ps = getPaths();
if (ps.size() > 1) {
Path good = null;
@@ -135,7 +134,7 @@ public class PathBuilder implements Disposable
public int chooseShortest()
{
- List<Path> ps = getPaths();
+ Collection<Path> ps = getPaths();
if (ps.size() > 1) {
Path good = ps.get(0);
@@ -151,7 +150,7 @@ public class PathBuilder implements Disposable
public int chooseExit(Orientation o)
{
- List<Path> ps = getPaths();
+ Collection<Path> ps = getPaths();
Path good = ps.get(0);
int mvt = pawn.getMovementPoints();
@@ -318,7 +317,7 @@ public class PathBuilder implements Disposable
return false;
}
- private List<Path> getPaths()
+ private Collection<Path> getPaths()
{
if (ctrlTiles.size() == 0)
return paths;
@@ -332,7 +331,7 @@ public class PathBuilder implements Disposable
return filteredPaths.get(i);
}
- private void printToErr(String what, List<Path> paths)
+ private void printToErr(String what, Collection<Path> paths)
{
System.err.println(what + " " + paths.size() + " - " + from + " -> " + to);
for (Path path : paths) {
diff --git a/core/src/ch/asynk/rustanddust/engine/util/Collection.java b/core/src/ch/asynk/rustanddust/engine/util/Collection.java
index c768d45..a7b5a02 100644
--- a/core/src/ch/asynk/rustanddust/engine/util/Collection.java
+++ b/core/src/ch/asynk/rustanddust/engine/util/Collection.java
@@ -4,15 +4,21 @@ import java.util.Iterator;
public interface Collection<E> extends Iterator, Iterable<E>
{
- public void clear();
-
public int size();
public boolean isEmpty();
+ public void clear();
+
+ public void ensureCapacity(int c);
+
+ public boolean contains(E e);
+
public E get(int idx);
public boolean add(E e);
- // public boolean contains(E e);
+ public E remove(int idx);
+
+ public boolean remove(E e);
}
diff --git a/core/src/ch/asynk/rustanddust/engine/util/IterableArray.java b/core/src/ch/asynk/rustanddust/engine/util/IterableArray.java
index baa58d9..1b965fc 100644
--- a/core/src/ch/asynk/rustanddust/engine/util/IterableArray.java
+++ b/core/src/ch/asynk/rustanddust/engine/util/IterableArray.java
@@ -1,51 +1,138 @@
package ch.asynk.rustanddust.engine.util;
-import java.util.ArrayList;
+import java.util.Arrays;
import java.util.Iterator;
-public class IterableArray<E> extends ArrayList<E> implements Collection<E>
+public class IterableArray<E> implements Collection<E>
{
- private int i;
+ private int idx;
private int s;
+ private int c;
+ transient E[] data;
- public IterableArray()
+ @SuppressWarnings("unchecked")
+ public IterableArray(int capacity)
+ {
+ this.s = 0;
+ this.c = capacity;
+ this.data = (E[]) new Object[c];
+ }
+
+ @Override
+ public int size()
+ {
+ return s;
+ }
+
+ @Override
+ public boolean isEmpty()
+ {
+ return (s == 0);
+ }
+
+ @Override
+ public void clear()
+ {
+ for (int i = 0; i < s; i++)
+ data[i] = null;
+ s = 0;
+ }
+
+ @Override
+ public void ensureCapacity(int min)
+ {
+ if (c > min) return;
+ c += (c >> 1);
+ if (c < min)
+ c = min;
+ data = Arrays.copyOf(data, c);
+ }
+
+ @Override
+ public boolean contains(E e)
+ {
+ if (e == null) {
+ for (int i = 0; i < s; i++) {
+ if (data[i] == null)
+ return true;
+ }
+ } else {
+ for (int i = 0; i < s; i++) {
+ if (e.equals(data[i]))
+ return true;
+ }
+ }
+ return false;
+ }
+
+ @Override
+ public E get(int i)
+ {
+ return data[i];
+ }
+
+ @Override
+ public boolean add(E e)
{
- super();
+ ensureCapacity(s + 1);
+ data[s] = e;
+ s += 1;
+ return true;
}
- public IterableArray(int n)
+ @Override
+ public E remove(int i)
+ {
+ E e = data[i];
+ int m = (s - i - 1);
+ if (m > 0)
+ System.arraycopy(data, i+1, data, i, m);
+ data[--s] = null;
+
+ return e;
+ }
+
+ @Override
+ public boolean remove(E e)
{
- super(n);
+ for (int i = 0; i < s; i++) {
+ if (e.equals(data[i])) {
+ int m = (s - i - 1);
+ if (m > 0)
+ System.arraycopy(data, i+1, data, i, m);
+ data[--s] = null;
+ return true;
+ }
+ }
+ return false;
}
@Override
@SuppressWarnings("unchecked")
public Iterator<E> iterator()
{
- this.i = 0;
- this.s = size();
+ this.idx = 0;
return (Iterator<E>) this;
}
@Override
public boolean hasNext()
{
- return (i < s);
+ return (idx < s);
}
@Override
public E next()
{
- E e = get(i);
- i += 1;
+ E e = get(idx);
+ idx += 1;
return e;
}
@Override
public void remove()
{
- i -=1;
- s -= 1;
- remove(i);
+ idx -= 1;
+ remove(idx);
}
}