nl::Weave::Profiles::DataManagement_Current::TraitUpdatableDataSink

Resumen

Herencia

Se hereda de:
  nl::Weave::Profiles::DataManagement_Current::TraitDataSink
  nl::Weave::Profiles::DataManagement_Current::TraitSchemaEngine::IGetDataDelegate

Constructores y destructores

TraitUpdatableDataSink(const TraitSchemaEngine *aEngine)

Funciones públicas

ClearUpdated(SubscriptionClient *apSubClient, PropertyPathHandle aPropertyHandle)
GetData(PropertyPathHandle aHandle, uint64_t aTagToWrite, nl::Weave::TLV::TLVWriter & aWriter, bool & aIsNull, bool & aIsPresent) __OVERRIDE
virtual WEAVE_ERROR
Con un controlador de ruta de acceso a un nodo, un escritor TLV y valores booleanos que indican si el valor es nulo o no está presente, obtén los datos de la fuente de la característica que creará una notificación.
GetSubscriptionClient() __OVERRIDE
virtual SubscriptionClient *
GetUpdateEncoder() __OVERRIDE
virtual UpdateEncoder *
IsUpdatableDataSink(void) __OVERRIDE
virtual bool
Lock(SubscriptionClient *apSubClient)
void
ReadData(TraitDataHandle aTraitDataHandle, PropertyPathHandle aHandle, uint64_t aTagToWrite, TLV::TLVWriter & aWriter, PropertyPathHandle & aPropertyPathHandleOfDictItemToStartFrom)
SetSubscriptionClient(SubscriptionClient *apSubClient) __OVERRIDE
virtual WEAVE_ERROR
SetUpdateEncoder(UpdateEncoder *apEncoder) __OVERRIDE
virtual WEAVE_ERROR
SetUpdated(SubscriptionClient *apSubClient, PropertyPathHandle aPropertyHandle, bool aIsConditional)
Declara que el PropertyPathHandle determinado tiene modificaciones locales.
Unlock(SubscriptionClient *apSubClient)
void

Funciones públicas

ClearUpdated

WEAVE_ERROR ClearUpdated(
  SubscriptionClient *apSubClient,
  PropertyPathHandle aPropertyHandle
)

GetData

virtual WEAVE_ERROR GetData(
  PropertyPathHandle aHandle,
  uint64_t aTagToWrite,
  nl::Weave::TLV::TLVWriter & aWriter,
  bool & aIsNull,
  bool & aIsPresent
) __OVERRIDE

Con un controlador de ruta de acceso a un nodo, un escritor TLV y valores booleanos que indican si el valor es nulo o no está presente, obtén los datos de la fuente de la característica que creará una notificación.

Si el controlador de la ruta de acceso no es un nodo hoja, TDM se encargará de escribir valores en el escritor (como abrir contenedores, anular la struct, etcétera). Si un nodo que no es de hoja es nulo o no está presente, TDM no llamará a GetData para sus elementos secundarios.

Esta función solo se llamará para los controladores anulables, opcionales, efímeros o de hoja. Se espera que cualquier característica con controladores que tengan esas opciones habilitadas implemente la lógica adecuada para propagar aIsNull y aIsPresent.

Detalles
Parámetros
[in] aHandle
El PropertyPathHandle en cuestión.
[in] aTagToWrite
Es la etiqueta que se escribe para el aHandle.
[in,out] aWriter
El escritor al que se le deben escribir elementos TLV.
[out] aIsNull
¿Se anuló aHandle? Si es así, TDM escribirá un elemento nulo. Si aHandle no es una hoja, el TDM omitirá los elementos secundarios.
[out] aIsPresent
¿Hay aHandle presente? Si no es así, y si aHandle no es una hoja, TDM omitirá la ruta de acceso y sus elementos secundarios.
Valores de retorno
WEAVE_NO_ERROR
Si tiene éxito.
other
No pudo recuperar datos y escribirlos en el escritor.

GetSubscriptionClient

virtual SubscriptionClient * GetSubscriptionClient() __OVERRIDE

GetUpdateEncoder

virtual UpdateEncoder * GetUpdateEncoder() __OVERRIDE

IsUpdatableDataSink

virtual bool IsUpdatableDataSink(
  void
) __OVERRIDE

Bloquear

void Lock(
  SubscriptionClient *apSubClient
)

ReadData

WEAVE_ERROR ReadData(
  TraitDataHandle aTraitDataHandle,
  PropertyPathHandle aHandle,
  uint64_t aTagToWrite,
  TLV::TLVWriter & aWriter,
  PropertyPathHandle & aPropertyPathHandleOfDictItemToStartFrom
)

SetSubscriptionClient

virtual WEAVE_ERROR SetSubscriptionClient(
  SubscriptionClient *apSubClient
) __OVERRIDE

SetUpdateEncoder

virtual WEAVE_ERROR SetUpdateEncoder(
  UpdateEncoder *apEncoder
) __OVERRIDE

SetUpdated

WEAVE_ERROR SetUpdated(
  SubscriptionClient *apSubClient,
  PropertyPathHandle aPropertyHandle,
  bool aIsConditional
)

Declara que el PropertyPathHandle determinado tiene modificaciones locales.

NotificationEngine no anulará el controlador ni sus elementos subordinados hasta que se haya procesado la solicitud de actualización. La aplicación recibirá devoluciones de llamada kEvent_OnUpdateComplete para este controlador o uno de sus principales con el resultado de la operación de actualización. La modificación puede ser condicional o no. Las actualizaciones condicionales de datos se perderán si la copia local de la instancia de trait ya no está sincronizada con la del publicador, ya que el publicador o otro cliente la mutaron. No se admiten mutaciones condicionales y no condicionales al mismo tiempo en la misma instancia de trait.

Detalles
Parámetros
[in] apSubClient
Un puntero para el SubscriptionClient que administra este receptor.
[in] aPropertyHandle
Cualquier PropertyPathHandle válido para esta instancia de Trait.
[in] aIsConditional
True para una actualización condicional; false.
Valores de retorno
WEAVE_NO_ERROR
Si el identificador de propiedad se agregó correctamente al conjunto de propiedades que se enviará al propietario de la característica
WEAVE_ERROR_INVALID_ARGUMENT
si el identificador o el puntero SubscriptionClient no son válidos.
WEAVE_ERROR_WDM_INCONSISTENT_CONDITIONALITY
si la instancia de trait ya se está actualizando con la condicionalidad opuesta.
WEAVE_ERROR_WDM_LOCAL_DATA_INCONSISTENT
si aIsCondition es verdadero, pero la instancia de la característica no tiene una versión válida.
WEAVE_ERROR_WDM_PATH_STORE_FULL
si no hay memoria para almacenar la ruta de acceso.
Other
WEAVE_ERROR según la falla.

TraitUpdatableDataSink

 TraitUpdatableDataSink(
  const TraitSchemaEngine *aEngine
)

Desbloquear

void Unlock(
  SubscriptionClient *apSubClient
)