/** * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * See the NOTICE file distributed with this work for additional * information regarding copyright ownership. */ /* * generated by Xtext 2.10.0 */ package org.thingml.xtext.serializer; import com.google.inject.Inject; 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.TokenAlias; import org.eclipse.xtext.serializer.analysis.ISyntacticSequencerPDAProvider.ISynNavigable; import org.eclipse.xtext.serializer.analysis.ISyntacticSequencerPDAProvider.ISynTransition; import org.eclipse.xtext.serializer.sequencer.AbstractSyntacticSequencer; import org.thingml.xtext.services.ThingMLGrammarAccess; @SuppressWarnings("all") public abstract class AbstractThingMLSyntacticSequencer extends AbstractSyntacticSequencer { protected ThingMLGrammarAccess grammarAccess; protected AbstractElementAlias match_Message_SemicolonKeyword_6_q; protected AbstractElementAlias match_ObjectType_SemicolonKeyword_3_q; protected AbstractElementAlias match_Primary_LeftParenthesisKeyword_0_0_a; protected AbstractElementAlias match_Primary_LeftParenthesisKeyword_0_0_p; protected AbstractElementAlias match_PrimitiveType_SemicolonKeyword_6_q; @Inject protected void init(IGrammarAccess access) { grammarAccess = (ThingMLGrammarAccess) access; match_Message_SemicolonKeyword_6_q = new TokenAlias(false, true, grammarAccess.getMessageAccess().getSemicolonKeyword_6()); match_ObjectType_SemicolonKeyword_3_q = new TokenAlias(false, true, grammarAccess.getObjectTypeAccess().getSemicolonKeyword_3()); match_Primary_LeftParenthesisKeyword_0_0_a = new TokenAlias(true, true, grammarAccess.getPrimaryAccess().getLeftParenthesisKeyword_0_0()); match_Primary_LeftParenthesisKeyword_0_0_p = new TokenAlias(true, false, grammarAccess.getPrimaryAccess().getLeftParenthesisKeyword_0_0()); match_PrimitiveType_SemicolonKeyword_6_q = new TokenAlias(false, true, grammarAccess.getPrimitiveTypeAccess().getSemicolonKeyword_6()); } @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_Message_SemicolonKeyword_6_q.equals(syntax)) emit_Message_SemicolonKeyword_6_q(semanticObject, getLastNavigableState(), syntaxNodes); else if (match_ObjectType_SemicolonKeyword_3_q.equals(syntax)) emit_ObjectType_SemicolonKeyword_3_q(semanticObject, getLastNavigableState(), syntaxNodes); else if (match_Primary_LeftParenthesisKeyword_0_0_a.equals(syntax)) emit_Primary_LeftParenthesisKeyword_0_0_a(semanticObject, getLastNavigableState(), syntaxNodes); else if (match_Primary_LeftParenthesisKeyword_0_0_p.equals(syntax)) emit_Primary_LeftParenthesisKeyword_0_0_p(semanticObject, getLastNavigableState(), syntaxNodes); else if (match_PrimitiveType_SemicolonKeyword_6_q.equals(syntax)) emit_PrimitiveType_SemicolonKeyword_6_q(semanticObject, getLastNavigableState(), syntaxNodes); else acceptNodes(getLastNavigableState(), syntaxNodes); } } /** * Ambiguous syntax: * ';'? * * This ambiguous syntax occurs at: * annotations+=PlatformAnnotation (ambiguity) (rule end) * name=ID '(' ')' (ambiguity) (rule end) * parameters+=Parameter ')' (ambiguity) (rule end) */ protected void emit_Message_SemicolonKeyword_6_q(EObject semanticObject, ISynNavigable transition, List<INode> nodes) { acceptNodes(transition, nodes); } /** * Ambiguous syntax: * ';'? * * This ambiguous syntax occurs at: * annotations+=PlatformAnnotation (ambiguity) (rule end) * name=ID (ambiguity) (rule end) */ protected void emit_ObjectType_SemicolonKeyword_3_q(EObject semanticObject, ISynNavigable transition, List<INode> nodes) { acceptNodes(transition, nodes); } /** * Ambiguous syntax: * '('* * * This ambiguous syntax occurs at: * (rule start) (ambiguity) '-' term=Primary * (rule start) (ambiguity) 'not' term=Primary * (rule start) (ambiguity) boolValue='false' * (rule start) (ambiguity) boolValue='true' * (rule start) (ambiguity) doubleValue=FLOAT * (rule start) (ambiguity) enum=[Enumeration|ID] * (rule start) (ambiguity) expression=STRING_EXT * (rule start) (ambiguity) function=[Function|ID] * (rule start) (ambiguity) intValue=INT * (rule start) (ambiguity) property=[Variable|ID] * (rule start) (ambiguity) reference=[ReferencedElmt|ID] * (rule start) (ambiguity) stringValue=STRING_LIT * (rule start) (ambiguity) {AndExpression.lhs=} * (rule start) (ambiguity) {ArrayIndex.array=} * (rule start) (ambiguity) {DivExpression.lhs=} * (rule start) (ambiguity) {EqualsExpression.lhs=} * (rule start) (ambiguity) {GreaterExpression.lhs=} * (rule start) (ambiguity) {GreaterOrEqualExpression.lhs=} * (rule start) (ambiguity) {LowerExpression.lhs=} * (rule start) (ambiguity) {LowerOrEqualExpression.lhs=} * (rule start) (ambiguity) {MinusExpression.lhs=} * (rule start) (ambiguity) {ModExpression.lhs=} * (rule start) (ambiguity) {NotEqualsExpression.lhs=} * (rule start) (ambiguity) {OrExpression.lhs=} * (rule start) (ambiguity) {PlusExpression.lhs=} * (rule start) (ambiguity) {TimesExpression.lhs=} */ protected void emit_Primary_LeftParenthesisKeyword_0_0_a(EObject semanticObject, ISynNavigable transition, List<INode> nodes) { acceptNodes(transition, nodes); } /** * Ambiguous syntax: * '('+ * * This ambiguous syntax occurs at: * (rule start) (ambiguity) {AndExpression.lhs=} * (rule start) (ambiguity) {DivExpression.lhs=} * (rule start) (ambiguity) {EqualsExpression.lhs=} * (rule start) (ambiguity) {GreaterExpression.lhs=} * (rule start) (ambiguity) {GreaterOrEqualExpression.lhs=} * (rule start) (ambiguity) {LowerExpression.lhs=} * (rule start) (ambiguity) {LowerOrEqualExpression.lhs=} * (rule start) (ambiguity) {MinusExpression.lhs=} * (rule start) (ambiguity) {ModExpression.lhs=} * (rule start) (ambiguity) {NotEqualsExpression.lhs=} * (rule start) (ambiguity) {OrExpression.lhs=} * (rule start) (ambiguity) {PlusExpression.lhs=} * (rule start) (ambiguity) {TimesExpression.lhs=} */ protected void emit_Primary_LeftParenthesisKeyword_0_0_p(EObject semanticObject, ISynNavigable transition, List<INode> nodes) { acceptNodes(transition, nodes); } /** * Ambiguous syntax: * ';'? * * This ambiguous syntax occurs at: * ByteSize=INT '>' (ambiguity) (rule end) * annotations+=PlatformAnnotation (ambiguity) (rule end) */ protected void emit_PrimitiveType_SemicolonKeyword_6_q(EObject semanticObject, ISynNavigable transition, List<INode> nodes) { acceptNodes(transition, nodes); } }