From c8ae1ec096f5d1ac6db4f3a0035f7da106444e4e Mon Sep 17 00:00:00 2001 From: bculkin2442 Date: Sun, 3 Apr 2016 17:45:05 -0400 Subject: General code refactoring and maintenance --- .../bjc/dicelang/ast/DiceASTReferenceChecker.java | 63 ++++++++++++++++++++++ 1 file changed, 63 insertions(+) create mode 100644 dice-lang/src/main/java/bjc/dicelang/ast/DiceASTReferenceChecker.java (limited to 'dice-lang/src/main/java/bjc/dicelang/ast/DiceASTReferenceChecker.java') diff --git a/dice-lang/src/main/java/bjc/dicelang/ast/DiceASTReferenceChecker.java b/dice-lang/src/main/java/bjc/dicelang/ast/DiceASTReferenceChecker.java new file mode 100644 index 0000000..aaabe8b --- /dev/null +++ b/dice-lang/src/main/java/bjc/dicelang/ast/DiceASTReferenceChecker.java @@ -0,0 +1,63 @@ +package bjc.dicelang.ast; + +import java.util.function.Consumer; + +import bjc.utils.data.GenHolder; + +/** + * Check if the specified node references a particular variable + * + * @author ben + * + */ +public final class DiceASTReferenceChecker + implements Consumer { + /** + * This is true if the specified node references the set variable + */ + private GenHolder referencesVariable; + + private String varName; + + /** + * Create a new reference checker + * + * @param referencesVar + * The holder of whether the variable is referenced or + * not + * @param varName + * The variable to check for references in + */ + public DiceASTReferenceChecker(GenHolder referencesVar, + String varName) { + this.referencesVariable = referencesVar; + this.varName = varName; + } + + @Override + public void accept(IDiceASTNode astNode) { + if (!referencesVariable.unwrap(bool -> bool)) { + if (isDirectReferenceToLast(astNode)) { + referencesVariable.transform((bool) -> false); + } + } + } + + /** + * Check if a given AST node directly references the meta-variable + * last + * + * @param astNode + * The node to check + * @return Whether or not the node directly references last + */ + private boolean isDirectReferenceToLast(IDiceASTNode astNode) { + if (astNode.getType() == DiceASTType.VARIABLE) { + VariableDiceNode node = (VariableDiceNode) astNode; + + return node.getVariable().equals(varName); + } else { + return false; + } + } +} \ No newline at end of file -- cgit v1.2.3