/**
* Copyright (c) 2010-2014, openHAB.org and others.
*
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*/
package org.openhab.binding.tinkerforge.internal.model.impl;
import java.lang.reflect.InvocationTargetException;
import java.util.concurrent.atomic.AtomicBoolean;
import org.eclipse.emf.common.notify.Notification;
import org.eclipse.emf.common.notify.NotificationChain;
import org.eclipse.emf.common.util.EList;
import org.eclipse.emf.ecore.EClass;
import org.eclipse.emf.ecore.InternalEObject;
import org.eclipse.emf.ecore.impl.ENotificationImpl;
import org.eclipse.emf.ecore.impl.MinimalEObjectImpl;
import org.eclipse.emf.ecore.util.EcoreUtil;
import org.openhab.binding.tinkerforge.internal.LoggerConstants;
import org.openhab.binding.tinkerforge.internal.TinkerforgeErrorHandler;
import org.openhab.binding.tinkerforge.internal.model.DigitalActorIO4;
import org.openhab.binding.tinkerforge.internal.model.GenericDevice;
import org.openhab.binding.tinkerforge.internal.model.IO4Device;
import org.openhab.binding.tinkerforge.internal.model.MBaseDevice;
import org.openhab.binding.tinkerforge.internal.model.MBrickletIO4;
import org.openhab.binding.tinkerforge.internal.model.MSubDevice;
import org.openhab.binding.tinkerforge.internal.model.MSubDeviceHolder;
import org.openhab.binding.tinkerforge.internal.model.MTFConfigConsumer;
import org.openhab.binding.tinkerforge.internal.model.ModelPackage;
import org.openhab.binding.tinkerforge.internal.model.TFIOActorConfiguration;
import org.openhab.binding.tinkerforge.internal.types.HighLowValue;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import com.tinkerforge.BrickletIO4;
import com.tinkerforge.NotConnectedException;
import com.tinkerforge.TimeoutException;
/**
* <!-- begin-user-doc -->
* An implementation of the model object '<em><b>Digital Actor IO4</b></em>'.
*
* @author Theo Weiss
* @since 1.3.0
* <!-- end-user-doc -->
* <p>
* The following features are implemented:
* <ul>
* <li>{@link org.openhab.binding.tinkerforge.internal.model.impl.DigitalActorIO4Impl#getDigitalState <em>Digital State</em>}</li>
* <li>{@link org.openhab.binding.tinkerforge.internal.model.impl.DigitalActorIO4Impl#getLogger <em>Logger</em>}</li>
* <li>{@link org.openhab.binding.tinkerforge.internal.model.impl.DigitalActorIO4Impl#getUid <em>Uid</em>}</li>
* <li>{@link org.openhab.binding.tinkerforge.internal.model.impl.DigitalActorIO4Impl#isPoll <em>Poll</em>}</li>
* <li>{@link org.openhab.binding.tinkerforge.internal.model.impl.DigitalActorIO4Impl#getEnabledA <em>Enabled A</em>}</li>
* <li>{@link org.openhab.binding.tinkerforge.internal.model.impl.DigitalActorIO4Impl#getSubId <em>Sub Id</em>}</li>
* <li>{@link org.openhab.binding.tinkerforge.internal.model.impl.DigitalActorIO4Impl#getMbrick <em>Mbrick</em>}</li>
* <li>{@link org.openhab.binding.tinkerforge.internal.model.impl.DigitalActorIO4Impl#getGenericDeviceId <em>Generic Device Id</em>}</li>
* <li>{@link org.openhab.binding.tinkerforge.internal.model.impl.DigitalActorIO4Impl#getTfConfig <em>Tf Config</em>}</li>
* <li>{@link org.openhab.binding.tinkerforge.internal.model.impl.DigitalActorIO4Impl#getDeviceType <em>Device Type</em>}</li>
* <li>{@link org.openhab.binding.tinkerforge.internal.model.impl.DigitalActorIO4Impl#getPin <em>Pin</em>}</li>
* <li>{@link org.openhab.binding.tinkerforge.internal.model.impl.DigitalActorIO4Impl#getDefaultState <em>Default State</em>}</li>
* <li>{@link org.openhab.binding.tinkerforge.internal.model.impl.DigitalActorIO4Impl#isKeepOnReconnect <em>Keep On Reconnect</em>}</li>
* </ul>
* </p>
*
* @generated
*/
public class DigitalActorIO4Impl extends MinimalEObjectImpl.Container implements DigitalActorIO4
{
/**
* The default value of the '{@link #getDigitalState() <em>Digital State</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #getDigitalState()
* @generated
* @ordered
*/
protected static final HighLowValue DIGITAL_STATE_EDEFAULT = null;
/**
* The cached value of the '{@link #getDigitalState() <em>Digital State</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #getDigitalState()
* @generated
* @ordered
*/
protected HighLowValue digitalState = DIGITAL_STATE_EDEFAULT;
/**
* The default value of the '{@link #getLogger() <em>Logger</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #getLogger()
* @generated
* @ordered
*/
protected static final Logger LOGGER_EDEFAULT = null;
/**
* The cached value of the '{@link #getLogger() <em>Logger</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #getLogger()
* @generated
* @ordered
*/
protected Logger logger = LOGGER_EDEFAULT;
/**
* The default value of the '{@link #getUid() <em>Uid</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #getUid()
* @generated
* @ordered
*/
protected static final String UID_EDEFAULT = null;
/**
* The cached value of the '{@link #getUid() <em>Uid</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #getUid()
* @generated
* @ordered
*/
protected String uid = UID_EDEFAULT;
/**
* The default value of the '{@link #isPoll() <em>Poll</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #isPoll()
* @generated
* @ordered
*/
protected static final boolean POLL_EDEFAULT = true;
/**
* The cached value of the '{@link #isPoll() <em>Poll</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #isPoll()
* @generated
* @ordered
*/
protected boolean poll = POLL_EDEFAULT;
/**
* The default value of the '{@link #getEnabledA() <em>Enabled A</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #getEnabledA()
* @generated
* @ordered
*/
protected static final AtomicBoolean ENABLED_A_EDEFAULT = null;
/**
* The cached value of the '{@link #getEnabledA() <em>Enabled A</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #getEnabledA()
* @generated
* @ordered
*/
protected AtomicBoolean enabledA = ENABLED_A_EDEFAULT;
/**
* The default value of the '{@link #getSubId() <em>Sub Id</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #getSubId()
* @generated
* @ordered
*/
protected static final String SUB_ID_EDEFAULT = null;
/**
* The cached value of the '{@link #getSubId() <em>Sub Id</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #getSubId()
* @generated
* @ordered
*/
protected String subId = SUB_ID_EDEFAULT;
/**
* The default value of the '{@link #getGenericDeviceId() <em>Generic Device Id</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #getGenericDeviceId()
* @generated
* @ordered
*/
protected static final String GENERIC_DEVICE_ID_EDEFAULT = null;
/**
* The cached value of the '{@link #getGenericDeviceId() <em>Generic Device Id</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #getGenericDeviceId()
* @generated
* @ordered
*/
protected String genericDeviceId = GENERIC_DEVICE_ID_EDEFAULT;
/**
* The cached value of the '{@link #getTfConfig() <em>Tf Config</em>}' containment reference.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #getTfConfig()
* @generated
* @ordered
*/
protected TFIOActorConfiguration tfConfig;
/**
* The default value of the '{@link #getDeviceType() <em>Device Type</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #getDeviceType()
* @generated
* @ordered
*/
protected static final String DEVICE_TYPE_EDEFAULT = "io4_actuator";
/**
* The cached value of the '{@link #getDeviceType() <em>Device Type</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #getDeviceType()
* @generated
* @ordered
*/
protected String deviceType = DEVICE_TYPE_EDEFAULT;
/**
* The default value of the '{@link #getPin() <em>Pin</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #getPin()
* @generated
* @ordered
*/
protected static final int PIN_EDEFAULT = 0;
/**
* The cached value of the '{@link #getPin() <em>Pin</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #getPin()
* @generated
* @ordered
*/
protected int pin = PIN_EDEFAULT;
/**
* The default value of the '{@link #getDefaultState() <em>Default State</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #getDefaultState()
* @generated
* @ordered
*/
protected static final String DEFAULT_STATE_EDEFAULT = null;
/**
* The cached value of the '{@link #getDefaultState() <em>Default State</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #getDefaultState()
* @generated
* @ordered
*/
protected String defaultState = DEFAULT_STATE_EDEFAULT;
/**
* The default value of the '{@link #isKeepOnReconnect() <em>Keep On Reconnect</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #isKeepOnReconnect()
* @generated
* @ordered
*/
protected static final boolean KEEP_ON_RECONNECT_EDEFAULT = false;
/**
* The cached value of the '{@link #isKeepOnReconnect() <em>Keep On Reconnect</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #isKeepOnReconnect()
* @generated
* @ordered
*/
protected boolean keepOnReconnect = KEEP_ON_RECONNECT_EDEFAULT;
private int mask;
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
protected DigitalActorIO4Impl()
{
super();
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
protected EClass eStaticClass()
{
return ModelPackage.Literals.DIGITAL_ACTOR_IO4;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public HighLowValue getDigitalState()
{
return digitalState;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public void setDigitalState(HighLowValue newDigitalState)
{
HighLowValue oldDigitalState = digitalState;
digitalState = newDigitalState;
if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, ModelPackage.DIGITAL_ACTOR_IO4__DIGITAL_STATE, oldDigitalState, digitalState));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public Logger getLogger()
{
return logger;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public void setLogger(Logger newLogger)
{
Logger oldLogger = logger;
logger = newLogger;
if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, ModelPackage.DIGITAL_ACTOR_IO4__LOGGER, oldLogger, logger));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public String getUid()
{
return uid;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public void setUid(String newUid)
{
String oldUid = uid;
uid = newUid;
if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, ModelPackage.DIGITAL_ACTOR_IO4__UID, oldUid, uid));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public boolean isPoll()
{
return poll;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public void setPoll(boolean newPoll)
{
boolean oldPoll = poll;
poll = newPoll;
if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, ModelPackage.DIGITAL_ACTOR_IO4__POLL, oldPoll, poll));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public AtomicBoolean getEnabledA()
{
return enabledA;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public void setEnabledA(AtomicBoolean newEnabledA)
{
AtomicBoolean oldEnabledA = enabledA;
enabledA = newEnabledA;
if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, ModelPackage.DIGITAL_ACTOR_IO4__ENABLED_A, oldEnabledA, enabledA));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public String getSubId()
{
return subId;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public void setSubId(String newSubId)
{
String oldSubId = subId;
subId = newSubId;
if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, ModelPackage.DIGITAL_ACTOR_IO4__SUB_ID, oldSubId, subId));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public MBrickletIO4 getMbrick()
{
if (eContainerFeatureID() != ModelPackage.DIGITAL_ACTOR_IO4__MBRICK) return null;
return (MBrickletIO4)eContainer();
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public NotificationChain basicSetMbrick(MBrickletIO4 newMbrick, NotificationChain msgs)
{
msgs = eBasicSetContainer((InternalEObject)newMbrick, ModelPackage.DIGITAL_ACTOR_IO4__MBRICK, msgs);
return msgs;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public void setMbrick(MBrickletIO4 newMbrick)
{
if (newMbrick != eInternalContainer() || (eContainerFeatureID() != ModelPackage.DIGITAL_ACTOR_IO4__MBRICK && newMbrick != null))
{
if (EcoreUtil.isAncestor(this, newMbrick))
throw new IllegalArgumentException("Recursive containment not allowed for " + toString());
NotificationChain msgs = null;
if (eInternalContainer() != null)
msgs = eBasicRemoveFromContainer(msgs);
if (newMbrick != null)
msgs = ((InternalEObject)newMbrick).eInverseAdd(this, ModelPackage.MSUB_DEVICE_HOLDER__MSUBDEVICES, MSubDeviceHolder.class, msgs);
msgs = basicSetMbrick(newMbrick, msgs);
if (msgs != null) msgs.dispatch();
}
else if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, ModelPackage.DIGITAL_ACTOR_IO4__MBRICK, newMbrick, newMbrick));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public String getGenericDeviceId()
{
return genericDeviceId;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public void setGenericDeviceId(String newGenericDeviceId)
{
String oldGenericDeviceId = genericDeviceId;
genericDeviceId = newGenericDeviceId;
if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, ModelPackage.DIGITAL_ACTOR_IO4__GENERIC_DEVICE_ID, oldGenericDeviceId, genericDeviceId));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public TFIOActorConfiguration getTfConfig()
{
return tfConfig;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public NotificationChain basicSetTfConfig(TFIOActorConfiguration newTfConfig, NotificationChain msgs)
{
TFIOActorConfiguration oldTfConfig = tfConfig;
tfConfig = newTfConfig;
if (eNotificationRequired())
{
ENotificationImpl notification = new ENotificationImpl(this, Notification.SET, ModelPackage.DIGITAL_ACTOR_IO4__TF_CONFIG, oldTfConfig, newTfConfig);
if (msgs == null) msgs = notification; else msgs.add(notification);
}
return msgs;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public void setTfConfig(TFIOActorConfiguration newTfConfig)
{
if (newTfConfig != tfConfig)
{
NotificationChain msgs = null;
if (tfConfig != null)
msgs = ((InternalEObject)tfConfig).eInverseRemove(this, EOPPOSITE_FEATURE_BASE - ModelPackage.DIGITAL_ACTOR_IO4__TF_CONFIG, null, msgs);
if (newTfConfig != null)
msgs = ((InternalEObject)newTfConfig).eInverseAdd(this, EOPPOSITE_FEATURE_BASE - ModelPackage.DIGITAL_ACTOR_IO4__TF_CONFIG, null, msgs);
msgs = basicSetTfConfig(newTfConfig, msgs);
if (msgs != null) msgs.dispatch();
}
else if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, ModelPackage.DIGITAL_ACTOR_IO4__TF_CONFIG, newTfConfig, newTfConfig));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public String getDeviceType()
{
return deviceType;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public int getPin()
{
return pin;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public void setPin(int newPin)
{
int oldPin = pin;
pin = newPin;
if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, ModelPackage.DIGITAL_ACTOR_IO4__PIN, oldPin, pin));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public String getDefaultState()
{
return defaultState;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public void setDefaultState(String newDefaultState)
{
String oldDefaultState = defaultState;
defaultState = newDefaultState;
if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, ModelPackage.DIGITAL_ACTOR_IO4__DEFAULT_STATE, oldDefaultState, defaultState));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public boolean isKeepOnReconnect()
{
return keepOnReconnect;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public void setKeepOnReconnect(boolean newKeepOnReconnect)
{
boolean oldKeepOnReconnect = keepOnReconnect;
keepOnReconnect = newKeepOnReconnect;
if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, ModelPackage.DIGITAL_ACTOR_IO4__KEEP_ON_RECONNECT, oldKeepOnReconnect, keepOnReconnect));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated NOT
*/
public void turnDigital(HighLowValue digitalState) {
BrickletIO4 bricklet = getMbrick().getTinkerforgeDevice();
try {
if (digitalState == HighLowValue.HIGH) {
bricklet.setSelectedValues((short) mask, (short) mask);
} else if (digitalState == HighLowValue.LOW) {
bricklet.setSelectedValues((short) mask, (short) 0);
} else {
logger.error("{} unkown digitalState {}", LoggerConstants.TFMODELUPDATE, digitalState);
}
setDigitalState(digitalState);
} catch (TimeoutException e) {
TinkerforgeErrorHandler.handleError(this, TinkerforgeErrorHandler.TF_TIMEOUT_EXCEPTION, e);
} catch (NotConnectedException e) {
TinkerforgeErrorHandler.handleError(this,
TinkerforgeErrorHandler.TF_NOT_CONNECTION_EXCEPTION, e);
}
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated NOT
*/
public void fetchDigitalValue() {
HighLowValue pinValue = HighLowValue.UNDEF;
try {
pinValue = extractValue(getMbrick().getTinkerforgeDevice().getValue());
setDigitalState(pinValue);
} catch (TimeoutException e) {
TinkerforgeErrorHandler.handleError(this, TinkerforgeErrorHandler.TF_TIMEOUT_EXCEPTION, e);
} catch (NotConnectedException e) {
TinkerforgeErrorHandler.handleError(this,
TinkerforgeErrorHandler.TF_NOT_CONNECTION_EXCEPTION, e);
}
}
/**
*
* @generated NOT
*/
private HighLowValue extractValue(int valueMask) {
HighLowValue value = HighLowValue.UNDEF;
if ((valueMask & mask) == mask) {
value = HighLowValue.HIGH;
} else {
value = HighLowValue.LOW;
}
return value;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated NOT
*/
public void init() {
setEnabledA(new AtomicBoolean());
poll = true; // don't use the setter to prevent notification
logger = LoggerFactory.getLogger(DigitalActorIO4Impl.class);
mask = 0001 << getPin();
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated NOT
*/
public void enable() {
logger.debug("{} enable called on DigitalActorIO4", LoggerConstants.TFINIT);
if (tfConfig != null) {
if (tfConfig.eIsSet(tfConfig.eClass().getEStructuralFeature("defaultState"))) {
logger.debug("{} setDefaultState: {}", LoggerConstants.TFINIT, tfConfig.getDefaultState());
setDefaultState(tfConfig.getDefaultState());
}
if (tfConfig.eIsSet(tfConfig.eClass().getEStructuralFeature("keepOnReconnect"))) {
logger
.debug("{} keepOnReconnect: {}", LoggerConstants.TFINIT, tfConfig.isKeepOnReconnect());
setKeepOnReconnect(tfConfig.isKeepOnReconnect());
}
}
String defaultState = getDefaultState();
try {
// there seems to be no interrupt support in the upstream api
if (getMbrick().getBrickd().isReconnected() && isKeepOnReconnect()) {
logger.debug("{} reconnected: no new port configuration set for {}",
LoggerConstants.TFINIT, getSubId());
} else if (defaultState == null || defaultState.equals("keep")) {
logger.debug("{} keep: no new port configuration set", LoggerConstants.TFINIT);
} else if (defaultState.equals("true")) {
logger.debug("{} setPortconfiguration to state: true", LoggerConstants.TFINIT);
getMbrick().getTinkerforgeDevice().setConfiguration((short) mask,
BrickletIO4.DIRECTION_OUT, true);
} else if (defaultState.equals("false")) {
logger.debug("{} setPortconfiguration to state: false", LoggerConstants.TFINIT);
getMbrick().getTinkerforgeDevice().setConfiguration((short) mask,
BrickletIO4.DIRECTION_OUT, false);
}
fetchDigitalValue();
} catch (TimeoutException e) {
TinkerforgeErrorHandler.handleError(this, TinkerforgeErrorHandler.TF_TIMEOUT_EXCEPTION, e);
} catch (NotConnectedException e) {
TinkerforgeErrorHandler.handleError(this,
TinkerforgeErrorHandler.TF_NOT_CONNECTION_EXCEPTION, e);
}
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated NOT
*/
public void disable() {}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public NotificationChain eInverseAdd(InternalEObject otherEnd, int featureID, NotificationChain msgs)
{
switch (featureID)
{
case ModelPackage.DIGITAL_ACTOR_IO4__MBRICK:
if (eInternalContainer() != null)
msgs = eBasicRemoveFromContainer(msgs);
return basicSetMbrick((MBrickletIO4)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 ModelPackage.DIGITAL_ACTOR_IO4__MBRICK:
return basicSetMbrick(null, msgs);
case ModelPackage.DIGITAL_ACTOR_IO4__TF_CONFIG:
return basicSetTfConfig(null, msgs);
}
return super.eInverseRemove(otherEnd, featureID, msgs);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public NotificationChain eBasicRemoveFromContainerFeature(NotificationChain msgs)
{
switch (eContainerFeatureID())
{
case ModelPackage.DIGITAL_ACTOR_IO4__MBRICK:
return eInternalContainer().eInverseRemove(this, ModelPackage.MSUB_DEVICE_HOLDER__MSUBDEVICES, MSubDeviceHolder.class, msgs);
}
return super.eBasicRemoveFromContainerFeature(msgs);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public Object eGet(int featureID, boolean resolve, boolean coreType)
{
switch (featureID)
{
case ModelPackage.DIGITAL_ACTOR_IO4__DIGITAL_STATE:
return getDigitalState();
case ModelPackage.DIGITAL_ACTOR_IO4__LOGGER:
return getLogger();
case ModelPackage.DIGITAL_ACTOR_IO4__UID:
return getUid();
case ModelPackage.DIGITAL_ACTOR_IO4__POLL:
return isPoll();
case ModelPackage.DIGITAL_ACTOR_IO4__ENABLED_A:
return getEnabledA();
case ModelPackage.DIGITAL_ACTOR_IO4__SUB_ID:
return getSubId();
case ModelPackage.DIGITAL_ACTOR_IO4__MBRICK:
return getMbrick();
case ModelPackage.DIGITAL_ACTOR_IO4__GENERIC_DEVICE_ID:
return getGenericDeviceId();
case ModelPackage.DIGITAL_ACTOR_IO4__TF_CONFIG:
return getTfConfig();
case ModelPackage.DIGITAL_ACTOR_IO4__DEVICE_TYPE:
return getDeviceType();
case ModelPackage.DIGITAL_ACTOR_IO4__PIN:
return getPin();
case ModelPackage.DIGITAL_ACTOR_IO4__DEFAULT_STATE:
return getDefaultState();
case ModelPackage.DIGITAL_ACTOR_IO4__KEEP_ON_RECONNECT:
return isKeepOnReconnect();
}
return super.eGet(featureID, resolve, coreType);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public void eSet(int featureID, Object newValue)
{
switch (featureID)
{
case ModelPackage.DIGITAL_ACTOR_IO4__DIGITAL_STATE:
setDigitalState((HighLowValue)newValue);
return;
case ModelPackage.DIGITAL_ACTOR_IO4__LOGGER:
setLogger((Logger)newValue);
return;
case ModelPackage.DIGITAL_ACTOR_IO4__UID:
setUid((String)newValue);
return;
case ModelPackage.DIGITAL_ACTOR_IO4__POLL:
setPoll((Boolean)newValue);
return;
case ModelPackage.DIGITAL_ACTOR_IO4__ENABLED_A:
setEnabledA((AtomicBoolean)newValue);
return;
case ModelPackage.DIGITAL_ACTOR_IO4__SUB_ID:
setSubId((String)newValue);
return;
case ModelPackage.DIGITAL_ACTOR_IO4__MBRICK:
setMbrick((MBrickletIO4)newValue);
return;
case ModelPackage.DIGITAL_ACTOR_IO4__GENERIC_DEVICE_ID:
setGenericDeviceId((String)newValue);
return;
case ModelPackage.DIGITAL_ACTOR_IO4__TF_CONFIG:
setTfConfig((TFIOActorConfiguration)newValue);
return;
case ModelPackage.DIGITAL_ACTOR_IO4__PIN:
setPin((Integer)newValue);
return;
case ModelPackage.DIGITAL_ACTOR_IO4__DEFAULT_STATE:
setDefaultState((String)newValue);
return;
case ModelPackage.DIGITAL_ACTOR_IO4__KEEP_ON_RECONNECT:
setKeepOnReconnect((Boolean)newValue);
return;
}
super.eSet(featureID, newValue);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public void eUnset(int featureID)
{
switch (featureID)
{
case ModelPackage.DIGITAL_ACTOR_IO4__DIGITAL_STATE:
setDigitalState(DIGITAL_STATE_EDEFAULT);
return;
case ModelPackage.DIGITAL_ACTOR_IO4__LOGGER:
setLogger(LOGGER_EDEFAULT);
return;
case ModelPackage.DIGITAL_ACTOR_IO4__UID:
setUid(UID_EDEFAULT);
return;
case ModelPackage.DIGITAL_ACTOR_IO4__POLL:
setPoll(POLL_EDEFAULT);
return;
case ModelPackage.DIGITAL_ACTOR_IO4__ENABLED_A:
setEnabledA(ENABLED_A_EDEFAULT);
return;
case ModelPackage.DIGITAL_ACTOR_IO4__SUB_ID:
setSubId(SUB_ID_EDEFAULT);
return;
case ModelPackage.DIGITAL_ACTOR_IO4__MBRICK:
setMbrick((MBrickletIO4)null);
return;
case ModelPackage.DIGITAL_ACTOR_IO4__GENERIC_DEVICE_ID:
setGenericDeviceId(GENERIC_DEVICE_ID_EDEFAULT);
return;
case ModelPackage.DIGITAL_ACTOR_IO4__TF_CONFIG:
setTfConfig((TFIOActorConfiguration)null);
return;
case ModelPackage.DIGITAL_ACTOR_IO4__PIN:
setPin(PIN_EDEFAULT);
return;
case ModelPackage.DIGITAL_ACTOR_IO4__DEFAULT_STATE:
setDefaultState(DEFAULT_STATE_EDEFAULT);
return;
case ModelPackage.DIGITAL_ACTOR_IO4__KEEP_ON_RECONNECT:
setKeepOnReconnect(KEEP_ON_RECONNECT_EDEFAULT);
return;
}
super.eUnset(featureID);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public boolean eIsSet(int featureID)
{
switch (featureID)
{
case ModelPackage.DIGITAL_ACTOR_IO4__DIGITAL_STATE:
return DIGITAL_STATE_EDEFAULT == null ? digitalState != null : !DIGITAL_STATE_EDEFAULT.equals(digitalState);
case ModelPackage.DIGITAL_ACTOR_IO4__LOGGER:
return LOGGER_EDEFAULT == null ? logger != null : !LOGGER_EDEFAULT.equals(logger);
case ModelPackage.DIGITAL_ACTOR_IO4__UID:
return UID_EDEFAULT == null ? uid != null : !UID_EDEFAULT.equals(uid);
case ModelPackage.DIGITAL_ACTOR_IO4__POLL:
return poll != POLL_EDEFAULT;
case ModelPackage.DIGITAL_ACTOR_IO4__ENABLED_A:
return ENABLED_A_EDEFAULT == null ? enabledA != null : !ENABLED_A_EDEFAULT.equals(enabledA);
case ModelPackage.DIGITAL_ACTOR_IO4__SUB_ID:
return SUB_ID_EDEFAULT == null ? subId != null : !SUB_ID_EDEFAULT.equals(subId);
case ModelPackage.DIGITAL_ACTOR_IO4__MBRICK:
return getMbrick() != null;
case ModelPackage.DIGITAL_ACTOR_IO4__GENERIC_DEVICE_ID:
return GENERIC_DEVICE_ID_EDEFAULT == null ? genericDeviceId != null : !GENERIC_DEVICE_ID_EDEFAULT.equals(genericDeviceId);
case ModelPackage.DIGITAL_ACTOR_IO4__TF_CONFIG:
return tfConfig != null;
case ModelPackage.DIGITAL_ACTOR_IO4__DEVICE_TYPE:
return DEVICE_TYPE_EDEFAULT == null ? deviceType != null : !DEVICE_TYPE_EDEFAULT.equals(deviceType);
case ModelPackage.DIGITAL_ACTOR_IO4__PIN:
return pin != PIN_EDEFAULT;
case ModelPackage.DIGITAL_ACTOR_IO4__DEFAULT_STATE:
return DEFAULT_STATE_EDEFAULT == null ? defaultState != null : !DEFAULT_STATE_EDEFAULT.equals(defaultState);
case ModelPackage.DIGITAL_ACTOR_IO4__KEEP_ON_RECONNECT:
return keepOnReconnect != KEEP_ON_RECONNECT_EDEFAULT;
}
return super.eIsSet(featureID);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public int eBaseStructuralFeatureID(int derivedFeatureID, Class<?> baseClass)
{
if (baseClass == MBaseDevice.class)
{
switch (derivedFeatureID)
{
case ModelPackage.DIGITAL_ACTOR_IO4__LOGGER: return ModelPackage.MBASE_DEVICE__LOGGER;
case ModelPackage.DIGITAL_ACTOR_IO4__UID: return ModelPackage.MBASE_DEVICE__UID;
case ModelPackage.DIGITAL_ACTOR_IO4__POLL: return ModelPackage.MBASE_DEVICE__POLL;
case ModelPackage.DIGITAL_ACTOR_IO4__ENABLED_A: return ModelPackage.MBASE_DEVICE__ENABLED_A;
default: return -1;
}
}
if (baseClass == MSubDevice.class)
{
switch (derivedFeatureID)
{
case ModelPackage.DIGITAL_ACTOR_IO4__SUB_ID: return ModelPackage.MSUB_DEVICE__SUB_ID;
case ModelPackage.DIGITAL_ACTOR_IO4__MBRICK: return ModelPackage.MSUB_DEVICE__MBRICK;
default: return -1;
}
}
if (baseClass == GenericDevice.class)
{
switch (derivedFeatureID)
{
case ModelPackage.DIGITAL_ACTOR_IO4__GENERIC_DEVICE_ID: return ModelPackage.GENERIC_DEVICE__GENERIC_DEVICE_ID;
default: return -1;
}
}
if (baseClass == IO4Device.class)
{
switch (derivedFeatureID)
{
default: return -1;
}
}
if (baseClass == MTFConfigConsumer.class)
{
switch (derivedFeatureID)
{
case ModelPackage.DIGITAL_ACTOR_IO4__TF_CONFIG: return ModelPackage.MTF_CONFIG_CONSUMER__TF_CONFIG;
default: return -1;
}
}
return super.eBaseStructuralFeatureID(derivedFeatureID, baseClass);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public int eDerivedStructuralFeatureID(int baseFeatureID, Class<?> baseClass)
{
if (baseClass == MBaseDevice.class)
{
switch (baseFeatureID)
{
case ModelPackage.MBASE_DEVICE__LOGGER: return ModelPackage.DIGITAL_ACTOR_IO4__LOGGER;
case ModelPackage.MBASE_DEVICE__UID: return ModelPackage.DIGITAL_ACTOR_IO4__UID;
case ModelPackage.MBASE_DEVICE__POLL: return ModelPackage.DIGITAL_ACTOR_IO4__POLL;
case ModelPackage.MBASE_DEVICE__ENABLED_A: return ModelPackage.DIGITAL_ACTOR_IO4__ENABLED_A;
default: return -1;
}
}
if (baseClass == MSubDevice.class)
{
switch (baseFeatureID)
{
case ModelPackage.MSUB_DEVICE__SUB_ID: return ModelPackage.DIGITAL_ACTOR_IO4__SUB_ID;
case ModelPackage.MSUB_DEVICE__MBRICK: return ModelPackage.DIGITAL_ACTOR_IO4__MBRICK;
default: return -1;
}
}
if (baseClass == GenericDevice.class)
{
switch (baseFeatureID)
{
case ModelPackage.GENERIC_DEVICE__GENERIC_DEVICE_ID: return ModelPackage.DIGITAL_ACTOR_IO4__GENERIC_DEVICE_ID;
default: return -1;
}
}
if (baseClass == IO4Device.class)
{
switch (baseFeatureID)
{
default: return -1;
}
}
if (baseClass == MTFConfigConsumer.class)
{
switch (baseFeatureID)
{
case ModelPackage.MTF_CONFIG_CONSUMER__TF_CONFIG: return ModelPackage.DIGITAL_ACTOR_IO4__TF_CONFIG;
default: return -1;
}
}
return super.eDerivedStructuralFeatureID(baseFeatureID, baseClass);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public int eDerivedOperationID(int baseOperationID, Class<?> baseClass)
{
if (baseClass == MBaseDevice.class)
{
switch (baseOperationID)
{
case ModelPackage.MBASE_DEVICE___INIT: return ModelPackage.DIGITAL_ACTOR_IO4___INIT;
case ModelPackage.MBASE_DEVICE___ENABLE: return ModelPackage.DIGITAL_ACTOR_IO4___ENABLE;
case ModelPackage.MBASE_DEVICE___DISABLE: return ModelPackage.DIGITAL_ACTOR_IO4___DISABLE;
default: return -1;
}
}
if (baseClass == MSubDevice.class)
{
switch (baseOperationID)
{
default: return -1;
}
}
if (baseClass == GenericDevice.class)
{
switch (baseOperationID)
{
default: return -1;
}
}
if (baseClass == IO4Device.class)
{
switch (baseOperationID)
{
default: return -1;
}
}
if (baseClass == MTFConfigConsumer.class)
{
switch (baseOperationID)
{
default: return -1;
}
}
return super.eDerivedOperationID(baseOperationID, baseClass);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public Object eInvoke(int operationID, EList<?> arguments) throws InvocationTargetException
{
switch (operationID)
{
case ModelPackage.DIGITAL_ACTOR_IO4___TURN_DIGITAL__HIGHLOWVALUE:
turnDigital((HighLowValue)arguments.get(0));
return null;
case ModelPackage.DIGITAL_ACTOR_IO4___FETCH_DIGITAL_VALUE:
fetchDigitalValue();
return null;
case ModelPackage.DIGITAL_ACTOR_IO4___INIT:
init();
return null;
case ModelPackage.DIGITAL_ACTOR_IO4___ENABLE:
enable();
return null;
case ModelPackage.DIGITAL_ACTOR_IO4___DISABLE:
disable();
return null;
}
return super.eInvoke(operationID, arguments);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public String toString()
{
if (eIsProxy()) return super.toString();
StringBuffer result = new StringBuffer(super.toString());
result.append(" (digitalState: ");
result.append(digitalState);
result.append(", logger: ");
result.append(logger);
result.append(", uid: ");
result.append(uid);
result.append(", poll: ");
result.append(poll);
result.append(", enabledA: ");
result.append(enabledA);
result.append(", subId: ");
result.append(subId);
result.append(", genericDeviceId: ");
result.append(genericDeviceId);
result.append(", deviceType: ");
result.append(deviceType);
result.append(", pin: ");
result.append(pin);
result.append(", defaultState: ");
result.append(defaultState);
result.append(", keepOnReconnect: ");
result.append(keepOnReconnect);
result.append(')');
return result.toString();
}
} //DigitalActorIO4Impl