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. --- .../java/bjc/dicelang/dicev2/CompoundDieMod.java | 80 ++++++++++++++++++++++ 1 file changed, 80 insertions(+) create mode 100644 dice/src/main/java/bjc/dicelang/dicev2/CompoundDieMod.java (limited to 'dice/src/main/java/bjc/dicelang/dicev2/CompoundDieMod.java') diff --git a/dice/src/main/java/bjc/dicelang/dicev2/CompoundDieMod.java b/dice/src/main/java/bjc/dicelang/dicev2/CompoundDieMod.java new file mode 100644 index 0000000..6b752f2 --- /dev/null +++ b/dice/src/main/java/bjc/dicelang/dicev2/CompoundDieMod.java @@ -0,0 +1,80 @@ +package bjc.dicelang.dicev2; + +import bjc.utils.funcutils.ListUtils; + +import java.util.ArrayList; +import java.util.List; +import java.util.function.LongPredicate; + +public class CompoundDieMod extends Die { + public final Die[] dice; + + public final LongPredicate compound; + + public final boolean penetrate; + + public CompoundDieMod(LongPredicate compound, Die... dice) { + this(compound, false, dice); + } + + public CompoundDieMod(LongPredicate compound, boolean penetrate, Die... dice) { + super(); + + this.dice = dice; + + this.compound = compound; + + this.penetrate = penetrate; + } + + public long[] roll() { + List lst = new ArrayList<>(5); + + for(Die die : dice) { + for(long val : die.roll()) { + long res = val; + + long newVal = die.rollSingle(); + + while(compound.test(newVal)) { + if(penetrate) newVal -= 1; + + res += newVal; + + newVal = die.rollSingle(); + } + + lst.add(res); + } + } + + return ListUtils.toPrimitive(lst); + } + + public long rollSingle() { + Die die = dice[0]; + + long newVal = die.rollSingle(); + + long res = newVal; + + while(compound.test(newVal)) { + newVal = die.rollSingle(); + + if(penetrate) newVal -= 1; + + res += newVal; + } + + return res; + } + + /* :UnoptimizableDice */ + public boolean canOptimize() { + return false; + } + + public long optimize() { + throw new UnsupportedOperationException("Exploding dice can't be optimized"); + } +} -- cgit v1.2.3