diff options
| author | Benjamin J. Culkin <bjculkin@mix.wvu.edu> | 2018-06-05 22:09:23 -0300 |
|---|---|---|
| committer | Benjamin J. Culkin <bjculkin@mix.wvu.edu> | 2018-06-05 22:09:23 -0300 |
| commit | 05c9922b30cd0dcd2a452673c2e155215d074b19 (patch) | |
| tree | 80f2cc1cfd239761f3d74d20159f780c1673781b /src/main/java/bjc/rgens/parser/RGrammar.java | |
| parent | f25d1062a56a81b17348b799e6d4d7e1dc12a1cc (diff) | |
Templates pt. 3
Templates should now work, though there is no syntax to reference them
from rules yet
In addition, several internal things have been changed so as to improve
code quality
Diffstat (limited to 'src/main/java/bjc/rgens/parser/RGrammar.java')
| -rwxr-xr-x | src/main/java/bjc/rgens/parser/RGrammar.java | 25 |
1 files changed, 11 insertions, 14 deletions
diff --git a/src/main/java/bjc/rgens/parser/RGrammar.java b/src/main/java/bjc/rgens/parser/RGrammar.java index 5ca26a4..d523479 100755 --- a/src/main/java/bjc/rgens/parser/RGrammar.java +++ b/src/main/java/bjc/rgens/parser/RGrammar.java @@ -58,7 +58,7 @@ public class RGrammar { /* The rules of the grammar. */ public Map<String, Rule> rules; /* The rules imported from other grammars. */ - private Map<String, RGrammar> importRules; + private Map<String, Rule> importRules; /* The rules exported from this grammar. */ private Set<String> exportRules; /* The initial rule of this grammar. */ @@ -75,6 +75,10 @@ public class RGrammar { */ public RGrammar(Map<String, Rule> ruls) { rules = ruls; + + for(Rule rl : ruls.values()) { + rl.belongsTo = this; + } } /** @@ -86,7 +90,7 @@ public class RGrammar { * @param importedRules * The set of imported rules to use. */ - public void setImportedRules(Map<String, RGrammar> importedRules) { + public void setImportedRules(Map<String, Rule> importedRules) { importRules = importedRules; } @@ -131,7 +135,7 @@ public class RGrammar { * @return A possible string from the grammar. */ public String generate(String startRule, Random rnd, Map<String, String> vars, - Map<String, IPair<RGrammar, Rule>> rlVars) { + Map<String, Rule> rlVars) { return generate(startRule, new GenerationState(new StringBuilder(), rnd, vars, rlVars, this)); } @@ -164,20 +168,13 @@ public class RGrammar { * We don't search imports, so it will always belong to this * grammar. */ - Rule rl = state.findRule(fromRule, false).getRight(); + Rule rl = state.findRule(fromRule, false); + if(rl == null) throw new GrammarException("Could not find rule " + rl.name); - if(rl.doRecur()) { - RuleCase start = rl.getCase(state.rnd); - System.err.printf("\tFINE: Generating %s (from %s in %s)\n", start, fromRule, name); + rl.generate(state); - generateCase(start, state); - - rl.endRecur(); - } else { - throw new RecurLimitException("Rule recurrence limit exceeded"); - } /* * @NOTE * @@ -326,7 +323,7 @@ public class RGrammar { return rules; } - public Map<String, RGrammar> getImportRules() { + public Map<String, Rule> getImportRules() { return importRules; } } |
