#ifndef INCLUDE_PLUGININTERFACE_H #define INCLUDE_PLUGININTERFACE_H #include #include #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; //!< This is the device set index if claimed else -1 bool removed; //!< 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), claimed(-1), removed(false) { } bool operator==(const SamplingDevice& rhs) const { return displayedName == rhs.displayedName && hardwareId == rhs.hardwareId && id == rhs.id && serial == rhs.serial; } }; typedef QList SamplingDevices; /** 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) {} }; typedef QList OriginDevices; virtual ~PluginInterface() { } 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