# HG changeset patch # User hgs # Date 1283262569 -19800 # Node ID 089681919c6fd27a981a7ef0635dc0c5f9e97839 # Parent 0abbef78e78be0452c27a0f835490de970694869 201033_02 diff -r 0abbef78e78b -r 089681919c6f messagingfw/alwaysonline/AlwaysOnlineManager/inc/AlwaysOnlineManager.h --- a/messagingfw/alwaysonline/AlwaysOnlineManager/inc/AlwaysOnlineManager.h Wed Aug 18 01:39:51 2010 +0530 +++ b/messagingfw/alwaysonline/AlwaysOnlineManager/inc/AlwaysOnlineManager.h Tue Aug 31 19:19:29 2010 +0530 @@ -248,18 +248,21 @@ void HandleStopPluginL( const TDes8& aParameter ); /** - * Handles stopping of plugin with given UID. + * Handles stopping of plugin with given implementation UID. * @since Series60 3.1 - * @param aPlugin, UID of plugin + * @param aPluginImplementationUid, implementation UID of plugin + * (implementation_uid in .rss). + * NOTE: There can be multiple instances of same plugin + * implementation. */ - void StopPluginL( const TUid& aPlugin ); + void StopPluginL( const TUid& aPluginImplementationUid ); /** - * Unloads the plugin with given UID and sets it as disabled. + * Unloads the plugin with given instance UID and sets it as disabled. * @since Series60 3.1 - * @param aPlugin, UID of plugin + * @param aPluginInstanceUid, UID of plugin instance */ - void DisablePlugin( const TUid& aPlugin ); + void DisablePlugin( const TUid& aPluginInstanceUid ); /** * Handles the final progress of an operation. diff -r 0abbef78e78b -r 089681919c6f messagingfw/alwaysonline/AlwaysOnlineManager/src/AlwaysOnlineManager.cpp --- a/messagingfw/alwaysonline/AlwaysOnlineManager/src/AlwaysOnlineManager.cpp Wed Aug 18 01:39:51 2010 +0530 +++ b/messagingfw/alwaysonline/AlwaysOnlineManager/src/AlwaysOnlineManager.cpp Tue Aug 31 19:19:29 2010 +0530 @@ -789,7 +789,7 @@ { KAOMANAGER_LOGGER_WRITE_FORMAT("CAlwaysOnlineManager::HandleOpCompletionL() : plugin: 0x%x", id); KAOMANAGER_LOGGER_WRITE_FORMAT("CAlwaysOnlineManager::HandleOpCompletionL() : command: %d", command); - KAOMANAGER_LOGGER_WRITE_FORMAT8("CAlwaysOnlineManager::HandleOpCompletionL() : result: %S", &result); + KAOMANAGER_LOGGER_WRITE_FORMAT("CAlwaysOnlineManager::HandleOpCompletionL() : result: %S", &result); switch ( static_cast( command ) ) { @@ -954,32 +954,29 @@ // CAlwaysOnlineManager::StopPluginL // ---------------------------------------------------------------------------- // -void CAlwaysOnlineManager::StopPluginL( - const TUid& aPlugin ) +void CAlwaysOnlineManager::StopPluginL( const TUid& aPluginImplementationUid ) { KAOMANAGER_LOGGER_FN1("CAlwaysOnlineManager::StopPluginL"); // Find the plugin and send stop command. - if ( iPluginArray->Count() ) + for ( TInt i = 0; i < iPluginArray->Count(); i++ ) { - // Get correct plugin from - for ( TInt i = 0; i < iPluginArray->Count(); i++ ) - { - TUid id = ( iPluginArray->At( i ) )->InstanceUid(); + TUid id = ( iPluginArray->At( i ) )->InstanceUid(); - // Is it this plugin? - if ( id == aPlugin ) - { - KAOMANAGER_LOGGER_WRITE_FORMAT("CAlwaysOnlineManager::StopPluginL() Calling stop to plugin: 0x%x", aPlugin); - TBuf8<1> dummyParam; - InvokeCommandHandlerL( - static_cast( EAOManagerPluginStop ), - dummyParam, - i ); - } + // Stop plugin if it has matching implemention UID. + // Will stop all plugin instances with matching implementation. + if ( REComSession::GetImplementationUidL(id) == aPluginImplementationUid ) + { + KAOMANAGER_LOGGER_WRITE_FORMAT( + "CAlwaysOnlineManager::StopPluginL() Calling stop to plugin: 0x%x", + id ); + TBuf8<1> dummyParam; + InvokeCommandHandlerL( + static_cast( EAOManagerPluginStop ), + dummyParam, + i ); } } - KAOMANAGER_LOGGER_FN2("CAlwaysOnlineManager::StopPluginL"); } @@ -987,35 +984,33 @@ // CAlwaysOnlineManager::DisablePlugin // ---------------------------------------------------------------------------- // -void CAlwaysOnlineManager::DisablePlugin( const TUid& aPlugin ) +void CAlwaysOnlineManager::DisablePlugin( const TUid& aPluginInstanceUid ) { KAOMANAGER_LOGGER_FN1("CAlwaysOnlineManager::DisablePlugin"); // Delete the plugin and mark it disabled. - if ( iPluginArray->Count() ) + for ( TInt i = 0; i < iPluginArray->Count(); i++ ) { - // Get correct plugin from - for ( TInt i = 0; i < iPluginArray->Count(); i++ ) + TUid id = ( iPluginArray->At( i ) )->InstanceUid(); + + // Delete plugin if it has matching instance UID. + if ( id == aPluginInstanceUid ) { - TUid id = ( iPluginArray->At( i ) )->InstanceUid(); - - // Is it this plugin? - if ( id == aPlugin ) - { - KAOMANAGER_LOGGER_WRITE_FORMAT("CAlwaysOnlineManager::DisablePlugin() Deleting plugin from array: 0x%x", aPlugin); - // Delete object - delete iPluginArray->At( i ); - // Delete element - iPluginArray->Delete( i ); - } + KAOMANAGER_LOGGER_WRITE_FORMAT( + "CAlwaysOnlineManager::DisablePlugin() Deleting plugin from array: 0x%x", + aPluginInstanceUid); + // Delete object + delete iPluginArray->At( i ); + // Delete element + iPluginArray->Delete( i ); } - // Set this plugin as disabled. - iCenRepControl->SetPluginStatus( aPlugin, ETrue ); - - // Refresh the list of disabled plugins UIDs. - iCenRepControl->UpdateDisabledPluginsUids( - *iDisabledPluginUidsArray ); } + // Set this plugin as disabled. + iCenRepControl->SetPluginStatus( aPluginInstanceUid, ETrue ); + + // Refresh the list of disabled plugins UIDs. + iCenRepControl->UpdateDisabledPluginsUids( *iDisabledPluginUidsArray ); + KAOMANAGER_LOGGER_FN2("CAlwaysOnlineManager::DisablePlugin"); }