2014-05-18 15:52:39 +00:00
|
|
|
#ifndef INCLUDE_PLUGININTERFACE_H
|
|
|
|
#define INCLUDE_PLUGININTERFACE_H
|
|
|
|
|
|
|
|
#include <QtPlugin>
|
|
|
|
#include <QString>
|
|
|
|
|
2018-03-20 12:49:21 +00:00
|
|
|
#include "export.h"
|
2018-03-03 19:23:38 +00:00
|
|
|
|
|
|
|
struct SDRBASE_API PluginDescriptor {
|
2014-05-18 15:52:39 +00:00
|
|
|
// general plugin description
|
|
|
|
const QString displayedName;
|
|
|
|
const QString version;
|
|
|
|
const QString copyright;
|
|
|
|
const QString website;
|
|
|
|
bool licenseIsGPL;
|
|
|
|
const QString sourceCodeURL;
|
|
|
|
};
|
|
|
|
|
|
|
|
class PluginAPI;
|
2019-05-08 20:11:53 +00:00
|
|
|
class DeviceAPI;
|
2017-10-29 23:02:28 +00:00
|
|
|
class DeviceUISet;
|
2017-09-25 22:22:08 +00:00
|
|
|
class PluginInstanceGUI;
|
2016-05-17 01:41:01 +00:00
|
|
|
class QWidget;
|
2017-09-14 06:49:31 +00:00
|
|
|
class DeviceSampleSource;
|
|
|
|
class DeviceSampleSink;
|
2019-05-18 04:30:37 +00:00
|
|
|
class DeviceSampleMIMO;
|
2017-11-08 07:31:00 +00:00
|
|
|
class BasebandSampleSink;
|
|
|
|
class BasebandSampleSource;
|
2019-05-09 15:27:12 +00:00
|
|
|
class ChannelAPI;
|
2014-05-18 15:52:39 +00:00
|
|
|
|
2018-03-03 19:23:38 +00:00
|
|
|
class SDRBASE_API PluginInterface {
|
2014-05-18 15:52:39 +00:00
|
|
|
public:
|
2016-10-13 20:23:43 +00:00
|
|
|
struct SamplingDevice
|
2015-09-30 04:57:40 +00:00
|
|
|
{
|
2017-11-01 19:06:33 +00:00
|
|
|
enum SamplingDeviceType
|
|
|
|
{
|
|
|
|
PhysicalDevice,
|
|
|
|
BuiltInDevice
|
|
|
|
};
|
|
|
|
|
2019-05-07 16:58:20 +00:00
|
|
|
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
|
|
|
|
StreamAny //!< May expose any number of input and/or output streams
|
|
|
|
};
|
|
|
|
|
2017-11-01 19:06:33 +00:00
|
|
|
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 ...)
|
2017-11-02 08:17:38 +00:00
|
|
|
QString serial; //!< The device serial number defined by the vendor or a fake one (SDRplay)
|
2017-11-01 19:06:33 +00:00
|
|
|
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
|
2019-05-07 16:58:20 +00:00
|
|
|
StreamType streamType; //!< This is the type of stream supported
|
2017-11-19 00:05:16 +00:00
|
|
|
int deviceNbItems; //!< Number of items (or streams) in the device. >1 for composite devices.
|
2017-11-01 19:06:33 +00:00
|
|
|
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
|
2015-09-30 04:57:40 +00:00
|
|
|
|
2016-10-13 20:23:43 +00:00
|
|
|
SamplingDevice(const QString& _displayedName,
|
2016-12-29 11:41:10 +00:00
|
|
|
const QString& _hardwareId,
|
2015-09-30 04:57:40 +00:00
|
|
|
const QString& _id,
|
|
|
|
const QString& _serial,
|
2017-11-01 09:37:00 +00:00
|
|
|
int _sequence,
|
2017-11-01 19:06:33 +00:00
|
|
|
SamplingDeviceType _type,
|
2019-05-07 16:58:20 +00:00
|
|
|
StreamType _streamType,
|
2017-11-19 00:05:16 +00:00
|
|
|
int _deviceNbItems,
|
2017-11-01 09:37:00 +00:00
|
|
|
int _deviceItemIndex) :
|
2014-05-18 15:52:39 +00:00
|
|
|
displayedName(_displayedName),
|
2016-12-29 11:41:10 +00:00
|
|
|
hardwareId(_hardwareId),
|
2015-09-30 04:57:40 +00:00
|
|
|
id(_id),
|
|
|
|
serial(_serial),
|
2017-11-01 09:37:00 +00:00
|
|
|
sequence(_sequence),
|
2017-11-01 19:06:33 +00:00
|
|
|
type(_type),
|
2019-05-07 16:58:20 +00:00
|
|
|
streamType(_streamType),
|
2017-11-19 00:05:16 +00:00
|
|
|
deviceNbItems(_deviceNbItems),
|
2017-11-01 09:37:00 +00:00
|
|
|
deviceItemIndex(_deviceItemIndex),
|
|
|
|
claimed(-1)
|
2014-05-18 15:52:39 +00:00
|
|
|
{ }
|
|
|
|
};
|
2016-10-13 20:23:43 +00:00
|
|
|
typedef QList<SamplingDevice> SamplingDevices;
|
2014-05-18 15:52:39 +00:00
|
|
|
|
2018-11-12 13:04:16 +00:00
|
|
|
virtual ~PluginInterface() { }
|
2014-05-18 15:52:39 +00:00
|
|
|
|
|
|
|
virtual const PluginDescriptor& getPluginDescriptor() const = 0;
|
|
|
|
virtual void initPlugin(PluginAPI* pluginAPI) = 0;
|
|
|
|
|
2016-10-13 21:42:08 +00:00
|
|
|
// channel Rx plugins
|
2017-10-30 00:11:35 +00:00
|
|
|
|
2017-11-07 22:49:27 +00:00
|
|
|
virtual PluginInstanceGUI* createRxChannelGUI(
|
2018-11-12 13:04:16 +00:00
|
|
|
DeviceUISet *deviceUISet,
|
|
|
|
BasebandSampleSink *rxChannel)
|
|
|
|
{
|
|
|
|
(void) deviceUISet;
|
|
|
|
(void) rxChannel;
|
|
|
|
return nullptr;
|
|
|
|
}
|
2014-05-18 15:52:39 +00:00
|
|
|
|
2017-12-23 08:54:42 +00:00
|
|
|
virtual BasebandSampleSink* createRxChannelBS(
|
2019-05-08 20:11:53 +00:00
|
|
|
DeviceAPI *deviceAPI)
|
2018-11-12 13:04:16 +00:00
|
|
|
{
|
|
|
|
(void) deviceAPI;
|
|
|
|
return nullptr;
|
|
|
|
}
|
2017-11-08 07:31:00 +00:00
|
|
|
|
2019-05-09 15:27:12 +00:00
|
|
|
virtual ChannelAPI* createRxChannelCS(
|
2019-05-08 20:11:53 +00:00
|
|
|
DeviceAPI *deviceAPI)
|
2018-11-12 13:04:16 +00:00
|
|
|
{
|
|
|
|
(void) deviceAPI;
|
|
|
|
return nullptr;
|
|
|
|
}
|
2017-12-17 22:15:42 +00:00
|
|
|
|
2017-11-08 07:31:00 +00:00
|
|
|
// channel Tx plugins
|
2017-10-30 00:11:35 +00:00
|
|
|
|
2017-11-07 23:05:49 +00:00
|
|
|
virtual PluginInstanceGUI* createTxChannelGUI(
|
2018-11-12 13:04:16 +00:00
|
|
|
DeviceUISet *deviceUISet,
|
|
|
|
BasebandSampleSource *txChannel)
|
|
|
|
{
|
|
|
|
(void) deviceUISet;
|
|
|
|
(void) txChannel;
|
|
|
|
return nullptr;
|
|
|
|
}
|
2016-10-14 16:47:19 +00:00
|
|
|
|
2017-12-23 08:54:42 +00:00
|
|
|
virtual BasebandSampleSource* createTxChannelBS(
|
2019-05-08 20:11:53 +00:00
|
|
|
DeviceAPI *deviceAPI)
|
2018-11-12 13:04:16 +00:00
|
|
|
{
|
|
|
|
(void) deviceAPI;
|
|
|
|
return nullptr;
|
|
|
|
}
|
2017-11-08 07:31:00 +00:00
|
|
|
|
2019-05-09 15:27:12 +00:00
|
|
|
virtual ChannelAPI* createTxChannelCS(
|
2019-05-08 20:11:53 +00:00
|
|
|
DeviceAPI *deviceAPI)
|
2018-11-12 13:04:16 +00:00
|
|
|
{
|
|
|
|
(void) deviceAPI;
|
|
|
|
return nullptr;
|
|
|
|
}
|
2017-12-17 22:15:42 +00:00
|
|
|
|
|
|
|
// device source plugins only
|
2017-10-30 00:11:35 +00:00
|
|
|
|
2016-10-13 20:23:43 +00:00
|
|
|
virtual SamplingDevices enumSampleSources() { return SamplingDevices(); }
|
2017-10-29 23:02:28 +00:00
|
|
|
|
|
|
|
virtual PluginInstanceGUI* createSampleSourcePluginInstanceGUI(
|
2018-11-12 13:04:16 +00:00
|
|
|
const QString& sourceId,
|
|
|
|
QWidget **widget,
|
|
|
|
DeviceUISet *deviceUISet)
|
|
|
|
{
|
|
|
|
(void) sourceId;
|
|
|
|
(void) widget;
|
|
|
|
(void) deviceUISet;
|
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
|
|
|
|
virtual DeviceSampleSource* createSampleSourcePluginInstanceInput( // creates the input "core"
|
|
|
|
const QString& sourceId,
|
2019-05-08 20:11:53 +00:00
|
|
|
DeviceAPI *deviceAPI)
|
2018-11-12 13:04:16 +00:00
|
|
|
{
|
|
|
|
(void) sourceId;
|
|
|
|
(void) deviceAPI;
|
|
|
|
return nullptr;
|
|
|
|
}
|
2017-09-25 22:22:08 +00:00
|
|
|
virtual void deleteSampleSourcePluginInstanceGUI(PluginInstanceGUI *ui);
|
2017-09-16 08:45:08 +00:00
|
|
|
virtual void deleteSampleSourcePluginInstanceInput(DeviceSampleSource *source);
|
2016-10-14 16:47:19 +00:00
|
|
|
|
|
|
|
// device sink plugins only
|
2017-10-30 00:11:35 +00:00
|
|
|
|
2016-10-14 16:47:19 +00:00
|
|
|
virtual SamplingDevices enumSampleSinks() { return SamplingDevices(); }
|
2017-10-30 00:11:35 +00:00
|
|
|
|
|
|
|
virtual PluginInstanceGUI* createSampleSinkPluginInstanceGUI(
|
2018-11-12 13:04:16 +00:00
|
|
|
const QString& sinkId,
|
|
|
|
QWidget **widget,
|
|
|
|
DeviceUISet *deviceUISet)
|
|
|
|
{
|
|
|
|
(void) sinkId;
|
|
|
|
(void) widget;
|
|
|
|
(void) deviceUISet;
|
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
|
|
|
|
virtual DeviceSampleSink* createSampleSinkPluginInstanceOutput( // creates the output "core"
|
|
|
|
const QString& sinkId,
|
2019-05-08 20:11:53 +00:00
|
|
|
DeviceAPI *deviceAPI)
|
2018-11-12 13:04:16 +00:00
|
|
|
{
|
|
|
|
(void) sinkId;
|
|
|
|
(void) deviceAPI;
|
|
|
|
return nullptr;
|
|
|
|
}
|
2017-10-30 00:11:35 +00:00
|
|
|
|
2017-09-25 22:22:08 +00:00
|
|
|
virtual void deleteSampleSinkPluginInstanceGUI(PluginInstanceGUI *ui);
|
2017-09-16 09:34:25 +00:00
|
|
|
virtual void deleteSampleSinkPluginInstanceOutput(DeviceSampleSink *sink);
|
2019-05-18 04:30:37 +00:00
|
|
|
|
|
|
|
// device MIMO plugins only
|
|
|
|
|
|
|
|
virtual SamplingDevices enumSampleMIMO() { return SamplingDevices(); }
|
|
|
|
|
|
|
|
virtual PluginInstanceGUI* createSampleMIMOPluginInstanceGUI(
|
|
|
|
const QString& mimoId,
|
|
|
|
QWidget **widget,
|
|
|
|
DeviceUISet *deviceUISet)
|
|
|
|
{
|
|
|
|
(void) mimoId;
|
|
|
|
(void) widget;
|
|
|
|
(void) deviceUISet;
|
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
|
|
|
|
virtual DeviceSampleMIMO* createSampleMIMOPluginInstanceMIMO( // creates the MIMO "core"
|
|
|
|
const QString& mimoId,
|
|
|
|
DeviceAPI *deviceAPI)
|
|
|
|
{
|
|
|
|
(void) mimoId;
|
|
|
|
(void) deviceAPI;
|
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
|
|
|
|
virtual void deleteSampleMIMOPluginInstanceGUI(PluginInstanceGUI *ui);
|
|
|
|
virtual void deleteSampleMIMOPluginInstanceMIMO(DeviceSampleMIMO *mimo);
|
|
|
|
|
2014-05-18 15:52:39 +00:00
|
|
|
};
|
|
|
|
|
2015-10-05 02:47:23 +00:00
|
|
|
Q_DECLARE_INTERFACE(PluginInterface, "SDRangel.PluginInterface/0.1");
|
2014-05-18 15:52:39 +00:00
|
|
|
|
|
|
|
#endif // INCLUDE_PLUGININTERFACE_H
|