![]() |
Open Lighting Architecture
Latest Git
|
An RDM Command that represents responses (GET, SET or DISCOVER).
Public Member Functions | |
RDMResponse (const UID &source, const UID &destination, uint8_t transaction_number, uint8_t response_type, uint8_t message_count, uint16_t sub_device, RDMCommand::RDMCommandClass command_class, uint16_t param_id, const uint8_t *data, unsigned int length) | |
Create a new RDM Response. More... | |
virtual void | Print (CommandPrinter *printer, bool summarize, bool unpack_param_data) const |
Output the contents of the command to a CommandPrinter. More... | |
RDMResponse * | Duplicate () const |
Make a copy of the response. More... | |
Accessors | |
uint8_t | ResponseType () const |
The Response Type. More... | |
RDMCommandClass | CommandClass () const |
The CommmandClass of this message. | |
Mutators | |
void | SetDestinationUID (const UID &destination_uid) |
Set the destination UID. More... | |
void | SetTransactionNumber (uint8_t transaction_number) |
Set the transaction number. More... | |
![]() | |
virtual uint16_t | Checksum (uint16_t checksum) const |
Modify the calculated checksum for this command. More... | |
bool | operator== (const RDMCommand &other) const |
Test for equality. More... | |
virtual uint8_t | SubStartCode () const |
The Sub-Start code for the RDMCommand. | |
virtual uint8_t | MessageLength () const |
The Message length field. | |
const UID & | SourceUID () const |
Returns the Source UID of the RDMCommand. | |
const UID & | DestinationUID () const |
Returns the Destination UID of the RDMCommand. | |
uint8_t | TransactionNumber () const |
Returns the Transaction Number of the RDMCommand. | |
uint8_t | PortIdResponseType () const |
Returns the Port ID of the RDMCommand. | |
uint8_t | MessageCount () const |
Returns the Message Count of the RDMCommand. | |
uint16_t | SubDevice () const |
Returns the SubDevice of the RDMCommand. | |
uint16_t | ParamId () const |
Returns the Parameter ID of the RDMCommand. | |
unsigned int | ParamDataSize () const |
Returns the Size of the Parameter Data of the RDMCommand. | |
const uint8_t * | ParamData () const |
Returns the Parameter Data of the RDMCommand. | |
std::string | ToString () const |
Create a human readable string from the RDMCommand object. More... | |
Static Public Member Functions | |
static RDMResponse * | InflateFromData (const uint8_t *data, size_t length, RDMStatusCode *status_code, const RDMRequest *request=NULL) |
static RDMResponse * | InflateFromData (const ola::io::ByteString &input, RDMStatusCode *status_code, const RDMRequest *request=NULL) |
static RDMResponse * | CombineResponses (const RDMResponse *response1, const RDMResponse *response2) |
Combine two RDMResponses. More... | |
![]() | |
static RDMCommand * | Inflate (const uint8_t *data, unsigned int length) |
Extract a RDMCommand from raw data. More... | |
Static Public Attributes | |
static const unsigned int | MAX_OVERFLOW_SIZE = 4 << 10 |
The maximum size of an ACK_OVERFLOW session that we'll buffer. More... | |
![]() | |
static const uint8_t | START_CODE = ola::rdm::START_CODE |
The RDM Start Code. More... | |
Additional Inherited Members | |
![]() | |
enum | RDMCommandClass { DISCOVER_COMMAND = 0x10, DISCOVER_COMMAND_RESPONSE = 0x11, GET_COMMAND = 0x20, GET_COMMAND_RESPONSE = 0x21, SET_COMMAND = 0x30, SET_COMMAND_RESPONSE = 0x31, INVALID_COMMAND = 0xff } |
A set of values representing CommandClasses in E1.20. More... | |
![]() | |
RDMCommand (const UID &source, const UID &destination, uint8_t transaction_number, uint8_t port_id, uint8_t message_count, uint16_t sub_device, uint16_t param_id, const uint8_t *data, unsigned int length) | |
Protected constructor for derived classes. | |
void | SetParamData (const uint8_t *data, unsigned int length) |
![]() | |
static RDMStatusCode | VerifyData (const uint8_t *data, size_t length, RDMCommandHeader *command_message) |
static RDMCommandClass | ConvertCommandClass (uint8_t command_type) |
![]() | |
uint8_t | m_port_id |
UID | m_source |
UID | m_destination |
uint8_t | m_transaction_number |
|
inline |
Create a new RDM Response.
source | The source UID. |
destination | The destination UID. |
transaction_number | The transaction number. |
response_type | The Response Type. |
message_count | Set to 0. |
sub_device | The Sub Device index. |
command_class | The Command Class of this request. |
param_id | The PID value. |
data | The parameter data, or NULL if there isn't any. |
length | The length of the parameter data. |
|
inline |
Make a copy of the response.
|
inlinestatic |
Create a RDMResponse request from raw data in a ByteString.
input | the raw response data. | |
[out] | status_code | a pointer to a RDMStatusCode to set |
request | an optional RDMRequest object that this response is for |
|
inlinevirtual |
Output the contents of the command to a CommandPrinter.
printer | CommandPrinter which will use the information |
summarize | enable a one line summary |
unpack_param_data | if the summary isn't enabled, this controls if we unpack and display parameter data. |
Reimplemented from ola::rdm::RDMCommand.
Reimplemented in ola::rdm::RDMDiscoveryResponse.
|
inline |
The Response Type.
|
inline |
|
inline |
Set the transaction number.
transaction_number | the new transaction number. |
|
static |
The maximum size of an ACK_OVERFLOW session that we'll buffer.
4k should be big enough for everyone ;)