summaryrefslogtreecommitdiff
path: root/BJC-Utils2/src/main/java/bjc/utils/gen/RandomGrammar.java
diff options
context:
space:
mode:
Diffstat (limited to 'BJC-Utils2/src/main/java/bjc/utils/gen/RandomGrammar.java')
-rw-r--r--BJC-Utils2/src/main/java/bjc/utils/gen/RandomGrammar.java69
1 files changed, 0 insertions, 69 deletions
diff --git a/BJC-Utils2/src/main/java/bjc/utils/gen/RandomGrammar.java b/BJC-Utils2/src/main/java/bjc/utils/gen/RandomGrammar.java
deleted file mode 100644
index 3de08d6..0000000
--- a/BJC-Utils2/src/main/java/bjc/utils/gen/RandomGrammar.java
+++ /dev/null
@@ -1,69 +0,0 @@
-package bjc.utils.gen;
-
-import bjc.utils.funcdata.FunctionalMap;
-import bjc.utils.funcdata.IList;
-
-/**
- * A weighted grammar where all the rules have a equal chance of occuring.
- *
- * @author ben
- *
- * @param <E>
- * The type of grammar elements to use.
- */
-public class RandomGrammar<E> extends WeightedGrammar<E> {
- /**
- * Create a new random grammar.
- */
- public RandomGrammar() {
- rules = new FunctionalMap<>();
- }
-
- /**
- * Add cases to a specified rule.
- *
- * @param rule
- * The name of the rule to add cases to.
- * @param cases
- * The cases to add for this rule.
- */
- @SafeVarargs
- public final void addCases(final E rule, final IList<E>... cases) {
- for (final IList<E> currentCase : cases) {
- super.addCase(rule, 1, currentCase);
- }
- }
-
- /**
- * Create a rule with the specified name and cases.
- *
- * @param rule
- * The name of the rule to add.
- * @param cases
- * The cases to add for this rule.
- */
- @SafeVarargs
- public final void makeRule(final E rule, final IList<E>... cases) {
- super.addRule(rule);
-
- for (final IList<E> currentCase : cases) {
- super.addCase(rule, 1, currentCase);
- }
- }
-
- /**
- * Create a rule with the specified name and cases.
- *
- * @param rule
- * The name of the rule to add.
- * @param cases
- * The cases to add for this rule.
- */
- public void makeRule(final E rule, final IList<IList<E>> cases) {
- if (cases == null) throw new NullPointerException("Cases must not be null");
-
- super.addRule(rule);
-
- cases.forEach(currentCase -> super.addCase(rule, 1, currentCase));
- }
-}