mirror of
				https://github.com/f4exb/sdrangel.git
				synced 2025-10-25 18:10:22 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			385 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			385 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| ///////////////////////////////////////////////////////////////////////////////////////
 | |
| // Copyright (C) 2012 maintech GmbH, Otto-Hahn-Str. 15, 97204 Hoechberg, Germany     //
 | |
| // written by Christian Daniel                                                       //
 | |
| // Copyright (C) 2015-2021 Edouard Griffiths, F4EXB <f4exb06@gmail.com>              //
 | |
| // Copyright (C) 2020, 2022 Jon Beniston, M7RCE <jon@beniston.com>                   //
 | |
| //                                                                                   //
 | |
| // 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/>.              //
 | |
| ///////////////////////////////////////////////////////////////////////////////////////
 | |
| #ifndef INCLUDE_PLUGININTERFACE_H
 | |
| #define INCLUDE_PLUGININTERFACE_H
 | |
| 
 | |
| #include <QtPlugin>
 | |
| #include <QString>
 | |
| 
 | |
| #include "export.h"
 | |
| 
 | |
| struct SDRBASE_API PluginDescriptor {
 | |
|     const QString hardwareId;
 | |
| 	// general plugin description
 | |
| 	const QString displayedName;
 | |
| 	const QString version;
 | |
| 	const QString copyright;
 | |
| 	const QString website;
 | |
| 	bool licenseIsGPL;
 | |
| 	const QString sourceCodeURL;
 | |
| };
 | |
| 
 | |
| class PluginAPI;
 | |
| class DeviceAPI;
 | |
| class DeviceSet;
 | |
| class DeviceUISet;
 | |
| class FeatureUISet;
 | |
| class WebAPIAdapterInterface;
 | |
| class DeviceGUI;
 | |
| class QWidget;
 | |
| class DeviceSampleSource;
 | |
| class DeviceSampleSink;
 | |
| class DeviceSampleMIMO;
 | |
| class BasebandSampleSink;
 | |
| class BasebandSampleSource;
 | |
| class MIMOChannel;
 | |
| class ChannelAPI;
 | |
| class ChannelGUI;
 | |
| class ChannelWebAPIAdapter;
 | |
| class DeviceWebAPIAdapter;
 | |
| class FeatureWebAPIAdapter;
 | |
| class Feature;
 | |
| class FeatureGUI;
 | |
| 
 | |
