Commit edcb532f authored by Don Gagne's avatar Don Gagne

Auto-Disconnect on cable pull

parent b612e4cd
...@@ -170,6 +170,9 @@ signals: ...@@ -170,6 +170,9 @@ signals:
void activeChanged(bool active); void activeChanged(bool active);
void _invokeWriteBytes(QByteArray); void _invokeWriteBytes(QByteArray);
/// Signalled when a link suddenly goes away due to it being removed by for example pulling the cable to the connection.
void connectionRemoved(LinkInterface* link);
/** /**
* @brief New data arrived * @brief New data arrived
* *
......
...@@ -216,6 +216,10 @@ void LinkManager::_addLink(LinkInterface* link) ...@@ -216,6 +216,10 @@ void LinkManager::_addLink(LinkInterface* link)
connect(link, &LinkInterface::connected, this, &LinkManager::_linkConnected); connect(link, &LinkInterface::connected, this, &LinkManager::_linkConnected);
connect(link, &LinkInterface::disconnected, this, &LinkManager::_linkDisconnected); connect(link, &LinkInterface::disconnected, this, &LinkManager::_linkDisconnected);
// This connection is queued since it will cloe the link. So we want the link emitter to return otherwise we would
// close the link our from under itself.
connect(link, &LinkInterface::connectionRemoved, this, &LinkManager::_linkConnectionRemoved, Qt::QueuedConnection);
} }
void LinkManager::disconnectAll(void) void LinkManager::disconnectAll(void)
...@@ -239,7 +243,9 @@ bool LinkManager::connectLink(LinkInterface* link) ...@@ -239,7 +243,9 @@ bool LinkManager::connectLink(LinkInterface* link)
void LinkManager::disconnectLink(LinkInterface* link) void LinkManager::disconnectLink(LinkInterface* link)
{ {
Q_ASSERT(link); if (!link || !_links.contains(link)) {
return;
}
link->_disconnect(); link->_disconnect();
LinkConfiguration* config = link->getLinkConfiguration(); LinkConfiguration* config = link->getLinkConfiguration();
...@@ -306,6 +312,12 @@ void LinkManager::_linkDisconnected(void) ...@@ -306,6 +312,12 @@ void LinkManager::_linkDisconnected(void)
emit linkDisconnected((LinkInterface*)sender()); emit linkDisconnected((LinkInterface*)sender());
} }
void LinkManager::_linkConnectionRemoved(LinkInterface* link)
{
// Link has been removed from system, disconnect it automatically
disconnectLink(link);
}
void LinkManager::suspendConfigurationUpdates(bool suspend) void LinkManager::suspendConfigurationUpdates(bool suspend)
{ {
_configUpdateSuspended = suspend; _configUpdateSuspended = suspend;
......
...@@ -202,6 +202,7 @@ signals: ...@@ -202,6 +202,7 @@ signals:
private slots: private slots:
void _linkConnected(void); void _linkConnected(void);
void _linkDisconnected(void); void _linkDisconnected(void);
void _linkConnectionRemoved(LinkInterface* link);
#ifndef __ios__ #ifndef __ios__
void _activeLinkCheck(void); void _activeLinkCheck(void);
#endif #endif
......
...@@ -182,10 +182,6 @@ bool SerialLink::_hardwareConnect(QSerialPort::SerialPortError& error, QString& ...@@ -182,10 +182,6 @@ bool SerialLink::_hardwareConnect(QSerialPort::SerialPortError& error, QString&
} }
_port = new QSerialPort(_config->portName()); _port = new QSerialPort(_config->portName());
if (!_port) {
emit communicationUpdate(getName(),"Error opening port: " + _config->portName());
return false; // couldn't create serial port.
}
QObject::connect(_port, static_cast<void (QSerialPort::*)(QSerialPort::SerialPortError)>(&QSerialPort::error), QObject::connect(_port, static_cast<void (QSerialPort::*)(QSerialPort::SerialPortError)>(&QSerialPort::error),
this, &SerialLink::linkError); this, &SerialLink::linkError);
...@@ -249,12 +245,19 @@ void SerialLink::_readBytes(void) ...@@ -249,12 +245,19 @@ void SerialLink::_readBytes(void)
void SerialLink::linkError(QSerialPort::SerialPortError error) void SerialLink::linkError(QSerialPort::SerialPortError error)
{ {
if (error != QSerialPort::NoError) { switch (error) {
case QSerialPort::NoError:
break;
case QSerialPort::ResourceError:
emit connectionRemoved(this);
break;
default:
// You can use the following qDebug output as needed during development. Make sure to comment it back out // You can use the following qDebug output as needed during development. Make sure to comment it back out
// when you are done. The reason for this is that this signal is very noisy. For example if you try to // when you are done. The reason for this is that this signal is very noisy. For example if you try to
// connect to a PixHawk before it is ready to accept the connection it will output a continuous stream // connect to a PixHawk before it is ready to accept the connection it will output a continuous stream
// of errors until the Pixhawk responds. // of errors until the Pixhawk responds.
//qCDebug(SerialLinkLog) << "SerialLink::linkError" << error; //qCDebug(SerialLinkLog) << "SerialLink::linkError" << error;
break;
} }
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment