AbstractAadl2SyntacticSequencer.java
/**
* Copyright (c) 2004-2025 Carnegie Mellon University and others. (see Contributors file).
* All Rights Reserved.
*
* NO WARRANTY. ALL MATERIAL IS FURNISHED ON AN "AS-IS" BASIS. CARNEGIE MELLON UNIVERSITY MAKES NO WARRANTIES OF ANY
* KIND, EITHER EXPRESSED OR IMPLIED, AS TO ANY MATTER INCLUDING, BUT NOT LIMITED TO, WARRANTY OF FITNESS FOR PURPOSE
* OR MERCHANTABILITY, EXCLUSIVITY, OR RESULTS OBTAINED FROM USE OF THE MATERIAL. CARNEGIE MELLON UNIVERSITY DOES NOT
* MAKE ANY WARRANTY OF ANY KIND WITH RESPECT TO FREEDOM FROM PATENT, TRADEMARK, OR COPYRIGHT INFRINGEMENT.
*
* This program and the accompanying materials are made available under the terms of the Eclipse Public License 2.0
* which is available at https://www.eclipse.org/legal/epl-2.0/
* SPDX-License-Identifier: EPL-2.0
*
* Created, in part, with funding and support from the United States Government. (see Acknowledgments file).
*
* This program includes and/or can make use of certain third party source code, object code, documentation and other
* files ("Third Party Software"). The Third Party Software that is used by this program is dependent upon your system
* configuration. By using this program, You agree to comply with any and all relevant Third Party Software terms and
* conditions contained in any such Third Party Software or separate license file distributed with such Third Party
* Software. The parties who own the Third Party Software ("Third Party Licensors") are intended third party benefici-
* aries to this license with respect to the terms applicable to their Third Party Software. Third Party Software li-
* censes only apply to the Third Party Software and not any other portion of this program or this program as a whole.
*/
package org.osate.xtext.aadl2.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.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;
import org.osate.xtext.aadl2.services.Aadl2GrammarAccess;
@SuppressWarnings("all")
public abstract class AbstractAadl2SyntacticSequencer extends AbstractSyntacticSequencer {
protected Aadl2GrammarAccess grammarAccess;
protected AbstractElementAlias match_AadlPackage___PropertiesKeyword_3_0_NoneKeyword_3_1_1_0_SemicolonKeyword_3_1_1_1__q;
@Inject
protected void init(IGrammarAccess access) {
grammarAccess = (Aadl2GrammarAccess) access;
match_AadlPackage___PropertiesKeyword_3_0_NoneKeyword_3_1_1_0_SemicolonKeyword_3_1_1_1__q = new GroupAlias(false, true, new TokenAlias(false, false, grammarAccess.getAadlPackageAccess().getPropertiesKeyword_3_0()), new TokenAlias(false, false, grammarAccess.getAadlPackageAccess().getNoneKeyword_3_1_1_0()), new TokenAlias(false, false, grammarAccess.getAadlPackageAccess().getSemicolonKeyword_3_1_1_1()));
}
@Override
protected String getUnassignedRuleCallToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (ruleCall.getRule() == grammarAccess.getAbstractImplementationKeywordsRule())
return getAbstractImplementationKeywordsToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getAppliesToKeywordsRule())
return getAppliesToKeywordsToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getBusAccessKeywordsRule())
return getBusAccessKeywordsToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getBusImplementationKeywordsRule())
return getBusImplementationKeywordsToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getDataAccessKeywordsRule())
return getDataAccessKeywordsToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getDataImplementationKeywordsRule())
return getDataImplementationKeywordsToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getDataPortKeywordsRule())
return getDataPortKeywordsToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getDeviceImplementationKeywordsRule())
return getDeviceImplementationKeywordsToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getEndToEndFlowKeywordsRule())
return getEndToEndFlowKeywordsToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getEventDataKeywordsRule())
return getEventDataKeywordsToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getEventDataPortKeywordsRule())
return getEventDataPortKeywordsToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getEventPortKeywordsRule())
return getEventPortKeywordsToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getFULLINAMERule())
return getFULLINAMEToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getFeatureGroupKeywordsRule())
return getFeatureGroupKeywordsToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getIDRule())
return getIDToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getInBindingKeywordsRule())
return getInBindingKeywordsToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getInModesKeywordsRule())
return getInModesKeywordsToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getInternalFeaturesKeywordsRule())
return getInternalFeaturesKeywordsToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getInverseOfKeywordsRule())
return getInverseOfKeywordsToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getListOfKeywordsRule())
return getListOfKeywordsToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getMemoryImplementationKeywordsRule())
return getMemoryImplementationKeywordsToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getPNAMERule())
return getPNAMEToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getProcessImplementationKeywordsRule())
return getProcessImplementationKeywordsToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getProcessorFeaturesKeywordsRule())
return getProcessorFeaturesKeywordsToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getProcessorImplementationKeywordsRule())
return getProcessorImplementationKeywordsToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getRangeOfKeywordsRule())
return getRangeOfKeywordsToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getRefinedToKeywordsRule())
return getRefinedToKeywordsToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getRequiresModesKeywordsRule())
return getRequiresModesKeywordsToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getSTARRule())
return getSTARToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getSubprogramAccessKeywordsRule())
return getSubprogramAccessKeywordsToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getSubprogramGroupAccessKeywordsRule())
return getSubprogramGroupAccessKeywordsToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getSubprogramGroupImplementationKeywordsRule())
return getSubprogramGroupImplementationKeywordsToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getSubprogramGroupKeywordsRule())
return getSubprogramGroupKeywordsToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getSubprogramImplementationKeywordsRule())
return getSubprogramImplementationKeywordsToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getSystemImplementationKeywordsRule())
return getSystemImplementationKeywordsToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getThreadGroupImplementationKeywordsRule())
return getThreadGroupImplementationKeywordsToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getThreadGroupKeywordsRule())
return getThreadGroupKeywordsToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getThreadImplementationKeywordsRule())
return getThreadImplementationKeywordsToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getVirtualBusImplementationKeywordsRule())
return getVirtualBusImplementationKeywordsToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getVirtualBusKeywordsRule())
return getVirtualBusKeywordsToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getVirtualProcessorImplementationKeywordsRule())
return getVirtualProcessorImplementationKeywordsToken(semanticObject, ruleCall, node);
else if (ruleCall.getRule() == grammarAccess.getVirtualProcessorKeywordsRule())
return getVirtualProcessorKeywordsToken(semanticObject, ruleCall, node);
return "";
}
/**
* AbstractImplementationKeywords:
* 'abstract' 'implementation'
* ;
*/
protected String getAbstractImplementationKeywordsToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "abstract implementation";
}
/**
* AppliesToKeywords:
* 'applies' 'to'
* ;
*/
protected String getAppliesToKeywordsToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "applies to";
}
/**
* BusAccessKeywords:
* 'bus' 'access'
* ;
*/
protected String getBusAccessKeywordsToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "bus access";
}
/**
* BusImplementationKeywords:
* 'bus' 'implementation'
* ;
*/
protected String getBusImplementationKeywordsToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "bus implementation";
}
/**
* DataAccessKeywords:
* 'data' 'access'
* ;
*/
protected String getDataAccessKeywordsToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "data access";
}
/**
* DataImplementationKeywords:
* 'data' 'implementation'
* ;
*/
protected String getDataImplementationKeywordsToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "data implementation";
}
/**
* DataPortKeywords:
* 'data' 'port'
* ;
*/
protected String getDataPortKeywordsToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "data port";
}
/**
* DeviceImplementationKeywords:
* 'device' 'implementation'
* ;
*/
protected String getDeviceImplementationKeywordsToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "device implementation";
}
/**
* EndToEndFlowKeywords:
* 'end' 'to' 'end' 'flow'
* ;
*/
protected String getEndToEndFlowKeywordsToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "end to end flow";
}
/**
* EventDataKeywords:
* 'event' 'data'
* ;
*/
protected String getEventDataKeywordsToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "event data";
}
/**
* EventDataPortKeywords:
* 'event' 'data' 'port'
* ;
*/
protected String getEventDataPortKeywordsToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "event data port";
}
/**
* EventPortKeywords:
* 'event' 'port'
* ;
*/
protected String getEventPortKeywordsToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "event port";
}
/**
* FULLINAME:
* ID '.' ID;
*/
protected String getFULLINAMEToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return ".";
}
/**
* FeatureGroupKeywords:
* 'feature' 'group'
* ;
*/
protected String getFeatureGroupKeywordsToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "feature group";
}
/**
* terminal ID: ('a'..'z'
* |'A'..'Z'
* ) ( ('_')? ('a'..'z'
* |'A'..'Z'
* |'0'..'9'))*;
*/
protected String getIDToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "";
}
/**
* InBindingKeywords:
* 'in' 'binding'
* ;
*/
protected String getInBindingKeywordsToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "in binding";
}
/**
* InModesKeywords:
* 'in' 'modes'
* ;
*/
protected String getInModesKeywordsToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "in modes";
}
/**
* InternalFeaturesKeywords:
* 'internal' 'features'
* ;
*/
protected String getInternalFeaturesKeywordsToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "internal features";
}
/**
* InverseOfKeywords:
* 'inverse' 'of'
* ;
*/
protected String getInverseOfKeywordsToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "inverse of";
}
/**
* ListOfKeywords:
* 'list' 'of'
* ;
*/
protected String getListOfKeywordsToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "list of";
}
/**
* MemoryImplementationKeywords:
* 'memory' 'implementation'
* ;
*/
protected String getMemoryImplementationKeywordsToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "memory implementation";
}
/**
* PNAME:
* ID ('::' ID)*;
*/
protected String getPNAMEToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "";
}
/**
* ProcessImplementationKeywords:
* 'process' 'implementation'
* ;
*/
protected String getProcessImplementationKeywordsToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "process implementation";
}
/**
* ProcessorFeaturesKeywords:
* 'processor' 'features'
* ;
*/
protected String getProcessorFeaturesKeywordsToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "processor features";
}
/**
* ProcessorImplementationKeywords:
* 'processor' 'implementation'
* ;
*/
protected String getProcessorImplementationKeywordsToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "processor implementation";
}
/**
* RangeOfKeywords:
* 'range' 'of'
* ;
*/
protected String getRangeOfKeywordsToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "range of";
}
/**
* RefinedToKeywords:
* 'refined' 'to'
* ;
*/
protected String getRefinedToKeywordsToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "refined to";
}
/**
* RequiresModesKeywords:
* 'requires' 'modes'
* ;
*/
protected String getRequiresModesKeywordsToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "requires modes";
}
/**
* STAR : '*';
*/
protected String getSTARToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "*";
}
/**
* SubprogramAccessKeywords:
* 'subprogram' 'access'
* ;
*/
protected String getSubprogramAccessKeywordsToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "subprogram access";
}
/**
* SubprogramGroupAccessKeywords:
* 'subprogram' 'group' 'access'
* ;
*/
protected String getSubprogramGroupAccessKeywordsToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "subprogram group access";
}
/**
* SubprogramGroupImplementationKeywords:
* 'subprogram' 'group' 'implementation'
* ;
*/
protected String getSubprogramGroupImplementationKeywordsToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "subprogram group implementation";
}
/**
* SubprogramGroupKeywords:
* 'subprogram' 'group'
* ;
*/
protected String getSubprogramGroupKeywordsToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "subprogram group";
}
/**
* SubprogramImplementationKeywords:
* 'subprogram' 'implementation'
* ;
*/
protected String getSubprogramImplementationKeywordsToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "subprogram implementation";
}
/**
* SystemImplementationKeywords:
* 'system' 'implementation'
* ;
*/
protected String getSystemImplementationKeywordsToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "system implementation";
}
/**
* ThreadGroupImplementationKeywords:
* 'thread' 'group' 'implementation'
* ;
*/
protected String getThreadGroupImplementationKeywordsToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "thread group implementation";
}
/**
* ThreadGroupKeywords:
* 'thread' 'group'
* ;
*/
protected String getThreadGroupKeywordsToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "thread group";
}
/**
* ThreadImplementationKeywords:
* 'thread' 'implementation'
* ;
*/
protected String getThreadImplementationKeywordsToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "thread implementation";
}
/**
* VirtualBusImplementationKeywords:
* 'virtual' 'bus' 'implementation'
* ;
*/
protected String getVirtualBusImplementationKeywordsToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "virtual bus implementation";
}
/**
* VirtualBusKeywords:
* 'virtual' 'bus'
* ;
*/
protected String getVirtualBusKeywordsToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "virtual bus";
}
/**
* VirtualProcessorImplementationKeywords:
* 'virtual' 'processor' 'implementation'
* ;
*/
protected String getVirtualProcessorImplementationKeywordsToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "virtual processor implementation";
}
/**
* VirtualProcessorKeywords:
* 'virtual' 'processor'
* ;
*/
protected String getVirtualProcessorKeywordsToken(EObject semanticObject, RuleCall ruleCall, INode node) {
if (node != null)
return getTokenText(node);
return "virtual processor";
}
@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_AadlPackage___PropertiesKeyword_3_0_NoneKeyword_3_1_1_0_SemicolonKeyword_3_1_1_1__q.equals(syntax))
emit_AadlPackage___PropertiesKeyword_3_0_NoneKeyword_3_1_1_0_SemicolonKeyword_3_1_1_1__q(semanticObject, getLastNavigableState(), syntaxNodes);
else acceptNodes(getLastNavigableState(), syntaxNodes);
}
}
/**
* <pre>
* Ambiguous syntax:
* ('properties' 'none' ';')?
*
* This ambiguous syntax occurs at:
* ownedPrivateSection=PrivatePackageSection (ambiguity) 'end' PNAME ';' (rule end)
* ownedPublicSection=PublicPackageSection (ambiguity) 'end' PNAME ';' (rule end)
* </pre>
*/
protected void emit_AadlPackage___PropertiesKeyword_3_0_NoneKeyword_3_1_1_0_SemicolonKeyword_3_1_1_1__q(EObject semanticObject, ISynNavigable transition, List<INode> nodes) {
acceptNodes(transition, nodes);
}
}