/*
* generated by Xtext
*/
package net.certware.argument.analysis.serializer;
import com.google.inject.Inject;
import java.util.List;
import net.certware.argument.analysis.services.AnalysisDSLGrammarAccess;
import org.eclipse.emf.ecore.EObject;
import org.eclipse.xtext.IGrammarAccess;
import org.eclipse.xtext.RuleCall;
import org.eclipse.xtext.nodemodel.INode;
import org.eclipse.xtext.serializer.analysis.GrammarAlias.AbstractElementAlias;
import org.eclipse.xtext.serializer.analysis.GrammarAlias.AlternativeAlias;
import org.eclipse.xtext.serializer.analysis.GrammarAlias.GroupAlias;
import org.eclipse.xtext.serializer.analysis.GrammarAlias.TokenAlias;
import org.eclipse.xtext.serializer.analysis.ISyntacticSequencerPDAProvider.ISynNavigable;
import org.eclipse.xtext.serializer.analysis.ISyntacticSequencerPDAProvider.ISynTransition;
import org.eclipse.xtext.serializer.sequencer.AbstractSyntacticSequencer;
@SuppressWarnings("all")
public class AnalysisDSLSyntacticSequencer extends AbstractSyntacticSequencer {
protected AnalysisDSLGrammarAccess grammarAccess;
protected AbstractElementAlias match_Atom___LeftParenthesisKeyword_1_0_RightParenthesisKeyword_1_2__q;
protected AbstractElementAlias match_Output_SATISFIABLETerminalRuleCall_1_0_or_UNSATISFIABLETerminalRuleCall_1_1;
@Inject
protected void init(IGrammarAccess access) {
grammarAccess = (AnalysisDSLGrammarAccess) access;
match_Atom___LeftParenthesisKeyword_1_0_RightParenthesisKeyword_1_2__q = new GroupAlias(false, true, new TokenAlias(false, false, grammarAccess.getAtomAccess().getLeftParenthesisKeyword_1_0()), new TokenAlias(false, false, grammarAccess.getAtomAccess().getRightParenthesisKeyword_1_2()));
match_Output_SATISFIABLETerminalRuleCall_1_0_or_UNSATISFIABLETerminalRuleCall_1_1 = new AlternativeAlias(false, false, new TokenAlias(false, false, grammarAccess.getOutputAccess().getSATISFIABLETerminalRuleCall_1_0()), new TokenAlias(false, false, grammarAccess.getOutputAccess().getUNSATISFIABLETerminalRuleCall_1_1()));
}
@Override
protected String getUnassignedRuleCallToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (ruleCall.getRule() == grammarAccess.getSATISFIABLERule())
return getSATISFIABLEToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getUNSATISFIABLERule())
return getUNSATISFIABLEToken(semanticObject, ruleCall, node);
return "";
}
/**
* terminal SATISFIABLE : 'SATISFIABLE';
*/
protected String getSATISFIABLEToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "SATISFIABLE";
}
/**
* terminal UNSATISFIABLE : 'UNSATISFIABLE';
*/
protected String getUNSATISFIABLEToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "UNSATISFIABLE";
}
@Override
protected void emitUnassignedTokens(EObject semanticObject, ISynTransition transition, INode fromNode, INode toNode) {
if (transition.getAmbiguousSyntaxes().isEmpty()) return;
List<INode> transitionNodes = collectNodes(fromNode, toNode);
for (AbstractElementAlias syntax : transition.getAmbiguousSyntaxes()) {
List<INode> syntaxNodes = getNodesFor(transitionNodes, syntax);
if (match_Atom___LeftParenthesisKeyword_1_0_RightParenthesisKeyword_1_2__q.equals(syntax))
emit_Atom___LeftParenthesisKeyword_1_0_RightParenthesisKeyword_1_2__q(semanticObject, getLastNavigableState(), syntaxNodes);
else if (match_Output_SATISFIABLETerminalRuleCall_1_0_or_UNSATISFIABLETerminalRuleCall_1_1.equals(syntax))
emit_Output_SATISFIABLETerminalRuleCall_1_0_or_UNSATISFIABLETerminalRuleCall_1_1(semanticObject, getLastNavigableState(), syntaxNodes);
else acceptNodes(getLastNavigableState(), syntaxNodes);
}
}
/**
* Ambiguous syntax:
* ('(' ')')?
*
* This ambiguous syntax occurs at:
* name=PREDICATE_NAME (ambiguity) (rule end)
*/
protected void emit_Atom___LeftParenthesisKeyword_1_0_RightParenthesisKeyword_1_2__q(EObject semanticObject, ISynNavigable transition, List<INode> nodes) {
acceptNodes(transition, nodes);
}
/**
* Ambiguous syntax:
* SATISFIABLE | UNSATISFIABLE
*
* This ambiguous syntax occurs at:
* (rule start) (ambiguity) (rule start)
* lines+=Line (ambiguity) (rule end)
*/
protected void emit_Output_SATISFIABLETerminalRuleCall_1_0_or_UNSATISFIABLETerminalRuleCall_1_1(EObject semanticObject, ISynNavigable transition, List<INode> nodes) {
acceptNodes(transition, nodes);
}
}