summaryrefslogtreecommitdiff
path: root/JPratt/src/main/java/bjc/pratt/commands
diff options
context:
space:
mode:
authorBen Culkin <scorpress@gmail.com>2023-10-25 19:33:51 -0400
committerBen Culkin <scorpress@gmail.com>2023-10-25 19:33:51 -0400
commitf2037af115d8459aeaed003bb7c4aa0557a040b9 (patch)
tree364333a240024b39ba6e40384ed92a3da29f9b2e /JPratt/src/main/java/bjc/pratt/commands
parentc3a5210cbcda9b5a80f37c31698e35ca6fb5a2d8 (diff)
Tweak
Diffstat (limited to 'JPratt/src/main/java/bjc/pratt/commands')
-rw-r--r--JPratt/src/main/java/bjc/pratt/commands/BranchInitialCommand.java38
-rw-r--r--JPratt/src/main/java/bjc/pratt/commands/CommandResult.java15
-rw-r--r--JPratt/src/main/java/bjc/pratt/commands/impls/InitialCommands.java29
3 files changed, 81 insertions, 1 deletions
diff --git a/JPratt/src/main/java/bjc/pratt/commands/BranchInitialCommand.java b/JPratt/src/main/java/bjc/pratt/commands/BranchInitialCommand.java
new file mode 100644
index 0000000..3f3093e
--- /dev/null
+++ b/JPratt/src/main/java/bjc/pratt/commands/BranchInitialCommand.java
@@ -0,0 +1,38 @@
+package bjc.pratt.commands;
+
+import java.util.Map;
+
+import bjc.pratt.ParserContext;
+import bjc.pratt.tokens.Token;
+import bjc.utils.parserutils.ParserException;
+
+/**
+ * Represents a initial command that has a number of 'sub-commands' in the way that Go/Git CLI does.
+ *
+ * @author bjcul
+ *
+ * @param <K> Token key type
+ * @param <V> Token value type
+ * @param <C> Parser context type
+ */
+public class BranchInitialCommand<K, V, C> implements InitialCommand<K, V, C> {
+ private Map<K, InitialCommand<K, V, C>> comMap;
+
+ /**
+ * Create a new branch initial command
+ *
+ * @param mep The map containing the commands
+ */
+ public BranchInitialCommand(Map<K, InitialCommand<K, V, C>> mep) {
+ this.comMap = mep;
+ }
+
+ @Override
+ public CommandResult<K, V> denote(Token<K, V> operator, ParserContext<K, V, C> ctx) throws ParserException {
+ Token<K, V> curToken = ctx.tokens.current();
+ ctx.tokens.expect(comMap.keySet());
+
+ return comMap.get(curToken.getKey()).denote(curToken, ctx);
+ }
+
+}
diff --git a/JPratt/src/main/java/bjc/pratt/commands/CommandResult.java b/JPratt/src/main/java/bjc/pratt/commands/CommandResult.java
index d27400f..38a55ae 100644
--- a/JPratt/src/main/java/bjc/pratt/commands/CommandResult.java
+++ b/JPratt/src/main/java/bjc/pratt/commands/CommandResult.java
@@ -94,4 +94,19 @@ public class CommandResult<K, V> {
CommandResult<K2, V2> result = new CommandResult<>(Status.BACKTRACK);
return result;
}
+
+ @Override
+ public String toString() {
+ StringBuilder builder = new StringBuilder();
+ builder.append("CommandResult [status=");
+ builder.append(status);
+ if (status == Status.SUCCESS) {
+ builder.append(", success=");
+ builder.append(success);
+ }
+ builder.append("]");
+ return builder.toString();
+ }
+
+
}
diff --git a/JPratt/src/main/java/bjc/pratt/commands/impls/InitialCommands.java b/JPratt/src/main/java/bjc/pratt/commands/impls/InitialCommands.java
index bfc4e4f..6af6954 100644
--- a/JPratt/src/main/java/bjc/pratt/commands/impls/InitialCommands.java
+++ b/JPratt/src/main/java/bjc/pratt/commands/impls/InitialCommands.java
@@ -7,9 +7,10 @@ import static bjc.pratt.blocks.ParseBlocks.trigger;
import java.util.function.UnaryOperator;
import bjc.pratt.blocks.ParseBlock;
-import bjc.pratt.commands.InitialCommand;
+import bjc.pratt.commands.*;
import bjc.pratt.tokens.Token;
import bjc.data.Tree;
+import bjc.functypes.MapBuilder;
/**
* * Contains factory methods for producing common implementations of
@@ -211,4 +212,30 @@ public class InitialCommands {
public static <K, V, C> InitialCommand<K, V, C> panfix(final int precedence, final K term, final Token<K, V> marker) {
return new PanfixCommand<>(marker, term, precedence);
}
+
+ /**
+ * Create a command that unconditionally returns a failure result.
+ *
+ * @param <K> Token key type
+ * @param <V> Token value type
+ * @param <C> Context type
+ *
+ * @return A command that unconditionally fails
+ */
+ public static <K, V, C> InitialCommand<K, V, C> fail() {
+ return (operator, ctx) -> CommandResult.fail();
+ }
+
+ /**
+ * Create a new builder for branching/sub-command style commands.
+ *
+ * @param <K> Token key type
+ * @param <V> Value key type
+ * @param <C> Context type
+ *
+ * @return A builder for branching/sub-command style commands
+ */
+ public static <K, V, C> MapBuilder<K, InitialCommand<K, V, C>, InitialCommand<K, V, C>> branch() {
+ return MapBuilder.from(BranchInitialCommand::new);
+ }
} \ No newline at end of file