From bf5f97983a7cd58e5d1147d6d6d93c2b307fe0fb Mon Sep 17 00:00:00 2001 From: bculkin2442 Date: Mon, 18 Apr 2016 17:22:36 -0400 Subject: Implemented arrays --- .../main/java/bjc/dicelang/ast/DiceASTParser.java | 73 ++++++++++++++++++++-- 1 file changed, 68 insertions(+), 5 deletions(-) (limited to 'dice-lang/src/main/java/bjc/dicelang/ast/DiceASTParser.java') diff --git a/dice-lang/src/main/java/bjc/dicelang/ast/DiceASTParser.java b/dice-lang/src/main/java/bjc/dicelang/ast/DiceASTParser.java index d8c94dc..c746c8b 100644 --- a/dice-lang/src/main/java/bjc/dicelang/ast/DiceASTParser.java +++ b/dice-lang/src/main/java/bjc/dicelang/ast/DiceASTParser.java @@ -1,6 +1,9 @@ package bjc.dicelang.ast; +import java.util.Deque; import java.util.InputMismatchException; +import java.util.function.Function; +import java.util.function.Predicate; import bjc.dicelang.IDiceExpression; import bjc.dicelang.ast.nodes.DiceLiteralNode; @@ -10,8 +13,13 @@ import bjc.dicelang.ast.nodes.ILiteralDiceNode; import bjc.dicelang.ast.nodes.IntegerLiteralNode; import bjc.dicelang.ast.nodes.OperatorDiceNode; import bjc.dicelang.ast.nodes.VariableDiceNode; +import bjc.utils.funcdata.FunctionalList; +import bjc.utils.funcdata.FunctionalMap; import bjc.utils.funcdata.IFunctionalList; +import bjc.utils.funcdata.IFunctionalMap; import bjc.utils.funcdata.ITree; +import bjc.utils.funcdata.Tree; +import bjc.utils.funcutils.StringUtils; import bjc.utils.parserutils.TreeConstructor; /** @@ -30,22 +38,77 @@ public class DiceASTParser { */ public static ITree createFromString(IFunctionalList tokens) { + Predicate specialPicker = (operator) -> { + if (StringUtils.containsOnly(operator, "\\[")) { + return true; + } else if (StringUtils.containsOnly(operator, "\\]")) { + return true; + } + + return false; + }; + + IFunctionalMap>, ITree>> operators = + new FunctionalMap<>(); + + operators.put("[", (queuedTrees) -> { + Tree openTree = new Tree<>("["); + + return openTree; + }); + + operators.put("]", (queuedTrees) -> { + return parseCloseArray(queuedTrees); + }); + ITree rawTokens = TreeConstructor.constructTree(tokens, (token) -> { return isOperatorNode(token); - }, (operator) -> false, null); - - // The last argument is valid because there are no special - // operators yet, so it'll never get called + }, specialPicker, operators::get); ITree tokenizedTree = rawTokens.rebuildTree(DiceASTParser::convertLeafNode, DiceASTParser::convertOperatorNode); - + return tokenizedTree; } + private static ITree + parseCloseArray(Deque> queuedTrees) { + IFunctionalList> children = new FunctionalList<>(); + + while (shouldContinuePopping(queuedTrees)) { + children.add(queuedTrees.pop()); + } + + queuedTrees.pop(); + + children.reverse(); + + ITree arrayTree = new Tree<>("[]", children); + + return arrayTree; + } + + private static boolean + shouldContinuePopping(Deque> queuedTrees) { + String peekToken = queuedTrees.peek().getHead(); + + return !peekToken.equals("["); + } + private static boolean isOperatorNode(String token) { + if (StringUtils.containsOnly(token, "\\[")) { + return true; + } else if (StringUtils.containsOnly(token, "\\]")) { + return true; + } + + if (token.equals("[]")) { + // This is a synthetic operator, constructed by [ and ] + return true; + } + try { OperatorDiceNode.fromString(token); return true; -- cgit v1.2.3