Skip to content

OcaJsonActuator#

This document describes the controller implementation of OcaJsonActuator. This class is documented in the AES70 standard as:

JSON value actuator.


Overview#

Class Declaration#

namespace aes70::controller
{
  class OcaJsonActuator : public OcaBasicActuator
  {
  public:
    OcaJsonActuator(std::shared_ptr<connection> connection,
            uin32_t object_number);
    OcaJsonActuator(const OcaJsonActuator &o);

    // Control Methods
    // Calls GetValue and calls on_result or on_failure
    void GetValue(auto on_result, failure_callback on_failure);
    // Calls SetValue and calls on_result or on_failure
    void SetValue(OcaJsonValue Setting, auto on_result, failure_callback on_failure);
    // Calls SetValue and does not wait for the response
    void SetValue(OcaJsonValue Setting);
    // Calls GetMaxLen and calls on_result or on_failure
    void GetMaxLen(auto on_result, failure_callback on_failure);

    // Observing Properties
    subscription observeValue(auto callback, failure_callback on_failure);

    // Property Changed Subscriptions
    subscription OnValueChanged(auto callback, failure_callback on_failure);
  };
}

Methods#

GetValue#

void GetValue(auto on_result, failure_callback on_failure)

Calls the method GetValue in the remote device.

Parameters:#

  • auto on_result: A callable (e.g. a lambda) with the following arguments:
    • OcaJsonValue Value
  • failure_callback on_failure: A callback which is called on error.

SetValue#

void SetValue(OcaJsonValue Setting, auto on_result, failure_callback on_failure)

Calls the method SetValue in the remote device. If no result and error callback is specified, the method will be called without requesting a response.

Parameters:#

  • OcaJsonValue Setting
  • auto on_result: A callable (e.g. a lambda) with 0 arguments.
  • failure_callback on_failure: A callback which is called on error.

GetMaxLen#

void GetMaxLen(auto on_result, failure_callback on_failure)

Calls the method GetMaxLen in the remote device.

Parameters:#

  • auto on_result: A callable (e.g. a lambda) with the following arguments:
    • OcaUint16 Len
  • failure_callback on_failure: A callback which is called on error.

observeValue#

subscription observeValue(auto callback, failure_callback on_failure)

Fetches the remote property Value and subscribes for modifications. The callback is called with the initial values of Value and whenever it changes.

Parameters:#

  • auto callback: A callable (e.g. a lambda) with one argument: OcaJsonValue Value
  • failure_callback on_failure: A callback which is called on error.

OnValueChanged#

subscription OnValueChanged(auto callback, failure_callback on_failure)

Parameters#

  • auto callback: A callable (e.g. a lambda) with one argument: OcaJsonValue Value
  • failure_callback on_failure: A callback which is called on error.