/////////////////////////////////////////////////////////////////////////////////// // Copyright (C) 2015 F4EXB // // written by Edouard Griffiths // // // // 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 // // // // 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 . // /////////////////////////////////////////////////////////////////////////////////// #ifndef INCLUDE_THREADEDSAMPLESINK_H #define INCLUDE_THREADEDSAMPLESINK_H #include #include #include "samplesink.h" #include "dsp/samplefifo.h" #include "util/messagequeue.h" #include "util/export.h" #include "util/syncmessenger.h" class SampleSink; /** * This class is a wrapper for SampleSink that runs the SampleSink object in its own thread */ class SDRANGELOVE_API ThreadedSampleSink : public QThread { Q_OBJECT public: ThreadedSampleSink(SampleSink* sampleSink); ~ThreadedSampleSink(); const SampleSink *getSink() const { return m_sampleSink; } MessageQueue* getInputMessageQueue() { return m_sampleSink->getInputMessageQueue(); } //!< Return pointer to sample sink's input message queue MessageQueue* getOutputMessageQueue() { return m_sampleSink->getOutputMessageQueue(); } //!< Return pointer to sample sink's output message queue void start(); //!< this thread start() void stop(); //!< this thread exit() and wait() bool sendWaitSink(Message& cmd); //!< Send message to sink synchronously void feed(SampleVector::const_iterator& begin, SampleVector::const_iterator& end, bool positiveOnly); //!< Feed sink with samples QString getSampleSinkObjectName() const; protected: SyncMessenger m_syncMessenger; //!< Used to process messages synchronously with the thread SampleSink* m_sampleSink; private: void run(); //!< this thread run() method private slots: void handleSynchronousMessages(); //!< Handle synchronous messages with the thread }; #endif // INCLUDE_THREADEDSAMPLESINK_H