| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  | ///////////////////////////////////////////////////////////////////////////////////
 | 
					
						
							|  |  |  | // Copyright (C) 2020 Edouard Griffiths, F4EXB.                                  //
 | 
					
						
							|  |  |  | //                                                                               //
 | 
					
						
							|  |  |  | // This program is free software; you can redistribute it and/or modify          //
 | 
					
						
							|  |  |  | // it under the terms of the GNU General Public License as published by          //
 | 
					
						
							|  |  |  | // the Free Software Foundation as version 3 of the License, or                  //
 | 
					
						
							|  |  |  | // (at your option) any later version.                                           //
 | 
					
						
							|  |  |  | //                                                                               //
 | 
					
						
							|  |  |  | // This program is distributed in the hope that it will be useful,               //
 | 
					
						
							|  |  |  | // but WITHOUT ANY WARRANTY; without even the implied warranty of                //
 | 
					
						
							|  |  |  | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the                  //
 | 
					
						
							|  |  |  | // GNU General Public License V3 for more details.                               //
 | 
					
						
							|  |  |  | //                                                                               //
 | 
					
						
							|  |  |  | // You should have received a copy of the GNU General Public License             //
 | 
					
						
							|  |  |  | // along with this program. If not, see <http://www.gnu.org/licenses/>.          //
 | 
					
						
							|  |  |  | ///////////////////////////////////////////////////////////////////////////////////
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <boost/crc.hpp>
 | 
					
						
							|  |  |  | #include <boost/cstdint.hpp>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <QNetworkAccessManager>
 | 
					
						
							|  |  |  | #include <QNetworkReply>
 | 
					
						
							|  |  |  | #include <QBuffer>
 | 
					
						
							| 
									
										
										
										
											2022-07-23 05:46:06 +02:00
										 |  |  | #include <QThread>
 | 
					
						
							|  |  |  | #include <QMutexLocker>
 | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "SWGChannelSettings.h"
 | 
					
						
							| 
									
										
										
										
											2022-05-13 22:24:48 +02:00
										 |  |  | #include "SWGWorkspaceInfo.h"
 | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  | #include "SWGChannelReport.h"
 | 
					
						
							|  |  |  | #include "SWGChannelActions.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "util/simpleserializer.h"
 | 
					
						
							|  |  |  | #include "dsp/dspcommands.h"
 | 
					
						
							|  |  |  | #include "dsp/dspdevicesourceengine.h"
 | 
					
						
							|  |  |  | #include "dsp/dspengine.h"
 | 
					
						
							|  |  |  | #include "dsp/devicesamplesource.h"
 | 
					
						
							|  |  |  | #include "dsp/hbfilterchainconverter.h"
 | 
					
						
							|  |  |  | #include "dsp/devicesamplemimo.h"
 | 
					
						
							|  |  |  | #include "device/deviceapi.h"
 | 
					
						
							| 
									
										
										
										
											2020-10-23 00:11:18 +02:00
										 |  |  | #include "feature/feature.h"
 | 
					
						
							|  |  |  | #include "maincore.h"
 | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "filesinkmessages.h"
 | 
					
						
							|  |  |  | #include "filesinkbaseband.h"
 | 
					
						
							|  |  |  | #include "filesink.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | MESSAGE_CLASS_DEFINITION(FileSink::MsgConfigureFileSink, Message) | 
					
						
							| 
									
										
										
										
											2021-02-23 08:26:42 +01:00
										 |  |  | MESSAGE_CLASS_DEFINITION(FileSink::MsgReportStartStop, Message) | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-21 20:24:18 +01:00
										 |  |  | const char* const FileSink::m_channelIdURI = "sdrangel.channel.filesink"; | 
					
						
							|  |  |  | const char* const FileSink::m_channelId = "FileSink"; | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | FileSink::FileSink(DeviceAPI *deviceAPI) : | 
					
						
							|  |  |  |         ChannelAPI(m_channelIdURI, ChannelAPI::StreamSingleSink), | 
					
						
							|  |  |  |         m_deviceAPI(deviceAPI), | 
					
						
							| 
									
										
										
										
											2022-07-23 05:46:06 +02:00
										 |  |  |         m_running(false), | 
					
						
							| 
									
										
										
										
											2020-11-14 05:51:19 +01:00
										 |  |  |         m_spectrumVis(SDR_RX_SCALEF), | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |         m_centerFrequency(0), | 
					
						
							|  |  |  |         m_frequencyOffset(0), | 
					
						
							|  |  |  |         m_basebandSampleRate(48000) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     setObjectName(m_channelId); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     applySettings(m_settings, true); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     m_deviceAPI->addChannelSink(this); | 
					
						
							|  |  |  |     m_deviceAPI->addChannelSinkAPI(this); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     m_networkManager = new QNetworkAccessManager(); | 
					
						
							| 
									
										
										
										
											2022-03-23 22:32:23 +01:00
										 |  |  |     QObject::connect( | 
					
						
							|  |  |  |         m_networkManager, | 
					
						
							|  |  |  |         &QNetworkAccessManager::finished, | 
					
						
							|  |  |  |         this, | 
					
						
							|  |  |  |         &FileSink::networkManagerFinished | 
					
						
							|  |  |  |     ); | 
					
						
							| 
									
										
										
										
											2022-03-18 17:08:04 +01:00
										 |  |  |     QObject::connect( | 
					
						
							|  |  |  |         this, | 
					
						
							|  |  |  |         &ChannelAPI::indexInDeviceSetChanged, | 
					
						
							|  |  |  |         this, | 
					
						
							|  |  |  |         &FileSink::handleIndexInDeviceSetChanged | 
					
						
							|  |  |  |     ); | 
					
						
							| 
									
										
										
										
											2022-07-23 05:46:06 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     start(); | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | FileSink::~FileSink() | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2022-07-23 05:46:06 +02:00
										 |  |  |     qDebug("FileSink::~FileSink"); | 
					
						
							| 
									
										
										
										
											2022-03-23 22:32:23 +01:00
										 |  |  |     QObject::disconnect( | 
					
						
							|  |  |  |         m_networkManager, | 
					
						
							|  |  |  |         &QNetworkAccessManager::finished, | 
					
						
							|  |  |  |         this, | 
					
						
							|  |  |  |         &FileSink::networkManagerFinished | 
					
						
							|  |  |  |     ); | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |     delete m_networkManager; | 
					
						
							|  |  |  |     m_deviceAPI->removeChannelSinkAPI(this); | 
					
						
							|  |  |  |     m_deviceAPI->removeChannelSink(this); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-07-23 05:46:06 +02:00
										 |  |  |     stop(); | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-04-16 16:45:53 +02:00
										 |  |  | void FileSink::setDeviceAPI(DeviceAPI *deviceAPI) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     if (deviceAPI != m_deviceAPI) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         m_deviceAPI->removeChannelSinkAPI(this); | 
					
						
							|  |  |  |         m_deviceAPI->removeChannelSink(this); | 
					
						
							|  |  |  |         m_deviceAPI = deviceAPI; | 
					
						
							|  |  |  |         m_deviceAPI->addChannelSink(this); | 
					
						
							|  |  |  |         m_deviceAPI->addChannelSinkAPI(this); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-19 14:10:31 +01:00
										 |  |  | void FileSink::setMessageQueueToGUI(MessageQueue* queue) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ChannelAPI::setMessageQueueToGUI(queue); | 
					
						
							| 
									
										
										
										
											2022-07-23 05:46:06 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     if (m_running) { | 
					
						
							|  |  |  |         m_basebandSink->setMessageQueueToGUI(queue); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-02-19 14:10:31 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  | uint32_t FileSink::getNumberOfDeviceStreams() const | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return m_deviceAPI->getNbSourceStreams(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void FileSink::feed(const SampleVector::const_iterator& begin, const SampleVector::const_iterator& end, bool firstOfBurst) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     (void) firstOfBurst; | 
					
						
							| 
									
										
										
										
											2022-07-23 05:46:06 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     if (m_running) { | 
					
						
							|  |  |  |         m_basebandSink->feed(begin, end); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void FileSink::start() | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2022-07-23 05:46:06 +02:00
										 |  |  |     QMutexLocker m_lock(&m_mutex); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (m_running) { | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  | 	qDebug("FileSink::start"); | 
					
						
							| 
									
										
										
										
											2022-07-23 05:46:06 +02:00
										 |  |  |     m_thread = new QThread(); | 
					
						
							|  |  |  |     m_basebandSink = new FileSinkBaseband(); | 
					
						
							|  |  |  |     m_basebandSink->setFifoLabel(QString("%1 [%2:%3]") | 
					
						
							|  |  |  |         .arg(m_channelId) | 
					
						
							|  |  |  |         .arg(m_deviceAPI->getDeviceSetIndex()) | 
					
						
							|  |  |  |         .arg(getIndexInDeviceSet()) | 
					
						
							|  |  |  |     ); | 
					
						
							|  |  |  |     m_basebandSink->setSpectrumSink(&m_spectrumVis); | 
					
						
							|  |  |  |     m_basebandSink->moveToThread(m_thread); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     QObject::connect( | 
					
						
							|  |  |  |         m_thread, | 
					
						
							|  |  |  |         &QThread::started, | 
					
						
							|  |  |  |         m_basebandSink, | 
					
						
							|  |  |  |         &FileSinkBaseband::startWork | 
					
						
							|  |  |  |     ); | 
					
						
							|  |  |  |     QObject::connect( | 
					
						
							|  |  |  |         m_thread, | 
					
						
							|  |  |  |         &QThread::finished, | 
					
						
							|  |  |  |         m_basebandSink, | 
					
						
							|  |  |  |         &QObject::deleteLater | 
					
						
							|  |  |  |     ); | 
					
						
							|  |  |  |     QObject::connect( | 
					
						
							|  |  |  |         m_thread, | 
					
						
							|  |  |  |         &QThread::finished, | 
					
						
							|  |  |  |         m_thread, | 
					
						
							|  |  |  |         &QThread::deleteLater | 
					
						
							|  |  |  |     ); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |     m_basebandSink->setMessageQueueToGUI(getMessageQueueToGUI()); | 
					
						
							|  |  |  |     m_basebandSink->setDeviceHwId(m_deviceAPI->getHardwareId()); | 
					
						
							|  |  |  |     m_basebandSink->setDeviceUId(m_deviceAPI->getDeviceUID()); | 
					
						
							| 
									
										
										
										
											2022-07-23 05:46:06 +02:00
										 |  |  |     m_thread->start(); | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     DSPSignalNotification *dspMsg = new DSPSignalNotification(m_basebandSampleRate, m_centerFrequency); | 
					
						
							|  |  |  |     m_basebandSink->getInputMessageQueue()->push(dspMsg); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     FileSinkBaseband::MsgConfigureFileSinkBaseband *msg = FileSinkBaseband::MsgConfigureFileSinkBaseband::create(m_settings, true); | 
					
						
							|  |  |  |     m_basebandSink->getInputMessageQueue()->push(msg); | 
					
						
							| 
									
										
										
										
											2021-02-23 08:26:42 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     if (getMessageQueueToGUI()) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         MsgReportStartStop *msg = MsgReportStartStop::create(true); | 
					
						
							|  |  |  |         getMessageQueueToGUI()->push(msg); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2022-07-23 05:46:06 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     m_running = true; | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void FileSink::stop() | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2022-07-23 05:46:06 +02:00
										 |  |  |     QMutexLocker m_lock(&m_mutex); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!m_running) { | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     qDebug("FileSink::stop:"); | 
					
						
							|  |  |  |     m_running = false; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	m_thread->quit(); | 
					
						
							|  |  |  | 	m_thread->wait(); | 
					
						
							| 
									
										
										
										
											2021-02-23 08:26:42 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     if (getMessageQueueToGUI()) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         MsgReportStartStop *msg = MsgReportStartStop::create(false); | 
					
						
							|  |  |  |         getMessageQueueToGUI()->push(msg); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | bool FileSink::handleMessage(const Message& cmd) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     if (DSPSignalNotification::match(cmd)) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         DSPSignalNotification& cfg = (DSPSignalNotification&) cmd; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         qDebug() << "FileSink::handleMessage: DSPSignalNotification:" | 
					
						
							|  |  |  |                 << " inputSampleRate: " << cfg.getSampleRate() | 
					
						
							|  |  |  |                 << " centerFrequency: " << cfg.getCenterFrequency(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         m_basebandSampleRate = cfg.getSampleRate(); | 
					
						
							|  |  |  |         m_centerFrequency = cfg.getCenterFrequency(); | 
					
						
							| 
									
										
										
										
											2022-07-23 05:46:06 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         if (m_running) { | 
					
						
							|  |  |  |             m_basebandSink->getInputMessageQueue()->push(new DSPSignalNotification(cfg)); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-04-13 11:08:21 +02:00
										 |  |  |         if (getMessageQueueToGUI()) { | 
					
						
							|  |  |  |             getMessageQueueToGUI()->push(new DSPSignalNotification(cfg)); | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else if (MsgConfigureFileSink::match(cmd)) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         MsgConfigureFileSink& cfg = (MsgConfigureFileSink&) cmd; | 
					
						
							|  |  |  |         qDebug() << "FileSink::handleMessage: MsgConfigureFileSink"; | 
					
						
							|  |  |  |         applySettings(cfg.getSettings(), cfg.getForce()); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return false; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | QByteArray FileSink::serialize() const | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return m_settings.serialize(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | bool FileSink::deserialize(const QByteArray& data) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     (void) data; | 
					
						
							|  |  |  |     if (m_settings.deserialize(data)) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         MsgConfigureFileSink *msg = MsgConfigureFileSink::create(m_settings, true); | 
					
						
							|  |  |  |         m_inputMessageQueue.push(msg); | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         m_settings.resetToDefaults(); | 
					
						
							|  |  |  |         MsgConfigureFileSink *msg = MsgConfigureFileSink::create(m_settings, true); | 
					
						
							|  |  |  |         m_inputMessageQueue.push(msg); | 
					
						
							|  |  |  |         return false; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void FileSink::getLocalDevices(std::vector<uint32_t>& indexes) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     indexes.clear(); | 
					
						
							|  |  |  |     DSPEngine *dspEngine = DSPEngine::instance(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     for (uint32_t i = 0; i < dspEngine->getDeviceSourceEnginesNumber(); i++) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         DSPDeviceSourceEngine *deviceSourceEngine = dspEngine->getDeviceSourceEngineByIndex(i); | 
					
						
							|  |  |  |         DeviceSampleSource *deviceSource = deviceSourceEngine->getSource(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (deviceSource->getDeviceDescription() == "LocalInput") { | 
					
						
							|  |  |  |             indexes.push_back(i); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | DeviceSampleSource *FileSink::getLocalDevice(uint32_t index) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     DSPEngine *dspEngine = DSPEngine::instance(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (index < dspEngine->getDeviceSourceEnginesNumber()) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         DSPDeviceSourceEngine *deviceSourceEngine = dspEngine->getDeviceSourceEngineByIndex(index); | 
					
						
							|  |  |  |         DeviceSampleSource *deviceSource = deviceSourceEngine->getSource(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (deviceSource->getDeviceDescription() == "LocalInput") | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             if (!getDeviceAPI()) { | 
					
						
							|  |  |  |                 qDebug("FileSink::getLocalDevice: the parent device is unset"); | 
					
						
							|  |  |  |             } else if (getDeviceAPI()->getDeviceUID() == deviceSourceEngine->getUID()) { | 
					
						
							|  |  |  |                 qDebug("FileSink::getLocalDevice: source device at index %u is the parent device", index); | 
					
						
							|  |  |  |             } else { | 
					
						
							|  |  |  |                 return deviceSource; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         else | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             qDebug("FileSink::getLocalDevice: source device at index %u is not a SigMF File sink", index); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         qDebug("FileSink::getLocalDevice: non existent source device index: %u", index); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return nullptr; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void FileSink::applySettings(const FileSinkSettings& settings, bool force) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     qDebug() << "FileSink::applySettings:" | 
					
						
							|  |  |  |         << "m_inputFrequencyOffset: " << settings.m_inputFrequencyOffset | 
					
						
							|  |  |  |         << "m_log2Decim: " << settings.m_log2Decim | 
					
						
							|  |  |  |         << "m_fileRecordName: " << settings.m_fileRecordName | 
					
						
							|  |  |  |         << "force: " << force; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     QList<QString> reverseAPIKeys; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if ((settings.m_inputFrequencyOffset != m_settings.m_inputFrequencyOffset) || force) { | 
					
						
							|  |  |  |         reverseAPIKeys.append("inputFrequencyOffset"); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if ((settings.m_fileRecordName != m_settings.m_fileRecordName) || force) { | 
					
						
							|  |  |  |         reverseAPIKeys.append("fileRecordName"); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if ((settings.m_rgbColor != m_settings.m_rgbColor) || force) { | 
					
						
							|  |  |  |         reverseAPIKeys.append("rgbColor"); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if ((settings.m_title != m_settings.m_title) || force) { | 
					
						
							|  |  |  |         reverseAPIKeys.append("title"); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if ((settings.m_log2Decim != m_settings.m_log2Decim) || force) { | 
					
						
							|  |  |  |         reverseAPIKeys.append("log2Decim"); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if ((settings.m_spectrumSquelchMode != m_settings.m_spectrumSquelchMode) || force) { | 
					
						
							|  |  |  |         reverseAPIKeys.append("spectrumSquelchMode"); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if ((settings.m_spectrumSquelch != m_settings.m_spectrumSquelch) || force) { | 
					
						
							|  |  |  |         reverseAPIKeys.append("spectrumSquelch"); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if ((settings.m_preRecordTime != m_settings.m_preRecordTime) || force) { | 
					
						
							|  |  |  |         reverseAPIKeys.append("preRecordTime"); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if ((settings.m_squelchPostRecordTime != m_settings.m_squelchPostRecordTime) || force) { | 
					
						
							|  |  |  |         reverseAPIKeys.append("squelchPostRecordTime"); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if ((settings.m_squelchRecordingEnable != m_settings.m_squelchRecordingEnable) || force) { | 
					
						
							|  |  |  |         reverseAPIKeys.append("squelchRecordingEnable"); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (m_settings.m_streamIndex != settings.m_streamIndex) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (m_deviceAPI->getSampleMIMO()) // change of stream is possible for MIMO devices only
 | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             m_deviceAPI->removeChannelSinkAPI(this); | 
					
						
							|  |  |  |             m_deviceAPI->removeChannelSink(this, m_settings.m_streamIndex); | 
					
						
							|  |  |  |             m_deviceAPI->addChannelSink(this, settings.m_streamIndex); | 
					
						
							|  |  |  |             m_deviceAPI->addChannelSinkAPI(this); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         reverseAPIKeys.append("streamIndex"); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-07-23 05:46:06 +02:00
										 |  |  |     if (m_running) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         FileSinkBaseband::MsgConfigureFileSinkBaseband *msg = FileSinkBaseband::MsgConfigureFileSinkBaseband::create(settings, force); | 
					
						
							|  |  |  |         m_basebandSink->getInputMessageQueue()->push(msg); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     if ((settings.m_useReverseAPI) && (reverseAPIKeys.size() != 0)) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         bool fullUpdate = ((m_settings.m_useReverseAPI != settings.m_useReverseAPI) && settings.m_useReverseAPI) || | 
					
						
							|  |  |  |                 (m_settings.m_reverseAPIAddress != settings.m_reverseAPIAddress) || | 
					
						
							|  |  |  |                 (m_settings.m_reverseAPIPort != settings.m_reverseAPIPort) || | 
					
						
							|  |  |  |                 (m_settings.m_reverseAPIDeviceIndex != settings.m_reverseAPIDeviceIndex) || | 
					
						
							|  |  |  |                 (m_settings.m_reverseAPIChannelIndex != settings.m_reverseAPIChannelIndex); | 
					
						
							|  |  |  |         webapiReverseSendSettings(reverseAPIKeys, settings, fullUpdate || force); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-02 23:07:15 +01:00
										 |  |  |     QList<ObjectPipe*> pipes; | 
					
						
							| 
									
										
										
										
											2022-03-02 23:57:35 +01:00
										 |  |  |     MainCore::instance()->getMessagePipes().getMessagePipes(this, "settings", pipes); | 
					
						
							| 
									
										
										
										
											2020-12-13 13:04:36 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-02 23:07:15 +01:00
										 |  |  |     if (pipes.size() > 0) { | 
					
						
							|  |  |  |         sendChannelSettings(pipes, reverseAPIKeys, settings, force); | 
					
						
							| 
									
										
										
										
											2020-10-23 00:11:18 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |     m_settings = settings; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void FileSink::record(bool record) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2022-07-23 05:46:06 +02:00
										 |  |  |     if (m_running) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         FileSinkBaseband::MsgConfigureFileSinkWork *msg = FileSinkBaseband::MsgConfigureFileSinkWork::create(record); | 
					
						
							|  |  |  |         m_basebandSink->getInputMessageQueue()->push(msg); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | uint64_t FileSink::getMsCount() const | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2022-07-23 05:46:06 +02:00
										 |  |  |     if (m_running) { | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |         return m_basebandSink->getMsCount(); | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |         return 0; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | uint64_t FileSink::getByteCount() const | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2022-07-23 05:46:06 +02:00
										 |  |  |     if (m_running) { | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |         return m_basebandSink->getByteCount(); | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |         return 0; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | unsigned int FileSink::getNbTracks() const | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2022-07-23 05:46:06 +02:00
										 |  |  |     if (m_running) { | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |         return m_basebandSink->getNbTracks(); | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |         return 0; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int FileSink::webapiSettingsGet( | 
					
						
							|  |  |  |         SWGSDRangel::SWGChannelSettings& response, | 
					
						
							|  |  |  |         QString& errorMessage) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     (void) errorMessage; | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |     response.setFileSinkSettings(new SWGSDRangel::SWGFileSinkSettings()); | 
					
						
							|  |  |  |     response.getFileSinkSettings()->init(); | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |     webapiFormatChannelSettings(response, m_settings); | 
					
						
							|  |  |  |     return 200; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-05-13 22:24:48 +02:00
										 |  |  | int FileSink::webapiWorkspaceGet( | 
					
						
							|  |  |  |         SWGSDRangel::SWGWorkspaceInfo& response, | 
					
						
							|  |  |  |         QString& errorMessage) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     (void) errorMessage; | 
					
						
							|  |  |  |     response.setIndex(m_settings.m_workspaceIndex); | 
					
						
							|  |  |  |     return 200; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  | int FileSink::webapiSettingsPutPatch( | 
					
						
							|  |  |  |         bool force, | 
					
						
							|  |  |  |         const QStringList& channelSettingsKeys, | 
					
						
							|  |  |  |         SWGSDRangel::SWGChannelSettings& response, | 
					
						
							|  |  |  |         QString& errorMessage) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     (void) errorMessage; | 
					
						
							|  |  |  |     FileSinkSettings settings = m_settings; | 
					
						
							|  |  |  |     webapiUpdateChannelSettings(settings, channelSettingsKeys, response); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     MsgConfigureFileSink *msg = MsgConfigureFileSink::create(settings, force); | 
					
						
							|  |  |  |     m_inputMessageQueue.push(msg); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     qDebug("FileSink::webapiSettingsPutPatch: forward to GUI: %p", m_guiMessageQueue); | 
					
						
							|  |  |  |     if (m_guiMessageQueue) // forward to GUI if any
 | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         MsgConfigureFileSink *msgToGUI = MsgConfigureFileSink::create(settings, force); | 
					
						
							|  |  |  |         m_guiMessageQueue->push(msgToGUI); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     webapiFormatChannelSettings(response, settings); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return 200; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int FileSink::webapiReportGet( | 
					
						
							|  |  |  |         SWGSDRangel::SWGChannelReport& response, | 
					
						
							|  |  |  |         QString& errorMessage) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     (void) errorMessage; | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |     response.setFileSinkReport(new SWGSDRangel::SWGFileSinkReport()); | 
					
						
							|  |  |  |     response.getFileSinkReport()->init(); | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |     webapiFormatChannelReport(response); | 
					
						
							|  |  |  |     return 200; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int FileSink::webapiActionsPost( | 
					
						
							|  |  |  |         const QStringList& channelActionsKeys, | 
					
						
							|  |  |  |         SWGSDRangel::SWGChannelActions& query, | 
					
						
							|  |  |  |         QString& errorMessage) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |     SWGSDRangel::SWGFileSinkActions *swgFileSinkActions = query.getFileSinkActions(); | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |     if (swgFileSinkActions) | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |     { | 
					
						
							|  |  |  |         if (channelActionsKeys.contains("record")) | 
					
						
							|  |  |  |         { | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |             bool record = swgFileSinkActions->getRecord() != 0; | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |             if (!m_settings.m_squelchRecordingEnable) | 
					
						
							|  |  |  |             { | 
					
						
							| 
									
										
										
										
											2022-07-23 05:46:06 +02:00
										 |  |  |                 if (m_running) | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     FileSinkBaseband::MsgConfigureFileSinkWork *msg = FileSinkBaseband::MsgConfigureFileSinkWork::create(record); | 
					
						
							|  |  |  |                     m_basebandSink->getInputMessageQueue()->push(msg); | 
					
						
							|  |  |  |                 } | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 if (getMessageQueueToGUI()) | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     FileSinkMessages::MsgReportRecording *msgToGUI = FileSinkMessages::MsgReportRecording::create(record); | 
					
						
							|  |  |  |                     getMessageQueueToGUI()->push(msgToGUI); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return 202; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |         errorMessage = "Missing FileSinkActions in query"; | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |         return 400; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void FileSink::webapiUpdateChannelSettings( | 
					
						
							|  |  |  |         FileSinkSettings& settings, | 
					
						
							|  |  |  |         const QStringList& channelSettingsKeys, | 
					
						
							|  |  |  |         SWGSDRangel::SWGChannelSettings& response) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     if (channelSettingsKeys.contains("inputFrequencyOffset")) { | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |         settings.m_inputFrequencyOffset = response.getFileSinkSettings()->getInputFrequencyOffset(); | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |     if (channelSettingsKeys.contains("fileRecordName")) { | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |         settings.m_fileRecordName = *response.getFileSinkSettings()->getFileRecordName(); | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |     if (channelSettingsKeys.contains("rgbColor")) { | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |         settings.m_rgbColor = response.getFileSinkSettings()->getRgbColor(); | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |     if (channelSettingsKeys.contains("title")) { | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |         settings.m_title = *response.getFileSinkSettings()->getTitle(); | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |     if (channelSettingsKeys.contains("log2Decim")) { | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |         settings.m_log2Decim = response.getFileSinkSettings()->getLog2Decim(); | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |     if (channelSettingsKeys.contains("spectrumSquelchMode")) { | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |         settings.m_spectrumSquelchMode = response.getFileSinkSettings()->getSpectrumSquelchMode() != 0; | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |     if (channelSettingsKeys.contains("spectrumSquelch")) { | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |         settings.m_spectrumSquelch = response.getFileSinkSettings()->getSpectrumSquelch(); | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |     if (channelSettingsKeys.contains("preRecordTime")) { | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |         settings.m_preRecordTime = response.getFileSinkSettings()->getPreRecordTime(); | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |     if (channelSettingsKeys.contains("squelchPostRecordTime")) { | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |         settings.m_squelchPostRecordTime = response.getFileSinkSettings()->getSquelchPostRecordTime(); | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |     if (channelSettingsKeys.contains("squelchRecordingEnable")) { | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |         settings.m_squelchRecordingEnable = response.getFileSinkSettings()->getSquelchRecordingEnable() != 0; | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |     if (channelSettingsKeys.contains("streamIndex")) { | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |         settings.m_streamIndex = response.getFileSinkSettings()->getStreamIndex(); | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |     if (channelSettingsKeys.contains("useReverseAPI")) { | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |         settings.m_useReverseAPI = response.getFileSinkSettings()->getUseReverseApi() != 0; | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |     if (channelSettingsKeys.contains("reverseAPIAddress")) { | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |         settings.m_reverseAPIAddress = *response.getFileSinkSettings()->getReverseApiAddress(); | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |     if (channelSettingsKeys.contains("reverseAPIPort")) { | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |         settings.m_reverseAPIPort = response.getFileSinkSettings()->getReverseApiPort(); | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |     if (channelSettingsKeys.contains("reverseAPIDeviceIndex")) { | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |         settings.m_reverseAPIDeviceIndex = response.getFileSinkSettings()->getReverseApiDeviceIndex(); | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |     if (channelSettingsKeys.contains("reverseAPIChannelIndex")) { | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |         settings.m_reverseAPIChannelIndex = response.getFileSinkSettings()->getReverseApiChannelIndex(); | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |     if (channelSettingsKeys.contains("inputFrequencyOffset")) { | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |         settings.m_reverseAPIChannelIndex = response.getFileSinkSettings()->getInputFrequencyOffset(); | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-12-01 00:20:14 +01:00
										 |  |  |     if (settings.m_spectrumGUI && channelSettingsKeys.contains("spectrumConfig")) { | 
					
						
							|  |  |  |         settings.m_spectrumGUI->updateFrom(channelSettingsKeys, response.getFileSinkSettings()->getSpectrumConfig()); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-12-02 23:54:39 +01:00
										 |  |  |     if (settings.m_channelMarker && channelSettingsKeys.contains("channelMarker")) { | 
					
						
							|  |  |  |         settings.m_channelMarker->updateFrom(channelSettingsKeys, response.getFileSinkSettings()->getChannelMarker()); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2022-01-09 05:27:12 +01:00
										 |  |  |     if (settings.m_rollupState && channelSettingsKeys.contains("rollupState")) { | 
					
						
							|  |  |  |         settings.m_rollupState->updateFrom(channelSettingsKeys, response.getFileSinkSettings()->getRollupState()); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void FileSink::webapiFormatChannelSettings(SWGSDRangel::SWGChannelSettings& response, const FileSinkSettings& settings) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |     response.getFileSinkSettings()->setInputFrequencyOffset(settings.m_inputFrequencyOffset); | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |     if (response.getFileSinkSettings()->getFileRecordName()) { | 
					
						
							|  |  |  |         *response.getFileSinkSettings()->getFileRecordName() = settings.m_fileRecordName; | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |     } else { | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |         response.getFileSinkSettings()->setFileRecordName(new QString(settings.m_fileRecordName)); | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |     response.getFileSinkSettings()->setRgbColor(settings.m_rgbColor); | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |     if (response.getFileSinkSettings()->getTitle()) { | 
					
						
							|  |  |  |         *response.getFileSinkSettings()->getTitle() = settings.m_title; | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |     } else { | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |         response.getFileSinkSettings()->setTitle(new QString(settings.m_title)); | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |     response.getFileSinkSettings()->setLog2Decim(settings.m_log2Decim); | 
					
						
							|  |  |  |     response.getFileSinkSettings()->setSpectrumSquelchMode(settings.m_spectrumSquelchMode ? 1 : 0); | 
					
						
							|  |  |  |     response.getFileSinkSettings()->setSpectrumSquelch(settings.m_spectrumSquelch); | 
					
						
							|  |  |  |     response.getFileSinkSettings()->setPreRecordTime(settings.m_preRecordTime); | 
					
						
							|  |  |  |     response.getFileSinkSettings()->setSquelchPostRecordTime(settings.m_squelchPostRecordTime); | 
					
						
							|  |  |  |     response.getFileSinkSettings()->setSquelchRecordingEnable(settings.m_squelchRecordingEnable ? 1 : 0); | 
					
						
							|  |  |  |     response.getFileSinkSettings()->setStreamIndex(settings.m_streamIndex); | 
					
						
							|  |  |  |     response.getFileSinkSettings()->setUseReverseApi(settings.m_useReverseAPI ? 1 : 0); | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |     if (response.getFileSinkSettings()->getReverseApiAddress()) { | 
					
						
							|  |  |  |         *response.getFileSinkSettings()->getReverseApiAddress() = settings.m_reverseAPIAddress; | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |     } else { | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |         response.getFileSinkSettings()->setReverseApiAddress(new QString(settings.m_reverseAPIAddress)); | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |     response.getFileSinkSettings()->setReverseApiPort(settings.m_reverseAPIPort); | 
					
						
							|  |  |  |     response.getFileSinkSettings()->setReverseApiDeviceIndex(settings.m_reverseAPIDeviceIndex); | 
					
						
							|  |  |  |     response.getFileSinkSettings()->setReverseApiChannelIndex(settings.m_reverseAPIChannelIndex); | 
					
						
							| 
									
										
										
										
											2021-12-01 00:20:14 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     if (settings.m_spectrumGUI) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (response.getFileSinkSettings()->getSpectrumConfig()) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             settings.m_spectrumGUI->formatTo(response.getFileSinkSettings()->getSpectrumConfig()); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         else | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             SWGSDRangel::SWGGLSpectrum *swgGLSpectrum = new SWGSDRangel::SWGGLSpectrum(); | 
					
						
							|  |  |  |             settings.m_spectrumGUI->formatTo(swgGLSpectrum); | 
					
						
							|  |  |  |             response.getFileSinkSettings()->setSpectrumConfig(swgGLSpectrum); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-12-02 23:54:39 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     if (settings.m_channelMarker) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (response.getFileSinkSettings()->getChannelMarker()) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             settings.m_channelMarker->formatTo(response.getFileSinkSettings()->getChannelMarker()); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         else | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             SWGSDRangel::SWGChannelMarker *swgChannelMarker = new SWGSDRangel::SWGChannelMarker(); | 
					
						
							|  |  |  |             settings.m_channelMarker->formatTo(swgChannelMarker); | 
					
						
							|  |  |  |             response.getFileSinkSettings()->setChannelMarker(swgChannelMarker); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2022-01-09 05:27:12 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     if (settings.m_rollupState) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (response.getFileSinkSettings()->getRollupState()) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             settings.m_rollupState->formatTo(response.getFileSinkSettings()->getRollupState()); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         else | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             SWGSDRangel::SWGRollupState *swgRollupState = new SWGSDRangel::SWGRollupState(); | 
					
						
							|  |  |  |             settings.m_rollupState->formatTo(swgRollupState); | 
					
						
							|  |  |  |             response.getFileSinkSettings()->setRollupState(swgRollupState); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void FileSink::webapiFormatChannelReport(SWGSDRangel::SWGChannelReport& response) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |     response.getFileSinkReport()->setRecordTimeMs(getMsCount()); | 
					
						
							|  |  |  |     response.getFileSinkReport()->setRecordSize(getByteCount()); | 
					
						
							|  |  |  |     response.getFileSinkReport()->setRecordCaptures(getNbTracks()); | 
					
						
							| 
									
										
										
										
											2022-07-23 05:46:06 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     if (m_running) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         response.getFileSinkReport()->setSpectrumSquelch(m_basebandSink->isSquelchOpen() ? 1 : 0); | 
					
						
							|  |  |  |         response.getFileSinkReport()->setSpectrumMax(m_basebandSink->getSpecMax()); | 
					
						
							|  |  |  |         response.getFileSinkReport()->setSinkSampleRate(m_basebandSink->getSinkSampleRate()); | 
					
						
							|  |  |  |         response.getFileSinkReport()->setRecording(m_basebandSink->isRecording() ? 1 : 0); | 
					
						
							|  |  |  |         response.getFileSinkReport()->setChannelSampleRate(m_basebandSink->getChannelSampleRate()); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void FileSink::webapiReverseSendSettings(QList<QString>& channelSettingsKeys, const FileSinkSettings& settings, bool force) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     SWGSDRangel::SWGChannelSettings *swgChannelSettings = new SWGSDRangel::SWGChannelSettings(); | 
					
						
							| 
									
										
										
										
											2020-10-23 00:11:18 +02:00
										 |  |  |     webapiFormatChannelSettings(channelSettingsKeys, swgChannelSettings, settings, force); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     QString channelSettingsURL = QString("http://%1:%2/sdrangel/deviceset/%3/channel/%4/settings") | 
					
						
							|  |  |  |             .arg(settings.m_reverseAPIAddress) | 
					
						
							|  |  |  |             .arg(settings.m_reverseAPIPort) | 
					
						
							|  |  |  |             .arg(settings.m_reverseAPIDeviceIndex) | 
					
						
							|  |  |  |             .arg(settings.m_reverseAPIChannelIndex); | 
					
						
							|  |  |  |     m_networkRequest.setUrl(QUrl(channelSettingsURL)); | 
					
						
							|  |  |  |     m_networkRequest.setHeader(QNetworkRequest::ContentTypeHeader, "application/json"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     QBuffer *buffer = new QBuffer(); | 
					
						
							|  |  |  |     buffer->open((QBuffer::ReadWrite)); | 
					
						
							|  |  |  |     buffer->write(swgChannelSettings->asJson().toUtf8()); | 
					
						
							|  |  |  |     buffer->seek(0); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // Always use PATCH to avoid passing reverse API settings
 | 
					
						
							|  |  |  |     QNetworkReply *reply = m_networkManager->sendCustomRequest(m_networkRequest, "PATCH", buffer); | 
					
						
							|  |  |  |     buffer->setParent(reply); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     delete swgChannelSettings; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-13 13:04:36 +01:00
										 |  |  | void FileSink::sendChannelSettings( | 
					
						
							| 
									
										
										
										
											2022-03-02 23:07:15 +01:00
										 |  |  |     const QList<ObjectPipe*>& pipes, | 
					
						
							| 
									
										
										
										
											2020-12-13 13:04:36 +01:00
										 |  |  |     QList<QString>& channelSettingsKeys, | 
					
						
							|  |  |  |     const FileSinkSettings& settings, | 
					
						
							|  |  |  |     bool force) | 
					
						
							| 
									
										
										
										
											2020-10-23 00:11:18 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2022-03-02 23:07:15 +01:00
										 |  |  |     for (const auto& pipe : pipes) | 
					
						
							| 
									
										
										
										
											2020-10-23 00:11:18 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2022-03-02 23:07:15 +01:00
										 |  |  |         MessageQueue *messageQueue = qobject_cast<MessageQueue*>(pipe->m_element); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (messageQueue) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             SWGSDRangel::SWGChannelSettings *swgChannelSettings = new SWGSDRangel::SWGChannelSettings(); | 
					
						
							|  |  |  |             webapiFormatChannelSettings(channelSettingsKeys, swgChannelSettings, settings, force); | 
					
						
							|  |  |  |             MainCore::MsgChannelSettings *msg = MainCore::MsgChannelSettings::create( | 
					
						
							|  |  |  |                 this, | 
					
						
							|  |  |  |                 channelSettingsKeys, | 
					
						
							|  |  |  |                 swgChannelSettings, | 
					
						
							|  |  |  |                 force | 
					
						
							|  |  |  |             ); | 
					
						
							|  |  |  |             messageQueue->push(msg); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2020-10-23 00:11:18 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void FileSink::webapiFormatChannelSettings( | 
					
						
							|  |  |  |         QList<QString>& channelSettingsKeys, | 
					
						
							|  |  |  |         SWGSDRangel::SWGChannelSettings *swgChannelSettings, | 
					
						
							|  |  |  |         const FileSinkSettings& settings, | 
					
						
							|  |  |  |         bool force | 
					
						
							|  |  |  | ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     swgChannelSettings->setDirection(0); // Single sink (Rx)
 | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |     swgChannelSettings->setOriginatorChannelIndex(getIndexInDeviceSet()); | 
					
						
							|  |  |  |     swgChannelSettings->setOriginatorDeviceSetIndex(getDeviceSetIndex()); | 
					
						
							| 
									
										
										
										
											2020-10-23 00:11:18 +02:00
										 |  |  |     swgChannelSettings->setChannelType(new QString(m_channelId)); | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |     swgChannelSettings->setFileSinkSettings(new SWGSDRangel::SWGFileSinkSettings()); | 
					
						
							|  |  |  |     SWGSDRangel::SWGFileSinkSettings *swgFileSinkSettings = swgChannelSettings->getFileSinkSettings(); | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     // transfer data that has been modified. When force is on transfer all data except reverse API data
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (channelSettingsKeys.contains("inputFrequencyOffset")) { | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |         swgFileSinkSettings->setInputFrequencyOffset(settings.m_inputFrequencyOffset); | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |     if (channelSettingsKeys.contains("fileRecordName")) { | 
					
						
							| 
									
										
										
										
											2022-11-13 22:24:03 +01:00
										 |  |  |         swgFileSinkSettings->setFileRecordName(new QString(settings.m_fileRecordName)); | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |     if (channelSettingsKeys.contains("rgbColor") || force) { | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |         swgFileSinkSettings->setRgbColor(settings.m_rgbColor); | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |     if (channelSettingsKeys.contains("title") || force) { | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |         swgFileSinkSettings->setTitle(new QString(settings.m_title)); | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |     if (channelSettingsKeys.contains("log2Decim") || force) { | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |         swgFileSinkSettings->setLog2Decim(settings.m_log2Decim); | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |     if (channelSettingsKeys.contains("spectrumSquelchMode")) { | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |         swgFileSinkSettings->setSpectrumSquelchMode(settings.m_spectrumSquelchMode ? 1 : 0); | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |     if (channelSettingsKeys.contains("spectrumSquelch")) { | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |         swgFileSinkSettings->setSpectrumSquelch(settings.m_spectrumSquelch); | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |     if (channelSettingsKeys.contains("preRecordTime")) { | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |         swgFileSinkSettings->setPreRecordTime(settings.m_preRecordTime); | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |     if (channelSettingsKeys.contains("squelchPostRecordTime")) { | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |         swgFileSinkSettings->setSquelchPostRecordTime(settings.m_squelchPostRecordTime); | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |     if (channelSettingsKeys.contains("squelchRecordingEnable")) { | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |         swgFileSinkSettings->setSquelchRecordingEnable(settings.m_squelchRecordingEnable ? 1 : 0); | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |     if (channelSettingsKeys.contains("streamIndex")) { | 
					
						
							| 
									
										
										
										
											2020-08-07 08:00:49 +02:00
										 |  |  |         swgFileSinkSettings->setStreamIndex(settings.m_streamIndex); | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-12-02 23:54:39 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-01 00:20:14 +01:00
										 |  |  |     if (settings.m_spectrumGUI && (channelSettingsKeys.contains("spectrunConfig") || force)) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         SWGSDRangel::SWGGLSpectrum *swgGLSpectrum = new SWGSDRangel::SWGGLSpectrum(); | 
					
						
							|  |  |  |         settings.m_spectrumGUI->formatTo(swgGLSpectrum); | 
					
						
							|  |  |  |         swgFileSinkSettings->setSpectrumConfig(swgGLSpectrum); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-12-02 23:54:39 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     if (settings.m_channelMarker && (channelSettingsKeys.contains("channelMarker") || force)) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         SWGSDRangel::SWGChannelMarker *swgChannelMarker = new SWGSDRangel::SWGChannelMarker(); | 
					
						
							|  |  |  |         settings.m_channelMarker->formatTo(swgChannelMarker); | 
					
						
							|  |  |  |         swgFileSinkSettings->setChannelMarker(swgChannelMarker); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2022-01-09 05:27:12 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     if (settings.m_rollupState && (channelSettingsKeys.contains("rollupState") || force)) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         SWGSDRangel::SWGRollupState *swgRollupState = new SWGSDRangel::SWGRollupState(); | 
					
						
							|  |  |  |         settings.m_rollupState->formatTo(swgRollupState); | 
					
						
							|  |  |  |         swgFileSinkSettings->setRollupState(swgRollupState); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-08-06 10:46:49 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void FileSink::networkManagerFinished(QNetworkReply *reply) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     QNetworkReply::NetworkError replyError = reply->error(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (replyError) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         qWarning() << "FileSink::networkManagerFinished:" | 
					
						
							|  |  |  |                 << " error(" << (int) replyError | 
					
						
							|  |  |  |                 << "): " << replyError | 
					
						
							|  |  |  |                 << ": " << reply->errorString(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         QString answer = reply->readAll(); | 
					
						
							|  |  |  |         answer.chop(1); // remove last \n
 | 
					
						
							|  |  |  |         qDebug("FileSink::networkManagerFinished: reply:\n%s", answer.toStdString().c_str()); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     reply->deleteLater(); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2022-03-18 17:08:04 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | void FileSink::handleIndexInDeviceSetChanged(int index) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2022-07-23 05:46:06 +02:00
										 |  |  |     if (!m_running || (index < 0)) { | 
					
						
							| 
									
										
										
										
											2022-03-18 17:08:04 +01:00
										 |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     QString fifoLabel = QString("%1 [%2:%3]") | 
					
						
							|  |  |  |         .arg(m_channelId) | 
					
						
							|  |  |  |         .arg(m_deviceAPI->getDeviceSetIndex()) | 
					
						
							|  |  |  |         .arg(index); | 
					
						
							|  |  |  |     m_basebandSink->setFifoLabel(fifoLabel); | 
					
						
							|  |  |  | } |