/**
* 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.TinkerforgeErrorHandler;
import org.openhab.binding.tinkerforge.internal.config.DeviceOptions;
import org.openhab.binding.tinkerforge.internal.model.MBrickd;
import org.openhab.binding.tinkerforge.internal.model.MBrickletPiezoSpeaker;
import org.openhab.binding.tinkerforge.internal.model.ModelPackage;
import org.openhab.binding.tinkerforge.internal.model.ProgrammableSwitchActor;
import org.openhab.binding.tinkerforge.internal.model.SwitchSensor;
import org.openhab.binding.tinkerforge.internal.tools.Tools;
import org.openhab.binding.tinkerforge.internal.types.OnOffValue;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import com.tinkerforge.BrickletPiezoSpeaker;
import com.tinkerforge.IPConnection;
import com.tinkerforge.NotConnectedException;
import com.tinkerforge.TimeoutException;
/**
* <!-- begin-user-doc -->
* An implementation of the model object '<em><b>MBricklet Piezo Speaker</b></em>'.
* <!-- end-user-doc -->
* <p>
* The following features are implemented:
* </p>
* <ul>
* <li>{@link org.openhab.binding.tinkerforge.internal.model.impl.MBrickletPiezoSpeakerImpl#getLogger <em>Logger</em>}
* </li>
* <li>{@link org.openhab.binding.tinkerforge.internal.model.impl.MBrickletPiezoSpeakerImpl#getUid <em>Uid</em>}</li>
* <li>{@link org.openhab.binding.tinkerforge.internal.model.impl.MBrickletPiezoSpeakerImpl#isPoll <em>Poll</em>}</li>
* <li>{@link org.openhab.binding.tinkerforge.internal.model.impl.MBrickletPiezoSpeakerImpl#getEnabledA <em>Enabled
* A</em>}</li>
* <li>{@link org.openhab.binding.tinkerforge.internal.model.impl.MBrickletPiezoSpeakerImpl#getTinkerforgeDevice
* <em>Tinkerforge Device</em>}</li>
* <li>{@link org.openhab.binding.tinkerforge.internal.model.impl.MBrickletPiezoSpeakerImpl#getIpConnection <em>Ip
* Connection</em>}</li>
* <li>{@link org.openhab.binding.tinkerforge.internal.model.impl.MBrickletPiezoSpeakerImpl#getConnectedUid
* <em>Connected Uid</em>}</li>
* <li>{@link org.openhab.binding.tinkerforge.internal.model.impl.MBrickletPiezoSpeakerImpl#getPosition
* <em>Position</em>}</li>
* <li>{@link org.openhab.binding.tinkerforge.internal.model.impl.MBrickletPiezoSpeakerImpl#getDeviceIdentifier
* <em>Device Identifier</em>}</li>
* <li>{@link org.openhab.binding.tinkerforge.internal.model.impl.MBrickletPiezoSpeakerImpl#getName <em>Name</em>}</li>
* <li>{@link org.openhab.binding.tinkerforge.internal.model.impl.MBrickletPiezoSpeakerImpl#getBrickd <em>Brickd</em>}
* </li>
* <li>{@link org.openhab.binding.tinkerforge.internal.model.impl.MBrickletPiezoSpeakerImpl#getSwitchState <em>Switch
* State</em>}</li>
* <li>{@link org.openhab.binding.tinkerforge.internal.model.impl.MBrickletPiezoSpeakerImpl#getDeviceType <em>Device
* Type</em>}</li>
* </ul>
*
* @generated
*/
public class MBrickletPiezoSpeakerImpl extends MinimalEObjectImpl.Container implements MBrickletPiezoSpeaker {
private static final String MORSE = "morse";
private static final String BEEP = "beep";
private static final String MODE = "mode";
/**
* 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 cached value of the '{@link #getTinkerforgeDevice() <em>Tinkerforge Device</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @see #getTinkerforgeDevice()
* @generated
* @ordered
*/
protected BrickletPiezoSpeaker tinkerforgeDevice;
/**
* The default value of the '{@link #getIpConnection() <em>Ip Connection</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @see #getIpConnection()
* @generated
* @ordered
*/
protected static final IPConnection IP_CONNECTION_EDEFAULT = null;
/**
* The cached value of the '{@link #getIpConnection() <em>Ip Connection</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @see #getIpConnection()
* @generated
* @ordered
*/
protected IPConnection ipConnection = IP_CONNECTION_EDEFAULT;
/**
* The default value of the '{@link #getConnectedUid() <em>Connected Uid</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @see #getConnectedUid()
* @generated
* @ordered
*/
protected static final String CONNECTED_UID_EDEFAULT = null;
/**
* The cached value of the '{@link #getConnectedUid() <em>Connected Uid</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @see #getConnectedUid()
* @generated
* @ordered
*/
protected String connectedUid = CONNECTED_UID_EDEFAULT;
/**
* The default value of the '{@link #getPosition() <em>Position</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @see #getPosition()
* @generated
* @ordered
*/
protected static final char POSITION_EDEFAULT = '\u0000';
/**
* The cached value of the '{@link #getPosition() <em>Position</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @see #getPosition()
* @generated
* @ordered
*/
protected char position = POSITION_EDEFAULT;
/**
* The default value of the '{@link #getDeviceIdentifier() <em>Device Identifier</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @see #getDeviceIdentifier()
* @generated
* @ordered
*/
protected static final int DEVICE_IDENTIFIER_EDEFAULT = 0;
/**
* The cached value of the '{@link #getDeviceIdentifier() <em>Device Identifier</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @see #getDeviceIdentifier()
* @generated
* @ordered
*/
protected int deviceIdentifier = DEVICE_IDENTIFIER_EDEFAULT;
/**
* The default value of the '{@link #getName() <em>Name</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @see #getName()
* @generated
* @ordered
*/
protected static final String NAME_EDEFAULT = null;
/**
* The cached value of the '{@link #getName() <em>Name</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @see #getName()
* @generated
* @ordered
*/
protected String name = NAME_EDEFAULT;
/**
* The default value of the '{@link #getSwitchState() <em>Switch State</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @see #getSwitchState()
* @generated
* @ordered
*/
protected static final OnOffValue SWITCH_STATE_EDEFAULT = null;
/**
* The cached value of the '{@link #getSwitchState() <em>Switch State</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @see #getSwitchState()
* @generated
* @ordered
*/
protected OnOffValue switchState = SWITCH_STATE_EDEFAULT;
/**
* 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 = "bricklet_piezo_speaker";
private static final String DURATIONS = "durations";
private static final String FREQUENCIES = "frequencies";
private static final String REPEAT = "repeat";
private static final String MORSECODES = "morsecodes";
/**
* 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;
private BeepFinishedListener beepFinishedListener;
private MorseFinishedListener morseFinishedListener;
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
protected MBrickletPiezoSpeakerImpl() {
super();
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
protected EClass eStaticClass() {
return ModelPackage.Literals.MBRICKLET_PIEZO_SPEAKER;
}
/**
* <!-- 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.MBRICKLET_PIEZO_SPEAKER__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.MBRICKLET_PIEZO_SPEAKER__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.MBRICKLET_PIEZO_SPEAKER__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.MBRICKLET_PIEZO_SPEAKER__ENABLED_A,
oldEnabledA, enabledA));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public BrickletPiezoSpeaker getTinkerforgeDevice() {
return tinkerforgeDevice;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public void setTinkerforgeDevice(BrickletPiezoSpeaker newTinkerforgeDevice) {
BrickletPiezoSpeaker oldTinkerforgeDevice = tinkerforgeDevice;
tinkerforgeDevice = newTinkerforgeDevice;
if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET,
ModelPackage.MBRICKLET_PIEZO_SPEAKER__TINKERFORGE_DEVICE, oldTinkerforgeDevice, tinkerforgeDevice));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public IPConnection getIpConnection() {
return ipConnection;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public void setIpConnection(IPConnection newIpConnection) {
IPConnection oldIpConnection = ipConnection;
ipConnection = newIpConnection;
if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, ModelPackage.MBRICKLET_PIEZO_SPEAKER__IP_CONNECTION,
oldIpConnection, ipConnection));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public String getConnectedUid() {
return connectedUid;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public void setConnectedUid(String newConnectedUid) {
String oldConnectedUid = connectedUid;
connectedUid = newConnectedUid;
if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, ModelPackage.MBRICKLET_PIEZO_SPEAKER__CONNECTED_UID,
oldConnectedUid, connectedUid));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public char getPosition() {
return position;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public void setPosition(char newPosition) {
char oldPosition = position;
position = newPosition;
if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, ModelPackage.MBRICKLET_PIEZO_SPEAKER__POSITION,
oldPosition, position));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public int getDeviceIdentifier() {
return deviceIdentifier;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public void setDeviceIdentifier(int newDeviceIdentifier) {
int oldDeviceIdentifier = deviceIdentifier;
deviceIdentifier = newDeviceIdentifier;
if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET,
ModelPackage.MBRICKLET_PIEZO_SPEAKER__DEVICE_IDENTIFIER, oldDeviceIdentifier, deviceIdentifier));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public String getName() {
return name;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public void setName(String newName) {
String oldName = name;
name = newName;
if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, ModelPackage.MBRICKLET_PIEZO_SPEAKER__NAME, oldName,
name));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public MBrickd getBrickd() {
if (eContainerFeatureID() != ModelPackage.MBRICKLET_PIEZO_SPEAKER__BRICKD)
return null;
return (MBrickd) eContainer();
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
public MBrickd basicGetBrickd() {
if (eContainerFeatureID() != ModelPackage.MBRICKLET_PIEZO_SPEAKER__BRICKD)
return null;
return (MBrickd) eInternalContainer();
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
public NotificationChain basicSetBrickd(MBrickd newBrickd, NotificationChain msgs) {
msgs = eBasicSetContainer((InternalEObject) newBrickd, ModelPackage.MBRICKLET_PIEZO_SPEAKER__BRICKD, msgs);
return msgs;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public void setBrickd(MBrickd newBrickd) {
if (newBrickd != eInternalContainer()
|| (eContainerFeatureID() != ModelPackage.MBRICKLET_PIEZO_SPEAKER__BRICKD && newBrickd != null)) {
if (EcoreUtil.isAncestor(this, newBrickd))
throw new IllegalArgumentException("Recursive containment not allowed for " + toString());
NotificationChain msgs = null;
if (eInternalContainer() != null)
msgs = eBasicRemoveFromContainer(msgs);
if (newBrickd != null)
msgs = ((InternalEObject) newBrickd).eInverseAdd(this, ModelPackage.MBRICKD__MDEVICES, MBrickd.class,
msgs);
msgs = basicSetBrickd(newBrickd, msgs);
if (msgs != null)
msgs.dispatch();
} else if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, ModelPackage.MBRICKLET_PIEZO_SPEAKER__BRICKD,
newBrickd, newBrickd));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public OnOffValue getSwitchState() {
return switchState;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public void setSwitchState(OnOffValue newSwitchState) {
OnOffValue oldSwitchState = switchState;
switchState = newSwitchState;
if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, ModelPackage.MBRICKLET_PIEZO_SPEAKER__SWITCH_STATE,
oldSwitchState, switchState));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public String getDeviceType() {
return deviceType;
}
/**
* <!-- begin-user-doc --> <!-- end-user-doc -->
*
* @generated NOT
*/
@Override
public void turnSwitch(OnOffValue state, DeviceOptions opts) {
if (state == OnOffValue.ON) {
beep(opts);
} else {
stopBeep();
}
}
/**
* <!-- begin-user-doc --> <!-- end-user-doc -->
*
* @generated NOT
*/
@Override
public void fetchSwitchState() {
// nothing to do
}
private enum Mode {
BEEP,
MORSE
}
private Long[] getDurations(String durationsopt) {
if (durationsopt == null) {
return null;
}
Long[] durations = null;
logger.debug("durationsopt: {}", durationsopt);
String[] numbers = durationsopt.split("\\|");
for (int i = 0; i < numbers.length; i++) {
logger.debug("duration number {}", numbers[i]);
}
durations = new Long[numbers.length];
for (int i = 0; i < numbers.length; i++) {
durations[i] = new Long(numbers[i]);
}
return durations;
}
private Integer[] getFrequencies(String frequenciesopt) {
Integer[] frequencies = null;
logger.debug("frequenciesopt {}", frequenciesopt);
String[] numbers = frequenciesopt.split("\\|");
frequencies = new Integer[numbers.length];
for (int i = 0; i < numbers.length; i++) {
frequencies[i] = new Integer(numbers[i]);
}
return frequencies;
}
private String[] getMorseCodes(String morseCodeOpt) {
String[] morseCodes = null;
logger.debug("morseCodeOpt {}", morseCodeOpt);
morseCodes = morseCodeOpt.split("\\|");
return morseCodes;
}
/**
* <!-- begin-user-doc --> <!-- end-user-doc -->
*
* @generated NOT
*/
private void beep(DeviceOptions opts) {
try {
Long[] durations = null;
Integer[] frequencies = null;
String[] morseCodes = null;
Long repeats = null;
Mode mode;
if (beepFinishedListener != null) {
logger.trace("removing beepFinishedListener");
tinkerforgeDevice.removeBeepFinishedListener(beepFinishedListener);
beepFinishedListener = null;
tinkerforgeDevice.beep(0, 0);
}
if (morseFinishedListener != null) {
logger.trace("removing morseFinishedListener");
tinkerforgeDevice.removeMorseCodeFinishedListener(morseFinishedListener);
morseFinishedListener = null;
tinkerforgeDevice.beep(0, 0);
}
if (opts != null) {
String modestr = Tools.getStringOpt(MODE, opts);
if (modestr == null) {
logger.error("mode is missing");
return;
}
if (modestr.toLowerCase().equals(BEEP)) {
mode = Mode.BEEP;
durations = getDurations(Tools.getStringOpt(DURATIONS, opts));
frequencies = getFrequencies(Tools.getStringOpt(FREQUENCIES, opts));
repeats = Tools.getLongOpt(REPEAT, opts, 1L);
logger.debug("repeats {}", repeats);
if (durations == null || frequencies == null) {
logger.error("durations and frequencies have values when mode is beep");
return;
} else if (durations.length != frequencies.length) {
logger.error(
"every frequence needs a duration value and vice versa: frequencies count {}, durationscount {}",
frequencies.length, durations.length);
return;
}
} else if (modestr.toLowerCase().equals(MORSE)) {
mode = Mode.MORSE;
frequencies = getFrequencies(Tools.getStringOpt(FREQUENCIES, opts));
morseCodes = getMorseCodes(Tools.getStringOpt(MORSECODES, opts));
repeats = Tools.getLongOpt(REPEAT, opts, 1L);
logger.debug("repeats {}", repeats);
if (morseCodes == null || frequencies == null) {
logger.error("morseCodes and frequencies have values when mode is morse");
return;
} else if (morseCodes.length != frequencies.length) {
logger.error(
"every morseCodes needs a frequency value and vice versa: morseCodes count {}, frequencies {}",
morseCodes.length, frequencies.length);
return;
}
} else {
logger.error("unknown mode string {}", modestr);
return;
}
} else {
logger.error("item configuration is missing");
return;
}
if (mode == Mode.BEEP) {
logger.debug("sending beeps");
logger.debug("adding new BeepFinishedListener");
beepFinishedListener = new BeepFinishedListener(this, durations, frequencies, repeats);
tinkerforgeDevice.addBeepFinishedListener(beepFinishedListener);
logger.debug("trigger beeping");
tinkerforgeDevice.beep(durations[0], frequencies[0]);
} else {
logger.debug("sending morse codes");
logger.debug("adding new MorseFinishedListener");
morseFinishedListener = new MorseFinishedListener(this, morseCodes, frequencies, repeats);
tinkerforgeDevice.addMorseCodeFinishedListener(morseFinishedListener);
logger.debug("trigger beeping");
// default morse code
logger.debug(" morse code");
tinkerforgeDevice.morseCode(morseCodes[0], frequencies[0]);
}
} catch (TimeoutException e) {
TinkerforgeErrorHandler.handleError(this, TinkerforgeErrorHandler.TF_TIMEOUT_EXCEPTION, e);
} catch (NotConnectedException e) {
TinkerforgeErrorHandler.handleError(this, TinkerforgeErrorHandler.TF_NOT_CONNECTION_EXCEPTION, e);
}
}
private class BeepFinishedListener implements BrickletPiezoSpeaker.BeepFinishedListener {
Long[] durations;
Integer[] frequencies;
Integer currentTone = 1;
Integer sequenceLength;
MBrickletPiezoSpeakerImpl mbricklet;
private long repeats;
private long round = 0;
public BeepFinishedListener(MBrickletPiezoSpeakerImpl mbricklet, Long[] durations, Integer[] frequencies,
long repeats) {
this.durations = durations;
this.frequencies = frequencies;
this.mbricklet = mbricklet;
this.repeats = repeats;
this.sequenceLength = frequencies.length;
}
@Override
public void beepFinished() {
try {
logger.debug("currentTone {}", currentTone);
if (currentTone >= sequenceLength) {
round++;
logger.debug("round {} repeat {}", round, repeats);
if (round < repeats) {
currentTone = 0; // for repeats currentTone must be 0 because the initial Tone was send
// from outside of the listener
} else {
// we are done
logger.debug("beep done");
setSwitchState(OnOffValue.OFF);
return;
}
} else {
logger.debug("currenTone {}, sequenceLength {}", currentTone, sequenceLength);
}
logger.debug("beep duration {} frequency {}", durations[currentTone], frequencies[currentTone]);
tinkerforgeDevice.beep(durations[currentTone], frequencies[currentTone]);
currentTone++;
} catch (TimeoutException e) {
TinkerforgeErrorHandler.handleError(mbricklet, TinkerforgeErrorHandler.TF_TIMEOUT_EXCEPTION, e);
} catch (NotConnectedException e) {
TinkerforgeErrorHandler.handleError(mbricklet, TinkerforgeErrorHandler.TF_NOT_CONNECTION_EXCEPTION, e);
}
}
}
private class MorseFinishedListener implements BrickletPiezoSpeaker.MorseCodeFinishedListener {
Integer[] frequencies;
String[] morseCodes;
Integer currentSequence = 1;
Integer sequenceLength;
MBrickletPiezoSpeakerImpl mbricklet;
private long repeats;
private long round = 0;
public MorseFinishedListener(MBrickletPiezoSpeakerImpl mbricklet, String[] morseCodes, Integer[] frequencies,
long repeats) {
this.frequencies = frequencies;
this.morseCodes = morseCodes;
this.mbricklet = mbricklet;
this.repeats = repeats;
this.sequenceLength = frequencies.length;
}
@Override
public void morseCodeFinished() {
try {
logger.debug("currentSequence {}", currentSequence);
if (currentSequence >= sequenceLength) {
round++;
logger.debug("round {} repeat {}", round, repeats);
if (round < repeats) {
currentSequence = 0; // for repeats currentSequence must be 0 because the initial Tone
// was send
// from outside of the listener
} else {
// we are done
logger.debug("beep done");
setSwitchState(OnOffValue.OFF);
return;
}
} else {
logger.debug("currentSequence {}, sequenceLength {}", currentSequence, sequenceLength);
}
logger.debug("morse code {} frequency {}", morseCodes[currentSequence], frequencies[currentSequence]);
tinkerforgeDevice.morseCode(morseCodes[currentSequence], frequencies[currentSequence]);
currentSequence++;
} catch (TimeoutException e) {
TinkerforgeErrorHandler.handleError(mbricklet, TinkerforgeErrorHandler.TF_TIMEOUT_EXCEPTION, e);
} catch (NotConnectedException e) {
TinkerforgeErrorHandler.handleError(mbricklet, TinkerforgeErrorHandler.TF_NOT_CONNECTION_EXCEPTION, e);
}
}
}
/**
* <!-- begin-user-doc --> <!-- end-user-doc -->
*
* @generated NOT
*/
@Override
public void init() {
setEnabledA(new AtomicBoolean());
logger = LoggerFactory.getLogger(MBrickletPiezoSpeakerImpl.class);
}
/**
* <!-- begin-user-doc --> <!-- end-user-doc -->
*
* @generated NOT
*/
@Override
public void enable() {
tinkerforgeDevice = new BrickletPiezoSpeaker(getUid(), getIpConnection());
}
/**
* <!-- begin-user-doc --> <!-- end-user-doc -->
*
* @generated NOT
*/
@Override
public void disable() {
stopBeep();
tinkerforgeDevice = null;
}
private void stopBeep() {
if (beepFinishedListener != null) {
tinkerforgeDevice.removeBeepFinishedListener(beepFinishedListener);
beepFinishedListener = null;
}
if (morseFinishedListener != null) {
tinkerforgeDevice.removeMorseCodeFinishedListener(morseFinishedListener);
morseFinishedListener = null;
}
try {
// stop beep
tinkerforgeDevice.beep(0, 0);
} 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
*/
@Override
public NotificationChain eInverseAdd(InternalEObject otherEnd, int featureID, NotificationChain msgs) {
switch (featureID) {
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__BRICKD:
if (eInternalContainer() != null)
msgs = eBasicRemoveFromContainer(msgs);
return basicSetBrickd((MBrickd) 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.MBRICKLET_PIEZO_SPEAKER__BRICKD:
return basicSetBrickd(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.MBRICKLET_PIEZO_SPEAKER__BRICKD:
return eInternalContainer().eInverseRemove(this, ModelPackage.MBRICKD__MDEVICES, MBrickd.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.MBRICKLET_PIEZO_SPEAKER__LOGGER:
return getLogger();
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__UID:
return getUid();
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__POLL:
return isPoll();
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__ENABLED_A:
return getEnabledA();
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__TINKERFORGE_DEVICE:
return getTinkerforgeDevice();
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__IP_CONNECTION:
return getIpConnection();
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__CONNECTED_UID:
return getConnectedUid();
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__POSITION:
return getPosition();
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__DEVICE_IDENTIFIER:
return getDeviceIdentifier();
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__NAME:
return getName();
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__BRICKD:
if (resolve)
return getBrickd();
return basicGetBrickd();
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__SWITCH_STATE:
return getSwitchState();
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__DEVICE_TYPE:
return getDeviceType();
}
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.MBRICKLET_PIEZO_SPEAKER__LOGGER:
setLogger((Logger) newValue);
return;
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__UID:
setUid((String) newValue);
return;
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__POLL:
setPoll((Boolean) newValue);
return;
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__ENABLED_A:
setEnabledA((AtomicBoolean) newValue);
return;
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__TINKERFORGE_DEVICE:
setTinkerforgeDevice((BrickletPiezoSpeaker) newValue);
return;
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__IP_CONNECTION:
setIpConnection((IPConnection) newValue);
return;
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__CONNECTED_UID:
setConnectedUid((String) newValue);
return;
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__POSITION:
setPosition((Character) newValue);
return;
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__DEVICE_IDENTIFIER:
setDeviceIdentifier((Integer) newValue);
return;
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__NAME:
setName((String) newValue);
return;
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__BRICKD:
setBrickd((MBrickd) newValue);
return;
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__SWITCH_STATE:
setSwitchState((OnOffValue) newValue);
return;
}
super.eSet(featureID, newValue);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public void eUnset(int featureID) {
switch (featureID) {
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__LOGGER:
setLogger(LOGGER_EDEFAULT);
return;
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__UID:
setUid(UID_EDEFAULT);
return;
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__POLL:
setPoll(POLL_EDEFAULT);
return;
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__ENABLED_A:
setEnabledA(ENABLED_A_EDEFAULT);
return;
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__TINKERFORGE_DEVICE:
setTinkerforgeDevice((BrickletPiezoSpeaker) null);
return;
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__IP_CONNECTION:
setIpConnection(IP_CONNECTION_EDEFAULT);
return;
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__CONNECTED_UID:
setConnectedUid(CONNECTED_UID_EDEFAULT);
return;
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__POSITION:
setPosition(POSITION_EDEFAULT);
return;
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__DEVICE_IDENTIFIER:
setDeviceIdentifier(DEVICE_IDENTIFIER_EDEFAULT);
return;
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__NAME:
setName(NAME_EDEFAULT);
return;
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__BRICKD:
setBrickd((MBrickd) null);
return;
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__SWITCH_STATE:
setSwitchState(SWITCH_STATE_EDEFAULT);
return;
}
super.eUnset(featureID);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public boolean eIsSet(int featureID) {
switch (featureID) {
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__LOGGER:
return LOGGER_EDEFAULT == null ? logger != null : !LOGGER_EDEFAULT.equals(logger);
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__UID:
return UID_EDEFAULT == null ? uid != null : !UID_EDEFAULT.equals(uid);
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__POLL:
return poll != POLL_EDEFAULT;
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__ENABLED_A:
return ENABLED_A_EDEFAULT == null ? enabledA != null : !ENABLED_A_EDEFAULT.equals(enabledA);
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__TINKERFORGE_DEVICE:
return tinkerforgeDevice != null;
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__IP_CONNECTION:
return IP_CONNECTION_EDEFAULT == null ? ipConnection != null
: !IP_CONNECTION_EDEFAULT.equals(ipConnection);
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__CONNECTED_UID:
return CONNECTED_UID_EDEFAULT == null ? connectedUid != null
: !CONNECTED_UID_EDEFAULT.equals(connectedUid);
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__POSITION:
return position != POSITION_EDEFAULT;
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__DEVICE_IDENTIFIER:
return deviceIdentifier != DEVICE_IDENTIFIER_EDEFAULT;
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__NAME:
return NAME_EDEFAULT == null ? name != null : !NAME_EDEFAULT.equals(name);
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__BRICKD:
return basicGetBrickd() != null;
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__SWITCH_STATE:
return SWITCH_STATE_EDEFAULT == null ? switchState != null : !SWITCH_STATE_EDEFAULT.equals(switchState);
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__DEVICE_TYPE:
return DEVICE_TYPE_EDEFAULT == null ? deviceType != null : !DEVICE_TYPE_EDEFAULT.equals(deviceType);
}
return super.eIsSet(featureID);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public int eBaseStructuralFeatureID(int derivedFeatureID, Class<?> baseClass) {
if (baseClass == SwitchSensor.class) {
switch (derivedFeatureID) {
case ModelPackage.MBRICKLET_PIEZO_SPEAKER__SWITCH_STATE:
return ModelPackage.SWITCH_SENSOR__SWITCH_STATE;
default:
return -1;
}
}
if (baseClass == ProgrammableSwitchActor.class) {
switch (derivedFeatureID) {
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 == SwitchSensor.class) {
switch (baseFeatureID) {
case ModelPackage.SWITCH_SENSOR__SWITCH_STATE:
return ModelPackage.MBRICKLET_PIEZO_SPEAKER__SWITCH_STATE;
default:
return -1;
}
}
if (baseClass == ProgrammableSwitchActor.class) {
switch (baseFeatureID) {
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 == SwitchSensor.class) {
switch (baseOperationID) {
case ModelPackage.SWITCH_SENSOR___FETCH_SWITCH_STATE:
return ModelPackage.MBRICKLET_PIEZO_SPEAKER___FETCH_SWITCH_STATE;
default:
return -1;
}
}
if (baseClass == ProgrammableSwitchActor.class) {
switch (baseOperationID) {
case ModelPackage.PROGRAMMABLE_SWITCH_ACTOR___TURN_SWITCH__ONOFFVALUE_DEVICEOPTIONS:
return ModelPackage.MBRICKLET_PIEZO_SPEAKER___TURN_SWITCH__ONOFFVALUE_DEVICEOPTIONS;
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.MBRICKLET_PIEZO_SPEAKER___TURN_SWITCH__ONOFFVALUE_DEVICEOPTIONS:
turnSwitch((OnOffValue) arguments.get(0), (DeviceOptions) arguments.get(1));
return null;
case ModelPackage.MBRICKLET_PIEZO_SPEAKER___FETCH_SWITCH_STATE:
fetchSwitchState();
return null;
case ModelPackage.MBRICKLET_PIEZO_SPEAKER___INIT:
init();
return null;
case ModelPackage.MBRICKLET_PIEZO_SPEAKER___ENABLE:
enable();
return null;
case ModelPackage.MBRICKLET_PIEZO_SPEAKER___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(" (logger: ");
result.append(logger);
result.append(", uid: ");
result.append(uid);
result.append(", poll: ");
result.append(poll);
result.append(", enabledA: ");
result.append(enabledA);
result.append(", tinkerforgeDevice: ");
result.append(tinkerforgeDevice);
result.append(", ipConnection: ");
result.append(ipConnection);
result.append(", connectedUid: ");
result.append(connectedUid);
result.append(", position: ");
result.append(position);
result.append(", deviceIdentifier: ");
result.append(deviceIdentifier);
result.append(", name: ");
result.append(name);
result.append(", switchState: ");
result.append(switchState);
result.append(", deviceType: ");
result.append(deviceType);
result.append(')');
return result.toString();
}
} // MBrickletPiezoSpeakerImpl