TriggerKey.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.analysis.modes.modemodel;
import org.eclipse.emf.common.notify.Notification;
import org.eclipse.emf.common.notify.NotificationChain;
import org.eclipse.emf.ecore.EClass;
import org.eclipse.emf.ecore.EObject;
import org.eclipse.emf.ecore.InternalEObject;
import org.eclipse.emf.ecore.impl.ENotificationImpl;
import org.eclipse.emf.ecore.impl.MinimalEObjectImpl;
/**
* <!-- begin-user-doc -->
* A representation of the model object '<em><b>Trigger Key</b></em>'.
* <!-- end-user-doc -->
*
* <p>
* The following features are supported:
* </p>
* <ul>
* <li>{@link org.osate.analysis.modes.modemodel.TriggerKey#getTrigger <em>Trigger</em>}</li>
* </ul>
*
* @generated
*/
public abstract class TriggerKey extends MinimalEObjectImpl.Container implements EObject {
/**
* The cached value of the '{@link #getTrigger() <em>Trigger</em>}' reference.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #getTrigger()
* @generated
* @ordered
*/
protected Trigger trigger;
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public TriggerKey() {
super();
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
protected EClass eStaticClass() {
return ModemodelPackage.Literals.TRIGGER_KEY;
}
/**
* Returns the value of the '<em><b>Trigger</b></em>' reference.
* It is bidirectional and its opposite is '{@link org.osate.analysis.modes.modemodel.Trigger#getKey <em>Key</em>}'.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @return the value of the '<em>Trigger</em>' reference.
* @see #setTrigger(Trigger)
* @see org.osate.analysis.modes.modemodel.Trigger#getKey
* @generated
*/
public Trigger getTrigger() {
return trigger;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public NotificationChain basicSetTrigger(Trigger newTrigger, NotificationChain msgs) {
Trigger oldTrigger = trigger;
trigger = newTrigger;
if (eNotificationRequired()) {
ENotificationImpl notification = new ENotificationImpl(this, Notification.SET,
ModemodelPackage.TRIGGER_KEY__TRIGGER, oldTrigger, newTrigger);
if (msgs == null) {
msgs = notification;
} else {
msgs.add(notification);
}
}
return msgs;
}
/**
* Sets the value of the '{@link org.osate.analysis.modes.modemodel.TriggerKey#getTrigger <em>Trigger</em>}' reference.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @param newTrigger the new value of the '<em>Trigger</em>' reference.
* @see #getTrigger()
* @generated
*/
public void setTrigger(Trigger newTrigger) {
if (newTrigger != trigger) {
NotificationChain msgs = null;
if (trigger != null) {
msgs = trigger.eInverseRemove(this, ModemodelPackage.TRIGGER__KEY, Trigger.class, msgs);
}
if (newTrigger != null) {
msgs = newTrigger.eInverseAdd(this, ModemodelPackage.TRIGGER__KEY, Trigger.class, msgs);
}
msgs = basicSetTrigger(newTrigger, msgs);
if (msgs != null) {
msgs.dispatch();
}
} else if (eNotificationRequired()) {
eNotify(new ENotificationImpl(this, Notification.SET, ModemodelPackage.TRIGGER_KEY__TRIGGER, newTrigger,
newTrigger));
}
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public NotificationChain eInverseAdd(InternalEObject otherEnd, int featureID, NotificationChain msgs) {
switch (featureID) {
case ModemodelPackage.TRIGGER_KEY__TRIGGER:
if (trigger != null) {
msgs = trigger.eInverseRemove(this, ModemodelPackage.TRIGGER__KEY, Trigger.class, msgs);
}
return basicSetTrigger((Trigger) otherEnd, msgs);
}
return super.eInverseAdd(otherEnd, featureID, msgs);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public NotificationChain eInverseRemove(InternalEObject otherEnd, int featureID, NotificationChain msgs) {
switch (featureID) {
case ModemodelPackage.TRIGGER_KEY__TRIGGER:
return basicSetTrigger(null, msgs);
}
return super.eInverseRemove(otherEnd, featureID, msgs);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public Object eGet(int featureID, boolean resolve, boolean coreType) {
switch (featureID) {
case ModemodelPackage.TRIGGER_KEY__TRIGGER:
return getTrigger();
}
return super.eGet(featureID, resolve, coreType);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public void eSet(int featureID, Object newValue) {
switch (featureID) {
case ModemodelPackage.TRIGGER_KEY__TRIGGER:
setTrigger((Trigger) newValue);
return;
}
super.eSet(featureID, newValue);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public void eUnset(int featureID) {
switch (featureID) {
case ModemodelPackage.TRIGGER_KEY__TRIGGER:
setTrigger((Trigger) null);
return;
}
super.eUnset(featureID);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public boolean eIsSet(int featureID) {
switch (featureID) {
case ModemodelPackage.TRIGGER_KEY__TRIGGER:
return trigger != null;
}
return super.eIsSet(featureID);
}
} // TriggerKey