1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
|
package com.ashardalon.pratt.commands.impls;
import com.ashardalon.pratt.ParserContext;
import com.ashardalon.pratt.commands.CommandResult;
import com.ashardalon.pratt.commands.InitialCommand;
import com.ashardalon.pratt.commands.CommandResult.Status;
import com.ashardalon.pratt.tokens.Token;
import bjc.data.SimpleTree;
import bjc.data.Tree;
import bjc.utils.parserutils.ParserException;
/**
* Represents a 'panfix' command, one where the operator is repeated prefix, infix and postfix.
* @author bjcul
*
* @param <K> The key type of the token
* @param <V> The value type of the token
* @param <C> The context type of the parser
*/
public final class PanfixCommand<K, V, C> implements InitialCommand<K, V, C> {
private final Token<K, V> marker;
private final K term;
private final int precedence;
/**
* Create a new panfix command.
*
* @param marker The marker token.
* @param term The value to use as the root of the result-tree
* @param precedence The precedence for this command
*/
public PanfixCommand(Token<K, V> marker, K term, int precedence) {
this.marker = marker;
this.term = term;
this.precedence = precedence;
}
@Override
public CommandResult<K, V> denote(Token<K, V> operator, ParserContext<K, V, C> ctx) throws ParserException {
CommandResult<K,V> resLeftSide = ctx.parse.parseExpression(precedence + 1, ctx.tokens, ctx.state, false);
if (resLeftSide.status != Status.SUCCESS) return resLeftSide;
Tree<Token<K, V>> leftSide = resLeftSide.success();
ctx.tokens.expect(term);
ctx.tokens.next();
CommandResult<K, V> resRightSide = ctx.parse.parseExpression(precedence + 1, ctx.tokens, ctx.state, false);
if (resLeftSide.status != Status.SUCCESS) return resRightSide;
Tree<Token<K,V>> rightSide = resRightSide.success();
ctx.tokens.expect(term);
ctx.tokens.next();
return CommandResult.success(new SimpleTree<>(marker, leftSide, rightSide));
}
}
|