mirror of
				https://github.com/f4exb/sdrangel.git
				synced 2025-10-26 02:20:26 -04:00 
			
		
		
		
	Message pipes rework: settings pipes change in AFC, SSB demod, Frequency tracker
This commit is contained in:
		
							parent
							
								
									1c5a777709
								
							
						
					
					
						commit
						283ab64c59
					
				| @ -270,10 +270,11 @@ void SSBDemod::applySettings(const SSBDemodSettings& settings, bool force) | |||||||
|         webapiReverseSendSettings(reverseAPIKeys, settings, fullUpdate || force); |         webapiReverseSendSettings(reverseAPIKeys, settings, fullUpdate || force); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     QList<MessageQueue*> *messageQueues = MainCore::instance()->getMessagePipes().getMessageQueues(this, "settings"); |     QList<ObjectPipe*> pipes; | ||||||
|  |     MainCore::instance()->getMessagePipes2().getMessagePipes(this, "settings", pipes); | ||||||
| 
 | 
 | ||||||
|     if (messageQueues) { |     if (pipes.size() > 0) { | ||||||
|         sendChannelSettings(messageQueues, reverseAPIKeys, settings, force); |         sendChannelSettings(pipes, reverseAPIKeys, settings, force); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     m_settings = settings; |     m_settings = settings; | ||||||
| @ -581,14 +582,18 @@ void SSBDemod::webapiReverseSendSettings(QList<QString>& channelSettingsKeys, co | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void SSBDemod::sendChannelSettings( | void SSBDemod::sendChannelSettings( | ||||||
|     QList<MessageQueue*> *messageQueues, |     const QList<ObjectPipe*>& pipes, | ||||||
|     QList<QString>& channelSettingsKeys, |     QList<QString>& channelSettingsKeys, | ||||||
|     const SSBDemodSettings& settings, |     const SSBDemodSettings& settings, | ||||||
|     bool force) |     bool force) | ||||||
| { | { | ||||||
|     QList<MessageQueue*>::iterator it = messageQueues->begin(); |     qDebug("SSBDemod::sendChannelSettings: %d pipes", pipes.size()); | ||||||
| 
 | 
 | ||||||
|     for (; it != messageQueues->end(); ++it) |     for (const auto& pipe : pipes) | ||||||
|  |     { | ||||||
|  |         MessageQueue *messageQueue = qobject_cast<MessageQueue*>(pipe->m_element); | ||||||
|  | 
 | ||||||
|  |         if (messageQueue) | ||||||
|         { |         { | ||||||
|             SWGSDRangel::SWGChannelSettings *swgChannelSettings = new SWGSDRangel::SWGChannelSettings(); |             SWGSDRangel::SWGChannelSettings *swgChannelSettings = new SWGSDRangel::SWGChannelSettings(); | ||||||
|             webapiFormatChannelSettings(channelSettingsKeys, swgChannelSettings, settings, force); |             webapiFormatChannelSettings(channelSettingsKeys, swgChannelSettings, settings, force); | ||||||
| @ -598,7 +603,8 @@ void SSBDemod::sendChannelSettings( | |||||||
|                 swgChannelSettings, |                 swgChannelSettings, | ||||||
|                 force |                 force | ||||||
|             ); |             ); | ||||||
|         (*it)->push(msg); |             messageQueue->push(msg); | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -36,6 +36,7 @@ class QNetworkAccessManager; | |||||||
| class QNetworkReply; | class QNetworkReply; | ||||||
| class QThread; | class QThread; | ||||||
| class DeviceAPI; | class DeviceAPI; | ||||||
|  | class ObjectPipe; | ||||||
| 
 | 
 | ||||||
| class SSBDemod : public BasebandSampleSink, public ChannelAPI { | class SSBDemod : public BasebandSampleSink, public ChannelAPI { | ||||||
| public: | public: | ||||||
| @ -148,7 +149,7 @@ private: | |||||||
|     void webapiFormatChannelReport(SWGSDRangel::SWGChannelReport& response); |     void webapiFormatChannelReport(SWGSDRangel::SWGChannelReport& response); | ||||||
|     void webapiReverseSendSettings(QList<QString>& channelSettingsKeys, const SSBDemodSettings& settings, bool force); |     void webapiReverseSendSettings(QList<QString>& channelSettingsKeys, const SSBDemodSettings& settings, bool force); | ||||||
|     void sendChannelSettings( |     void sendChannelSettings( | ||||||
|         QList<MessageQueue*> *messageQueues, |         const QList<ObjectPipe*>& pipes, | ||||||
|         QList<QString>& channelSettingsKeys, |         QList<QString>& channelSettingsKeys, | ||||||
|         const SSBDemodSettings& settings, |         const SSBDemodSettings& settings, | ||||||
|         bool force |         bool force | ||||||
|  | |||||||
| @ -274,10 +274,11 @@ void FreqTracker::applySettings(const FreqTrackerSettings& settings, bool force) | |||||||
|         webapiReverseSendSettings(reverseAPIKeys, settings, fullUpdate || force); |         webapiReverseSendSettings(reverseAPIKeys, settings, fullUpdate || force); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     QList<MessageQueue*> *messageQueues = MainCore::instance()->getMessagePipes().getMessageQueues(this, "settings"); |     QList<ObjectPipe*> pipes; | ||||||
|  |     MainCore::instance()->getMessagePipes2().getMessagePipes(this, "settings", pipes); | ||||||
| 
 | 
 | ||||||
|     if (messageQueues) { |     if (pipes.size() > 0) { | ||||||
|         sendChannelSettings(messageQueues, reverseAPIKeys, settings, force); |         sendChannelSettings(pipes, reverseAPIKeys, settings, force); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     m_settings = settings; |     m_settings = settings; | ||||||
| @ -551,14 +552,16 @@ void FreqTracker::webapiReverseSendSettings(QList<QString>& channelSettingsKeys, | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void FreqTracker::sendChannelSettings( | void FreqTracker::sendChannelSettings( | ||||||
|     QList<MessageQueue*> *messageQueues, |     const QList<ObjectPipe*>& pipes, | ||||||
|     QList<QString>& channelSettingsKeys, |     QList<QString>& channelSettingsKeys, | ||||||
|     const FreqTrackerSettings& settings, |     const FreqTrackerSettings& settings, | ||||||
|     bool force) |     bool force) | ||||||
| { | { | ||||||
|     QList<MessageQueue*>::iterator it = messageQueues->begin(); |     for (const auto& pipe : pipes) | ||||||
|  |     { | ||||||
|  |         MessageQueue *messageQueue = qobject_cast<MessageQueue*>(pipe->m_element); | ||||||
| 
 | 
 | ||||||
|     for (; it != messageQueues->end(); ++it) |         if (messageQueue) | ||||||
|         { |         { | ||||||
|             SWGSDRangel::SWGChannelSettings *swgChannelSettings = new SWGSDRangel::SWGChannelSettings(); |             SWGSDRangel::SWGChannelSettings *swgChannelSettings = new SWGSDRangel::SWGChannelSettings(); | ||||||
|             webapiFormatChannelSettings(channelSettingsKeys, swgChannelSettings, settings, force); |             webapiFormatChannelSettings(channelSettingsKeys, swgChannelSettings, settings, force); | ||||||
| @ -568,7 +571,8 @@ void FreqTracker::sendChannelSettings( | |||||||
|                 swgChannelSettings, |                 swgChannelSettings, | ||||||
|                 force |                 force | ||||||
|             ); |             ); | ||||||
|         (*it)->push(msg); |             messageQueue->push(msg); | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -33,6 +33,7 @@ | |||||||
| class QNetworkAccessManager; | class QNetworkAccessManager; | ||||||
| class QNetworkReply; | class QNetworkReply; | ||||||
| class DeviceAPI; | class DeviceAPI; | ||||||
|  | class ObjectPipe; | ||||||
| 
 | 
 | ||||||
| class FreqTracker : public BasebandSampleSink, public ChannelAPI { | class FreqTracker : public BasebandSampleSink, public ChannelAPI { | ||||||
| public: | public: | ||||||
| @ -145,7 +146,7 @@ private: | |||||||
|     void webapiFormatChannelReport(SWGSDRangel::SWGChannelReport& response); |     void webapiFormatChannelReport(SWGSDRangel::SWGChannelReport& response); | ||||||
|     void webapiReverseSendSettings(QList<QString>& channelSettingsKeys, const FreqTrackerSettings& settings, bool force); |     void webapiReverseSendSettings(QList<QString>& channelSettingsKeys, const FreqTrackerSettings& settings, bool force); | ||||||
|     void sendChannelSettings( |     void sendChannelSettings( | ||||||
|         QList<MessageQueue*> *messageQueues, |         const QList<ObjectPipe*>& pipes, | ||||||
|         QList<QString>& channelSettingsKeys, |         QList<QString>& channelSettingsKeys, | ||||||
|         const FreqTrackerSettings& settings, |         const FreqTrackerSettings& settings, | ||||||
|         bool force |         bool force | ||||||
|  | |||||||
| @ -630,6 +630,7 @@ void AFC::trackerDeviceChange(int deviceIndex) | |||||||
| 
 | 
 | ||||||
|     MainCore *mainCore = MainCore::instance(); |     MainCore *mainCore = MainCore::instance(); | ||||||
|     m_trackerDeviceSet = mainCore->getDeviceSets()[deviceIndex]; |     m_trackerDeviceSet = mainCore->getDeviceSets()[deviceIndex]; | ||||||
|  |     m_trackerChannelAPI = nullptr; | ||||||
| 
 | 
 | ||||||
|     for (int i = 0; i < m_trackerDeviceSet->getNumberOfChannels(); i++) |     for (int i = 0; i < m_trackerDeviceSet->getNumberOfChannels(); i++) | ||||||
|     { |     { | ||||||
| @ -651,12 +652,22 @@ void AFC::trackerDeviceChange(int deviceIndex) | |||||||
|                 ); |                 ); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|  |             connect(pipe, SIGNAL(toBeDeleted(int, QObject*)), this, SLOT(handleTrackerMessagePipeToBeDeleted(int, QObject*))); | ||||||
|             m_trackerChannelAPI = channel; |             m_trackerChannelAPI = channel; | ||||||
|             break; |             break; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | void AFC::handleTrackerMessagePipeToBeDeleted(int reason, QObject* object) | ||||||
|  | { | ||||||
|  |     if ((reason == 0) && ((ChannelAPI*) object == m_trackerChannelAPI))  // tracker channel has been de;eted
 | ||||||
|  |     { | ||||||
|  |         m_trackerChannelAPI = nullptr; | ||||||
|  |         updateDeviceSetLists(); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
| void AFC::trackedDeviceChange(int deviceIndex) | void AFC::trackedDeviceChange(int deviceIndex) | ||||||
| { | { | ||||||
|     qDebug("AFC::trackedDeviceChange: deviceIndex: %d", deviceIndex); |     qDebug("AFC::trackedDeviceChange: deviceIndex: %d", deviceIndex); | ||||||
| @ -667,6 +678,8 @@ void AFC::trackedDeviceChange(int deviceIndex) | |||||||
| 
 | 
 | ||||||
|     MainCore *mainCore = MainCore::instance(); |     MainCore *mainCore = MainCore::instance(); | ||||||
|     m_trackedDeviceSet = mainCore->getDeviceSets()[deviceIndex]; |     m_trackedDeviceSet = mainCore->getDeviceSets()[deviceIndex]; | ||||||
|  |     m_trackerIndexInDeviceSet = -1; | ||||||
|  |     m_trackedChannelAPIs.clear(); | ||||||
| 
 | 
 | ||||||
|     for (int i = 0; i < m_trackedDeviceSet->getNumberOfChannels(); i++) |     for (int i = 0; i < m_trackedDeviceSet->getNumberOfChannels(); i++) | ||||||
|     { |     { | ||||||
| @ -688,41 +701,58 @@ void AFC::trackedDeviceChange(int deviceIndex) | |||||||
|                 ); |                 ); | ||||||
|                 m_trackerIndexInDeviceSet = i; |                 m_trackerIndexInDeviceSet = i; | ||||||
|             } |             } | ||||||
|  | 
 | ||||||
|  |             m_trackedChannelAPIs.push_back(channel); | ||||||
|  |             connect(pipe, SIGNAL(toBeDeleted(int, QObject*)), this, SLOT(handleTrackedMessagePipeToBeDeleted(int, QObject*))); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | void AFC::handleTrackedMessagePipeToBeDeleted(int reason, QObject* object) | ||||||
|  | { | ||||||
|  |     if ((reason == 0) && m_trackedChannelAPIs.contains((ChannelAPI*) object)) | ||||||
|  |     { | ||||||
|  |         m_trackedChannelAPIs.removeAll((ChannelAPI*) object); | ||||||
|  |         updateDeviceSetLists(); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
| void AFC::removeTrackerFeatureReference() | void AFC::removeTrackerFeatureReference() | ||||||
| { | { | ||||||
|     if (m_trackerChannelAPI) |     if (m_trackerChannelAPI) | ||||||
|     { |     { | ||||||
|         if (MainCore::instance()->existsChannel(m_trackerChannelAPI)) |  | ||||||
|         { |  | ||||||
|             qDebug("AFC::removeTrackerFeatureReference: m_trackerChannelAPI: %s", qPrintable(m_trackerChannelAPI->objectName())); |  | ||||||
|         ObjectPipe *pipe = MainCore::instance()->getMessagePipes2().unregisterProducerToConsumer(m_trackerChannelAPI, this, "settings"); |         ObjectPipe *pipe = MainCore::instance()->getMessagePipes2().unregisterProducerToConsumer(m_trackerChannelAPI, this, "settings"); | ||||||
|  | 
 | ||||||
|  |         if (pipe) | ||||||
|  |         { | ||||||
|             MessageQueue *messageQueue = qobject_cast<MessageQueue*>(pipe->m_element); |             MessageQueue *messageQueue = qobject_cast<MessageQueue*>(pipe->m_element); | ||||||
| 
 | 
 | ||||||
|             if (messageQueue) { |             if (messageQueue) { | ||||||
|                 disconnect(messageQueue, SIGNAL(messageEnqueued()), this, SLOT(handleChannelMessageQueue(MessageQueue*))); |                 disconnect(messageQueue, SIGNAL(messageEnqueued()), this, SLOT(handleChannelMessageQueue(MessageQueue*))); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  | 
 | ||||||
|  |         m_trackerChannelAPI = nullptr; | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void AFC::removeTrackedFeatureReferences() | void AFC::removeTrackedFeatureReferences() | ||||||
| { | { | ||||||
|     for (QList<ChannelAPI*>::iterator it = m_trackedChannelAPIs.begin(); it != m_trackedChannelAPIs.end(); ++it) |     for (auto& channel : m_trackedChannelAPIs) | ||||||
|     { |     { | ||||||
|         ChannelAPI *channel = *it; |         ObjectPipe *pipe = MainCore::instance()->getMessagePipes2().unregisterProducerToConsumer(channel, this, "settings"); | ||||||
| 
 | 
 | ||||||
|         if (MainCore::instance()->existsChannel(channel)) |         if (pipe) | ||||||
|         { |         { | ||||||
|             qDebug("AFC::removeTrackedFeatureReferences: channel: %s", qPrintable(channel->objectName())); |             MessageQueue *messageQueue = qobject_cast<MessageQueue*>(pipe->m_element); | ||||||
|             MainCore::instance()->getMessagePipes2().unregisterProducerToConsumer(channel, this, "settings"); | 
 | ||||||
|  |             if (messageQueue) { | ||||||
|  |                 disconnect(messageQueue, SIGNAL(messageEnqueued()), this, SLOT(handleChannelMessageQueue(MessageQueue*))); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|     m_trackedChannelAPIs.clear(); |         m_trackedChannelAPIs.removeAll(channel); | ||||||
|  |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void AFC::handleChannelMessageQueue(MessageQueue* messageQueue) | void AFC::handleChannelMessageQueue(MessageQueue* messageQueue) | ||||||
|  | |||||||
| @ -226,6 +226,8 @@ private: | |||||||
| private slots: | private slots: | ||||||
|     void networkManagerFinished(QNetworkReply *reply); |     void networkManagerFinished(QNetworkReply *reply); | ||||||
|     void handleChannelMessageQueue(MessageQueue* messageQueue); |     void handleChannelMessageQueue(MessageQueue* messageQueue); | ||||||
|  |     void handleTrackerMessagePipeToBeDeleted(int reason, QObject* object); | ||||||
|  |     void handleTrackedMessagePipeToBeDeleted(int reason, QObject* object); | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| #endif // INCLUDE_FEATURE_AFC_H_
 | #endif // INCLUDE_FEATURE_AFC_H_
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user