Open Lighting Architecture 0.10.9
Loading...
Searching...
No Matches
ola::rdm::DiscoverableRDMControllerAdaptor Class Reference

Detailed Description

Inheritance diagram for ola::rdm::DiscoverableRDMControllerAdaptor:
ola::rdm::DiscoverableRDMControllerInterface ola::rdm::RDMControllerInterface

Public Member Functions

 DiscoverableRDMControllerAdaptor (const UID &uid, RDMControllerInterface *interface)
 
void SendRDMRequest (RDMRequest *request, RDMCallback *on_complete)
 Send a RDM command.
 
void RunFullDiscovery (RDMDiscoveryCallback *callback)
 Start a full discovery operation.
 
void RunIncrementalDiscovery (RDMDiscoveryCallback *callback)
 Start an incremental discovery operation.
 
- Public Member Functions inherited from ola::rdm::DiscoverableRDMControllerInterface
- Public Member Functions inherited from ola::rdm::RDMControllerInterface

Member Function Documentation

◆ RunFullDiscovery()

void ola::rdm::DiscoverableRDMControllerAdaptor::RunFullDiscovery ( RDMDiscoveryCallback * callback)
inlinevirtual

Start a full discovery operation.

Parameters
callbackThe callback run when discovery completes. This may run immediately in some implementations.

Implements ola::rdm::DiscoverableRDMControllerInterface.

◆ RunIncrementalDiscovery()

void ola::rdm::DiscoverableRDMControllerAdaptor::RunIncrementalDiscovery ( RDMDiscoveryCallback * callback)
inlinevirtual

Start an incremental discovery operation.

Parameters
callbackThe callback run when discovery completes. This may run immediately in some implementations.

Implements ola::rdm::DiscoverableRDMControllerInterface.

◆ SendRDMRequest()

void ola::rdm::DiscoverableRDMControllerAdaptor::SendRDMRequest ( RDMRequest * request,
RDMCallback * on_complete )
inlinevirtual

Send a RDM command.

Parameters
requestthe RDMRequest, ownership is transferred.
on_completeThe callback to run when the request completes.

Implementors much ensure that the callback is always run at some point. In other words, there must be no way that a request can be dropped in such a way that the callback is never run. Doing so will either block all subsequent requests, or leak memory depending on the implementation.

Also the implementor of this class may want to re-write the transaction #, and possibly the UID (changing src UIDs isn't addressed by the RDM spec).

The RDMRequest may be a DISCOVERY_COMMAND, if the implementation does not support DISCOVERY_COMMANDs then the callback should be run with ola::rdm::RDM_PLUGIN_DISCOVERY_NOT_SUPPORTED.

Implements ola::rdm::RDMControllerInterface.


The documentation for this class was generated from the following file: