diff options
Diffstat (limited to 'include/routing/IAmRoutingReceive.h')
-rw-r--r-- | include/routing/IAmRoutingReceive.h | 482 |
1 files changed, 79 insertions, 403 deletions
diff --git a/include/routing/IAmRoutingReceive.h b/include/routing/IAmRoutingReceive.h index 2d61f9e..dd86531 100644 --- a/include/routing/IAmRoutingReceive.h +++ b/include/routing/IAmRoutingReceive.h @@ -1,5 +1,5 @@ /**
- * Copyright (C) 2012, BMW AG
+ * Copyright (C) 2012 - 2014, BMW AG *
* This file is part of GENIVI Project AudioManager.
*
@@ -12,15 +12,16 @@ * this file, You can obtain one at http://mozilla.org/MPL/2.0/.
*
*
- * \author Christian Mueller, christian.linke@bmw.de BMW 2011,2012
+ * \author Christian Linke, christian.linke@bmw.de BMW 2011 - 2014 *
* \file
- * For further information see http://www.genivi.org/.
+ * For further information see http://projects.genivi.org/audio-manager *
- * THIS CODE HAS BEEN GENERATED BY ENTERPRISE ARCHITECT GENIVI MODEL. PLEASE CHANGE ONLY IN ENTERPRISE ARCHITECT AND GENERATE AGAIN
+ * THIS CODE HAS BEEN GENERATED BY ENTERPRISE ARCHITECT GENIVI MODEL. + * PLEASE CHANGE ONLY IN ENTERPRISE ARCHITECT AND GENERATE AGAIN. */
-#if !defined(EA_B7A11CC8_9777_4421_8677_D9CE084D5E2B__INCLUDED_)
-#define EA_B7A11CC8_9777_4421_8677_D9CE084D5E2B__INCLUDED_
+#if !defined(EA_6ECD9991_3219_4bf4_B9F7_DDE15D8683C6__INCLUDED_) +#define EA_6ECD9991_3219_4bf4_B9F7_DDE15D8683C6__INCLUDED_ #include <vector>
#include <string>
@@ -36,407 +37,82 @@ class CAmSocketHandler; #define RoutingReceiveVersion "2.0" namespace am { - /** - * Routing Receive sendInterface description. This class implements everything from RoutingAdapter -> Audiomanager - * There are two rules that have to be kept in mind when implementing against this interface:\n - * \warning - * 1. CALLS TO THIS INTERFACE ARE NOT THREAD SAFE !!!! \n - * 2. YOU MAY NOT CALL THE CALLING INTERFACE DURING AN SYNCHRONOUS OR ASYNCHRONOUS CALL THAT EXPECTS A RETURN VALUE.\n - * \details - * Violation these rules may lead to unexpected behavior! Nevertheless you can implement thread safe by using the deferred- - * call pattern described on the wiki which also helps to implement calls that are forbidden.\n - * For more information, please check CAmSerializer - * @author Christian Mueller - * @created 17-Jan-2013 10:00:25 - */ - class IAmRoutingReceive - { - public: - IAmRoutingReceive() { +/** + * Routing Receive sendInterface description. This class implements everything + * from RoutingAdapter -> Audiomanager + * There are two rules that have to be kept in mind when implementing against this + * interface:\n + * \warning + * 1. CALLS TO THIS INTERFACE ARE NOT THREAD SAFE !!!! \n + * 2. YOU MAY NOT CALL THE CALLING INTERFACE DURING AN SYNCHRONOUS OR ASYNCHRONOUS + * CALL THAT EXPECTS A RETURN VALUE.\n + * \details + * Violation these rules may lead to unexpected behavior! Nevertheless you can + * implement thread safe by using the deferred-call pattern described on the wiki + * which also helps to implement calls that are forbidden.\n + * For more information, please check CAmSerializer + */ +class IAmRoutingReceive +{ - } +public: + IAmRoutingReceive() { - virtual ~IAmRoutingReceive() { + } - } + virtual ~IAmRoutingReceive() { - /** - * This function returns the version of the interface - * - * @param version retrieves the verison of the interface - */ - virtual void getInterfaceVersion(std::string& version) const =0; - /** - * acknowledges a asyncConnect - * - * @param handle - * @param connectionID - * @param error E_OK on success, E_ABORTED if action was aborted, E_UNKNOWN on error - */ - virtual void ackConnect(const am_Handle_s handle, const am_connectionID_t connectionID, const am_Error_e error) =0; - /** - * acknowledges a asyncDisconnect - * - * @param handle - * @param connectionID - * @param error E_OK on success, E_ABORTED if action was aborted, E_UNKNOWN on error - */ - virtual void ackDisconnect(const am_Handle_s handle, const am_connectionID_t connectionID, const am_Error_e error) =0; - /** - * acknowledges a asyncsetSinkVolume - * - * @param handle - * @param volume The current actual value that is set - * @param error E_OK on success, E_ABORTED if action was aborted, E_UNKNOWN on error - */ - virtual void ackSetSinkVolumeChange(const am_Handle_s handle, const am_volume_t volume, const am_Error_e error) =0; - /** - * acknowledges a asyncsetSourceVolume - * - * @param handle handle that belongs to the change - * @param volume the current volume - * @param error E_OK on success, E_ABORTED if action was aborted, E_UNKNOWN on error - */ - virtual void ackSetSourceVolumeChange(const am_Handle_s handle, const am_volume_t volume, const am_Error_e error) =0; - /** - * acknowlegde for asyncSetSourceState - * - * @param handle - * @param error E_OK on success, E_ABORTED if action was aborted, E_UNKNOWN on error - */ - virtual void ackSetSourceState(const am_Handle_s handle, const am_Error_e error) =0; - /** - * acknowledges asyncSetSinkSoundProperties - * - * @param handle - * @param error E_OK on success, E_ABORTED if action was aborted, E_UNKNOWN on error - */ - virtual void ackSetSinkSoundProperties(const am_Handle_s handle, const am_Error_e error) =0; - /** - * acknowledges asyncSetSinkSoundProperty - * - * @param handle - * @param error E_OK on success, E_ABORTED if action was aborted, E_UNKNOWN on error - */ - virtual void ackSetSinkSoundProperty(const am_Handle_s handle, const am_Error_e error) =0; - /** - * acknowledges asyncSetSourceSoundProperties - * - * @param handle - * @param error E_OK on success, E_ABORTED if action was aborted, E_UNKNOWN on error - */ - virtual void ackSetSourceSoundProperties(const am_Handle_s handle, const am_Error_e error) =0; - /** - * acknowledges asyncSetSourceSoundProperty - * - * @param handle - * @param error E_OK on success, E_ABORTED if action was aborted, E_UNKNOWN on error - */ - virtual void ackSetSourceSoundProperty(const am_Handle_s handle, const am_Error_e error) =0; - /** - * acknowledges asyncCrossFade - * - * @param handle - * @param hotSink this is the current hot sink, HS_INTERMEDIATE is here when a crossfading action did not reach the end - * @param error E_OK on success, E_ABORTED if action was aborted, E_UNKNOWN on error - */ - virtual void ackCrossFading(const am_Handle_s handle, const am_HotSink_e hotSink, const am_Error_e error) =0; - /** - * acknowledges a volume tick. This can be used to display volumechanges during ramps - * - * @param handle - * @param sourceID - * @param volume - */ - virtual void ackSourceVolumeTick(const am_Handle_s handle, const am_sourceID_t sourceID, const am_volume_t volume) =0; - /** - * acknowledges a volume tick. This can be used to display volumechanges during ramps - * - * @param handle - * @param sinkID - * @param volume - */ - virtual void ackSinkVolumeTick(const am_Handle_s handle, const am_sinkID_t sinkID, const am_volume_t volume) =0; - /** - * This function returns the ID to the given domainName. If already a domain is registered with this name, it will return - * the corresponding ID, if not it will reserve an ID but not register the domain. The other parameters of the domain will - * be overwritten when the domain is registered. - * @return E_OK on success, E_UNKNOWN on error - * - * @param name - * @param domainID - */ - virtual am_Error_e peekDomain(const std::string& name, am_domainID_t& domainID) =0; - /** - * registers a domain - * @return E_OK on succes, E_ALREADY_EXISTENT if already registered E_UNKOWN on error - * - * @param domainData domainID in am_Domain_s must be 0! - * @param domainID - */ - virtual am_Error_e registerDomain(const am_Domain_s& domainData, am_domainID_t& domainID) =0; - /** - * deregisters a domain. All sources, sinks, gateways and crossfaders from that domain will be removed as well. - * @return E_OK on succes, E_NON_EXISTENT if not found E_UNKOWN on error - * - * @param domainID < the nonde of the bus - */ - virtual am_Error_e deregisterDomain(const am_domainID_t domainID) =0; - /** - * registers a gateway. @return E_OK on succes, E_ALREADY_EXISTENT if already registered E_UNKOWN on error - * - * @param gatewayData In a fixed setup, the gatewayID must be below 100. In a dynamic setup, the gatewayID shall be 0. - * listSourceFormats and listSinkFormats are empty at registration time. Values are taken over when sources and sinks are - * registered. - * - * - * @param gatewayID - */ - virtual am_Error_e registerGateway(const am_Gateway_s& gatewayData, am_gatewayID_t& gatewayID) =0; - /** - * deregisters a gateway. Also removes all sinks and sources of the controlling domain. - * @return E_OK on succes, E_NON_EXISTENT if not found E_UNKOWN on error - * - * @param gatewayID domainID of the control domain - */ - virtual am_Error_e deregisterGateway(const am_gatewayID_t gatewayID) =0; - /** - * This function returns the ID to the given sinkName. If already a sink is registered with this name, it will return the - * corresponding ID, if not it will reserve an ID but not register the sink. The other parameters of the sink will be - * overwritten when the sink is registered. - * @return E_OK on success, E_UNKNOWN on error - * - * @param name ID is not valid since not created yet - * @param sinkID - */ - virtual am_Error_e peekSink(const std::string& name, am_sinkID_t& sinkID) =0; - /** - * Registers a sink. If the sink is part of a gateway, the listconnectionFormats is copied to the gatewayInformation - * @return E_OK on succes, E_ALREADY_EXISTENT if already registered E_UNKOWN on error - * - * @param sinkData In a fixed setup, the sinkID within am_Sink_s must be below 100. In a dynamic setup the sinkID must - * be 0 in am_Sink_s. - * @param sinkID - */ - virtual am_Error_e registerSink(const am_Sink_s& sinkData, am_sinkID_t& sinkID) =0; - /** - * deregisters a sink. - * @return E_OK on succes, E_NON_EXISTENT if not found E_UNKOWN on error - * - * @param sinkID - */ - virtual am_Error_e deregisterSink(const am_sinkID_t sinkID) =0; - /** - * This function returns the ID to the given sourceName. If already a source is registered with this name, it will return - * the corresponding ID, if not it will reserve an ID but not register the source. The other parameters of the source will - * be overwritten when the source is registered. - * @return E_OK on success, E_UNKNOWN on error - * - * @param name - * @param sourceID - */ - virtual am_Error_e peekSource(const std::string& name, am_sourceID_t& sourceID) =0; - /** - * registers a source. If the source is part of a gateway, the listconnectionFormats is copied to the gatewayInformation - * @return E_OK on success, E_UNKNOWN on error, E_ALREADY_EXIST if either name or sourceID already exists - * - * @param sourceData In a fixed setup, the sourceID within am_Source_s must be below 100. In a dynamic setup the - * sourceID must be 0 in am_Source_s - * @param sourceID - */ - virtual am_Error_e registerSource(const am_Source_s& sourceData, am_sourceID_t& sourceID) =0; - /** - * deregisters a source - * @return E_OK on succes, E_NON_EXISTENT if not found E_UNKOWN on error - * - * @param sourceID - */ - virtual am_Error_e deregisterSource(const am_sourceID_t sourceID) =0; - /** - * this function registers a crossfader. - * @return E_OK on succes, E_ALREADY_EXISTENT if already registered E_UNKOWN on error - * - * @param crossfaderData in a fixed setup, the crossfaderID must be below 100. In a dynamic setup the crossfasderID - * shall be 0 - * @param crossfaderID - */ - virtual am_Error_e registerCrossfader(const am_Crossfader_s& crossfaderData, am_crossfaderID_t& crossfaderID) =0; - /** - * this function deregisters a crossfader. removes all sources and sinks assiated as well. - * @return E_OK on succes, E_NON_EXISTENT if not found E_UNKOWN on error - * - * @param crossfaderID - */ - virtual am_Error_e deregisterCrossfader(const am_crossfaderID_t crossfaderID) =0; - /** - * this function peeks a sourceclassID. It is used by the RoutingPlugins to determine the SinkClassIDs of a sinkClass. - * @return E_OK on succes, E_DATABASE_ERROR on error - * - * @param name - * @param sourceClassID - */ - virtual am_Error_e peekSourceClassID(const std::string& name, am_sourceClass_t& sourceClassID) =0; - /** - * this function peeks a sourceclassID. It is used by the RoutingPlugins to determine the SinkClassIDs of a sinkClass. - * @return E_OK on succes, E_DATABASE_ERROR on error - * - * @param name - * @param sinkClassID - */ - virtual am_Error_e peekSinkClassID(const std::string& name, am_sinkClass_t& sinkClassID) =0; - /** - * is called when a low level interrupt changes it status. - * - * @param sourceID - * @param interruptState - */ - virtual void hookInterruptStatusChange(const am_sourceID_t sourceID, const am_InterruptState_e interruptState) =0; - /** - * This hook is called when all elements from a domain are registered. - * Is used by the Controller to know when all expected domains are finally registered - * - * @param domainID - */ - virtual void hookDomainRegistrationComplete(const am_domainID_t domainID) =0; - /** - * is called when a sink changes its availability - * - * @param sinkID - * @param availability - */ - virtual void hookSinkAvailablityStatusChange(const am_sinkID_t sinkID, const am_Availability_s& availability) =0; - /** - * is called when a source changes its availability - * - * @param sourceID - * @param availability - */ - virtual void hookSourceAvailablityStatusChange(const am_sourceID_t sourceID, const am_Availability_s& availability) =0; - /** - * is called when a domain changes its status. This used for early domains only - * - * @param domainID - * @param domainState - */ - virtual void hookDomainStateChange(const am_domainID_t domainID, const am_DomainState_e domainState) =0; - /** - * is called when the timinginformation (delay) changed for a connection. - * - * @param connectionID - * @param delay - */ - virtual void hookTimingInformationChanged(const am_connectionID_t connectionID, const am_timeSync_t delay) =0; - /** - * this function is used to send out all data that has been changed in an early state. - * @return E_OK on success, E_UNKNOWN on error - * - * @param earlyData - */ - virtual void sendChangedData(const std::vector<am_EarlyData_s>& earlyData) =0; - /** - * this function is used to retrieve a pointer to the dBusConnectionWrapper - * @return E_OK if pointer is valid, E_UKNOWN if AudioManager was compiled without DBus Support - * - * @param dbusConnectionWrapper This is a wrapper class that is needed to keep dbus inclusions away from the interface. - * The DBusWrapperClass will return the pointer to the DbusConnection call (getDBusConnection) - */ - virtual am_Error_e getDBusConnectionWrapper(CAmDbusWrapper*& dbusConnectionWrapper) const =0; - /** - * This function returns the pointer to the socketHandler. This can be used to integrate socket-based activites like - * communication with the mainloop of the AudioManager. - * returns E_OK if pointer is valid, E_UNKNOWN in case AudioManager was compiled without socketHandler support, - * - * @param socketHandler - */ - virtual am_Error_e getSocketHandler(CAmSocketHandler*& socketHandler) const =0; - /** - * confirms the setRoutingReady Command - * - * @param handle the handle that was given via setRoutingReady - * @param error E_OK if the ready command succeeded. E_UNKNOWN if an error happened. - */ - virtual void confirmRoutingReady(const uint16_t handle, const am_Error_e error) =0; - /** - * confirms the setRoutingRundown Command - * - * @param handle handle that was given via setRoutingRundown - * @param error E_OK if the ready command succeeded. E_UNKNOWN if an error happened. - */ - virtual void confirmRoutingRundown(const uint16_t handle, const am_Error_e error) =0; - /** - * updates data of an gateway. @return E_OK on success, E_NON_EXISTENT if the gatewayID is not valid. - * - * @param gatewayID This is the new gateway data that has been updated. Please note that changing source and sink IDs, - * - * @param listSourceFormats - * @param listSinkFormats - * @param convertionMatrix - */ - virtual am_Error_e updateGateway(const am_gatewayID_t gatewayID, const std::vector<am_ConnectionFormat_e>& listSourceFormats, const std::vector<am_ConnectionFormat_e>& listSinkFormats, const std::vector<bool>& convertionMatrix) =0; - /** - * updates data of an gateway. @return E_OK on success, E_NON_EXISTENT if the sinkID is not valid. - * - * @param sinkID The sinkID of the sink - * @param sinkClassID - * @param listSoundProperties - * @param listConnectionFormats - * @param listMainSoundProperties - */ - virtual am_Error_e updateSink(const am_sinkID_t sinkID, const am_sinkClass_t sinkClassID, const std::vector<am_SoundProperty_s>& listSoundProperties, const std::vector<am_ConnectionFormat_e>& listConnectionFormats, const std::vector<am_MainSoundProperty_s>& listMainSoundProperties) =0; - /** - * updates data of an source. @return E_OK on success, E_NON_EXISTENT if the sourceID in the struct is not valid. - * Please note that only the following data out of am_Source_s have effect when they are changed: - * sourceClassID, - * listSoundProperties, - * listConnectionFormats, - * listMainSoundProperties - * - * @param sourceID the sourceID of the source - * @param sourceClassID - * @param listSoundProperties - * @param listConnectionFormats - * @param listMainSoundProperties - */ - virtual am_Error_e updateSource(const am_sourceID_t sourceID, const am_sourceClass_t sourceClassID, const std::vector<am_SoundProperty_s>& listSoundProperties, const std::vector<am_ConnectionFormat_e>& listConnectionFormats, const std::vector<am_MainSoundProperty_s>& listMainSoundProperties) =0; - /** - * acknowledges a asyncSetSinkVolumes - * - * @param handle - * @param listvolumes The list of volumes that have been set. ramp and time values have no meaning when the struct is - * used here. - * @param error E_OK on success, E_ABORTED if action was aborted, E_UNKNOWN on error - */ - virtual void ackSetVolumes(const am_Handle_s handle, const std::vector<am_Volumes_s>& listvolumes, const am_Error_e error) =0; - /** - * The acknowledge of the SinkNotificationConfiguration - * - * @param handle - * @param error - */ - virtual void ackSinkNotificationConfiguration(const am_Handle_s handle, const am_Error_e error) =0; - /** - * The acknowledge of the SourceNotificationConfiguration - * - * @param handle - * @param error - */ - virtual void ackSourceNotificationConfiguration(const am_Handle_s handle, const am_Error_e error) =0; - /** - * is called whenever a notified value needs to be send - * - * @param sinkID The sinkID of the sink where the data changed - * @param payload The payload - */ - virtual void hookSinkNotificationDataChange(const am_sinkID_t sinkID, const am_NotificationPayload_s& payload) =0; - /** - * is called whenever a notified value needs to be send - * - * @param sourceID The sinkID of the sink where the data changed - * @param payload The payload - */ - virtual void hookSourceNotificationDataChange(const am_sourceID_t sourceID, const am_NotificationPayload_s& payload) =0; + } - }; + virtual void getInterfaceVersion(std::string& version) const =0; + virtual void ackConnect(const am_Handle_s handle, const am_connectionID_t connectionID, const am_Error_e error) =0; + virtual void ackDisconnect(const am_Handle_s handle, const am_connectionID_t connectionID, const am_Error_e error) =0; + virtual void ackSetSinkVolumeChange(const am_Handle_s handle, const am_volume_t volume, const am_Error_e error) =0; + virtual void ackSetSourceVolumeChange(const am_Handle_s handle, const am_volume_t volume, const am_Error_e error) =0; + virtual void ackSetSourceState(const am_Handle_s handle, const am_Error_e error) =0; + virtual void ackSetSinkSoundProperties(const am_Handle_s handle, const am_Error_e error) =0; + virtual void ackSetSinkSoundProperty(const am_Handle_s handle, const am_Error_e error) =0; + virtual void ackSetSourceSoundProperties(const am_Handle_s handle, const am_Error_e error) =0; + virtual void ackSetSourceSoundProperty(const am_Handle_s handle, const am_Error_e error) =0; + virtual void ackCrossFading(const am_Handle_s handle, const am_HotSink_e hotSink, const am_Error_e error) =0; + virtual void ackSourceVolumeTick(const am_Handle_s handle, const am_sourceID_t sourceID, const am_volume_t volume) =0; + virtual void ackSinkVolumeTick(const am_Handle_s handle, const am_sinkID_t sinkID, const am_volume_t volume) =0; + virtual am_Error_e peekDomain(const std::string& name, am_domainID_t& domainID) =0; + virtual am_Error_e registerDomain(const am_Domain_s& domainData, am_domainID_t& domainID) =0; + virtual am_Error_e deregisterDomain(const am_domainID_t domainID) =0; + virtual am_Error_e registerGateway(const am_Gateway_s& gatewayData, am_gatewayID_t& gatewayID) =0; + virtual am_Error_e deregisterGateway(const am_gatewayID_t gatewayID) =0; + virtual am_Error_e peekSink(const std::string& name, am_sinkID_t& sinkID) =0; + virtual am_Error_e registerSink(const am_Sink_s& sinkData, am_sinkID_t& sinkID) =0; + virtual am_Error_e deregisterSink(const am_sinkID_t sinkID) =0; + virtual am_Error_e peekSource(const std::string& name, am_sourceID_t& sourceID) =0; + virtual am_Error_e registerSource(const am_Source_s& sourceData, am_sourceID_t& sourceID) =0; + virtual am_Error_e deregisterSource(const am_sourceID_t sourceID) =0; + virtual am_Error_e registerCrossfader(const am_Crossfader_s& crossfaderData, am_crossfaderID_t& crossfaderID) =0; + virtual am_Error_e deregisterCrossfader(const am_crossfaderID_t crossfaderID) =0; + virtual am_Error_e peekSourceClassID(const std::string& name, am_sourceClass_t& sourceClassID) =0; + virtual am_Error_e peekSinkClassID(const std::string& name, am_sinkClass_t& sinkClassID) =0; + virtual void hookInterruptStatusChange(const am_sourceID_t sourceID, const am_InterruptState_e interruptState) =0; + virtual void hookDomainRegistrationComplete(const am_domainID_t domainID) =0; + virtual void hookSinkAvailablityStatusChange(const am_sinkID_t sinkID, const am_Availability_s& availability) =0; + virtual void hookSourceAvailablityStatusChange(const am_sourceID_t sourceID, const am_Availability_s& availability) =0; + virtual void hookDomainStateChange(const am_domainID_t domainID, const am_DomainState_e domainState) =0; + virtual void hookTimingInformationChanged(const am_connectionID_t connectionID, const am_timeSync_t delay) =0; + virtual void sendChangedData(const std::vector<am_EarlyData_s>& earlyData) =0; + virtual am_Error_e getDBusConnectionWrapper(CAmDbusWrapper*& dbusConnectionWrapper) const =0; + virtual am_Error_e getSocketHandler(CAmSocketHandler*& socketHandler) const =0; + virtual void confirmRoutingReady(const uint16_t handle, const am_Error_e error) =0; + virtual void confirmRoutingRundown(const uint16_t handle, const am_Error_e error) =0; + virtual am_Error_e updateGateway(const am_gatewayID_t gatewayID, const std::vector<am_CustomConnectionFormat_t>& listSourceFormats, const std::vector<am_CustomConnectionFormat_t>& listSinkFormats, const std::vector<bool>& convertionMatrix) =0; + virtual am_Error_e updateSink(const am_sinkID_t sinkID, const am_sinkClass_t sinkClassID, const std::vector<am_SoundProperty_s>& listSoundProperties, const std::vector<am_CustomConnectionFormat_t>& listConnectionFormats, const std::vector<am_MainSoundProperty_s>& listMainSoundProperties) =0; + virtual am_Error_e updateSource(const am_sourceID_t sourceID, const am_sourceClass_t sourceClassID, const std::vector<am_SoundProperty_s>& listSoundProperties, const std::vector<am_CustomConnectionFormat_t>& listConnectionFormats, const std::vector<am_MainSoundProperty_s>& listMainSoundProperties) =0; + virtual void ackSetVolumes(const am_Handle_s handle, const std::vector<am_Volumes_s>& listvolumes, const am_Error_e error) =0; + virtual void ackSinkNotificationConfiguration(const am_Handle_s handle, const am_Error_e error) =0; + virtual void ackSourceNotificationConfiguration(const am_Handle_s handle, const am_Error_e error) =0; + virtual void hookSinkNotificationDataChange(const am_sinkID_t sinkID, const am_NotificationPayload_s& payload) =0; + virtual void hookSourceNotificationDataChange(const am_sourceID_t sourceID, const am_NotificationPayload_s& payload) =0; + +}; } -#endif // !defined(EA_B7A11CC8_9777_4421_8677_D9CE084D5E2B__INCLUDED_) +#endif // !defined(EA_6ECD9991_3219_4bf4_B9F7_DDE15D8683C6__INCLUDED_) |