From 775394cf6b4a3c6a7e7345affeb45bb34f6e4517 Mon Sep 17 00:00:00 2001 From: "Benjamin J. Culkin" Date: Sat, 2 Jun 2018 17:32:24 -0300 Subject: Finish die rewrite This adds all of the remaining missing die modifiers, as well as a few base die types that were missing. --- .../main/java/bjc/dicelang/dicev2/PoolDiceMod.java | 42 ++++++++++++++++++++++ 1 file changed, 42 insertions(+) create mode 100644 dice/src/main/java/bjc/dicelang/dicev2/PoolDiceMod.java (limited to 'dice/src/main/java/bjc/dicelang/dicev2/PoolDiceMod.java') diff --git a/dice/src/main/java/bjc/dicelang/dicev2/PoolDiceMod.java b/dice/src/main/java/bjc/dicelang/dicev2/PoolDiceMod.java new file mode 100644 index 0000000..8733908 --- /dev/null +++ b/dice/src/main/java/bjc/dicelang/dicev2/PoolDiceMod.java @@ -0,0 +1,42 @@ +package bjc.dicelang.dicev2; + +import bjc.utils.funcutils.ListUtils; + +import java.util.ArrayList; +import java.util.List; + +public class PoolDiceMod extends Die { + public Die[] dice; + + public PoolDiceMod(Die... dice) { + super(); + + this.dice = dice; + } + + public long[] roll() { + List lst = new ArrayList<>(dice.length); + + for(Die die : dice) { + for(long val : die.roll()) { + lst.add(val); + } + } + + return ListUtils.toPrimitive(lst); + } + + /* :NoSingleRolls */ + public long rollSingle() { + throw new UnsupportedOperationException("Pooled dice can't be rolled singly"); + } + + /* :UnoptimizableDice */ + public boolean canOptimize() { + return false; + } + + public long optimize() { + throw new UnsupportedOperationException("Pooled dice can't be optimized"); + } +} -- cgit v1.2.3