diff options
| author | Ben Culkin <scorpress@gmail.com> | 2020-10-06 19:14:55 -0400 |
|---|---|---|
| committer | Ben Culkin <scorpress@gmail.com> | 2020-10-06 19:14:55 -0400 |
| commit | a166818ea312c83489d9397165bd16aa61fe5438 (patch) | |
| tree | 8dc4741b987e45611d3929db91a4fe1ab7ad01a5 /dice/src/main/java/bjc/dicelang/dicev2/ReduceDieMod.java | |
| parent | 5a26fb2c0d899b1c80fabb39366a7b7db4d8ca41 (diff) | |
Info cleanup
Diffstat (limited to 'dice/src/main/java/bjc/dicelang/dicev2/ReduceDieMod.java')
| -rw-r--r-- | dice/src/main/java/bjc/dicelang/dicev2/ReduceDieMod.java | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/dice/src/main/java/bjc/dicelang/dicev2/ReduceDieMod.java b/dice/src/main/java/bjc/dicelang/dicev2/ReduceDieMod.java index 266e270..070c510 100644 --- a/dice/src/main/java/bjc/dicelang/dicev2/ReduceDieMod.java +++ b/dice/src/main/java/bjc/dicelang/dicev2/ReduceDieMod.java @@ -2,12 +2,35 @@ package bjc.dicelang.dicev2; import java.util.function.LongBinaryOperator; +/** + * Die pool which performs a reduction. + * + * @author Ben Culkin + * + */ public class ReduceDieMod extends Die { + /** + * The die pool. + */ public final Die[] dice; + /** + * The reduction operation. + */ public final LongBinaryOperator fold; + + /** + * The initial value for the reduction. + */ public final long initial; + /** + * Create a new reducing die pool. + * + * @param fold The reduction operation. + * @param initial The initial value for the reduction. + * @param dice The die pool. + */ public ReduceDieMod(LongBinaryOperator fold, long initial, Die... dice) { super(); @@ -17,10 +40,12 @@ public class ReduceDieMod extends Die { this.initial = initial; } + @Override public long[] roll() { return new long[] { rollSingle() }; } + @Override public long rollSingle() { long res = initial; @@ -33,6 +58,7 @@ public class ReduceDieMod extends Die { return res; } + @Override public boolean canOptimize() { for(Die die : dice) { if(!die.canOptimize()) return false; @@ -41,6 +67,7 @@ public class ReduceDieMod extends Die { return true; } + @Override public long optimize() { long res = 0; |
