package emfviews.dsl.serializer; import com.google.inject.Inject; import emfviews.dsl.services.VpdlGrammarAccess; import java.util.List; 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.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 VpdlSyntacticSequencer extends AbstractSyntacticSequencer { protected VpdlGrammarAccess grammarAccess; protected AbstractElementAlias match_Comparison_EqualsSignKeyword_1_0_or_GreaterThanSignEqualsSignKeyword_1_2_or_GreaterThanSignKeyword_1_4_or_LessThanSignEqualsSignKeyword_1_1_or_LessThanSignGreaterThanSignKeyword_1_5_or_LessThanSignKeyword_1_3; protected AbstractElementAlias match_Condition_AndKeyword_1_0_0_or_OrKeyword_1_0_1; @Inject protected void init(IGrammarAccess access) { grammarAccess = (VpdlGrammarAccess) access; match_Comparison_EqualsSignKeyword_1_0_or_GreaterThanSignEqualsSignKeyword_1_2_or_GreaterThanSignKeyword_1_4_or_LessThanSignEqualsSignKeyword_1_1_or_LessThanSignGreaterThanSignKeyword_1_5_or_LessThanSignKeyword_1_3 = new AlternativeAlias(false, false, new TokenAlias(false, false, grammarAccess.getComparisonAccess().getEqualsSignKeyword_1_0()), new TokenAlias(false, false, grammarAccess.getComparisonAccess().getGreaterThanSignEqualsSignKeyword_1_2()), new TokenAlias(false, false, grammarAccess.getComparisonAccess().getGreaterThanSignKeyword_1_4()), new TokenAlias(false, false, grammarAccess.getComparisonAccess().getLessThanSignEqualsSignKeyword_1_1()), new TokenAlias(false, false, grammarAccess.getComparisonAccess().getLessThanSignGreaterThanSignKeyword_1_5()), new TokenAlias(false, false, grammarAccess.getComparisonAccess().getLessThanSignKeyword_1_3())); match_Condition_AndKeyword_1_0_0_or_OrKeyword_1_0_1 = new AlternativeAlias(false, false, new TokenAlias(false, false, grammarAccess.getConditionAccess().getAndKeyword_1_0_0()), new TokenAlias(false, false, grammarAccess.getConditionAccess().getOrKeyword_1_0_1())); } @Override protected String getUnassignedRuleCallToken(EObject semanticObject, RuleCall ruleCall, INode node) { return ""; } @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_Comparison_EqualsSignKeyword_1_0_or_GreaterThanSignEqualsSignKeyword_1_2_or_GreaterThanSignKeyword_1_4_or_LessThanSignEqualsSignKeyword_1_1_or_LessThanSignGreaterThanSignKeyword_1_5_or_LessThanSignKeyword_1_3.equals(syntax)) emit_Comparison_EqualsSignKeyword_1_0_or_GreaterThanSignEqualsSignKeyword_1_2_or_GreaterThanSignKeyword_1_4_or_LessThanSignEqualsSignKeyword_1_1_or_LessThanSignGreaterThanSignKeyword_1_5_or_LessThanSignKeyword_1_3(semanticObject, getLastNavigableState(), syntaxNodes); else if(match_Condition_AndKeyword_1_0_0_or_OrKeyword_1_0_1.equals(syntax)) emit_Condition_AndKeyword_1_0_0_or_OrKeyword_1_0_1(semanticObject, getLastNavigableState(), syntaxNodes); else acceptNodes(getLastNavigableState(), syntaxNodes); } } /** * Syntax: * ( '=' | '<=' | '>=' | '<' | '>' | '<>' ) */ protected void emit_Comparison_EqualsSignKeyword_1_0_or_GreaterThanSignEqualsSignKeyword_1_2_or_GreaterThanSignKeyword_1_4_or_LessThanSignEqualsSignKeyword_1_1_or_LessThanSignGreaterThanSignKeyword_1_5_or_LessThanSignKeyword_1_3(EObject semanticObject, ISynNavigable transition, List<INode> nodes) { acceptNodes(transition, nodes); } /** * Syntax: * 'and' | 'or' */ protected void emit_Condition_AndKeyword_1_0_0_or_OrKeyword_1_0_1(EObject semanticObject, ISynNavigable transition, List<INode> nodes) { acceptNodes(transition, nodes); } }