/**
* Copyright (c) 2010-2016 by the respective copyright holders.
*
* 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.DigitalActorIO16;
import org.openhab.binding.tinkerforge.internal.model.GenericDevice;
import org.openhab.binding.tinkerforge.internal.model.IODevice;
import org.openhab.binding.tinkerforge.internal.model.MBaseDevice;
import org.openhab.binding.tinkerforge.internal.model.MBrickletIO16;
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.BrickletIO16;
import com.tinkerforge.NotConnectedException;
import com.tinkerforge.TimeoutException;
/**
* <!-- begin-user-doc -->
*
* @author Theo Weiss
* @since 1.4.0
* <!-- end-user-doc -->
* <p>
* The following features are implemented:
* </p>
* <ul>
* <li>{@link org.openhab.binding.tinkerforge.internal.model.impl.DigitalActorIO16Impl#getDigitalState
* <em>Digital State</em>}</li>
* <li>{@link org.openhab.binding.tinkerforge.internal.model.impl.DigitalActorIO16Impl#getLogger
* <em>Logger</em>}</li>
* <li>{@link org.openhab.binding.tinkerforge.internal.model.impl.DigitalActorIO16Impl#getUid <em>Uid</em>}</li>
* <li>{@link org.openhab.binding.tinkerforge.internal.model.impl.DigitalActorIO16Impl#isPoll <em>Poll</em>}</li>
* <li>{@link org.openhab.binding.tinkerforge.internal.model.impl.DigitalActorIO16Impl#getEnabledA <em>Enabled
* A</em>}</li>
* <li>{@link org.openhab.binding.tinkerforge.internal.model.impl.DigitalActorIO16Impl#getSubId <em>Sub
* Id</em>}</li>
* <li>{@link org.openhab.binding.tinkerforge.internal.model.impl.DigitalActorIO16Impl#getMbrick
* <em>Mbrick</em>}</li>
* <li>{@link org.openhab.binding.tinkerforge.internal.model.impl.DigitalActorIO16Impl#getGenericDeviceId
* <em>Generic Device Id</em>}</li>
* <li>{@link org.openhab.binding.tinkerforge.internal.model.impl.DigitalActorIO16Impl#getTfConfig <em>Tf
* Config</em>}</li>
* <li>{@link org.openhab.binding.tinkerforge.internal.model.impl.DigitalActorIO16Impl#getDeviceType <em>Device
* Type</em>}</li>
* <li>{@link org.openhab.binding.tinkerforge.internal.model.impl.DigitalActorIO16Impl#getPort
* <em>Port</em>}</li>
* <li>{@link org.openhab.binding.tinkerforge.internal.model.impl.DigitalActorIO16Impl#getPin <em>Pin</em>}</li>
* <li>{@link org.openhab.binding.tinkerforge.internal.model.impl.DigitalActorIO16Impl#getDefaultState
* <em>Default State</em>}</li>
* <li>{@link org.openhab.binding.tinkerforge.internal.model.impl.DigitalActorIO16Impl#isKeepOnReconnect <em>Keep
* On Reconnect</em>}</li>
* </ul>
*
* @generated
*/
public class DigitalActorIO16Impl extends MinimalEObjectImpl.Container implements DigitalActorIO16 {
/**
* 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 = "io_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 #getPort() <em>Port</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @see #getPort()
* @generated
* @ordered
*/
protected static final char PORT_EDEFAULT = '\u0000';
/**
* The cached value of the '{@link #getPort() <em>Port</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @see #getPort()
* @generated
* @ordered
*/
protected char port = PORT_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 DigitalActorIO16Impl() {
super();
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
protected EClass eStaticClass() {
return ModelPackage.Literals.DIGITAL_ACTOR_IO16;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public HighLowValue getDigitalState() {
return digitalState;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public void setDigitalState(HighLowValue newDigitalState) {
HighLowValue oldDigitalState = digitalState;
digitalState = newDigitalState;
if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, ModelPackage.DIGITAL_ACTOR_IO16__DIGITAL_STATE,
oldDigitalState, digitalState));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public Logger getLogger() {
return logger;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public void setLogger(Logger newLogger) {
Logger oldLogger = logger;
logger = newLogger;
if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, ModelPackage.DIGITAL_ACTOR_IO16__LOGGER, oldLogger,
logger));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public String getUid() {
return uid;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public void setUid(String newUid) {
String oldUid = uid;
uid = newUid;
if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, ModelPackage.DIGITAL_ACTOR_IO16__UID, oldUid, uid));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public boolean isPoll() {
return poll;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public void setPoll(boolean newPoll) {
boolean oldPoll = poll;
poll = newPoll;
if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, ModelPackage.DIGITAL_ACTOR_IO16__POLL, oldPoll,
poll));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public AtomicBoolean getEnabledA() {
return enabledA;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public void setEnabledA(AtomicBoolean newEnabledA) {
AtomicBoolean oldEnabledA = enabledA;
enabledA = newEnabledA;
if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, ModelPackage.DIGITAL_ACTOR_IO16__ENABLED_A,
oldEnabledA, enabledA));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public String getSubId() {
return subId;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public void setSubId(String newSubId) {
String oldSubId = subId;
subId = newSubId;
if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, ModelPackage.DIGITAL_ACTOR_IO16__SUB_ID, oldSubId,
subId));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public MBrickletIO16 getMbrick() {
if (eContainerFeatureID() != ModelPackage.DIGITAL_ACTOR_IO16__MBRICK)
return null;
return (MBrickletIO16) eContainer();
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
public MBrickletIO16 basicGetMbrick() {
if (eContainerFeatureID() != ModelPackage.DIGITAL_ACTOR_IO16__MBRICK)
return null;
return (MBrickletIO16) eInternalContainer();
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
public NotificationChain basicSetMbrick(MBrickletIO16 newMbrick, NotificationChain msgs) {
msgs = eBasicSetContainer((InternalEObject) newMbrick, ModelPackage.DIGITAL_ACTOR_IO16__MBRICK, msgs);
return msgs;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public void setMbrick(MBrickletIO16 newMbrick) {
if (newMbrick != eInternalContainer()
|| (eContainerFeatureID() != ModelPackage.DIGITAL_ACTOR_IO16__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_IO16__MBRICK, newMbrick,
newMbrick));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public String getGenericDeviceId() {
return genericDeviceId;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public void setGenericDeviceId(String newGenericDeviceId) {
String oldGenericDeviceId = genericDeviceId;
genericDeviceId = newGenericDeviceId;
if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, ModelPackage.DIGITAL_ACTOR_IO16__GENERIC_DEVICE_ID,
oldGenericDeviceId, genericDeviceId));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
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_IO16__TF_CONFIG, oldTfConfig, newTfConfig);
if (msgs == null)
msgs = notification;
else
msgs.add(notification);
}
return msgs;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
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_IO16__TF_CONFIG, null, msgs);
if (newTfConfig != null)
msgs = ((InternalEObject) newTfConfig).eInverseAdd(this,
EOPPOSITE_FEATURE_BASE - ModelPackage.DIGITAL_ACTOR_IO16__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_IO16__TF_CONFIG,
newTfConfig, newTfConfig));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public String getDeviceType() {
return deviceType;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public char getPort() {
return port;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public void setPort(char newPort) {
char oldPort = port;
port = newPort;
if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, ModelPackage.DIGITAL_ACTOR_IO16__PORT, oldPort,
port));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public int getPin() {
return pin;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public void setPin(int newPin) {
int oldPin = pin;
pin = newPin;
if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, ModelPackage.DIGITAL_ACTOR_IO16__PIN, oldPin, pin));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public String getDefaultState() {
return defaultState;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public void setDefaultState(String newDefaultState) {
String oldDefaultState = defaultState;
defaultState = newDefaultState;
if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, ModelPackage.DIGITAL_ACTOR_IO16__DEFAULT_STATE,
oldDefaultState, defaultState));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public boolean isKeepOnReconnect() {
return keepOnReconnect;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public void setKeepOnReconnect(boolean newKeepOnReconnect) {
boolean oldKeepOnReconnect = keepOnReconnect;
keepOnReconnect = newKeepOnReconnect;
if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, ModelPackage.DIGITAL_ACTOR_IO16__KEEP_ON_RECONNECT,
oldKeepOnReconnect, keepOnReconnect));
}
/**
* <!-- begin-user-doc --> <!-- end-user-doc -->
*
* @generated NOT
*/
@Override
public void turnDigital(HighLowValue digitalState) {
BrickletIO16 brickletIO16 = getMbrick().getTinkerforgeDevice();
try {
if (digitalState == HighLowValue.HIGH) {
brickletIO16.setSelectedValues(getPort(), (short) mask, (short) mask);
} else if (digitalState == HighLowValue.LOW) {
brickletIO16.setSelectedValues(getPort(), (short) mask, (short) 0);
} else {
logger.error("{} unknown 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
*/
@Override
public void fetchDigitalValue() {
HighLowValue pinValue = HighLowValue.UNDEF;
try {
pinValue = extractValue(getMbrick().getTinkerforgeDevice().getPort(getPort()));
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);
}
}
/**
* <!-- begin-user-doc --> <!-- end-user-doc -->
*
* @generated NOT
*/
@Override
public void init() {
setEnabledA(new AtomicBoolean());
poll = true; // don't use the setter to prevent notification
logger = LoggerFactory.getLogger(DigitalActorIO16Impl.class);
mask = 00000001 << getPin();
}
/**
* <!-- begin-user-doc --> <!-- end-user-doc -->
*
* @generated NOT
*/
@Override
public void enable() {
logger.debug("{} enable called on DigitalActor", 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().setPortConfiguration(getPort(), (short) mask,
BrickletIO16.DIRECTION_OUT, true);
} else if (defaultState.equals("false")) {
logger.debug("{} setPortconfiguration to state: false", LoggerConstants.TFINIT);
getMbrick().getTinkerforgeDevice().setPortConfiguration(getPort(), (short) mask,
BrickletIO16.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);
}
}
/**
*
* @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
*/
@Override
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_IO16__MBRICK:
if (eInternalContainer() != null)
msgs = eBasicRemoveFromContainer(msgs);
return basicSetMbrick((MBrickletIO16) 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_IO16__MBRICK:
return basicSetMbrick(null, msgs);
case ModelPackage.DIGITAL_ACTOR_IO16__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_IO16__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_IO16__DIGITAL_STATE:
return getDigitalState();
case ModelPackage.DIGITAL_ACTOR_IO16__LOGGER:
return getLogger();
case ModelPackage.DIGITAL_ACTOR_IO16__UID:
return getUid();
case ModelPackage.DIGITAL_ACTOR_IO16__POLL:
return isPoll();
case ModelPackage.DIGITAL_ACTOR_IO16__ENABLED_A:
return getEnabledA();
case ModelPackage.DIGITAL_ACTOR_IO16__SUB_ID:
return getSubId();
case ModelPackage.DIGITAL_ACTOR_IO16__MBRICK:
if (resolve)
return getMbrick();
return basicGetMbrick();
case ModelPackage.DIGITAL_ACTOR_IO16__GENERIC_DEVICE_ID:
return getGenericDeviceId();
case ModelPackage.DIGITAL_ACTOR_IO16__TF_CONFIG:
return getTfConfig();
case ModelPackage.DIGITAL_ACTOR_IO16__DEVICE_TYPE:
return getDeviceType();
case ModelPackage.DIGITAL_ACTOR_IO16__PORT:
return getPort();
case ModelPackage.DIGITAL_ACTOR_IO16__PIN:
return getPin();
case ModelPackage.DIGITAL_ACTOR_IO16__DEFAULT_STATE:
return getDefaultState();
case ModelPackage.DIGITAL_ACTOR_IO16__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_IO16__DIGITAL_STATE:
setDigitalState((HighLowValue) newValue);
return;
case ModelPackage.DIGITAL_ACTOR_IO16__LOGGER:
setLogger((Logger) newValue);
return;
case ModelPackage.DIGITAL_ACTOR_IO16__UID:
setUid((String) newValue);
return;
case ModelPackage.DIGITAL_ACTOR_IO16__POLL:
setPoll((Boolean) newValue);
return;
case ModelPackage.DIGITAL_ACTOR_IO16__ENABLED_A:
setEnabledA((AtomicBoolean) newValue);
return;
case ModelPackage.DIGITAL_ACTOR_IO16__SUB_ID:
setSubId((String) newValue);
return;
case ModelPackage.DIGITAL_ACTOR_IO16__MBRICK:
setMbrick((MBrickletIO16) newValue);
return;
case ModelPackage.DIGITAL_ACTOR_IO16__GENERIC_DEVICE_ID:
setGenericDeviceId((String) newValue);
return;
case ModelPackage.DIGITAL_ACTOR_IO16__TF_CONFIG:
setTfConfig((TFIOActorConfiguration) newValue);
return;
case ModelPackage.DIGITAL_ACTOR_IO16__PORT:
setPort((Character) newValue);
return;
case ModelPackage.DIGITAL_ACTOR_IO16__PIN:
setPin((Integer) newValue);
return;
case ModelPackage.DIGITAL_ACTOR_IO16__DEFAULT_STATE:
setDefaultState((String) newValue);
return;
case ModelPackage.DIGITAL_ACTOR_IO16__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_IO16__DIGITAL_STATE:
setDigitalState(DIGITAL_STATE_EDEFAULT);
return;
case ModelPackage.DIGITAL_ACTOR_IO16__LOGGER:
setLogger(LOGGER_EDEFAULT);
return;
case ModelPackage.DIGITAL_ACTOR_IO16__UID:
setUid(UID_EDEFAULT);
return;
case ModelPackage.DIGITAL_ACTOR_IO16__POLL:
setPoll(POLL_EDEFAULT);
return;
case ModelPackage.DIGITAL_ACTOR_IO16__ENABLED_A:
setEnabledA(ENABLED_A_EDEFAULT);
return;
case ModelPackage.DIGITAL_ACTOR_IO16__SUB_ID:
setSubId(SUB_ID_EDEFAULT);
return;
case ModelPackage.DIGITAL_ACTOR_IO16__MBRICK:
setMbrick((MBrickletIO16) null);
return;
case ModelPackage.DIGITAL_ACTOR_IO16__GENERIC_DEVICE_ID:
setGenericDeviceId(GENERIC_DEVICE_ID_EDEFAULT);
return;
case ModelPackage.DIGITAL_ACTOR_IO16__TF_CONFIG:
setTfConfig((TFIOActorConfiguration) null);
return;
case ModelPackage.DIGITAL_ACTOR_IO16__PORT:
setPort(PORT_EDEFAULT);
return;
case ModelPackage.DIGITAL_ACTOR_IO16__PIN:
setPin(PIN_EDEFAULT);
return;
case ModelPackage.DIGITAL_ACTOR_IO16__DEFAULT_STATE:
setDefaultState(DEFAULT_STATE_EDEFAULT);
return;
case ModelPackage.DIGITAL_ACTOR_IO16__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_IO16__DIGITAL_STATE:
return DIGITAL_STATE_EDEFAULT == null ? digitalState != null
: !DIGITAL_STATE_EDEFAULT.equals(digitalState);
case ModelPackage.DIGITAL_ACTOR_IO16__LOGGER:
return LOGGER_EDEFAULT == null ? logger != null : !LOGGER_EDEFAULT.equals(logger);
case ModelPackage.DIGITAL_ACTOR_IO16__UID:
return UID_EDEFAULT == null ? uid != null : !UID_EDEFAULT.equals(uid);
case ModelPackage.DIGITAL_ACTOR_IO16__POLL:
return poll != POLL_EDEFAULT;
case ModelPackage.DIGITAL_ACTOR_IO16__ENABLED_A:
return ENABLED_A_EDEFAULT == null ? enabledA != null : !ENABLED_A_EDEFAULT.equals(enabledA);
case ModelPackage.DIGITAL_ACTOR_IO16__SUB_ID:
return SUB_ID_EDEFAULT == null ? subId != null : !SUB_ID_EDEFAULT.equals(subId);
case ModelPackage.DIGITAL_ACTOR_IO16__MBRICK:
return basicGetMbrick() != null;
case ModelPackage.DIGITAL_ACTOR_IO16__GENERIC_DEVICE_ID:
return GENERIC_DEVICE_ID_EDEFAULT == null ? genericDeviceId != null
: !GENERIC_DEVICE_ID_EDEFAULT.equals(genericDeviceId);
case ModelPackage.DIGITAL_ACTOR_IO16__TF_CONFIG:
return tfConfig != null;
case ModelPackage.DIGITAL_ACTOR_IO16__DEVICE_TYPE:
return DEVICE_TYPE_EDEFAULT == null ? deviceType != null : !DEVICE_TYPE_EDEFAULT.equals(deviceType);
case ModelPackage.DIGITAL_ACTOR_IO16__PORT:
return port != PORT_EDEFAULT;
case ModelPackage.DIGITAL_ACTOR_IO16__PIN:
return pin != PIN_EDEFAULT;
case ModelPackage.DIGITAL_ACTOR_IO16__DEFAULT_STATE:
return DEFAULT_STATE_EDEFAULT == null ? defaultState != null
: !DEFAULT_STATE_EDEFAULT.equals(defaultState);
case ModelPackage.DIGITAL_ACTOR_IO16__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_IO16__LOGGER:
return ModelPackage.MBASE_DEVICE__LOGGER;
case ModelPackage.DIGITAL_ACTOR_IO16__UID:
return ModelPackage.MBASE_DEVICE__UID;
case ModelPackage.DIGITAL_ACTOR_IO16__POLL:
return ModelPackage.MBASE_DEVICE__POLL;
case ModelPackage.DIGITAL_ACTOR_IO16__ENABLED_A:
return ModelPackage.MBASE_DEVICE__ENABLED_A;
default:
return -1;
}
}
if (baseClass == MSubDevice.class) {
switch (derivedFeatureID) {
case ModelPackage.DIGITAL_ACTOR_IO16__SUB_ID:
return ModelPackage.MSUB_DEVICE__SUB_ID;
case ModelPackage.DIGITAL_ACTOR_IO16__MBRICK:
return ModelPackage.MSUB_DEVICE__MBRICK;
default:
return -1;
}
}
if (baseClass == GenericDevice.class) {
switch (derivedFeatureID) {
case ModelPackage.DIGITAL_ACTOR_IO16__GENERIC_DEVICE_ID:
return ModelPackage.GENERIC_DEVICE__GENERIC_DEVICE_ID;
default:
return -1;
}
}
if (baseClass == IODevice.class) {
switch (derivedFeatureID) {
default:
return -1;
}
}
if (baseClass == MTFConfigConsumer.class) {
switch (derivedFeatureID) {
case ModelPackage.DIGITAL_ACTOR_IO16__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_IO16__LOGGER;
case ModelPackage.MBASE_DEVICE__UID:
return ModelPackage.DIGITAL_ACTOR_IO16__UID;
case ModelPackage.MBASE_DEVICE__POLL:
return ModelPackage.DIGITAL_ACTOR_IO16__POLL;
case ModelPackage.MBASE_DEVICE__ENABLED_A:
return ModelPackage.DIGITAL_ACTOR_IO16__ENABLED_A;
default:
return -1;
}
}
if (baseClass == MSubDevice.class) {
switch (baseFeatureID) {
case ModelPackage.MSUB_DEVICE__SUB_ID:
return ModelPackage.DIGITAL_ACTOR_IO16__SUB_ID;
case ModelPackage.MSUB_DEVICE__MBRICK:
return ModelPackage.DIGITAL_ACTOR_IO16__MBRICK;
default:
return -1;
}
}
if (baseClass == GenericDevice.class) {
switch (baseFeatureID) {
case ModelPackage.GENERIC_DEVICE__GENERIC_DEVICE_ID:
return ModelPackage.DIGITAL_ACTOR_IO16__GENERIC_DEVICE_ID;
default:
return -1;
}
}
if (baseClass == IODevice.class) {
switch (baseFeatureID) {
default:
return -1;
}
}
if (baseClass == MTFConfigConsumer.class) {
switch (baseFeatureID) {
case ModelPackage.MTF_CONFIG_CONSUMER__TF_CONFIG:
return ModelPackage.DIGITAL_ACTOR_IO16__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_IO16___INIT;
case ModelPackage.MBASE_DEVICE___ENABLE:
return ModelPackage.DIGITAL_ACTOR_IO16___ENABLE;
case ModelPackage.MBASE_DEVICE___DISABLE:
return ModelPackage.DIGITAL_ACTOR_IO16___DISABLE;
default:
return -1;
}
}
if (baseClass == MSubDevice.class) {
switch (baseOperationID) {
default:
return -1;
}
}
if (baseClass == GenericDevice.class) {
switch (baseOperationID) {
default:
return -1;
}
}
if (baseClass == IODevice.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_IO16___TURN_DIGITAL__HIGHLOWVALUE:
turnDigital((HighLowValue) arguments.get(0));
return null;
case ModelPackage.DIGITAL_ACTOR_IO16___FETCH_DIGITAL_VALUE:
fetchDigitalValue();
return null;
case ModelPackage.DIGITAL_ACTOR_IO16___INIT:
init();
return null;
case ModelPackage.DIGITAL_ACTOR_IO16___ENABLE:
enable();
return null;
case ModelPackage.DIGITAL_ACTOR_IO16___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(", port: ");
result.append(port);
result.append(", pin: ");
result.append(pin);
result.append(", defaultState: ");
result.append(defaultState);
result.append(", keepOnReconnect: ");
result.append(keepOnReconnect);
result.append(')');
return result.toString();
}
} // DigitalActorImpl