diff options
author | christian linke <christian.linke@bmw.de> | 2012-12-17 16:15:11 +0100 |
---|---|---|
committer | christian linke <christian.linke@bmw.de> | 2012-12-17 16:15:11 +0100 |
commit | 54c5e965fe8f9a53a78834028fd65c792493da2b (patch) | |
tree | 560d7b1209e6a8d4798de9568e4b4a947c2ab42a /include/control | |
parent | 215e8a72dc81e8a86dd5b3a8ca40fd2c7c6a0b9c (diff) | |
download | audiomanager-54c5e965fe8f9a53a78834028fd65c792493da2b.tar.gz |
* added new interfaces & nsm support + nsm tests + fixed some unit tests + fixed rundown
Signed-off-by: christian linke <christian.linke@bmw.de>
Diffstat (limited to 'include/control')
-rw-r--r-- | include/control/IAmControlReceive.h | 527 | ||||
-rw-r--r-- | include/control/IAmControlSend.h | 229 |
2 files changed, 493 insertions, 263 deletions
diff --git a/include/control/IAmControlReceive.h b/include/control/IAmControlReceive.h index 1cbf244..ccba927 100644 --- a/include/control/IAmControlReceive.h +++ b/include/control/IAmControlReceive.h @@ -12,15 +12,15 @@ * this file, You can obtain one at http://mozilla.org/MPL/2.0/.
*
*
- * \author Christian Mueller, christian.ei.mueller@bmw.de BMW 2011,2012
+ * \author Christian Mueller, christian.linke@bmw.de BMW 2011,2012
*
* \file
* For further information see http://www.genivi.org/.
*
* THIS CODE HAS BEEN GENERATED BY ENTERPRISE ARCHITECT GENIVI MODEL. PLEASE CHANGE ONLY IN ENTERPRISE ARCHITECT AND GENERATE AGAIN
*/
-#if !defined(EA_6E701C15_A8E8_4ad3_A50B_D91A5BD0973F__INCLUDED_)
-#define EA_6E701C15_A8E8_4ad3_A50B_D91A5BD0973F__INCLUDED_
+#if !defined(EA_AC2A0532_F989_4f95_A467_1055C94D9C1E__INCLUDED_)
+#define EA_AC2A0532_F989_4f95_A467_1055C94D9C1E__INCLUDED_
#include <vector>
#include <string>
@@ -30,24 +30,25 @@ class CAmSocketHandler; }
-#define ControlReceiveVersion "1.0" +#include "audiomanagertypes.h" +#include "projecttypes.h" +#include "NodeStateManager.h" + +#define ControlReceiveVersion "2.0" namespace am { /** - * This interface gives access to all important functions of the audiomanager that - * are used by the AudioManagerController to control the system. - * There are two rules that have to be kept in mind when implementing against this - * interface:\n + * This interface gives access to all important functions of the audiomanager that are used by the AudioManagerController + * to control the system. + * 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 + * 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 + * 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 07-Mar-2012 6:06:18 PM + * @created 16-Dez-2012 15:58:15 */ class IAmControlReceive { @@ -71,20 +72,17 @@ namespace am { * calculates a route from source to sink. * @return E_OK on success, E_UNKNOWN on error * - * @param onlyfree if true return only routes which use gateways that are not - * in use at the moment + * @param onlyfree if true return only routes which use gateways that are not in use at the moment * @param sourceID * @param sinkID - * @param returnList this is a list of routes that are possible to take. - * unsorted! The longest could be first. + * @param returnList this is a list of routes that are possible to take. unsorted! The longest could be first. * In case not route can be found, the list will return empty. */ virtual am_Error_e getRoute(const bool onlyfree, const am_sourceID_t sourceID, const am_sinkID_t sinkID, std::vector<am_Route_s>& returnList) =0; /** * With this function, elementary connects can be triggered by the controller. - * @return E_OK on success, E_UNKNOWN on error, E_WRONG_FORMAT of - * connectionFormats do not match, E_NO_CHANGE if the desired connection is - * already build up + * @return E_OK on success, E_UNKNOWN on error, E_WRONG_FORMAT of connectionFormats do not match, E_NO_CHANGE if the + * desired connection is already build up * * @param handle * @param connectionID @@ -95,8 +93,8 @@ namespace am { virtual am_Error_e connect(am_Handle_s& handle, am_connectionID_t& connectionID, const am_ConnectionFormat_e format, const am_sourceID_t sourceID, const am_sinkID_t sinkID) =0; /** * is used to disconnect a connection - * @return E_OK on success, E_UNKNOWN on error, E_NON_EXISTENT if connection was - * not found, E_NO_CHANGE if no change is neccessary + * @return E_OK on success, E_UNKNOWN on error, E_NON_EXISTENT if connection was not found, E_NO_CHANGE if no change is + * neccessary * * @param handle * @param connectionID @@ -104,12 +102,10 @@ namespace am { virtual am_Error_e disconnect(am_Handle_s& handle, const am_connectionID_t connectionID) =0; /** * triggers a cross fade. - * @return E_OK on success, E_UNKNOWN on error E_NO_CHANGE if no change is - * neccessary + * @return E_OK on success, E_UNKNOWN on error E_NO_CHANGE if no change is neccessary * * @param handle - * @param hotSource this is the source that is going to be the active one after - * the fading + * @param hotSource this is the source that is going to be the active one after the fading * @param crossfaderID * @param rampType * @param rampTime rampTime 0 means default value @@ -123,10 +119,9 @@ namespace am { */ virtual am_Error_e abortAction(const am_Handle_s handle) =0; /** - * this method sets a source state for a source. This function will trigger the - * callback cbAckSetSourceState - * @return E_OK on success, E_NO_CHANGE if the desired value is already correct, - * E_UNKNOWN on error, E_NO_CHANGE if no change is neccessary + * this method sets a source state for a source. This function will trigger the callback cbAckSetSourceState + * @return E_OK on success, E_NO_CHANGE if the desired value is already correct, E_UNKNOWN on error, E_NO_CHANGE if no + * change is neccessary * * @param handle * @param sourceID @@ -134,13 +129,12 @@ namespace am { */ virtual am_Error_e setSourceState(am_Handle_s& handle, const am_sourceID_t sourceID, const am_SourceState_e state) =0; /** - * with this function, setting of sinks volumes is done. The behavior of the - * volume set is depended on the given ramp and time information. - * This function is not only used to ramp volume, but also to mute and direct set - * the level. Exact behavior is depended on the selected mute ramps. - * @return E_OK on success, E_NO_CHANGE if the volume is already on the desired - * value, E_OUT_OF_RANGE is the volume is out of range, E_UNKNOWN on every other - * error. + * with this function, setting of sinks volumes is done. The behavior of the volume set is depended on the given ramp and + * time information. + * This function is not only used to ramp volume, but also to mute and direct set the level. Exact behavior is depended on + * the selected mute ramps. + * @return E_OK on success, E_NO_CHANGE if the volume is already on the desired value, E_OUT_OF_RANGE is the volume is out + * of range, E_UNKNOWN on every other error. * * @param handle * @param sinkID @@ -150,13 +144,12 @@ namespace am { */ virtual am_Error_e setSinkVolume(am_Handle_s& handle, const am_sinkID_t sinkID, const am_volume_t volume, const am_RampType_e ramp, const am_time_t time) =0; /** - * with this function, setting of source volumes is done. The behavior of the - * volume set is depended on the given ramp and time information. - * This function is not only used to ramp volume, but also to mute and direct set - * the level. Exact behavior is depended on the selected mute ramps. - * @return E_OK on success, E_NO_CHANGE if the volume is already on the desired - * value, E_OUT_OF_RANGE is the volume is out of range, E_UNKNOWN on every other - * error. + * with this function, setting of source volumes is done. The behavior of the volume set is depended on the given ramp and + * time information. + * This function is not only used to ramp volume, but also to mute and direct set the level. Exact behavior is depended on + * the selected mute ramps. + * @return E_OK on success, E_NO_CHANGE if the volume is already on the desired value, E_OUT_OF_RANGE is the volume is out + * of range, E_UNKNOWN on every other error. * * @param handle * @param sourceID @@ -167,8 +160,8 @@ namespace am { virtual am_Error_e setSourceVolume(am_Handle_s& handle, const am_sourceID_t sourceID, const am_volume_t volume, const am_RampType_e rampType, const am_time_t time) =0; /** * is used to set several sinkSoundProperties at a time - * @return E_OK on success, E_UNKNOWN on error, E_OUT_OF_RANGE if property is out - * of range, E_NO_CHANGE if no change is neccessary + * @return E_OK on success, E_UNKNOWN on error, E_OUT_OF_RANGE if property is out of range, E_NO_CHANGE if no change is + * neccessary * * @param handle * @param sinkID @@ -177,8 +170,8 @@ namespace am { virtual am_Error_e setSinkSoundProperties(am_Handle_s& handle, const am_sinkID_t sinkID, const std::vector<am_SoundProperty_s>& soundProperty) =0; /** * is used to set sinkSoundProperties - * @return E_OK on success, E_UNKNOWN on error, E_OUT_OF_RANGE if property is out - * of range, E_NO_CHANGE if no change is neccessary + * @return E_OK on success, E_UNKNOWN on error, E_OUT_OF_RANGE if property is out of range, E_NO_CHANGE if no change is + * neccessary * * @param handle * @param sinkID @@ -187,8 +180,8 @@ namespace am { virtual am_Error_e setSinkSoundProperty(am_Handle_s& handle, const am_sinkID_t sinkID, const am_SoundProperty_s& soundProperty) =0; /** * is used to set several SourceSoundProperties at a time - * @return E_OK on success, E_UNKNOWN on error, E_OUT_OF_RANGE if property is out - * of range. E_NO_CHANGE if no change is neccessary + * @return E_OK on success, E_UNKNOWN on error, E_OUT_OF_RANGE if property is out of range. E_NO_CHANGE if no change is + * neccessary * * @param handle * @param sourceID @@ -197,8 +190,8 @@ namespace am { virtual am_Error_e setSourceSoundProperties(am_Handle_s& handle, const am_sourceID_t sourceID, const std::vector<am_SoundProperty_s>& soundProperty) =0; /** * is used to set sourceSoundProperties - * @return E_OK on success, E_UNKNOWN on error, E_OUT_OF_RANGE if property is out - * of range. E_NO_CHANGE if no change is neccessary + * @return E_OK on success, E_UNKNOWN on error, E_OUT_OF_RANGE if property is out of range. E_NO_CHANGE if no change is + * neccessary * * @param handle * @param sourceID @@ -207,8 +200,7 @@ namespace am { virtual am_Error_e setSourceSoundProperty(am_Handle_s& handle, const am_sourceID_t sourceID, const am_SoundProperty_s& soundProperty) =0; /** * sets the domain state of a domain - * @return E_OK on success, E_UNKNOWN on error, E_NO_CHANGE if no change is - * neccessary + * @return E_OK on success, E_UNKNOWN on error, E_NO_CHANGE if no change is neccessary * * @param domainID * @param domainState @@ -216,8 +208,8 @@ namespace am { virtual am_Error_e setDomainState(const am_domainID_t domainID, const am_DomainState_e domainState) =0; /** * enters a domain in the database, creates and ID - * @return E_OK on success, E_ALREADY_EXISTENT if the ID or name is already in the - * database, E_DATABASE_ERROR if the database had an error + * @return E_OK on success, E_ALREADY_EXISTENT if the ID or name is already in the database, E_DATABASE_ERROR if the + * database had an error * * @param domainData domainID in am_Domain_s must be 0 here * @param domainID @@ -227,127 +219,109 @@ namespace am { * enters a mainconnection in the database, creates and ID * @return E_OK on success, E_DATABASE_ERROR if the database had an error * - * @param mainConnectionData the MainConnectionID is omitted since it is - * created during the registration + * @param mainConnectionData the MainConnectionID is omitted since it is created during the registration * @param connectionID */ virtual am_Error_e enterMainConnectionDB(const am_MainConnection_s& mainConnectionData, am_mainConnectionID_t& connectionID) =0; /** * enters a sink in the database. - * The sinkID in am_Sink_s shall be 0 in case of a dynamic added source A sinkID - * greater than 100 will be assigned. If a specific sinkID with a value <100 is - * given, the given value will be used. This is for a static setup where the ID's - * are predefined. - * @return E_OK on success, E_ALREADY_EXISTENT if the ID or name is already in the - * database, E_DATABASE_ERROR if the database had an error - * - * @param sinkData the sinkID will be omitted since it is created during the - * registration + * The sinkID in am_Sink_s shall be 0 in case of a dynamic added source A sinkID greater than 100 will be assigned. If a + * specific sinkID with a value <100 is given, the given value will be used. This is for a static setup where the ID's are + * predefined. + * @return E_OK on success, E_ALREADY_EXISTENT if the ID or name is already in the database, E_DATABASE_ERROR if the + * database had an error + * + * @param sinkData the sinkID will be omitted since it is created during the registration * @param sinkID */ virtual am_Error_e enterSinkDB(const am_Sink_s& sinkData, am_sinkID_t& sinkID) =0; /** * enters a crossfader in the database. - * The crossfaderID in am_Crossfader_s shall be 0 in case of a dynamic added - * source A crossfaderID greater than 100 will be assigned. If a specific - * crossfaderID with a value <100 is given, the given value will be used. This is - * for a static setup where the ID's are predefined. - * @return E_OK on success, E_ALREADY_EXISTENT if the ID or name is already in the - * database, E_DATABASE_ERROR if the database had an error - * - * @param crossfaderData the ID in the data will be ignored since it is created - * during the registration + * The crossfaderID in am_Crossfader_s shall be 0 in case of a dynamic added source A crossfaderID greater than 100 will + * be assigned. If a specific crossfaderID with a value <100 is given, the given value will be used. This is for a static + * setup where the ID's are predefined. + * @return E_OK on success, E_ALREADY_EXISTENT if the ID or name is already in the database, E_DATABASE_ERROR if the + * database had an error + * + * @param crossfaderData the ID in the data will be ignored since it is created during the registration * @param crossfaderID */ virtual am_Error_e enterCrossfaderDB(const am_Crossfader_s& crossfaderData, am_crossfaderID_t& crossfaderID) =0; /** * enters a gateway in the database. - * The gatewayID in am_Gateway_s shall be 0 in case of a dynamic added source A - * gatewayID greater than 100 will be assigned. If a specific gatewayID with a - * value <100 is given, the given value will be used. This is for a static setup + * The gatewayID in am_Gateway_s shall be 0 in case of a dynamic added source A gatewayID greater than 100 will be + * assigned. If a specific gatewayID with a value <100 is given, the given value will be used. This is for a static setup * where the ID's are predefined. - * @return E_OK on success, E_ALREADY_EXISTENT if the ID or name is already in the - * database, E_DATABASE_ERROR if the database had an error + * @return E_OK on success, E_ALREADY_EXISTENT if the ID or name is already in the database, E_DATABASE_ERROR if the + * database had an 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 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 enterGatewayDB(const am_Gateway_s& gatewayData, am_gatewayID_t& gatewayID) =0; /** * enters a source in the database. - * The sourceID in am_Source_s shall be 0 in case of a dynamic added source A - * sourceID greater than 100 will be assigned. If a specific sourceID with a value - * <100 is given, the given value will be used. This is for a static setup where - * the ID's are predefined. - * @return E_OK on success, E_ALREADY_EXISTENT if the ID or name is already in the - * database, E_DATABASE_ERROR if the database had an error - * - * @param sourceData sourceID is omitted here since it is created during - * registration + * The sourceID in am_Source_s shall be 0 in case of a dynamic added source A sourceID greater than 100 will be assigned. + * If a specific sourceID with a value <100 is given, the given value will be used. This is for a static setup where the + * ID's are predefined. + * @return E_OK on success, E_ALREADY_EXISTENT if the ID or name is already in the database, E_DATABASE_ERROR if the + * database had an error + * + * @param sourceData sourceID is omitted here since it is created during registration * @param sourceID */ virtual am_Error_e enterSourceDB(const am_Source_s& sourceData, am_sourceID_t& sourceID) =0; /** * Enters a sourceClass into the database. - * @return E_OK on success, E_ALREADY_EXISTENT if the ID or name is already in the - * database, E_DATABASE_ERROR if the database had an error + * @return E_OK on success, E_ALREADY_EXISTENT if the ID or name is already in the database, E_DATABASE_ERROR if the + * database had an error * - * @param sinkClass IDs given with the SinkCLassID are valid below 100 (static). - * If given as 0, sinkClass will be enterd dynamic and ID above 100 will be - * created. + * @param sinkClass IDs given with the SinkCLassID are valid below 100 (static). If given as 0, sinkClass will be + * enterd dynamic and ID above 100 will be created. * @param sinkClassID */ virtual am_Error_e enterSinkClassDB(const am_SinkClass_s& sinkClass, am_sinkClass_t& sinkClassID) =0; /** * Enters a sourceClass into the database. - * The sourceClassID in am_sourceClass_s shall be 0 in case of a dynamic added - * source A sourceClassID greater than 100 will be assigned. If a specific - * sourceClassID with a value <100 is given, the given value will be used. This is - * for a static setup where the ID's are predefined. - * @return E_OK on success, E_ALREADY_EXISTENT if the ID or name is already in the - * database, E_DATABASE_ERROR if the database had an error + * The sourceClassID in am_sourceClass_s shall be 0 in case of a dynamic added source A sourceClassID greater than 100 + * will be assigned. If a specific sourceClassID with a value <100 is given, the given value will be used. This is for a + * static setup where the ID's are predefined. + * @return E_OK on success, E_ALREADY_EXISTENT if the ID or name is already in the database, E_DATABASE_ERROR if the + * database had an error * * @param sourceClassID - * @param sourceClass IDs given with the SourceCLassID are valid below 100 - * (static). If given as 0, sourceClass will be enterd dynamic and ID above 100 - * will be created. + * @param sourceClass IDs given with the SourceCLassID are valid below 100 (static). If given as 0, sourceClass will be + * enterd dynamic and ID above 100 will be created. */ virtual am_Error_e enterSourceClassDB(am_sourceClass_t& sourceClassID, const am_SourceClass_s& sourceClass) =0; /** * changes class information of a sinkclass. - * The properties will overwrite the values of the sinkClassID given in the - * sinkClass. - * It is the duty of the controller to check if the property is valid. If it does - * not exist, the daemon will not return an error. - * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if - * sinkClassID was not found. + * The properties will overwrite the values of the sinkClassID given in the sinkClass. + * It is the duty of the controller to check if the property is valid. If it does not exist, the daemon will not return an + * error. + * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if sinkClassID was not found. * - * @param sinkClass if a SourceClass ID other than 0 is given, the - * classInformation replaces the existing one. In case of ClassID 0, a new classID - * is created and returned + * @param sinkClass if a SourceClass ID other than 0 is given, the classInformation replaces the existing one. In case + * of ClassID 0, a new classID is created and returned */ virtual am_Error_e changeSinkClassInfoDB(const am_SinkClass_s& sinkClass) =0; /** * changes class information of a sourceClass. - * The properties will overwrite the values of the sourceClassID given in the - * sourceClass. - * It is the duty of the controller to check if the property is valid. If it does - * not exist, the daemon will not return an error. - * @return E_OK on success, E_DATABASE_ERROR on error and E_NON_EXISTENT if the - * ClassID does not exist. + * The properties will overwrite the values of the sourceClassID given in the sourceClass. + * It is the duty of the controller to check if the property is valid. If it does not exist, the daemon will not return an + * error. + * @return E_OK on success, E_DATABASE_ERROR on error and E_NON_EXISTENT if the ClassID does not exist. * - * @param sourceClass if a SourceClass ID other than 0 is given, the - * classInformation replaces the existing one. In case of ClassID 0, a new classID - * is created and returned + * @param sourceClass if a SourceClass ID other than 0 is given, the classInformation replaces the existing one. In + * case of ClassID 0, a new classID is created and returned */ virtual am_Error_e changeSourceClassInfoDB(const am_SourceClass_s& sourceClass) =0; /** * This function is used to enter the system Properties into the database. - * All entries in the database will be erased before entering the new List. It - * should only be called once at system startup. + * All entries in the database will be erased before entering the new List. It should only be called once at system + * startup. * @return E_OK on success, E_DATABASE_ERROR if the database had an error * * @param listSystemProperties @@ -355,8 +329,7 @@ namespace am { virtual am_Error_e enterSystemPropertiesListDB(const std::vector<am_SystemProperty_s>& listSystemProperties) =0; /** * changes the mainConnectionState of MainConnection - * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if - * mainconnection + * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if mainconnection * * @param mainconnectionID * @param listConnectionID @@ -364,8 +337,7 @@ namespace am { virtual am_Error_e changeMainConnectionRouteDB(const am_mainConnectionID_t mainconnectionID, const std::vector<am_connectionID_t>& listConnectionID) =0; /** * changes the mainConnectionState of MainConnection - * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if - * mainconnection + * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if mainconnection * * @param mainconnectionID * @param connectionState @@ -373,8 +345,7 @@ namespace am { virtual am_Error_e changeMainConnectionStateDB(const am_mainConnectionID_t mainconnectionID, const am_ConnectionState_e connectionState) =0; /** * changes the sink volume of a sink - * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if sink was - * not found + * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if sink was not found * * @param mainVolume * @param sinkID @@ -382,8 +353,7 @@ namespace am { virtual am_Error_e changeSinkMainVolumeDB(const am_mainVolume_t mainVolume, const am_sinkID_t sinkID) =0; /** * changes the availablility of a sink - * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if sink was - * not found + * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if sink was not found * * @param availability * @param sinkID @@ -391,8 +361,7 @@ namespace am { virtual am_Error_e changeSinkAvailabilityDB(const am_Availability_s& availability, const am_sinkID_t sinkID) =0; /** * changes the domainstate of a domain - * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if domain - * was not found + * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if domain was not found * * @param domainState * @param domainID @@ -400,8 +369,7 @@ namespace am { virtual am_Error_e changDomainStateDB(const am_DomainState_e domainState, const am_domainID_t domainID) =0; /** * changes the mute state of a sink - * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if sink was - * not found + * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if sink was not found * * @param muteState * @param sinkID @@ -409,8 +377,7 @@ namespace am { virtual am_Error_e changeSinkMuteStateDB(const am_MuteState_e muteState, const am_sinkID_t sinkID) =0; /** * changes the mainsinksoundproperty of a sink - * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if sink was - * not found + * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if sink was not found * * @param soundProperty * @param sinkID @@ -418,8 +385,7 @@ namespace am { virtual am_Error_e changeMainSinkSoundPropertyDB(const am_MainSoundProperty_s& soundProperty, const am_sinkID_t sinkID) =0; /** * changes the mainsourcesoundproperty of a sink - * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if source - * was not found + * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if source was not found * * @param soundProperty * @param sourceID @@ -427,8 +393,7 @@ namespace am { virtual am_Error_e changeMainSourceSoundPropertyDB(const am_MainSoundProperty_s& soundProperty, const am_sourceID_t sourceID) =0; /** * changes the availablility of a source - * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if source - * was not found + * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if source was not found * * @param availability * @param sourceID @@ -436,80 +401,70 @@ namespace am { virtual am_Error_e changeSourceAvailabilityDB(const am_Availability_s& availability, const am_sourceID_t sourceID) =0; /** * changes a systemProperty - * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if property - * was not found + * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if property was not found * * @param property */ virtual am_Error_e changeSystemPropertyDB(const am_SystemProperty_s& property) =0; /** * removes a mainconnection from the DB - * @return E_OK on success, E_NON_EXISTENT if main connection was not found, - * E_DATABASE_ERROR if the database had an error + * @return E_OK on success, E_NON_EXISTENT if main connection was not found, E_DATABASE_ERROR if the database had an error * * @param mainConnectionID */ virtual am_Error_e removeMainConnectionDB(const am_mainConnectionID_t mainConnectionID) =0; /** * removes a sink from the DB - * @return E_OK on success, E_NON_EXISTENT if sink was not found, E_DATABASE_ERROR - * if the database had an error + * @return E_OK on success, E_NON_EXISTENT if sink was not found, E_DATABASE_ERROR if the database had an error * * @param sinkID */ virtual am_Error_e removeSinkDB(const am_sinkID_t sinkID) =0; /** * removes a source from the DB - * @return E_OK on success, E_NON_EXISTENT if source was not found, - * E_DATABASE_ERROR if the database had an error + * @return E_OK on success, E_NON_EXISTENT if source was not found, E_DATABASE_ERROR if the database had an error * * @param sourceID */ virtual am_Error_e removeSourceDB(const am_sourceID_t sourceID) =0; /** * removes a gateway from the DB - * @return E_OK on success, E_NON_EXISTENT if gateway was not found, - * E_DATABASE_ERROR if the database had an error + * @return E_OK on success, E_NON_EXISTENT if gateway was not found, E_DATABASE_ERROR if the database had an error * * @param gatewayID */ virtual am_Error_e removeGatewayDB(const am_gatewayID_t gatewayID) =0; /** * removes a crossfader from the DB - * @return E_OK on success, E_NON_EXISTENT if crossfader was not found, - * E_DATABASE_ERROR if the database had an error + * @return E_OK on success, E_NON_EXISTENT if crossfader was not found, E_DATABASE_ERROR if the database had an error * * @param crossfaderID */ virtual am_Error_e removeCrossfaderDB(const am_crossfaderID_t crossfaderID) =0; /** * removes a domain from the DB - * @return E_OK on success, E_NON_EXISTENT if domain was not found, - * E_DATABASE_ERROR if the database had an error + * @return E_OK on success, E_NON_EXISTENT if domain was not found, E_DATABASE_ERROR if the database had an error * * @param domainID */ virtual am_Error_e removeDomainDB(const am_domainID_t domainID) =0; /** * removes a domain from the DB - * @return E_OK on success, E_NON_EXISTENT if domain was not found, - * E_DATABASE_ERROR if the database had an error + * @return E_OK on success, E_NON_EXISTENT if domain was not found, E_DATABASE_ERROR if the database had an error * * @param sinkClassID */ virtual am_Error_e removeSinkClassDB(const am_sinkClass_t sinkClassID) =0; /** * removes a domain from the DB - * @return E_OK on success, E_NON_EXISTENT if domain was not found, - * E_DATABASE_ERROR if the database had an error + * @return E_OK on success, E_NON_EXISTENT if domain was not found, E_DATABASE_ERROR if the database had an error * * @param sourceClassID */ virtual am_Error_e removeSourceClassDB(const am_sourceClass_t sourceClassID) =0; /** * returns the ClassInformation of a source - * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if source - * was not found + * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if source was not found * * @param sourceID * @param classInfo @@ -517,8 +472,7 @@ namespace am { virtual am_Error_e getSourceClassInfoDB(const am_sourceID_t sourceID, am_SourceClass_s& classInfo) const =0; /** * returns the ClassInformation of a sink - * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if sink was - * not found + * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if sink was not found * * @param sinkID * @param sinkClass @@ -526,8 +480,7 @@ namespace am { virtual am_Error_e getSinkClassInfoDB(const am_sinkID_t sinkID, am_SinkClass_s& sinkClass) const =0; /** * returns the sinkData of a sink - * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if sink was - * not found + * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if sink was not found * * @param sinkID * @param sinkData @@ -535,8 +488,7 @@ namespace am { virtual am_Error_e getSinkInfoDB(const am_sinkID_t sinkID, am_Sink_s& sinkData) const =0; /** * returns the sourcekData of a source - * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if sink was - * not found + * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if sink was not found * * @param sourceID * @param sourceData @@ -544,8 +496,7 @@ namespace am { virtual am_Error_e getSourceInfoDB(const am_sourceID_t sourceID, am_Source_s& sourceData) const =0; /** * return source and sink of a gateway - * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if gateway - * was not found + * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if gateway was not found * * @param gatewayID * @param gatewayData @@ -553,8 +504,7 @@ namespace am { virtual am_Error_e getGatewayInfoDB(const am_gatewayID_t gatewayID, am_Gateway_s& gatewayData) const =0; /** * returns sources and the sink of a crossfader - * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if - * crossfader was not found + * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if crossfader was not found * * @param crossfaderID * @param crossfaderData @@ -562,8 +512,7 @@ namespace am { virtual am_Error_e getCrossfaderInfoDB(const am_crossfaderID_t crossfaderID, am_Crossfader_s& crossfaderData) const =0; /** * returns sources and the sink of a crossfader - * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if - * crossfader was not found + * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if crossfader was not found * * @param mainConnectionID * @param mainConnectionData @@ -571,8 +520,7 @@ namespace am { virtual am_Error_e getMainConnectionInfoDB(const am_mainConnectionID_t mainConnectionID, am_MainConnection_s& mainConnectionData) const =0; /** * returns all sinks of a domain - * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if domain - * was not found + * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if domain was not found * * @param domainID * @param listSinkID @@ -580,8 +528,7 @@ namespace am { virtual am_Error_e getListSinksOfDomain(const am_domainID_t domainID, std::vector<am_sinkID_t>& listSinkID) const =0; /** * returns all source of a domain - * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if domain - * was not found + * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if domain was not found * * @param domainID * @param listSourceID @@ -589,8 +536,7 @@ namespace am { virtual am_Error_e getListSourcesOfDomain(const am_domainID_t domainID, std::vector<am_sourceID_t>& listSourceID) const =0; /** * returns all crossfaders of a domain - * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if domain - * was not found + * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if domain was not found * * @param domainID * @param listCrossfadersID @@ -598,8 +544,7 @@ namespace am { virtual am_Error_e getListCrossfadersOfDomain(const am_domainID_t domainID, std::vector<am_crossfaderID_t>& listCrossfadersID) const =0; /** * returns all gateways of a domain - * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if domain - * was not found + * @return E_OK on success, E_DATABASE_ERROR on error, E_NON_EXISTENT if domain was not found * * @param domainID * @param listGatewaysID @@ -682,45 +627,217 @@ namespace am { */ virtual am_Error_e getListSystemProperties(std::vector<am_SystemProperty_s>& listSystemProperties) const =0; /** - * sets the command interface to ready. Will send setCommandReady to each of the - * plugins. The corresponding answer is confirmCommandReady. + * sets the command interface to ready. Will send setCommandReady to each of the plugins. The corresponding answer is + * confirmCommandReady. */ virtual void setCommandReady() =0; /** - * sets the command interface into the rundown state. Will send setCommandRundown - * to each of the plugins. The corresponding answer is confirmCommandRundown. + * sets the command interface into the rundown state. Will send setCommandRundown to each of the plugins. The + * corresponding answer is confirmCommandRundown. */ virtual void setCommandRundown() =0; /** - * sets the routinginterface to ready. Will send the command setRoutingReady to - * each of the plugins. The related answer is confirmRoutingReady. + * sets the routinginterface to ready. Will send the command setRoutingReady to each of the plugins. The related answer + * is confirmRoutingReady. */ virtual void setRoutingReady() =0; /** - * sets the routinginterface to the rundown state. Will send the command - * setRoutingRundown to each of the plugins. The related answer is - * confirmRoutingRundown. + * sets the routinginterface to the rundown state. Will send the command setRoutingRundown to each of the plugins. The + * related answer is confirmRoutingRundown. */ virtual void setRoutingRundown() =0; /** * acknowledges the setControllerReady call. + * + * @param error E_OK if the ready command succeeded. E_UNKNOWN if an error happened. */ - virtual void confirmControllerReady() =0; + virtual void confirmControllerReady(const am_Error_e error) =0; /** - * acknowledges the setControllerRundown call. + * Acknowledges the setControllerRundown call. + * + * @param error E_OK if the ready command succeeded. E_UNKNOWN if an error happened. + * If an error !=E_OK is returned than the AudioManager will terminate with an exception. + * If E_OK is returned, the AudioManager will exit clean */ - virtual void confirmControllerRundown() =0; + virtual void confirmControllerRundown(const am_Error_e error) =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, + * 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) =0; + /** + * Change the data of the source. + * + * @param sourceID The sourceID of the source that needs to be changed. + * @param sourceClassID If this sourceClassID !=0, the sourceClassID of the source will be changed. + * @param listSoundProperties If the size of the list !=0, the list replaces the current one. + * @param listConnectionFormats If the size of the list !=0, the list replaces the current one. + * @param listMainSoundProperties If the size of the list !=0, the list replaces the current one. + */ + virtual am_Error_e changeSourceDB(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; + /** + * Change the data of the sink. + * + * @param sinkID the sinkID of the sink to be changed + * @param sinkClassID If !=0, the sinkClass will replace the current one. + * @param listSoundProperties The list of the sound properties. If The lenght of the list !=0, the current + * soundProperties will be changed. + * @param listConnectionFormats The list of the connectionformats to be changed. They will only be changed, if length + * of the list !=0 + * @param listMainSoundProperties The list of the mainsoundproperties that need to be changed. Will be changed. if the + * length of the list !=0 + */ + virtual am_Error_e changeSinkDB(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; + /** + * changes Gateway Data + * + * @param gatewayID the gatewayData to be changed + * @param listSourceConnectionFormats The list of the sourceConnectionFormats. Will be changed it the lenght of the + * list !=0. + * @param listSinkConnectionFormats The list of the sinkConnectionFormats. Will be changed it the lenght of the list + * !=0. + * @param convertionMatrix the convertionmatrix + */ + virtual am_Error_e changeGatewayDB(const am_gatewayID_t gatewayID, const std::vector<am_ConnectionFormat_e> listSourceConnectionFormats, const std::vector<am_ConnectionFormat_e> listSinkConnectionFormats, const std::vector<bool> convertionMatrix) =0; + /** + * with this function, setting of multiple volumes at a time is done. The behavior of the volume set is depended on the + * given ramp and time information. + * This function is not only used to ramp volume, but also to mute and direct set the level. Exact behavior is depended on + * the selected mute ramps. + * @return E_OK on success, E_NO_CHANGE if the volume is already on the desired value, E_OUT_OF_RANGE is the volume is out + * of range, E_UNKNOWN on every other error. + * + * @param handle + * @param listVolumes + */ + virtual am_Error_e setVolumes(am_Handle_s& handle, const std::vector<am_Volumes_s> listVolumes) =0; + /** + * set a sink notification configuration + * + * @param handle the handle that will be assigned for this operation + * @param sinkID the sinkID + * @param notificationConfiguration + */ + virtual am_Error_e setSinkNotificationConfiguration(am_Handle_s& handle, const am_sinkID_t sinkID, const am_NotificationConfiguration_s notificationConfiguration) =0; + /** + * set a source notification configuration + * + * @param handle the handle that will be assigned for this operation + * @param sourceID the sinkID + * @param norificationConfiguration + */ + virtual am_Error_e setSourceNotificationConfiguration(am_Handle_s& handle, const am_sourceID_t sourceID, const am_NotificationConfiguration_s norificationConfiguration) =0; + /** + * Sends out the main notificiation of a sink + * @return E_OK on success, E_UNKNOWN on error + * + * @param sinkID + * @param notificationPayload the payload + */ + virtual void sendSinkMainNotificationPayload(const am_sinkID_t sinkID, const am_NotificationPayload_s notificationPayload) =0; + /** + * Sends out the main notificiation of a source + * @return E_OK on success, E_UNKNOWN on error + * + * @param sourceID + * @param notificationPayload the payload + */ + virtual void sendSourceMainNotificationPayload(const am_sourceID_t sourceID, const am_NotificationPayload_s notificationPayload) =0; + /** + * change the mainNotificationConfiguration of a sink + * @return E_OK when successful, E_DATABASE on error + * + * @param sinkID the sinkID + * @param mainNotificationConfiguration the mainNotificationConfiguration + */ + virtual am_Error_e changeMainSinkNotificationConfigurationDB(const am_sinkID_t sinkID, const am_NotificationConfiguration_s mainNotificationConfiguration) =0; + /** + * change the mainNotificationConfiguration of a source + * @return E_OK when successful, E_DATABASE on error + * + * @param sourceID the sourceID + * @param mainNotificationConfiguration the mainNotificationConfiguration + */ + virtual am_Error_e changeMainSourceNotificationConfigurationDB(const am_sourceID_t sourceID, const am_NotificationConfiguration_s mainNotificationConfiguration) =0; + /** + * Retrieves the Restart Reason Property + * @return E_OK on success E_UNKNOWN if property could not be retrieved. + * + * @param restartReason the restart reason + */ + virtual am_Error_e nsmGetRestartReasonProperty(NsmRestartReason_e& restartReason) =0; + /** + * Retrieves the shutdown reason property + * @return E_OK on success E_UNKNOWN if property could not be retrieved. + * + * @param ShutdownReason The shutdown reason + */ + virtual am_Error_e nsmGetShutdownReasonProperty(NsmShutdownReason_e& ShutdownReason) =0; + /** + * Retrieves the running reason + * @return E_OK on success E_UNKNOWN if property could not be retrieved. + * + * @param nsmRunningReason the running reson + */ + virtual am_Error_e nsmGetRunningReasonProperty(NsmRunningReason_e& nsmRunningReason) =0; + /** + * @return NsmErrorStatus_Ok in case of success + * + * @param nsmNodeState The current node state + */ + virtual NsmErrorStatus_e nsmGetNodeState(NsmNodeState_e& nsmNodeState) =0; + /** + * Retrieves the current session state + * @return NsmErrorStatus_Ok on success E_UNKNOWN if property could not be retrieved. + * + * @param sessionName The current session state + * @param seatID + * @param sessionState The sessionState + */ + virtual NsmErrorStatus_e nsmGetSessionState(const std::string& sessionName, const NsmSeat_e& seatID, NsmSessionState_e& sessionState) =0; + /** + * Retrieves the current applicationmode + * @return NsmErrorStatus_Ok on success E_UNKNOWN if property could not be retrieved. + * + * @param applicationMode The current application Mode + */ + virtual NsmErrorStatus_e nsmGetApplicationMode(NsmApplicationMode_e& applicationMode) =0; + /** + * Registers the AudioManager as shutdown client + * @return NsmErrorStatus_Ok on success + * The interface for the client will be provided by the AudioManagerDeamon, therefore is no need to mention it here. + * + * @param shutdownMode The shutdown mode that the controller wants to register for. Can be + * @param timeoutMs Max. Timeout to wait for response from shutdown client in ms + */ + virtual NsmErrorStatus_e nsmRegisterShutdownClient(const uint32_t shutdownMode, const uint32_t timeoutMs) =0; + /** + * unregisters the AudioManager as shutdown client + * @return NsmErrorStatus_Ok on success + * + * @param shutdownMode Shutdown mode for which client wants to unregister (NSM_SHUTDOWNTYPE_NORMAL, + * NSM_SHUTDOWNTYPE_FAST) + */ + virtual NsmErrorStatus_e nsmUnRegisterShutdownClient(const uint32_t shutdownMode) =0; + /** + * @return E_OK on success, E_UNKOWN if interface could not be reached + * + * @param version + */ + virtual am_Error_e nsmGetInterfaceVersion(uint32_t& version) =0; + /** + * Sends out the lifecyclerequest complete to the NSM + * @return NsmErrorStatus_Ok in case of success + * + * @param RequestId The request ID of the request. + * @param status The result of the call to "LifecycleRequest". NsmErrorStatus_Ok: Request successfully processed. + * NsmErrorStatus_Error: An error occured while processing the "LifecycleRequest". + */ + virtual NsmErrorStatus_e nsmSendLifecycleRequestComplete(const uint32_t RequestId, const NsmErrorStatus_e status) =0; }; } -#endif // !defined(EA_6E701C15_A8E8_4ad3_A50B_D91A5BD0973F__INCLUDED_) +#endif // !defined(EA_AC2A0532_F989_4f95_A467_1055C94D9C1E__INCLUDED_) diff --git a/include/control/IAmControlSend.h b/include/control/IAmControlSend.h index bac33b2..9b2d0b9 100644 --- a/include/control/IAmControlSend.h +++ b/include/control/IAmControlSend.h @@ -12,15 +12,15 @@ * this file, You can obtain one at http://mozilla.org/MPL/2.0/.
*
*
- * \author Christian Mueller, christian.ei.mueller@bmw.de BMW 2011,2012
+ * \author Christian Mueller, christian.linke@bmw.de BMW 2011,2012
*
* \file
* For further information see http://www.genivi.org/.
*
* THIS CODE HAS BEEN GENERATED BY ENTERPRISE ARCHITECT GENIVI MODEL. PLEASE CHANGE ONLY IN ENTERPRISE ARCHITECT AND GENERATE AGAIN
*/
-#if !defined(EA_B9BE9751_825D_44b9_86F1_C2F02E5FA3ED__INCLUDED_)
-#define EA_B9BE9751_825D_44b9_86F1_C2F02E5FA3ED__INCLUDED_
+#if !defined(EA_9CC33091_C4F5_4262_9C42_042DFB7606F2__INCLUDED_)
+#define EA_9CC33091_C4F5_4262_9C42_042DFB7606F2__INCLUDED_
#include <vector>
#include <string>
@@ -31,27 +31,25 @@ class IAmControlReceive; } #include "IAmControlReceive.h" +#include "audiomanagertypes.h" +#include "NodeStateManager.h" -#define ControlSendVersion "1.0" +#define ControlSendVersion "2.0" namespace am { /** * This interface is presented by the AudioManager controller. - * All the hooks represent system events that need to be handled. The callback - * functions are used to handle for example answers to function calls on the - * AudioManagerCoreInterface. - * There are two rules that have to be kept in mind when implementing against this - * interface:\n + * All the hooks represent system events that need to be handled. The callback functions are used to handle for example + * answers to function calls on the AudioManagerCoreInterface. + * 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 + * 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 + * 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 07-Mar-2012 6:06:18 PM + * @created 16-Dez-2012 15:58:15 */ class IAmControlSend { @@ -75,25 +73,32 @@ namespace am { /** * Starts up the controller. * - * @param controlreceiveinterface This is a pointer to the - * ControlReceiveInterface so that the controller knows to whom to communicate. + * @param controlreceiveinterface This is a pointer to the ControlReceiveInterface so that the controller knows to whom + * to communicate. */ virtual am_Error_e startupController(IAmControlReceive* controlreceiveinterface) =0; /** - * this message is used tell the controller that it should get ready. This message - * must be acknowledged via confirmControllerReady. + * this message is used tell the controller that it should get ready. This message must be acknowledged via + * confirmControllerReady. */ virtual void setControllerReady() =0; /** - * this message tells the controller that he should prepare everything for the - * power to be switched off. This message must be acknowledged via - * confirmControllerRundown. + * This message tells the controller that he should prepare everything for the power to be switched off. This message must + * be acknowledged via confirmControllerRundown. + * The method will give the signal as integer that was responsible for calling the setControllerRundown. + * This function is called from the signal handler, either direct (when the program is killed) or from within the mainloop + * (if the program is terminated). + * + * @param signal The signal NO that was responsible for the rundown. Can be: + * SIGINT + * SIGQUIT + * SIGTERM + * SIGHUP */ - virtual void setControllerRundown() =0; + virtual void setControllerRundown(const int16_t signal) =0; /** * is called when a connection request comes in via the command interface - * @return E_OK on success, E_NOT_POSSIBLE on error, E_ALREADY_EXISTENT if already - * exists + * @return E_OK on success, E_NOT_POSSIBLE on error, E_ALREADY_EXISTENT if already exists * * @param sourceID * @param sinkID @@ -102,8 +107,7 @@ namespace am { virtual am_Error_e hookUserConnectionRequest(const am_sourceID_t sourceID, const am_sinkID_t sinkID, am_mainConnectionID_t& mainConnectionID) =0; /** * is called when a disconnection request comes in via the command interface - * @return E_OK on success, E_NOT_POSSIBLE on error, E_NON_EXISTENT if connection - * does not exists + * @return E_OK on success, E_NOT_POSSIBLE on error, E_NON_EXISTENT if connection does not exists * * @param connectionID */ @@ -157,8 +161,7 @@ namespace am { virtual am_Error_e hookUserSetSinkMuteState(const am_sinkID_t sinkID, const am_MuteState_e muteState) =0; /** * is called when a routing adaptor registers its domain - * @return E_OK on success, E_UNKNOWN on error, E_ALREADY_EXISTENT if already - * exists + * @return E_OK on success, E_UNKNOWN on error, E_ALREADY_EXISTENT if already exists * * @param domainData ID is omitted here since it has not been created yet * @param domainID @@ -179,8 +182,7 @@ namespace am { virtual void hookSystemDomainRegistrationComplete(const am_domainID_t domainID) =0; /** * is called when a routing adaptor registers a sink - * @return E_OK on success, E_UNKNOWN on error, E_ALREADY_EXISTENT if already - * exists + * @return E_OK on success, E_UNKNOWN on error, E_ALREADY_EXISTENT if already exists * * @param sinkData Id is omitted here, since it has not been created yet * @param sinkID @@ -195,8 +197,7 @@ namespace am { virtual am_Error_e hookSystemDeregisterSink(const am_sinkID_t sinkID) =0; /** * is called when a routing adaptor registers a source - * @return E_OK on success, E_UNKNOWN on error, E_ALREADY_EXISTENT if already - * exists + * @return E_OK on success, E_UNKNOWN on error, E_ALREADY_EXISTENT if already exists * * @param sourceData ID is omitted here since it is not yet created * @param sourceID @@ -211,11 +212,9 @@ namespace am { virtual am_Error_e hookSystemDeregisterSource(const am_sourceID_t sourceID) =0; /** * is called when a routing adaptor registers a gateway - * @return E_OK on success, E_UNKNOWN on error, E_ALREADY_EXISTENT if already - * exists + * @return E_OK on success, E_UNKNOWN on error, E_ALREADY_EXISTENT if already exists * - * @param gatewayData gatewayID is not set here since it is not created at this - * point of time + * @param gatewayData gatewayID is not set here since it is not created at this point of time * @param gatewayID */ virtual am_Error_e hookSystemRegisterGateway(const am_Gateway_s& gatewayData, am_gatewayID_t& gatewayID) =0; @@ -228,11 +227,9 @@ namespace am { virtual am_Error_e hookSystemDeregisterGateway(const am_gatewayID_t gatewayID) =0; /** * is called when a routing adaptor registers a crossfader - * @return E_OK on success, E_UNKNOWN on error, E_ALREADY_EXISTENT if already - * exists + * @return E_OK on success, E_UNKNOWN on error, E_ALREADY_EXISTENT if already exists * - * @param crossfaderData gatewayID is not set here since it is not created at - * this point of time + * @param crossfaderData gatewayID is not set here since it is not created at this point of time * @param crossfaderID */ virtual am_Error_e hookSystemRegisterCrossfader(const am_Crossfader_s& crossfaderData, am_crossfaderID_t& crossfaderID) =0; @@ -295,15 +292,13 @@ namespace am { virtual void hookSystemReceiveEarlyData(const std::vector<am_EarlyData_s>& data) =0; /** * this hook provides information about speed changes. - * The quantization and sampling rate of the speed can be adjusted at compile time - * of the AudioManagerDaemon. + * The quantization and sampling rate of the speed can be adjusted at compile time of the AudioManagerDaemon. * * @param speed */ virtual void hookSystemSpeedChange(const am_speed_t speed) =0; /** - * this hook is fired whenever the timing information of a mainconnection has - * changed. + * this hook is fired whenever the timing information of a mainconnection has changed. * * @param mainConnectionID * @param time @@ -343,8 +338,8 @@ namespace am { * ack for source volume changes * * @param handle the handle that is connected to the volume change - * @param voulme the volume after the action ended (the desired volume if - * everything went right, the actual one in case of abortion) + * @param voulme the volume after the action ended (the desired volume if everything went right, the actual one in case + * of abortion) * @param error */ virtual void cbAckSetSourceVolumeChange(const am_Handle_s handle, const am_volume_t voulme, const am_Error_e error) =0; @@ -384,36 +379,154 @@ namespace am { */ virtual void cbAckSetSinkSoundProperty(const am_Handle_s handle, const am_Error_e error) =0; /** - * This function is used by the routing algorithm to retrieve a priorized list of - * connectionFormats from the Controller. + * This function is used by the routing algorithm to retrieve a priorized list of connectionFormats from the Controller. * @return E_OK in case of successfull priorisation. * * @param sourceID sourceID of source that shall be connected * @param sinkID sinkID of sink that shall be connected - * @param listRoute This route is the one the priorized connectionFormats is - * for. + * @param listRoute This route is the one the priorized connectionFormats is for. * @param listPossibleConnectionFormats list of possible connectionformats - * @param listPrioConnectionFormats the list return with prioos from the - * controller. Best choice on first position. + * @param listPrioConnectionFormats the list return with prioos from the controller. Best choice on first position. */ virtual am_Error_e getConnectionFormatChoice(const am_sourceID_t sourceID, const am_sinkID_t sinkID, const am_Route_s listRoute, const std::vector<am_ConnectionFormat_e> listPossibleConnectionFormats, std::vector<am_ConnectionFormat_e>& listPrioConnectionFormats) =0; /** * confirms the setCommandReady call + * + * @param error E_OK if everything went right. If a plugin returns an error, it will be forwared here */ - virtual void confirmCommandReady() =0; + virtual void confirmCommandReady(const am_Error_e error) =0; /** * confirms the setRoutingReady call + * + * @param error E_OK if everything went right. If a plugin returns an error, it will be forwared here */ - virtual void confirmRoutingReady() =0; + virtual void confirmRoutingReady(const am_Error_e error) =0; /** * confirms the setCommandRundown call + * + * @param error E_OK if everything went right. If a plugin returns an error, it will be forwared here */ - virtual void confirmCommandRundown() =0; + virtual void confirmCommandRundown(const am_Error_e error) =0; /** * confirms the setRoutingRundown command + * + * @param error E_OK if everything went right. If a plugin returns an error, it will be forwared here + */ + virtual void confirmRoutingRundown(const am_Error_e error) =0; + /** + * update form the SinkData + * + * @param sinkID the sinkID + * @param sinkClassID + * @param listSoundProperties + * @param listConnectionFormats + * @param listMainSoundProperties + */ + virtual am_Error_e hookSystemUpdateSink(const am_sinkID_t sinkID, const am_sinkClass_t sinkClassID, const std::vector<am_SoundProperty_s> listSoundProperties, const std::vector<am_ConnectionFormat_e> listConnectionFormats, std::vector<am_MainSoundProperty_s> listMainSoundProperties) =0; + /** + * update from the source Data + * + * @param sourceID the sourceID + * @param sourceClassID + * @param listSoundProperties + * @param listConnectionFormats + * @param listMainSoundProperties + */ + virtual am_Error_e hookSystemUpdateSource(const am_sourceID_t sourceID, const am_sourceClass_t sourceClassID, const std::vector<am_SoundProperty_s> listSoundProperties, const std::vector<am_ConnectionFormat_e> listConnectionFormats, std::vector<am_MainSoundProperty_s> listMainSoundProperties) =0; + /** + * updates the Gateway Data + * + * @param gatewayID the gatewayID + * @param listSourceConnectionFormats + * @param listSinkConnectionFormats + * @param convertionMatrix + */ + virtual am_Error_e hookSystemUpdateGateway(const am_gatewayID_t gatewayID, const std::vector<am_ConnectionFormat_e> listSourceConnectionFormats, const std::vector<am_ConnectionFormat_e> listSinkConnectionFormats, const std::vector<bool> convertionMatrix) =0; + /** + * ack for mulitple volume changes + * + * @param handle + * @param listVolumes the list of volumes with the current status + * @param error + */ + virtual void cbAckSetVolume(const am_Handle_s handle, const std::vector<am_Volumes_s> listVolumes, const am_Error_e error) =0; + /** + * The acknowledge of the sink notification configuration + * + * @param handle the handle + * @param error the error + */ + virtual void cbAckSetSinkNotificationConfiguration(const am_Handle_s handle, const am_Error_e error) =0; + /** + * The acknowledge of the sink notification configuration + * + * @param handle the handle + * @param error the error + */ + virtual void cbAckSetSourceNotificationConfiguration(const am_Handle_s handle, const am_Error_e error) =0; + /** + * + * @param sinkID the sinkID of the changed notification + * @param payload the payload + */ + virtual void hookSinkNotificationDataChanged(const am_sinkID_t sinkID, const am_NotificationPayload_s payload) =0; + /** + * + * @param sourceID the sinkID of the changed notification + * @param payload the payload + */ + virtual void hookSourceNotificationDataChanged(const am_sourceID_t sourceID, const am_NotificationPayload_s payload) =0; + /** + * sets a user MainSinkNotificationConfiguration + * @return E_OK on success, E_OUT_OF_RANGE if out of range, E_UNKNOWN on error + * + * @param sinkID + * @param notificationConfiguration + */ + virtual am_Error_e hookUserSetMainSinkNotificationConfiguration(const am_sinkID_t sinkID, const am_NotificationConfiguration_s notificationConfiguration) =0; + /** + * sets a user MainSourceNotificationConfiguration + * @return E_OK on success, E_OUT_OF_RANGE if out of range, E_UNKNOWN on error + * + * @param sourceID + * @param notificationConfiguration + */ + virtual am_Error_e hookUserSetMainSourceNotificationConfiguration(const am_sourceID_t sourceID, const am_NotificationConfiguration_s notificationConfiguration) =0; + /** + * This hook is connected to the NodeState signal of the NodeStateManager + * + * @param NodeStateId The new current state of the node + */ + virtual void hookSystemNodeStateChanged(const NsmNodeState_e NodeStateId) =0; + /** + * This hook is connected to the NodeApplicationMode signal of the NodeStateManager + * + * @param ApplicationModeId The new ApplicationMode + */ + virtual void hookSystemNodeApplicationModeChanged(const NsmApplicationMode_e ApplicationModeId) =0; + /** + * the sessionstate change was send by the NSM + * + * @param sessionName + * @param seatID + * @param sessionStateID + */ + virtual void hookSystemSessionStateChanged(const std::string sessionName, const int32_t seatID, const NsmSessionState_e sessionStateID) =0; + /** + * A lifecycle request comes in from the NSM and must be processed. + * @return NsmErrorStatus_Ok if successful + * The controller has to respond to this message with LifecycleRequestComplete. + * + * @param Request the shutdown request from the NSM. One of the types + * + * NSM_SHUTDOWNTYPE_RUNUP, NSM_SHUTDOWNTYPE_NORMAL + * NSM_SHUTDOWNTYPE_FAST + * + * In order to receive this request, the controller needs to register for this request first via RegisterShutdownClient + * @param RequestId the requestID */ - virtual void confirmRoutingRundown() =0; + virtual NsmErrorStatus_e hookSystemLifecycleRequest(const uint32_t Request, const uint32_t RequestId) =0; }; } -#endif // !defined(EA_B9BE9751_825D_44b9_86F1_C2F02E5FA3ED__INCLUDED_) +#endif // !defined(EA_9CC33091_C4F5_4262_9C42_042DFB7606F2__INCLUDED_) |