| class SDRBASE_API PluginInterface {
 | |
| public:
 | |
| 	struct SamplingDevice
 | |
| 	{
 | |
|         enum SamplingDeviceType
 | |
|         {
 | |
|             PhysicalDevice,
 | |
|             BuiltInDevice
 | |
|         };
 | |
| 
 | |
|         enum StreamType
 | |
|         {
 | |
|             StreamSingleRx, //!< Exposes a single input stream that can be one of the streams of a physical device
 | |
|             StreamSingleTx, //!< Exposes a single output stream that can be one of the streams of a physical device
 | |
|             StreamMIMO      //!< May expose any number of input and/or output streams
 | |
|         };
 | |
| 
 | |
| 		QString displayedName;    //!< The human readable name
 | |
| 		QString hardwareId;       //!< The internal id that identifies the type of hardware (i.e. HackRF, BladeRF, ...)
 | |
| 		QString id;               //!< The internal plugin ID corresponding to the device (i.e. for HackRF input, for HackRF output ...)
 | |
| 		QString serial;           //!< The device serial number defined by the vendor or a fake one (SDRplay)
 | |
| 		int sequence;             //!< The device sequence. >0 when more than one device of the same type is connected
 | |
| 		SamplingDeviceType type;  //!< The sampling device type for behavior information
 | |
| 		StreamType streamType;    //!< This is the type of stream supported
 | |
| 		int deviceNbItems;        //!< Number of items (or streams) in the device. >1 for composite devices.
 | |
| 		int deviceItemIndex;      //!< For composite devices this is the Rx or Tx stream index. -1 if not initialized
 | |
| 		int claimed = -1;         //!< This is the device set index if claimed else -1
 | |
|         bool removed = false;     //!< Set if device has been removed
 | |
| 
 | |
| 		SamplingDevice(const QString& _displayedName,
 | |
|                 const QString& _hardwareId,
 | |
| 				const QString& _id,
 | |
| 				const QString& _serial,
 | |
| 				int _sequence,
 | |
| 				SamplingDeviceType _type,
 | |
| 				StreamType _streamType,
 | |
| 				int _deviceNbItems,
 | |
| 				int _deviceItemIndex) :
 | |
| 			displayedName(_displayedName),
 | |
| 			hardwareId(_hardwareId),
 | |
| 			id(_id),
 | |
| 			serial(_serial),
 | |
| 			sequence(_sequence),
 | |
| 			type(_type),
 | |
| 			streamType(_streamType),
 | |
| 			deviceNbItems(_deviceNbItems),
 | |
| 			deviceItemIndex(_deviceItemIndex)
 | |
| 		{ }
 | |
| 
 | |
|         bool operator==(const SamplingDevice& rhs) const
 | |
|         {
 | |
|             return displayedName == rhs.displayedName
 | |
|                 && hardwareId == rhs.hardwareId
 | |
|                 && id == rhs.id
 | |
|                 && serial == rhs.serial;
 | |
|         }
 | |
| 	};
 | |
| 	using SamplingDevices = QList<SamplingDevice>;
 | |
| 
 | |
|     /** This is the device from which the sampling devices are derived. For physical devices this represents
 | |
|      * a single physical unit (a LimeSDR, HackRF, BladeRF, RTL-SDR dongle, ...) that is enumerated once and
 | |
|      * reported in the system so that the "sampling devices" used in the system can be registered
 | |
|     */
 | |
|     struct OriginDevice
 | |
|     {
 | |
|         QString displayableName; //!< A human readable name
 | |
|         QString hardwareId;      //!< The internal id that identifies the type of hardware (i.e. HackRF, BladeRF, ...)
 | |
|         QString serial;          //!< The device serial number defined by the vendor or a fake one (SDRplay)
 | |
|         int sequence;            //!< The device sequence in order of enumeration
 | |
|         int nbRxStreams;         //!< Number of receiver streams
 | |
|         int nbTxStreams;         //!< Number of transmitter streams
 | |
| 
 | |
|         OriginDevice(
 | |
|                 const QString& _displayableName,
 | |
|                 const QString& _hardwareId,
 | |
| 				const QString& _serial,
 | |
| 				int _sequence,
 | |
|                 int _nbRxStreams,
 | |
|                 int _nbTxStreams
 | |
|         ) :
 | |
|             displayableName(_displayableName),
 | |
|             hardwareId(_hardwareId),
 | |
|             serial(_serial),
 | |
|             sequence(_sequence),
 | |
|             nbRxStreams(_nbRxStreams),
 | |
|             nbTxStreams(_nbTxStreams)
 | |
|         {}
 | |
|     };
 | |
|     using OriginDevices = QList<OriginDevice>;
 | |
| 
 | |
|     virtual ~PluginInterface() = default;
 | |
| 
 | |
| 	virtual const PluginDescriptor& getPluginDescriptor() const = 0;
 | |
| 	virtual void initPlugin(PluginAPI* pluginAPI) = 0;
 | |
| 
 | |
| 	// channel Rx plugins
 | |
| 
 | |
|     virtual void createRxChannel(DeviceAPI *deviceAPI, BasebandSampleSink **bs, ChannelAPI **cs) const
 | |
|     {
 | |
|         (void) deviceAPI;
 | |
|         (void) bs;
 | |
|         (void) cs;
 | |
|     }
 | |
| 
 | |
|     virtual ChannelGUI* createRxChannelGUI(
 | |
|             DeviceUISet *deviceUISet,
 | |
|             BasebandSampleSink *rxChannel) const
 | |
|     {
 | |
|         (void) deviceUISet;
 | |
|         (void) rxChannel;
 | |
|         return nullptr;
 | |
|     }
 | |
| 
 | |
|     // channel Tx plugins
 | |
| 
 | |
|     virtual void createTxChannel(DeviceAPI *deviceAPI, BasebandSampleSource **bs, ChannelAPI **cs) const
 | |
|     {
 | |
|         (void) deviceAPI;
 | |
|         (void) bs;
 | |
|         (void) cs;
 | |
|     }
 | |
| 
 | |
| 	virtual ChannelGUI* createTxChannelGUI(
 | |
|             DeviceUISet *deviceUISet,
 | |
|             BasebandSampleSource *txChannel) const
 | |
|     {
 | |
|         (void) deviceUISet;
 | |
|         (void) txChannel;
 | |
|         return nullptr;
 | |
|     }
 | |
| 
 | |
|     // channel MIMO plugins
 | |
| 
 | |
|     virtual void createMIMOChannel(DeviceAPI *deviceAPI, MIMOChannel **bs, ChannelAPI **cs) const
 | |
|     {
 | |
|         (void) deviceAPI;
 | |
|         (void) bs;
 | |
|         (void) cs;
 | |
|     }
 | |
| 
 | |
| 	virtual ChannelGUI* createMIMOChannelGUI(
 | |
|             DeviceUISet *deviceUISet,
 | |
|             MIMOChannel *mimoChannel) const
 | |
|     {
 | |
|         (void) deviceUISet;
 | |
|         (void) mimoChannel;
 | |
|         return nullptr;
 | |
|     }
 | |
| 
 | |
|     // any channel
 | |
| 
 | |
|     virtual ChannelWebAPIAdapter* createChannelWebAPIAdapter() const
 | |
|     {
 | |
|         return nullptr;
 | |
|     }
 | |
| 
 | |
|     // any feature
 | |
| 
 | |
|     virtual FeatureWebAPIAdapter* createFeatureWebAPIAdapter() const
 | |
|     {
 | |
|         return nullptr;
 | |
|     }
 | |
| 
 | |
|     // any device
 | |
| 
 | |
|     virtual void enumOriginDevices(QStringList& listedHwIds, OriginDevices& originDevices)
 | |
|     {
 | |
|         (void) listedHwIds;
 | |
|         (void) originDevices;
 | |
|     }
 | |
| 
 | |
|     virtual SamplingDevice::SamplingDeviceType getSamplingDeviceType() const {
 | |
|         return SamplingDevice::SamplingDeviceType::PhysicalDevice;
 | |
|     }
 | |
| 
 | |
|     virtual QString getDeviceTypeId() const {
 | |
|         return QString("");
 | |
|     }
 | |
| 
 | |
|     // device source plugins only
 | |
| 
 | |
| 	virtual SamplingDevices enumSampleSources(const OriginDevices& originDevices)
 | |
|     {
 | |
|         (void) originDevices;
 | |
|         return SamplingDevices();
 | |
|     }
 | |
| 
 | |
| 	virtual DeviceGUI* createSampleSourcePluginInstanceGUI(
 | |
|             const QString& sourceId,
 | |
|             QWidget **widget,
 | |
|             DeviceUISet *deviceUISet)
 | |
|     {
 | |
|         (void) sourceId;
 | |
|         (void) widget;
 | |
|         (void) deviceUISet;
 | |
|         return nullptr;
 | |
|     }
 | |
| 
 | |
|     virtual DeviceSampleSource* createSampleSourcePluginInstance( // creates the input "core"
 | |
|             const QString& sourceId,
 | |
|             DeviceAPI *deviceAPI)
 | |
|     {
 | |
|         (void) sourceId;
 | |
|         (void) deviceAPI;
 | |
|         return nullptr;
 | |
|     }
 | |
| 	virtual void deleteSampleSourcePluginInstanceInput(DeviceSampleSource *source);
 | |
| 
 | |
|     virtual int getDefaultRxNbItems() const {
 | |
|         return 1;
 | |
|     }
 | |
| 
 | |
| 	// device sink plugins only
 | |
| 
 | |
| 	virtual SamplingDevices enumSampleSinks(const OriginDevices& originDevices)
 | |
|     {
 | |
|         (void) originDevices;
 | |
|         return SamplingDevices();
 | |
|     }
 | |
| 
 | |
| 	virtual DeviceGUI* createSampleSinkPluginInstanceGUI(
 | |
|             const QString& sinkId,
 | |
|             QWidget **widget,
 | |
|             DeviceUISet *deviceUISet)
 | |
|     {
 | |
|         (void) sinkId;
 | |
|         (void) widget;
 | |
|         (void) deviceUISet;
 | |
|         return nullptr;
 | |
|     }
 | |
| 
 | |
|     virtual DeviceSampleSink* createSampleSinkPluginInstance( // creates the output "core"
 | |
|             const QString& sinkId,
 | |
|             DeviceAPI *deviceAPI)
 | |
|     {
 | |
|         (void) sinkId;
 | |
|         (void) deviceAPI;
 | |
|         return nullptr;
 | |
|     }
 | |
| 
 | |
|     virtual void deleteSampleSinkPluginInstanceOutput(DeviceSampleSink *sink);
 | |
| 
 | |
|     virtual int getDefaultTxNbItems() const {
 | |
|         return 1;
 | |
|     }
 | |
| 
 | |
|     // device MIMO plugins only
 | |
| 
 | |
| 	virtual SamplingDevices enumSampleMIMO(const OriginDevices& originDevices)
 | |
|     {
 | |
|         (void) originDevices;
 | |
|         return SamplingDevices();
 | |
|     }
 | |
| 
 | |
| 	virtual DeviceGUI* createSampleMIMOPluginInstanceGUI(
 | |
|             const QString& mimoId,
 | |
|             QWidget **widget,
 | |
|             DeviceUISet *deviceUISet)
 | |
|     {
 | |
|         (void) mimoId;
 | |
|         (void) widget;
 | |
|         (void) deviceUISet;
 | |
|         return nullptr;
 | |
|     }
 | |
| 
 | |
|     virtual DeviceSampleMIMO* createSampleMIMOPluginInstance( // creates the MIMO "core"
 | |
|             const QString& mimoId,
 | |
|             DeviceAPI *deviceAPI)
 | |
|     {
 | |
|         (void) mimoId;
 | |
|         (void) deviceAPI;
 | |
|         return nullptr;
 | |
|     }
 | |
| 
 | |
|     virtual void deleteSampleMIMOPluginInstanceMIMO(DeviceSampleMIMO *mimo);
 | |
| 
 | |
|     virtual int getDefaultMIMONbItems() const {
 | |
|         return 1;
 | |
|     }
 | |
| 
 | |
|     // Callback to allow plugin to add elements to top-level GUI (such as menu items)
 | |
|     virtual bool createTopLevelGUI()
 | |
|     {
 | |
|         return true;
 | |
|     }
 | |
| 
 | |
|     // Serialise global plugin settings (i.e. settings that are not per-instance)
 | |
|     virtual QByteArray serializeGlobalSettings() const
 | |
|     {
 | |
|         QByteArray empty;
 | |
|         return empty;
 | |
|     }
 | |
| 
 | |
|     virtual bool deserializeGlobalSettings(const QByteArray& data)
 | |
|     {
 | |
|         (void) data;
 | |
|         return true;
 | |
|     }
 | |
| 
 | |
|     // all devices
 | |
| 
 | |
|     virtual DeviceWebAPIAdapter* createDeviceWebAPIAdapter() const {
 | |
|         return nullptr;
 | |
|     }
 | |
| 
 | |
|     // Features
 | |
| 
 | |
|     virtual FeatureGUI* createFeatureGUI(FeatureUISet *featureUISet, Feature *feature) const
 | |
|     {
 | |
|         (void) featureUISet;
 | |
|         (void) feature;
 | |
|         return nullptr;
 | |
|     }
 | |
| 
 | |
|     virtual Feature* createFeature(WebAPIAdapterInterface *webAPIAdapterInterface) const
 | |
|     {
 | |
|         (void) webAPIAdapterInterface;
 | |
|         return nullptr;
 | |
|     }
 | |
| };
 | |
| 
 | |
| Q_DECLARE_INTERFACE(PluginInterface, "SDRangel.PluginInterface/0.1")
 | |
| 
 | |
| #endif // INCLUDE_PLUGININTERFACE_H
 |