# HG changeset patch # User William Roberts # Date 1275050212 -3600 # Node ID 8a75bf74485cd91b59e65f24ab24c7917e486220 # Parent 1b207dd38b723225b2c752ce5e05b633d3e5635c# Parent 3310e4b0dae07c2e902f3f3f521e8bf8f496ef69 Remerge fix for bug 1960 diff -r 3310e4b0dae0 -r 8a75bf74485c contentcontrolsrv/ccsrv/group/ccsrv.mmp --- a/contentcontrolsrv/ccsrv/group/ccsrv.mmp Tue May 18 16:21:42 2010 +0100 +++ b/contentcontrolsrv/ccsrv/group/ccsrv.mmp Fri May 28 13:36:52 2010 +0100 @@ -23,7 +23,7 @@ TARGETTYPE exe UID 0x1000008d 0x20026f53 -CAPABILITY ALL -TCB -DRM +CAPABILITY CAP_SERVER VENDORID VID_DEFAULT SECUREID 0x20026f53 diff -r 3310e4b0dae0 -r 8a75bf74485c contentcontrolsrv/ccsrv/src/ccsrv.cpp --- a/contentcontrolsrv/ccsrv/src/ccsrv.cpp Tue May 18 16:21:42 2010 +0100 +++ b/contentcontrolsrv/ccsrv/src/ccsrv.cpp Fri May 28 13:36:52 2010 +0100 @@ -50,7 +50,7 @@ // Requested capabilities const CPolicyServer::TPolicyElement KCcCapability[] = { - {_INIT_SECURITY_POLICY_C2( ECapabilityReadUserData, ECapabilityWriteUserData ), CPolicyServer::EFailClient} + {_INIT_SECURITY_POLICY_C2( ECapabilityReadDeviceData, ECapabilityWriteDeviceData ), CPolicyServer::EFailClient} }; const CPolicyServer::TPolicy KCcPolicy = diff -r 3310e4b0dae0 -r 8a75bf74485c contentcontrolsrv/ccsrv/src/ccsrvsession.cpp --- a/contentcontrolsrv/ccsrv/src/ccsrvsession.cpp Tue May 18 16:21:42 2010 +0100 +++ b/contentcontrolsrv/ccsrv/src/ccsrvsession.cpp Fri May 28 13:36:52 2010 +0100 @@ -524,39 +524,27 @@ // Complete request req->Message().Complete( KErrNone ); - if ( aMessage.DataSize() ) - { - // Store request data to be read later - // with GetMsgData() - req->SetTrId( aMessage.TrId() ); - req->SetData( aMessage.Data() ); - iRequests.AppendL( req ); - CleanupStack::Pop( req ); - } - else - { - CleanupStack::PopAndDestroy( req ); - } + CleanupStack::PopAndDestroy( req ); } - else + + // Store message to enable message data requesting later or + // to wait receiver to be ready to receive request + if ( found && aMessage.DataSize() || + !found && ( aMessage.Function() == ECcApiReq || + aMessage.Function() == ECcApiNtf ) ) { - if ( aMessage.Function() == ECcApiReq || - aMessage.Function() == ECcApiNtf ) - { - // Store message to handled later - CCcSrvMsg* msg = CCcSrvMsg::NewL(); - CleanupStack::PushL( msg ); - msg->SetFunction( aMessage.Function() ); - msg->SetSender( aMessage.Sender() ); - msg->SetReceiver( aMessage.Receiver() ); - msg->SetMsgId( aMessage.MsgId() ); - msg->SetTrId( aMessage.TrId() ); - msg->SetStatus( aMessage.Status() ); - msg->SetData( aMessage.Data() ); - iRequests.AppendL( msg ); - CleanupStack::Pop( msg ); - } - // ECcApiResp are ignored + // Store message to handled later + CCcSrvMsg* msg = CCcSrvMsg::NewL(); + CleanupStack::PushL( msg ); + msg->SetFunction( aMessage.Function() ); + msg->SetSender( aMessage.Sender() ); + msg->SetReceiver( aMessage.Receiver() ); + msg->SetMsgId( aMessage.MsgId() ); + msg->SetTrId( aMessage.TrId() ); + msg->SetStatus( aMessage.Status() ); + msg->SetData( aMessage.Data() ); + iRequests.AppendL( msg ); + CleanupStack::Pop( msg ); } } diff -r 3310e4b0dae0 -r 8a75bf74485c contentpublishingsrv/contentharvester/contentharvesterswiplugin/inc/chswiplugin.h --- a/contentpublishingsrv/contentharvester/contentharvesterswiplugin/inc/chswiplugin.h Tue May 18 16:21:42 2010 +0100 +++ b/contentpublishingsrv/contentharvester/contentharvesterswiplugin/inc/chswiplugin.h Fri May 28 13:36:52 2010 +0100 @@ -99,7 +99,13 @@ void RemoveWidgetL( const TDesC& aType, const TDesC& aPublisherId ); - + /** + * Checks if mass memory is available + * @return ETrue if internal mass memory is available in this device + * EFalse if not + */ + TBool InternalMassMemoryAvailable( ); + private: /** @@ -140,6 +146,13 @@ * Mass storage mode flag. */ TBool iMassStorageMode; + + /* + * Flag indicating if mass memory is available on this hardware + */ + TBool iMassMemoryAvailable; + + }; diff -r 3310e4b0dae0 -r 8a75bf74485c contentpublishingsrv/contentharvester/contentharvesterswiplugin/src/chswiplugin.cpp --- a/contentpublishingsrv/contentharvester/contentharvesterswiplugin/src/chswiplugin.cpp Tue May 18 16:21:42 2010 +0100 +++ b/contentpublishingsrv/contentharvester/contentharvesterswiplugin/src/chswiplugin.cpp Fri May 28 13:36:52 2010 +0100 @@ -22,6 +22,7 @@ #include #include #include +#include #include "cpglobals.h" #include "chswiusbhandler.h" @@ -75,6 +76,7 @@ User::LeaveIfError( iApaLsSession.Connect() ); User::LeaveIfError( iFs.Connect() ); + iMassMemoryAvailable = InternalMassMemoryAvailable(); iUsbHandler = CCHSwiUsbHandler::NewL( this, iFs ); iUsbObserver = CCHSwiUsbObserver::NewL( iUsbHandler, iFs ); @@ -280,7 +282,45 @@ // TBool CCHSwiPlugin::IsMassStorageMode() { - return iMassStorageMode; + if (iMassMemoryAvailable) + { + return iMassStorageMode; + } + else + { + return EFalse; + } } +// ---------------------------------------------------------------------------- +// +// ---------------------------------------------------------------------------- +// +TBool CCHSwiPlugin::InternalMassMemoryAvailable( ) + { + TBool result(EFalse); + // List all drives in the system + TDriveList driveList; + TInt error = iFs.DriveList( driveList ); + + if ( KErrNone == error ) + { + for ( TInt driveNumber = EDriveY; + driveNumber >= EDriveA; + driveNumber-- ) + { + TUint status( 0 ); + TInt error = DriveInfo::GetDriveStatus( iFs, driveNumber, status ); + if( (KErrNone == error) && ( status & DriveInfo::EDriveExternallyMountable ) + && ( status & DriveInfo::EDriveInternal ) ) + { + // Internal Memory + result = ETrue; + break; + } + } + } + return result; + } + // End of File diff -r 3310e4b0dae0 -r 8a75bf74485c homescreenpluginsrv/hspsmanager/bwins/hspsclientu.def --- a/homescreenpluginsrv/hspsmanager/bwins/hspsclientu.def Tue May 18 16:21:42 2010 +0100 +++ b/homescreenpluginsrv/hspsmanager/bwins/hspsclientu.def Fri May 28 13:36:52 2010 +0100 @@ -10,13 +10,13 @@ ?hspsInstallTheme@ChspsClient@@UAE?AW4ThspsServiceCompletedMessage@@ABVTDesC16@@AAVChspsODT@@@Z @ 9 NONAME ; enum ThspsServiceCompletedMessage ChspsClient::hspsInstallTheme(class TDesC16 const &, class ChspsODT &) ?hspsReinstallConf@ChspsClient@@QAE?AW4ThspsServiceCompletedMessage@@HH@Z @ 10 NONAME ; enum ThspsServiceCompletedMessage ChspsClient::hspsReinstallConf(int, int) ?hspsRestoreDefault@ChspsClient@@UAE?AW4ThspsServiceCompletedMessage@@ABVChspsODT@@AAV3@@Z @ 11 NONAME ; enum ThspsServiceCompletedMessage ChspsClient::hspsRestoreDefault(class ChspsODT const &, class ChspsODT &) - ?hspsRestoreConfigurations@ChspsClient@@QAE?AW4ThspsServiceCompletedMessage@@HH@Z @ 12 NONAME ; enum ThspsServiceCompletedMessage ChspsClient::hspsRestoreConfigurations(int, int) - ?hspsReplacePlugin@ChspsClient@@UAE?AW4ThspsServiceCompletedMessage@@HHH@Z @ 13 NONAME ; enum ThspsServiceCompletedMessage ChspsClient::hspsReplacePlugin(int, int, int) - ?hspsSetActiveTheme@ChspsClient@@UAE?AW4ThspsServiceCompletedMessage@@ABVChspsODT@@AAV3@@Z @ 14 NONAME ; enum ThspsServiceCompletedMessage ChspsClient::hspsSetActiveTheme(class ChspsODT const &, class ChspsODT &) - ?hspsPluginUpdateL@ChspsClient@@UAE?AW4ThspsServiceCompletedMessage@@ABVChspsODT@@@Z @ 15 NONAME ; enum ThspsServiceCompletedMessage ChspsClient::hspsPluginUpdateL(class ChspsODT const &) - ?hspsInstallNextPhaseL@ChspsClient@@UAE?AW4ThspsServiceCompletedMessage@@AAVChspsODT@@@Z @ 16 NONAME ; enum ThspsServiceCompletedMessage ChspsClient::hspsInstallNextPhaseL(class ChspsODT &) - ?hspsAddPlugin@ChspsClient@@UAE?AW4ThspsServiceCompletedMessage@@HHHHAAH@Z @ 17 NONAME ; enum ThspsServiceCompletedMessage ChspsClient::hspsAddPlugin(int, int, int, int, int &) - ?hspsSetPluginSettings@ChspsClient@@UAE?AW4ThspsServiceCompletedMessage@@ABVChspsODT@@HAAVChspsDomDocument@@H@Z @ 18 NONAME ; enum ThspsServiceCompletedMessage ChspsClient::hspsSetPluginSettings(class ChspsODT const &, int, class ChspsDomDocument &, int) + ?hspsReplacePlugin@ChspsClient@@UAE?AW4ThspsServiceCompletedMessage@@HHH@Z @ 12 NONAME ; enum ThspsServiceCompletedMessage ChspsClient::hspsReplacePlugin(int, int, int) + ?hspsSetActiveTheme@ChspsClient@@UAE?AW4ThspsServiceCompletedMessage@@ABVChspsODT@@AAV3@@Z @ 13 NONAME ; enum ThspsServiceCompletedMessage ChspsClient::hspsSetActiveTheme(class ChspsODT const &, class ChspsODT &) + ?hspsPluginUpdateL@ChspsClient@@UAE?AW4ThspsServiceCompletedMessage@@ABVChspsODT@@@Z @ 14 NONAME ; enum ThspsServiceCompletedMessage ChspsClient::hspsPluginUpdateL(class ChspsODT const &) + ?hspsInstallNextPhaseL@ChspsClient@@UAE?AW4ThspsServiceCompletedMessage@@AAVChspsODT@@@Z @ 15 NONAME ; enum ThspsServiceCompletedMessage ChspsClient::hspsInstallNextPhaseL(class ChspsODT &) + ?hspsAddPlugin@ChspsClient@@UAE?AW4ThspsServiceCompletedMessage@@HHHHAAH@Z @ 16 NONAME ; enum ThspsServiceCompletedMessage ChspsClient::hspsAddPlugin(int, int, int, int, int &) + ?hspsSetPluginSettings@ChspsClient@@UAE?AW4ThspsServiceCompletedMessage@@ABVChspsODT@@HAAVChspsDomDocument@@H@Z @ 17 NONAME ; enum ThspsServiceCompletedMessage ChspsClient::hspsSetPluginSettings(class ChspsODT const &, int, class ChspsDomDocument &, int) + ?hspsRestoreConfigurations@ChspsClient@@QAE?AW4ThspsServiceCompletedMessage@@HW4ThspsRestore@@@Z @ 18 NONAME ; enum ThspsServiceCompletedMessage ChspsClient::hspsRestoreConfigurations(int, enum ThspsRestore) ?NewL@ChspsClient@@SAPAV1@AAVMhspsThemeManagementServiceObserver@@@Z @ 19 NONAME ; class ChspsClient * ChspsClient::NewL(class MhspsThemeManagementServiceObserver &) ?SetLogBus@ChspsClient@@QAEXPAX@Z @ 20 NONAME ; void ChspsClient::SetLogBus(void *) ?hspsSetActivePlugin@ChspsClient@@UAE?AW4ThspsServiceCompletedMessage@@HH@Z @ 21 NONAME ; enum ThspsServiceCompletedMessage ChspsClient::hspsSetActivePlugin(int, int) diff -r 3310e4b0dae0 -r 8a75bf74485c homescreenpluginsrv/hspsmanager/client/hspsclient.cpp --- a/homescreenpluginsrv/hspsmanager/client/hspsclient.cpp Tue May 18 16:21:42 2010 +0100 +++ b/homescreenpluginsrv/hspsmanager/client/hspsclient.cpp Fri May 28 13:36:52 2010 +0100 @@ -896,13 +896,13 @@ // EXPORT_C ThspsServiceCompletedMessage ChspsClient::hspsRestoreConfigurations( const TInt aAppUid, - const TBool aReinstall ) + const ThspsRestore aRestore ) { ThspsServiceCompletedMessage ret = EhspsRestoreConfigurationsFailed; ThspsParamRestoreConfigurations params; params.appUid = aAppUid; - params.restoreAll = aReinstall; + params.restore = aRestore; ret = ( ThspsServiceCompletedMessage )iSession.RestoreConfigurations( iResultData, params ); diff -r 3310e4b0dae0 -r 8a75bf74485c homescreenpluginsrv/hspsmanager/eabi/hspsclientu.def --- a/homescreenpluginsrv/hspsmanager/eabi/hspsclientu.def Tue May 18 16:21:42 2010 +0100 +++ b/homescreenpluginsrv/hspsmanager/eabi/hspsclientu.def Fri May 28 13:36:52 2010 +0100 @@ -25,7 +25,7 @@ _ZN11ChspsClient22hspsCancelInstallThemeEv @ 24 NONAME _ZN11ChspsClient24hspsCancelGetListHeadersEv @ 25 NONAME _ZN11ChspsClient24hspsRestoreActiveAppConfEii @ 26 NONAME - _ZN11ChspsClient25hspsRestoreConfigurationsEii @ 27 NONAME + _ZN11ChspsClient25hspsRestoreConfigurationsEi12ThspsRestore @ 27 NONAME _ZN11ChspsClient4NewLER35MhspsThemeManagementServiceObserver @ 28 NONAME _ZN11ChspsClient5NewLCER35MhspsThemeManagementServiceObserver @ 29 NONAME _ZN11ChspsClient9SetLogBusEPv @ 30 NONAME diff -r 3310e4b0dae0 -r 8a75bf74485c homescreenpluginsrv/hspsmanager/inc/hspsinstallationhandler.h --- a/homescreenpluginsrv/hspsmanager/inc/hspsinstallationhandler.h Tue May 18 16:21:42 2010 +0100 +++ b/homescreenpluginsrv/hspsmanager/inc/hspsinstallationhandler.h Fri May 28 13:36:52 2010 +0100 @@ -209,6 +209,12 @@ */ void DisableNotifications(); + /** + * Disables installation of UDA and eMMC content. + * @since S60 5.2 + */ + void DisableUdaEmmcInstallations(); + public: // Functions from base classes /** @@ -798,6 +804,9 @@ // Set if installation files are located in ROM or in UDA, validation is not required TBool iTrustedInstallation; + // Set if installation files should be searched from UDA and eMMC drives + TBool iInstallFromUDAEmmc; + // Set if widget mutliinstance flag TInt32 iMultiInstance; diff -r 3310e4b0dae0 -r 8a75bf74485c homescreenpluginsrv/hspsmanager/inc/hspsmaintenancehandler.h --- a/homescreenpluginsrv/hspsmanager/inc/hspsmaintenancehandler.h Tue May 18 16:21:42 2010 +0100 +++ b/homescreenpluginsrv/hspsmanager/inc/hspsmaintenancehandler.h Fri May 28 13:36:52 2010 +0100 @@ -817,7 +817,15 @@ ChspsDomDocument& aAppDom, ChspsDomNode& aMissingPluginNode, const TInt aPluginUid ); - + + /** + * Restores plug-ins by reinstallation. + * @since S60 5.2 + * @param aInstallUdaEmmc Set if UDA and eMMC drives should used + */ + void HandleReinstallationL( + const TBool aInstallUdaEmmc ); + /** * Removes all plugins from the plugins node and related * resources from the resource array. diff -r 3310e4b0dae0 -r 8a75bf74485c homescreenpluginsrv/hspsmanager/inc/hspsrominstaller.h --- a/homescreenpluginsrv/hspsmanager/inc/hspsrominstaller.h Tue May 18 16:21:42 2010 +0100 +++ b/homescreenpluginsrv/hspsmanager/inc/hspsrominstaller.h Fri May 28 13:36:52 2010 +0100 @@ -49,24 +49,14 @@ * @since S60 5.0 * @param aThemeServer is a reference to theme server instance * @param aFsSession is a reference to file server instance + * @param aInstallUdaEmmc is set if UDA and eMMC drives should be utilized * @return A pointer to the created instance of ChspsRomInstaller. */ static ChspsRomInstaller* NewL( ChspsThemeServer& aThemeServer, - RFs& aFsSession ); + RFs& aFsSession, + const TBool aInstallUdaEmmc = ETrue ); - /** - * NewLC. - * Two-phased constructor. - * Creates a ChspsClinet object using two phase construction, - * and return a pointer to the created object. - * @since S60 5.0 - * @param aObserver The object to be used to handle updates from the server. - * @return a pointer to the created instance of ChspsRomInstaller. - */ - static ChspsRomInstaller* NewLC( - ChspsThemeServer& aThemeServer, - RFs& aFsSession ); /** * ~ChspsRomInstaller. @@ -80,7 +70,8 @@ /** - * Installs all plugin configurations which can be found from ROM and C drives (UDA). + * Installs all plugin configurations which can be found from the + * internal drives. * @since S60 5.2 */ void InstallL(); @@ -145,10 +136,12 @@ * @since S60 5.0 * @param aObserver The object to be used to handle updates from the server. * @param aFsSession is a reference to file server instance + * @param aInstallUdaEmmc is set if UDA and eMMC drives should be utilized */ ChspsRomInstaller( ChspsThemeServer& aThemeServer, - RFs& aFsSession ); + RFs& aFsSession, + const TBool aInstallUdaEmmc ); /** * ConstructL. @@ -158,9 +151,10 @@ void ConstructL(); /** - * Retrieves manifest files from both Z and C drives located in + * Retrieves manifest files from all internal drives in * \\private\200159C0\install\ paths. - * @since S60 5.0 + * @since S60 5.0 + * @param aFileArray An array of file names */ void FindInstallationFilesL( RPointerArray& aFileArray ); @@ -202,6 +196,9 @@ */ ChspsLogBus* iLogBus; #endif + + // Set if plug-ins should be installed from UDA and eMMC drives + TBool iInstallUdaEmmc; }; diff -r 3310e4b0dae0 -r 8a75bf74485c homescreenpluginsrv/hspsmanager/inc/hspsserverutil.h --- a/homescreenpluginsrv/hspsmanager/inc/hspsserverutil.h Tue May 18 16:21:42 2010 +0100 +++ b/homescreenpluginsrv/hspsmanager/inc/hspsserverutil.h Fri May 28 13:36:52 2010 +0100 @@ -534,6 +534,8 @@ * @param aFs is a reference to open file server session handle * @param aPath is path of the file * @param aFilename is name and extension of the file + * @param aFindFromUdaEmmcDrives is true if files should be searched from + * the UDA/eMMC drives * @param aDrivePathName Full path with a drive letter to the * resource file (output) */ @@ -541,6 +543,7 @@ RFs& aFs, const TDesC& aPath, const TDesC& aFilename, + const TBool aFindFromUdaEmmcDrives, TFileName& aDrivePathName ); /** diff -r 3310e4b0dae0 -r 8a75bf74485c homescreenpluginsrv/hspsmanager/inc/hspsthemeserver.h --- a/homescreenpluginsrv/hspsmanager/inc/hspsthemeserver.h Tue May 18 16:21:42 2010 +0100 +++ b/homescreenpluginsrv/hspsmanager/inc/hspsthemeserver.h Fri May 28 13:36:52 2010 +0100 @@ -175,6 +175,12 @@ #include "hsps_builds_cfg.hrh" +// C-Drive directory for the SISX installation files +_LIT( KImportDirectoryC, "c:\\private\\200159c0\\import\\" ); + +// E-Drive directory for the SISX installation files +_LIT( KImportDirectoryE, "e:\\private\\200159c0\\import\\" ); + /** hspsThemeServer name: */ _LIT(KhspsThemeServerName,"hspsthemeserver"); @@ -637,14 +643,17 @@ /** * Installs widgets located at \private\200159C0\install\ directories. * @since S60 5.0 + * @param aInstallUdaEmmc True if widgets should be installed from C and E drives */ - void InstallWidgetsL(); + void InstallWidgetsL( + const TBool aInstallUdaEmmc = ETrue ); /** * Install all widgets from uda + * @param aImportDirectory import directory path * @since S60 5.2 */ - void InstallUDAWidgetsL(); + void InstallUDAWidgetsL( const TDesC& aImportDirectory ); public: // from MhspsFileChangeObserver diff -r 3310e4b0dae0 -r 8a75bf74485c homescreenpluginsrv/hspsmanager/src/hspsinstallationhandler.cpp --- a/homescreenpluginsrv/hspsmanager/src/hspsinstallationhandler.cpp Tue May 18 16:21:42 2010 +0100 +++ b/homescreenpluginsrv/hspsmanager/src/hspsinstallationhandler.cpp Fri May 28 13:36:52 2010 +0100 @@ -127,6 +127,7 @@ iInstallationMode = EServiceHandler; iTrustedInstallation = EFalse; iInstallationType = EInstallationTypeNew; + iInstallFromUDAEmmc = ETrue; iFamilyMask = 0; } @@ -1987,6 +1988,7 @@ iFsSession, iThemeFilePath, nameBuf->Des(), + iInstallFromUDAEmmc, fullName ); delete nameBuf; nameBuf = NULL; @@ -2187,6 +2189,15 @@ } // ----------------------------------------------------------------------------- +// Disables eclipsing from UDA and eMMC drives +// ----------------------------------------------------------------------------- +// +void ChspsInstallationHandler::DisableUdaEmmcInstallations() + { + iInstallFromUDAEmmc = EFalse; + } + +// ----------------------------------------------------------------------------- // Finds locale specific subdirectories and DTD resources and appends those // into the resource array // Should be executed prior to the CheckHeader method! @@ -2343,73 +2354,81 @@ // void ChspsInstallationHandler::AddLocalesL( const TDesC& aPath ) - { - // Find all locale specific subfolders - TFindFile fileFinder( iFsSession ); - _LIT( KFilter, "*" ); - CDir* fileList( NULL ); - fileFinder.FindWildByDir( KFilter, aPath, fileList ); - if ( fileList ) + { + // Retrieve phone supported language. + CArrayFixFlat* languageCodes = NULL; + hspsServerUtil::GetInstalledLanguagesL( languageCodes ); + CleanupStack::PushL( languageCodes ); + + // Ensure that path contains '\' at the end. + TFileName xuikonPath; + xuikonPath.Copy( aPath ); + if( xuikonPath.Length() > KPathDelim().Length() ) { - CleanupStack::PushL( fileList ); - TFileName localePath; - for( TInt i = 0; i < fileList->Count(); i++ ) + if( xuikonPath.Mid( xuikonPath.Length() - + KPathDelim().Length() + ).Compare( KPathDelim ) != 0 ) { - const TEntry& entry = (*fileList)[i]; - if ( entry.IsDir() ) + xuikonPath.Append( KPathDelim ); + } + } + + _LIT( KFormatting, "%02d" ); + TFileName localePath; + + for( TInt i = 0; i < languageCodes->Count(); i++ ) + { + const TInt languageCode = languageCodes->At( i ); + + // Construct locale path using two digit minium + // width and zero as padding. + + localePath.Copy( xuikonPath ); + localePath.AppendFormat( KFormatting, languageCode ); + localePath.Append( KPathDelim ); + + // Check if folder for supported language exists. + TBool exists = EFalse; + + if( BaflUtils::FolderExists( iFsSession, localePath ) ) + { + exists = ETrue; + } + + // Support also one digit type folder naming. + if( !exists && languageCode < 10 ) + { + localePath.Copy( xuikonPath ); + localePath.AppendNum( languageCode ); + localePath.Append( KPathDelim ); + + if( BaflUtils::FolderExists( iFsSession, localePath ) ) { - TInt languageIndex = 0; - TLex lex( entry.iName ); - TInt error = lex.Val( languageIndex ); - - // See enumarations from e32lang.h - if( !error && languageIndex >= ELangTest ) - { - - // Process only supported languages - CArrayFixFlat* languageCodes = NULL; - hspsServerUtil::GetInstalledLanguagesL( languageCodes ); - CleanupStack::PushL( languageCodes ); - TBool isSupported = EFalse; - for( TInt i=0; iCount(); i++ ) - { - if( languageCodes->At( i ) == languageIndex ) - { - isSupported = ETrue; - break; - } - } - CleanupStack::PopAndDestroy( languageCodes ); - if( !isSupported ) - { - continue; - } - - // If we found the first language specification - if ( !iDefaultSpecificationSet ) - { - // Assume this is the default language shown incase - // there is no locale for the active UI language - iDefaultSpecification = (TLanguage)languageIndex; - iDefaultSpecificationSet = ETrue; - } - - // Setup a path to the subdirectory - localePath.Copy( aPath ); - localePath.Append( entry.iName ); - localePath.Append( KPathDelim ); - - // Find localized resources - AddLocalizedResourcesL( - localePath, - (TLanguage)languageIndex ); - } - } - + exists = ETrue; + } + } + + if( exists ) + { + // If we found the first language specification + if ( !iDefaultSpecificationSet ) + { + // Assume this is the default language shown incase + // there is no locale for the active UI language + iDefaultSpecification = (TLanguage)languageCode; + iDefaultSpecificationSet = ETrue; + } + + + // Find and add localized resources + AddLocalizedResourcesL( + localePath, + (TLanguage)languageCode ); } - CleanupStack::PopAndDestroy( fileList ); - fileList = NULL; } + + CleanupStack::PopAndDestroy( languageCodes ); + languageCodes = NULL; } // ----------------------------------------------------------------------------- @@ -2461,6 +2480,7 @@ // Find localized files from the provided directory RArray driveArray; CleanupClosePushL( driveArray ); + driveArray.Append( EDriveE ); driveArray.Append( EDriveC ); FindResourceFilesL( aPath, EFalse, driveArray, NULL ); diff -r 3310e4b0dae0 -r 8a75bf74485c homescreenpluginsrv/hspsmanager/src/hspsmaintenancehandler.cpp --- a/homescreenpluginsrv/hspsmanager/src/hspsmaintenancehandler.cpp Tue May 18 16:21:42 2010 +0100 +++ b/homescreenpluginsrv/hspsmanager/src/hspsmaintenancehandler.cpp Fri May 28 13:36:52 2010 +0100 @@ -4646,65 +4646,64 @@ { User::Leave( KErrArgument ); } - // Enable modification of owned configurations only + if( params.restore != EhspsRestoreAll + && params.restore != EhspsRestoreRom + && params.restore != EhspsRestoreViews ) + { + User::Leave( KErrArgument ); + } + + // Enable modification of plug-in configurations which the client owns if( messagePtr.SecureId().iId != params.appUid ) { User::Leave( KErrAccessDenied ); } TInt err = KErrNone; + + // Lock the Plugin Repository (a.k.a. Def.rep) if( iDefinitionRepository.Locked() ) { // Repository locked - err = KErrAccessDenied; + User::Leave( KErrAccessDenied ); + } + iDefinitionRepository.Lock(); + CleanupStack::PushL( TCleanupItem( UnlockRepository, &iDefinitionRepository ) ); + + if( params.restore == EhspsRestoreAll + || params.restore == EhspsRestoreRom ) + { + TBool installUdaEmmc = ETrue; + if( params.restore == EhspsRestoreRom ) + { + installUdaEmmc = EFalse; + } + TRAP( err, HandleReinstallationL( installUdaEmmc ) ); + iThemeServer.SetResourceFileCopyRequired( params.appUid ); } - + + // Get active root configuration for the client application + ChspsODT* appODT = ChspsODT::NewL(); + CleanupStack::PushL( appODT ); + + iThemeServer.GetActivateAppConfigurationL( + params.appUid, + *appODT ); + + // As a backup if the re-installations failed or client panics due to + // an updated data plug-in then remove all but one view and empty it + if ( err || params.restore == EhspsRestoreViews ) + { + // Remove all views but the 1st locked one and reset active view, + // if none were found then leave the first view only + RemoveUnlockedViewsL( *appODT ); + + // Remove all widgets from the active view + err = RestoreActiveViewL( *appODT ); + } + if( !err ) { - // Lock the Plugin Repository (a.k.a. Def.rep) - iDefinitionRepository.Lock(); - CleanupStack::PushL( TCleanupItem( UnlockRepository, &iDefinitionRepository ) ); - - // Get active root configuration for the client application - ChspsODT* appODT = ChspsODT::NewL(); - CleanupStack::PushL( appODT ); - -#ifdef HSPS_LOG_ACTIVE - if( iLogBus ) - { - iLogBus->LogText( - _L( "ChspsMaintenanceHandler::ServiceRestoreConfigurationsL(): - Dump before the changes:" ) - ); - ChspsOdtDump::Dump( *appODT, *iLogBus ); - } -#endif - - TInt err = KErrNone; - if ( !params.restoreAll ) - { - // reinstall all widgets - TRAP( err, iThemeServer.InstallWidgetsL(); - iThemeServer.InstallUDAWidgetsL() ); - - // Force updating of the header cache - iThemeServer.UpdateHeaderListCacheL(); - } - - iThemeServer.GetActivateAppConfigurationL( - params.appUid, - *appODT ); - - // As a backup, if restoration of the active view fails, - // or if all views but the locked view should be removedc - if ( err || params.restoreAll ) - { - // Remove all views but the locked one and reset active view - RemoveUnlockedViewsL( *appODT ); - - // Remove all widgets from the active view - err = RestoreActiveViewL( *appODT ); - } - #ifdef HSPS_LOG_ACTIVE if( iLogBus ) { @@ -4714,19 +4713,16 @@ ChspsOdtDump::Dump( *appODT, *iLogBus ); } #endif - if( !err ) - { - // Stores the new application configuration into the repository - err = iDefinitionRepository.SetOdtL( *appODT ); - ret = EhspsRestoreConfigurationsSuccess; - } + // Stores the new application configuration into the repository + err = iDefinitionRepository.SetOdtL( *appODT ); + ret = EhspsRestoreConfigurationsSuccess; + } - CleanupStack::PopAndDestroy( appODT ); - - // Unlock after the changes have been done - iDefinitionRepository.Unlock(); - CleanupStack::Pop(&iDefinitionRepository); - } + CleanupStack::PopAndDestroy( appODT ); + + // Unlock after the changes have been done + iDefinitionRepository.Unlock(); + CleanupStack::Pop(&iDefinitionRepository); // Error handling iResult->iXuikonError = err; @@ -4736,6 +4732,26 @@ } // ----------------------------------------------------------------------------- +// ChspsMaintenanceHandler::HandleReinstallationL +// ----------------------------------------------------------------------------- +// +void ChspsMaintenanceHandler::HandleReinstallationL( + const TBool aInstallUdaEmmc ) + { + // Install plug-in configurations from the "install" directories + iThemeServer.InstallWidgetsL( aInstallUdaEmmc ); + if( aInstallUdaEmmc ) + { + // Install plug-in configurations from the "import" directories in C and E + iThemeServer.InstallUDAWidgetsL( KImportDirectoryC ); + iThemeServer.InstallUDAWidgetsL( KImportDirectoryE ); + } + + // Force updating of the header cache + iThemeServer.UpdateHeaderListCacheL(); + } + +// ----------------------------------------------------------------------------- // ChspsMaintenanceHandler::RestoreActiveViewL // ----------------------------------------------------------------------------- // diff -r 3310e4b0dae0 -r 8a75bf74485c homescreenpluginsrv/hspsmanager/src/hspsrominstaller.cpp --- a/homescreenpluginsrv/hspsmanager/src/hspsrominstaller.cpp Tue May 18 16:21:42 2010 +0100 +++ b/homescreenpluginsrv/hspsmanager/src/hspsrominstaller.cpp Fri May 28 13:36:52 2010 +0100 @@ -69,26 +69,17 @@ // ----------------------------------------------------------------------------- ChspsRomInstaller* ChspsRomInstaller::NewL( ChspsThemeServer& aThemeServer, - RFs& aFsSession ) - { - ChspsRomInstaller* self = NewLC( aThemeServer, aFsSession ); + RFs& aFsSession, + const TBool aInstallUdaEmmc ) + { + ChspsRomInstaller* self = + new ( ELeave ) ChspsRomInstaller( aThemeServer, aFsSession, aInstallUdaEmmc ); + CleanupStack::PushL( self ); + self->ConstructL(); CleanupStack::Pop( self ); return( self ) ; } -// ----------------------------------------------------------------------------- -// ChspsRomInstaller::NewLC() -// Two-phased constructor. -// ----------------------------------------------------------------------------- -ChspsRomInstaller* ChspsRomInstaller::NewLC( - ChspsThemeServer& aThemeServer, - RFs& aFsSession) - { - ChspsRomInstaller* self = new ( ELeave ) ChspsRomInstaller( aThemeServer, aFsSession ); - CleanupStack::PushL( self ); - self->ConstructL(); - return self; - } // ----------------------------------------------------------------------------- // ChspsRomInstaller::ConstructL() @@ -101,6 +92,12 @@ // Prevent notifications from ROM based installations iInstallationHandler->DisableNotifications(); + + // Skip UDA and eMMC drives if restoring plug-ins + if( !iInstallUdaEmmc ) + { + iInstallationHandler->DisableUdaEmmcInstallations(); + } } // ----------------------------------------------------------------------------- @@ -109,11 +106,13 @@ // ----------------------------------------------------------------------------- ChspsRomInstaller::ChspsRomInstaller( ChspsThemeServer& aThemeServer, - RFs& aFsSession ) - : CActive(EPriorityStandard), - iThemeServer(aThemeServer), - iFsSession(aFsSession), - iRet(EhspsInstallThemeFailed) + RFs& aFsSession, + const TBool aInstallUdaEmmc ) + : CActive( EPriorityStandard ), + iThemeServer( aThemeServer ), + iFsSession( aFsSession ), + iRet( EhspsInstallThemeFailed ), + iInstallUdaEmmc( aInstallUdaEmmc ) { CActiveScheduler::Add( this ); } @@ -138,7 +137,7 @@ RPointerArray fileArray; CleanupResetAndDestroyPushL( fileArray ); - // Find UDA and ROM widgets to be installed + // Find the manifest files FindInstallationFilesL( fileArray ); // Install the manifest files @@ -174,8 +173,14 @@ { __ASSERT_DEBUG( aFileArray.Count() == 0, User::Leave( KErrArgument ) ); - DoFindInstallationFilesL( aFileArray, KPrivateInstallE ); - DoFindInstallationFilesL( aFileArray, KPrivateInstallC ); + if( iInstallUdaEmmc ) + { + // Handle installation of the imaker exports + DoFindInstallationFilesL( aFileArray, KPrivateInstallE ); + DoFindInstallationFilesL( aFileArray, KPrivateInstallC ); + } + + // ROM DoFindInstallationFilesL( aFileArray, KPrivateInstallZ ); } diff -r 3310e4b0dae0 -r 8a75bf74485c homescreenpluginsrv/hspsmanager/src/hspsserverutil.cpp --- a/homescreenpluginsrv/hspsmanager/src/hspsserverutil.cpp Tue May 18 16:21:42 2010 +0100 +++ b/homescreenpluginsrv/hspsmanager/src/hspsserverutil.cpp Fri May 28 13:36:52 2010 +0100 @@ -1853,7 +1853,8 @@ TInt hspsServerUtil::FindFile( RFs& aFs, const TDesC& aPath, - const TDesC& aFilename, + const TDesC& aFilename, + const TBool aFindFromUdaEmmcDrives, TFileName& aDrivePathName ) { TInt err = KErrNotFound; @@ -1875,7 +1876,14 @@ TFindFile fileFinder( aFs ); fileFinder.SetFindMask( KDriveAttExclude|KDriveAttRemovable|KDriveAttRemote|KDriveAttSubsted ); - aFs.SetSessionToPrivate( EDriveE ); + if( aFindFromUdaEmmcDrives ) + { + aFs.SetSessionToPrivate( EDriveE ); + } + else + { + aFs.SetSessionToPrivate( EDriveZ ); + } err = fileFinder.FindByDir( filename, path ); aFs.SetSessionToPrivate( EDriveC ); if( !err ) diff -r 3310e4b0dae0 -r 8a75bf74485c homescreenpluginsrv/hspsmanager/src/hspsthemeserver.cpp --- a/homescreenpluginsrv/hspsmanager/src/hspsthemeserver.cpp Tue May 18 16:21:42 2010 +0100 +++ b/homescreenpluginsrv/hspsmanager/src/hspsthemeserver.cpp Fri May 28 13:36:52 2010 +0100 @@ -54,9 +54,6 @@ // CONSTANTS -// Directory for the SISX installation files -_LIT( KImportDirectoryC, "c:\\private\\200159c0\\import\\" ); - // Directories for backup folders _LIT( KBackupThemesDirectoryC, "c:\\private\\200159c0\\backup\\themes\\" ); @@ -2611,13 +2608,13 @@ // ChspsThemeServer::InstallUDAWidgetsL() // ----------------------------------------------------------------------------- // -void ChspsThemeServer::InstallUDAWidgetsL() +void ChspsThemeServer::InstallUDAWidgetsL( const TDesC& aImportDirectory ) { //Get list of uda dir's TPtrC filter( KFilterAllPluginImportsV1 ); CDir* importDir( NULL ); TFindFile fileFinder( iFsSession ); - fileFinder.FindWildByDir( filter, KImportDirectoryC, importDir ); + fileFinder.FindWildByDir( filter, aImportDirectory, importDir ); CleanupStack::PushL( importDir ); if ( importDir && importDir->Count() > 0 ) @@ -2631,7 +2628,7 @@ // Get manifest path HBufC* manifestBuf = GetManifestFromImportLC( udaName, - KImportDirectoryC ); + aImportDirectory ); //install TRAPD( err, installer->InstallConfigurationL( *manifestBuf ) ); @@ -2684,8 +2681,9 @@ // Install widgets from \private\200159C0\install\ directories (ROM and UDA image) InstallWidgetsL(); - // Install widgets from \private\200159C0\imports\ directory (UDA image) - InstallUDAWidgetsL(); + // Install widgets from \private\200159C0\imports\ directory (UDA image) C & E + InstallUDAWidgetsL( KImportDirectoryC ); + InstallUDAWidgetsL( KImportDirectoryE ); // Post RFS installations have been done, prevent re-installations at next startup // by reading firmware version and saving it to cenrep. @@ -2765,10 +2763,11 @@ // ChspsThemeServer::InstallWidgetsL() // ----------------------------------------------------------------------------- // -void ChspsThemeServer::InstallWidgetsL() +void ChspsThemeServer::InstallWidgetsL( + const TBool aInstallUdaEmmc ) { __ASSERT_DEBUG( !iRomInstaller, User::Leave( KErrGeneral) ); - iRomInstaller = ChspsRomInstaller::NewL( *this, iFsSession ); + iRomInstaller = ChspsRomInstaller::NewL( *this, iFsSession, aInstallUdaEmmc ); #ifdef HSPS_LOG_ACTIVE iRomInstaller->SetLogBus( iLogBus ); #endif @@ -2779,8 +2778,7 @@ iRomInstaller = 0; // Force updating of the header cache - ThspsRepositoryInfo info( EhspsCacheUpdate ); - iDefinitionRepository->RegisterNotification( info ); + TRAP_IGNORE( UpdateHeaderListCacheL() ); } // ----------------------------------------------------------------------------- diff -r 3310e4b0dae0 -r 8a75bf74485c homescreenpluginsrv/inc/hspsclient.h --- a/homescreenpluginsrv/inc/hspsclient.h Tue May 18 16:21:42 2010 +0100 +++ b/homescreenpluginsrv/inc/hspsclient.h Fri May 28 13:36:52 2010 +0100 @@ -445,20 +445,15 @@ const TInt aConfUid ); /** - * Restores plugin configurations by either removing all plugins - * from the active view or by removing all extra views. - * In latter case, the first locked view is emptied. If there are - * no locked views then the first view will remain while others - * are removed. + * Restores plugin configurations according to the input. * @since S60 5.2 * @param aAppUid Application uid - * @param aReinstall False if only the active view should be fixed, - * True if also all extra views should removed + * @param aRestore Operation to be executed * @return ThspsServiceCompletedMessage expressing the result of the call. */ IMPORT_C ThspsServiceCompletedMessage hspsRestoreConfigurations( const TInt aAppUid, - const TBool aReinstall ); + const ThspsRestore aRestore ); protected: // Functions from base classes diff -r 3310e4b0dae0 -r 8a75bf74485c homescreenpluginsrv/inc/hspsthememanagement.h --- a/homescreenpluginsrv/inc/hspsthememanagement.h Tue May 18 16:21:42 2010 +0100 +++ b/homescreenpluginsrv/inc/hspsthememanagement.h Fri May 28 13:36:52 2010 +0100 @@ -1028,16 +1028,20 @@ TBool storingStatus; // storing status telling if modified plugin settings are needed to stored its reference. }; +enum ThspsRestore + { + EhspsRestoreAll = 0, // restores plug-ins from eMMC, UDA and ROM + EhspsRestoreRom, // restores plug-ins from ROM + EhspsRestoreViews // removes extra views and empties them + }; + /** * Input parameter for the RestoreActiveAppConf service */ struct ThspsParamRestoreConfigurations { TInt appUid; // uid of the application - TBool restoreAll; // false: if all widget plugins should be removed from the active view, - // true: if all widget plugins should be removed from the first locked view - // (or if locked views were not found then from first unlocked view) - // and if all other views should be removed + ThspsRestore restore; // operation }; diff -r 3310e4b0dae0 -r 8a75bf74485c homescreensrv_plat/hs_content_control_api/inc/hscontentcontrol.h --- a/homescreensrv_plat/hs_content_control_api/inc/hscontentcontrol.h Tue May 18 16:21:42 2010 +0100 +++ b/homescreensrv_plat/hs_content_control_api/inc/hscontentcontrol.h Fri May 28 13:36:52 2010 +0100 @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008 Nokia Corporation and/or its subsidiary(-ies). + * Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies). * All rights reserved. * This component and the accompanying materials are made available * under the terms of "Eclipse Public License v1.0" @@ -25,31 +25,32 @@ // Forward declarations /** - * Content control interface - * - * - * @code + * Content control interface to notify observers about installation and + * uninstallation of Home screen configurations * - * @endcode - * - * @lib hscontentcontrol.lib - * @since S60 v5.0 + * @since S60 v5.2 */ class MHsContentControl { public: /** + * Notify changes in widget installations * + * @since S60 v5.2 */ virtual void NotifyWidgetListChanged() = 0; /** + * Notify changes in view installations * + * @since S60 v5.2 */ virtual void NotifyViewListChanged() = 0; /** + * Notify changes in application configuration installations * + * @since S60 v5.2 */ virtual void NotifyAppListChanged() = 0; diff -r 3310e4b0dae0 -r 8a75bf74485c homescreensrv_plat/hs_content_control_api/inc/hscontentcontroller.h --- a/homescreensrv_plat/hs_content_control_api/inc/hscontentcontroller.h Tue May 18 16:21:42 2010 +0100 +++ b/homescreensrv_plat/hs_content_control_api/inc/hscontentcontroller.h Fri May 28 13:36:52 2010 +0100 @@ -1,5 +1,5 @@ /* -* Copyright (c) 2008 Nokia Corporation and/or its subsidiary(-ies). +* Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies). * All rights reserved. * This component and the accompanying materials are made available * under the terms of "Eclipse Public License v1.0" @@ -28,7 +28,7 @@ // Constants /** - * unable to add widget because active page is full. + * Unable to add widget because active page is full. * No widgets can be added to this page before removing some first. */ const TInt KHsErrorViewFull = -87001; @@ -40,7 +40,7 @@ const TInt KHsErrorMaxInstanceCountExceeded = -87002; /** - * unable to add widget because widget is too large to fit. + * Unable to add widget because widget is too large to fit. * A smaller widget might fit though. */ const TInt KHsErrorDoesNotFit = -87003; @@ -48,21 +48,18 @@ /** - * Content controller interface - * - * - * @code + * Content controller interface defining the interface to modify + * Home screen content. * - * @endcode - * - * @lib hscontentcontrol.lib - * @since S60 v5.0 + * @since S60 v5.2 */ class MHsContentController { public: /** * Returns the list of available Home screen widgets + * + * @since S60 v5.2 * @param aArray List of widgets * @return KErrNone on success, any of system wide error codes */ @@ -71,6 +68,8 @@ /** * Returns the list of Home screen widgets included in an application * configuration or a view + * + * @since S60 v5.2 * @param aInfo Content info defining the application configuration * or the view which widget list is requested * @param aArray List of widgets @@ -80,6 +79,8 @@ /** * Returns the list of available Home screen views + * + * @since S60 v5.2 * @param aArray List of views * @return KErrNone on success, any of system wide error codes */ @@ -88,6 +89,8 @@ /** * Returns the list of available Home screen views included in an * application configuration + * + * @since S60 v5.2 * @param aInfo Content info defining the application configuration * @param aArray List of views * @return KErrNone on success, any of system wide error codes @@ -96,6 +99,8 @@ /** * Returns the list of available Home screen application configurations + * + * @since S60 v5.2 * @param aArray List of application configurations * @return KErrNone on success, any of system wide error codes */ @@ -103,6 +108,8 @@ /** * Adds a widget to the active Home screen view. + * + * @since S60 v5.2 * @param aInfo Widget request to be added * @return KErrNone on success, any of system wide error codes, * KHsErrorViewFull, KHsErrorMaxInstanceCountExceeded or @@ -112,6 +119,8 @@ /** * Removes a widget from the configuration. + * + * @since S60 v5.2 * @param aInfo Widget request to be removed * @return KErrNone on success, any of system wide error codes */ @@ -119,6 +128,8 @@ /** * Adds a view to the active Home screen application configuration. + * + * @since S60 v5.2 * @param aInfo View request to be added * @return KErrNone on success, any of system wide error codes */ @@ -126,6 +137,8 @@ /** * Removes a view from the configuration. + * + * @since S60 v5.2 * @param aInfo View request to be removed * @return KErrNone on success, any of system wide error codes */ @@ -133,6 +146,8 @@ /** * Activates the Home screen view + * + * @since S60 v5.2 * @param aInfo View request to be activated * @return KErrNone on success, any of system wide error codes */ @@ -140,6 +155,8 @@ /** * Activates the Home screen application configuration + * + * @since S60 v5.2 * @param aInfo Application configuration request to be activated * @return KErrNone on success, any of system wide error codes */ @@ -147,6 +164,8 @@ /** * Returns the active Home screen view + * + * @since S60 v5.2 * @param aInfo Active view * @return KErrNone on success, any of system wide error codes */ @@ -154,6 +173,8 @@ /** * Returns the active Home screen application configuration + * + * @since S60 v5.2 * @param aInfo Active application configuration * @return KErrNone on success, any of system wide error codes */ diff -r 3310e4b0dae0 -r 8a75bf74485c homescreensrv_plat/hs_content_control_api/inc/hscontentinfo.h --- a/homescreensrv_plat/hs_content_control_api/inc/hscontentinfo.h Tue May 18 16:21:42 2010 +0100 +++ b/homescreensrv_plat/hs_content_control_api/inc/hscontentinfo.h Fri May 28 13:36:52 2010 +0100 @@ -1,5 +1,5 @@ /* -* Copyright (c) 2008 Nokia Corporation and/or its subsidiary(-ies). +* Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies). * All rights reserved. * This component and the accompanying materials are made available * under the terms of "Eclipse Public License v1.0" @@ -28,39 +28,44 @@ /** * Content data * - * - * @code - * - * @endcode - * - * @lib hscontentcontrol.lib - * @since S60 v5.0 + * @lib hscontentinfo.lib + * @since S60 v5.2 */ NONSHARABLE_CLASS( CHsContentInfo ) : public CBase { public: /** * Two-phased constructor. + * + * @since S60 v5.2 */ IMPORT_C static CHsContentInfo* NewL(); /** * Two-phased constructor. + * + * @since S60 v5.2 */ IMPORT_C static CHsContentInfo* NewL( RReadStream& aStream ); /** * Two-phased constructor. + * + * @since S60 v5.2 */ IMPORT_C static CHsContentInfo* NewLC(); /** * Clone. + * + * @since S60 v5.2 */ IMPORT_C CHsContentInfo* CloneL(); /** * Destructor. + * + * @since S60 v5.2 */ ~CHsContentInfo(); @@ -77,7 +82,7 @@ /** * Set Widget name. * - * @since S60 5.0 + * @since S60 5.2 * @param aName. Name of the widget. * @return Reference to this */ @@ -86,7 +91,7 @@ /** * Set Widget name. * - * @since S60 5.0 + * @since S60 5.2 * @param aName. Name of the widget. * @return Reference to this */ @@ -95,7 +100,7 @@ /** * Set Widget's publisher Id . * - * @since S60 5.0 + * @since S60 5.2 * @param aPublisherId. Name of the publisher. * @return Reference to this */ @@ -104,7 +109,7 @@ /** * Set Widget id. * - * @since S60 5.0 + * @since S60 5.2 * @param aUid Static uid of the widget. * @return Reference to this */ @@ -113,7 +118,7 @@ /** * Set Widget plugin id. * - * @since S60 5.0 + * @since S60 5.2 * @param aId Dynamic id generated by hsps. * @return Reference to this */ @@ -122,7 +127,7 @@ /** * Set widget type. Possible values widget and template * - * @since S60 5.0 + * @since S60 5.2 * @param aType Widget type. */ IMPORT_C void SetTypeL( const TDesC8& aType ); @@ -130,7 +135,7 @@ /** * Access to widget name. * - * @since S60 5.0 + * @since S60 5.2 * @return Reference to name */ IMPORT_C const TDesC& Name() const; @@ -138,7 +143,7 @@ /** * Access to widget's publisher id. * - * @since S60 5.0 + * @since S60 5.2 * @return Reference to publisher id */ IMPORT_C const TDesC& PublisherId() const; @@ -146,7 +151,7 @@ /** * Access to widget uid. * - * @since S60 5.0 + * @since S60 5.2 * @return Uid or KNullDesC8 */ IMPORT_C const TDesC8& Uid() const; @@ -154,7 +159,7 @@ /** * Access to widget name. * - * @since S60 5.0 + * @since S60 5.2 * @return Reference to name */ IMPORT_C HBufC8* NameAs8BitLC() const; @@ -162,7 +167,7 @@ /** * Access to widget plugin id. * - * @since S60 5.0 + * @since S60 5.2 * @return Plugin id or null if not set */ IMPORT_C const TDesC8& PluginId() const; @@ -170,7 +175,7 @@ /** * Set widget type. Possible values widget and template * - * @since S60 5.0 + * @since S60 5.2 * @return Type or KNullDesC8. */ IMPORT_C const TDesC8& Type() const; @@ -185,6 +190,7 @@ /** * Get Maximum number of widgets * + * @since S60 5.2 * @return number of widgets or defaule value 1 */ IMPORT_C TInt MaxWidgets() const; @@ -192,6 +198,7 @@ /** * Externalize. * + * @since S60 5.2 * @param aStream A stream to externalize to */ IMPORT_C void ExternalizeL( RWriteStream& aStream ); @@ -199,7 +206,7 @@ /** * Sets whether this widget can be added to the active HS page * - * @since S60 5.0 + * @since S60 5.2 * @param aValue ETrue if can be added, EFalse otherwise */ IMPORT_C void SetCanBeAdded( TBool aValue ); @@ -207,7 +214,7 @@ /** * Queries whether this widget can be added to the active HS page * - * @since S60 5.0 + * @since S60 5.2 * @return ETrue if can be added, EFalse otherwise */ IMPORT_C TBool CanBeAdded() const; @@ -215,7 +222,7 @@ /** * Sets whether this widget can be removed from the active HS page * - * @since S60 5.0 + * @since S60 5.2 * @param aValue ETrue if can be added, EFalse otherwise */ IMPORT_C void SetCanBeRemoved( TBool aValue ); @@ -223,7 +230,7 @@ /** * Queries whether this widget can be removed from the active HS page * - * @since S60 5.0 + * @since S60 5.2 * @return ETrue if can be removed, EFalse otherwise */ IMPORT_C TBool CanBeRemoved() const; @@ -231,7 +238,7 @@ /** * Sets this widget's installation time * - * @since S60 5.0 + * @since S60 5.2 * @param aTime Installation time */ IMPORT_C void SetInstallationTime( TTime& aTime ); @@ -239,7 +246,7 @@ /** * Gets this widget's installation time * - * @since S60 5.0 + * @since S60 5.2 * @return Installation time */ IMPORT_C TTime InstallationTime() const; @@ -247,7 +254,7 @@ /** * Sets this widget's description * - * @since S60 5.0 + * @since S60 5.2 * @param aDescription Description */ IMPORT_C void SetDescriptionL( const TDesC& aDescription ); @@ -255,7 +262,7 @@ /** * Sets this widget's description * - * @since S60 5.0 + * @since S60 5.2 * @param aDescription Description */ IMPORT_C void SetDescriptionL( const TDesC8& aDescription ); @@ -263,7 +270,7 @@ /** * Gets this widget's description * - * @since S60 5.0 + * @since S60 5.2 * @return Description */ IMPORT_C const TDesC& Description() const; @@ -271,7 +278,7 @@ /** * Sets this widget's icon path * - * @since S60 5.0 + * @since S60 5.2 * @param aPath Path */ IMPORT_C void SetIconPathL( const TDesC& aIconPath ); @@ -279,30 +286,30 @@ /** * Gets this widget's icon path * - * @since S60 5.0 + * @since S60 5.2 * @return Path */ IMPORT_C const TDesC& IconPath() const; /** * Internalize + * + * @since S60 5.2 * @param aStream A stream where the class is internalized - * - * @since S60 5.0 */ IMPORT_C void InternalizeL( RReadStream& aStream ); /** * Returns size of a descriptor needed to externalize the class * - * @since S60 5.0 + * @since S60 5.2 */ IMPORT_C TInt Size(); /** * Set WRT widget publisher uid. * - * @since S60 5.0 + * @since S60 5.2 * @param aUid Publisher uid of the wrt widget. * @return Reference to this */ @@ -311,7 +318,7 @@ /** * Access to WRT widget publisher uid. * - * @since S60 5.0 + * @since S60 5.2 * @return PublisherUid or KNullDesC8 */ IMPORT_C const TDesC8& PublisherUid() const; @@ -319,7 +326,7 @@ /** * Sets whether this is a WRT widget * - * @since S60 5.0 + * @since S60 5.2 * @param aIsWrt, ETrue if is WRT */ IMPORT_C void SetIsWrt( TBool aIsWrt ); @@ -327,7 +334,7 @@ /** * Returns whether this is a WRT widget * - * @since S60 5.0 + * @since S60 5.2 * @return ETrue if WRT, EFalse otherwise */ IMPORT_C TBool IsWrt() const; @@ -335,7 +342,7 @@ /** * Sets whether an application confguration or a view is full * - * @since S60 5.0 + * @since S60 5.2 * @param aIsFull, ETrue if application configuration or a view is full */ IMPORT_C void SetIsFull( TBool aIsFull ); @@ -343,7 +350,7 @@ /** * Returns whether an application configuration or a view is full * - * @since S60 5.0 + * @since S60 5.2 * @return ETrue if application configuration or view is full, * EFalse otherwise */ @@ -352,7 +359,7 @@ /** * Marshals Content Info data to a descriptor * - * @since S60 5.0 + * @since S60 5.2 * @return Descriptor containing the externalized Content Info data */ IMPORT_C HBufC8* MarshalL(); diff -r 3310e4b0dae0 -r 8a75bf74485c homescreensrv_plat/hs_content_control_api/inc/hscontentinfoarray.h --- a/homescreensrv_plat/hs_content_control_api/inc/hscontentinfoarray.h Tue May 18 16:21:42 2010 +0100 +++ b/homescreensrv_plat/hs_content_control_api/inc/hscontentinfoarray.h Fri May 28 13:36:52 2010 +0100 @@ -1,5 +1,5 @@ /* -* Copyright (c) 2008 Nokia Corporation and/or its subsidiary(-ies). +* Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies). * All rights reserved. * This component and the accompanying materials are made available * under the terms of "Eclipse Public License v1.0" @@ -30,53 +30,66 @@ /** * Content data * - * - * @code - * - * @endcode - * - * @lib hscontentcontrol.lib - * @since S60 v5.0 + * @lib hscontentinfo.lib + * @since S60 v5.2 */ class CHsContentInfoArray : public CBase { public: /** * Two-phased constructor. + * + * @since S60 v5.2 */ IMPORT_C static CHsContentInfoArray* NewL(); /** * Two-phased constructor. + * + * @since S60 v5.2 */ IMPORT_C static CHsContentInfoArray* NewL( RReadStream& aStream ); /** * Destructor. + * + * @since S60 v5.2 */ virtual ~CHsContentInfoArray(); /** * Externalizes the array into the stream. + * + * @since S60 v5.2 */ IMPORT_C void ExternalizeL( RWriteStream& aStream ); + /** + * Returns reference to content info array + * + * @since S60 v5.2 + * @return Content info array + */ IMPORT_C RPointerArray< CHsContentInfo >& Array(); /** * Internalizes the array from the stream. + * + * @since S60 v5.2 */ IMPORT_C void InternalizeL( RReadStream& aStream ); /** * Returns size of a descriptor needed to externalize the class + * + * @since S60 v5.2 */ IMPORT_C TInt Size(); /** * Marshals Content Info array to a descriptor * - * @since S60 5.0 + * @since S60 5.2 * @return Descriptor containing the externalized Content Info array data */ IMPORT_C HBufC8* MarshalL(); diff -r 3310e4b0dae0 -r 8a75bf74485c homescreensrv_plat/sapi_homescreenplugin/hspsservice/bwins/hspsserviceu.def --- a/homescreensrv_plat/sapi_homescreenplugin/hspsservice/bwins/hspsserviceu.def Tue May 18 16:21:42 2010 +0100 +++ b/homescreensrv_plat/sapi_homescreenplugin/hspsservice/bwins/hspsserviceu.def Fri May 28 13:36:52 2010 +0100 @@ -1,25 +1,25 @@ EXPORTS - ?RestoreConfigurationsL@CHspsPersonalisationService@@QAEXHH@Z @ 1 NONAME ; void CHspsPersonalisationService::RestoreConfigurationsL(int, int) - ?GetODTL@CHspsConfigurationService@@QAEXH@Z @ 2 NONAME ; void CHspsConfigurationService::GetODTL(int) - ?GetAppConfListL@CHspsPersonalisationService@@QAEXHKAAV?$CArrayPtrFlat@VChspsODT@@@@@Z @ 3 NONAME ; void CHspsPersonalisationService::GetAppConfListL(int, unsigned long, class CArrayPtrFlat &) - ?SetConfStateL@CHspsPersonalisationService@@QAEXHAAVTDesC8@@00@Z @ 4 NONAME ; void CHspsPersonalisationService::SetConfStateL(int, class TDesC8 &, class TDesC8 &, class TDesC8 &) - ?InvalidateODT@CHspsConfigurationService@@QAEXXZ @ 5 NONAME ; void CHspsConfigurationService::InvalidateODT(void) - ?RemovePluginL@CHspsPersonalisationService@@QAEXHAAVTDesC8@@@Z @ 6 NONAME ; void CHspsPersonalisationService::RemovePluginL(int, class TDesC8 &) - ?SetActiveAppConfL@CHspsPersonalisationService@@QAEXHAAVTDesC8@@@Z @ 7 NONAME ; void CHspsPersonalisationService::SetActiveAppConfL(int, class TDesC8 &) - ?GetPluginListL@CHspsPersonalisationService@@QAEXAAVTDesC8@@0KHAAV?$CArrayPtrFlat@VChspsODT@@@@@Z @ 8 NONAME ; void CHspsPersonalisationService::GetPluginListL(class TDesC8 &, class TDesC8 &, unsigned long, int, class CArrayPtrFlat &) - ?RestoreActiveAppConfL@CHspsPersonalisationService@@QAEXHAAVTDesC8@@@Z @ 9 NONAME ; void CHspsPersonalisationService::RestoreActiveAppConfL(int, class TDesC8 &) - ?AddPluginL@CHspsPersonalisationService@@QAEXHAAVTDesC8@@00AAH@Z @ 10 NONAME ; void CHspsPersonalisationService::AddPluginL(int, class TDesC8 &, class TDesC8 &, class TDesC8 &, int &) - ?SetLogBus@CHspsConfigurationService@@QAEXPAVChspsLogBus@@@Z @ 11 NONAME ; void CHspsConfigurationService::SetLogBus(class ChspsLogBus *) - ?GetAppUidL@CHspsConfigurationService@@QAEXAAH@Z @ 12 NONAME ; void CHspsConfigurationService::GetAppUidL(int &) - ?MovePluginsL@CHspsPersonalisationService@@QAEXHAAVTDesC8@@AAV?$CArrayFixFlat@H@@@Z @ 13 NONAME ; void CHspsPersonalisationService::MovePluginsL(int, class TDesC8 &, class CArrayFixFlat &) - ?RegisterObserverL@CHspsConfigurationService@@QAEHPAVCHspsReqNotifCallback@@@Z @ 14 NONAME ; int CHspsConfigurationService::RegisterObserverL(class CHspsReqNotifCallback *) - ?GetDOML@CHspsConfigurationService@@QAEAAVChspsDomDocument@@XZ @ 15 NONAME ; class ChspsDomDocument & CHspsConfigurationService::GetDOML(void) - ?NewL@CHspsConfigurationService@@SAPAV1@XZ @ 16 NONAME ; class CHspsConfigurationService * CHspsConfigurationService::NewL(void) - ?NewL@CHspsPersonalisationService@@SAPAV1@XZ @ 17 NONAME ; class CHspsPersonalisationService * CHspsPersonalisationService::NewL(void) - ?SetPluginSettingsL@CHspsPersonalisationService@@QAEXHAAVTDesC8@@AAVChspsDomDocument@@H@Z @ 18 NONAME ; void CHspsPersonalisationService::SetPluginSettingsL(int, class TDesC8 &, class ChspsDomDocument &, int) - ?GetFamilyL@CHspsConfigurationService@@QAEXAAK@Z @ 19 NONAME ; void CHspsConfigurationService::GetFamilyL(unsigned long &) - ?ReplacePluginL@CHspsPersonalisationService@@QAEXHABVTDesC8@@0@Z @ 20 NONAME ; void CHspsPersonalisationService::ReplacePluginL(int, class TDesC8 const &, class TDesC8 const &) - ?GetPluginOdtL@CHspsPersonalisationService@@QAEXHAAVTDesC8@@PAVChspsODT@@@Z @ 21 NONAME ; void CHspsPersonalisationService::GetPluginOdtL(int, class TDesC8 &, class ChspsODT *) - ?SetActivePluginL@CHspsPersonalisationService@@QAEXHAAVTDesC8@@@Z @ 22 NONAME ; void CHspsPersonalisationService::SetActivePluginL(int, class TDesC8 &) - ?UnRegisterObserverL@CHspsConfigurationService@@QAEXXZ @ 23 NONAME ; void CHspsConfigurationService::UnRegisterObserverL(void) + ?GetODTL@CHspsConfigurationService@@QAEXH@Z @ 1 NONAME ; void CHspsConfigurationService::GetODTL(int) + ?GetAppConfListL@CHspsPersonalisationService@@QAEXHKAAV?$CArrayPtrFlat@VChspsODT@@@@@Z @ 2 NONAME ; void CHspsPersonalisationService::GetAppConfListL(int, unsigned long, class CArrayPtrFlat &) + ?SetConfStateL@CHspsPersonalisationService@@QAEXHAAVTDesC8@@00@Z @ 3 NONAME ; void CHspsPersonalisationService::SetConfStateL(int, class TDesC8 &, class TDesC8 &, class TDesC8 &) + ?InvalidateODT@CHspsConfigurationService@@QAEXXZ @ 4 NONAME ; void CHspsConfigurationService::InvalidateODT(void) + ?RemovePluginL@CHspsPersonalisationService@@QAEXHAAVTDesC8@@@Z @ 5 NONAME ; void CHspsPersonalisationService::RemovePluginL(int, class TDesC8 &) + ?SetActiveAppConfL@CHspsPersonalisationService@@QAEXHAAVTDesC8@@@Z @ 6 NONAME ; void CHspsPersonalisationService::SetActiveAppConfL(int, class TDesC8 &) + ?GetPluginListL@CHspsPersonalisationService@@QAEXAAVTDesC8@@0KHAAV?$CArrayPtrFlat@VChspsODT@@@@@Z @ 7 NONAME ; void CHspsPersonalisationService::GetPluginListL(class TDesC8 &, class TDesC8 &, unsigned long, int, class CArrayPtrFlat &) + ?RestoreActiveAppConfL@CHspsPersonalisationService@@QAEXHAAVTDesC8@@@Z @ 8 NONAME ; void CHspsPersonalisationService::RestoreActiveAppConfL(int, class TDesC8 &) + ?AddPluginL@CHspsPersonalisationService@@QAEXHAAVTDesC8@@00AAH@Z @ 9 NONAME ; void CHspsPersonalisationService::AddPluginL(int, class TDesC8 &, class TDesC8 &, class TDesC8 &, int &) + ?SetLogBus@CHspsConfigurationService@@QAEXPAVChspsLogBus@@@Z @ 10 NONAME ; void CHspsConfigurationService::SetLogBus(class ChspsLogBus *) + ?GetAppUidL@CHspsConfigurationService@@QAEXAAH@Z @ 11 NONAME ; void CHspsConfigurationService::GetAppUidL(int &) + ?MovePluginsL@CHspsPersonalisationService@@QAEXHAAVTDesC8@@AAV?$CArrayFixFlat@H@@@Z @ 12 NONAME ; void CHspsPersonalisationService::MovePluginsL(int, class TDesC8 &, class CArrayFixFlat &) + ?RegisterObserverL@CHspsConfigurationService@@QAEHPAVCHspsReqNotifCallback@@@Z @ 13 NONAME ; int CHspsConfigurationService::RegisterObserverL(class CHspsReqNotifCallback *) + ?GetDOML@CHspsConfigurationService@@QAEAAVChspsDomDocument@@XZ @ 14 NONAME ; class ChspsDomDocument & CHspsConfigurationService::GetDOML(void) + ?NewL@CHspsConfigurationService@@SAPAV1@XZ @ 15 NONAME ; class CHspsConfigurationService * CHspsConfigurationService::NewL(void) + ?NewL@CHspsPersonalisationService@@SAPAV1@XZ @ 16 NONAME ; class CHspsPersonalisationService * CHspsPersonalisationService::NewL(void) + ?SetPluginSettingsL@CHspsPersonalisationService@@QAEXHAAVTDesC8@@AAVChspsDomDocument@@H@Z @ 17 NONAME ; void CHspsPersonalisationService::SetPluginSettingsL(int, class TDesC8 &, class ChspsDomDocument &, int) + ?GetFamilyL@CHspsConfigurationService@@QAEXAAK@Z @ 18 NONAME ; void CHspsConfigurationService::GetFamilyL(unsigned long &) + ?ReplacePluginL@CHspsPersonalisationService@@QAEXHABVTDesC8@@0@Z @ 19 NONAME ; void CHspsPersonalisationService::ReplacePluginL(int, class TDesC8 const &, class TDesC8 const &) + ?GetPluginOdtL@CHspsPersonalisationService@@QAEXHAAVTDesC8@@PAVChspsODT@@@Z @ 20 NONAME ; void CHspsPersonalisationService::GetPluginOdtL(int, class TDesC8 &, class ChspsODT *) + ?SetActivePluginL@CHspsPersonalisationService@@QAEXHAAVTDesC8@@@Z @ 21 NONAME ; void CHspsPersonalisationService::SetActivePluginL(int, class TDesC8 &) + ?UnRegisterObserverL@CHspsConfigurationService@@QAEXXZ @ 22 NONAME ; void CHspsConfigurationService::UnRegisterObserverL(void) + ?RestoreConfigurationsL@CHspsPersonalisationService@@QAEXHW4TRestore@1@@Z @ 23 NONAME ; void CHspsPersonalisationService::RestoreConfigurationsL(int, enum CHspsPersonalisationService::TRestore) diff -r 3310e4b0dae0 -r 8a75bf74485c homescreensrv_plat/sapi_homescreenplugin/hspsservice/eabi/hspsserviceu.def --- a/homescreensrv_plat/sapi_homescreenplugin/hspsservice/eabi/hspsserviceu.def Tue May 18 16:21:42 2010 +0100 +++ b/homescreensrv_plat/sapi_homescreenplugin/hspsservice/eabi/hspsserviceu.def Fri May 28 13:36:52 2010 +0100 @@ -20,7 +20,7 @@ _ZN27CHspsPersonalisationService17SetActiveAppConfLEiR6TDesC8 @ 19 NONAME _ZN27CHspsPersonalisationService18SetPluginSettingsLEiR6TDesC8R16ChspsDomDocumenti @ 20 NONAME _ZN27CHspsPersonalisationService21RestoreActiveAppConfLEiR6TDesC8 @ 21 NONAME - _ZN27CHspsPersonalisationService22RestoreConfigurationsLEii @ 22 NONAME + _ZN27CHspsPersonalisationService22RestoreConfigurationsLEiNS_8TRestoreE @ 22 NONAME _ZN27CHspsPersonalisationService4NewLEv @ 23 NONAME _ZTI25CHspsConfigurationService @ 24 NONAME _ZTI27CHspsPersonalisationService @ 25 NONAME diff -r 3310e4b0dae0 -r 8a75bf74485c homescreensrv_plat/sapi_homescreenplugin/hspsservice/inc/hspspersonalisationservice.h --- a/homescreensrv_plat/sapi_homescreenplugin/hspsservice/inc/hspspersonalisationservice.h Tue May 18 16:21:42 2010 +0100 +++ b/homescreensrv_plat/sapi_homescreenplugin/hspsservice/inc/hspspersonalisationservice.h Fri May 28 13:36:52 2010 +0100 @@ -44,7 +44,14 @@ class CHspsPersonalisationService : public CBase, public MhspsThemeManagementServiceObserver { public: // Constructor and destructor - + + enum TRestore + { + EDefault, + ERom, + EViews + }; + /** * Two-phased constructor. * @@ -243,19 +250,14 @@ const TDesC8& aConfUid ); /** - * Restores plugin configurations by either removing all plugins - * from the active view or by removing all extra views. - * In latter case, the first locked view is emptied. If there are - * no locked views then the first view will remain while others - * are removed. + * Restores plugin configurations according to the input. * @since S60 5.2 * @param aAppUid Application uid - * @param aResetAllViews False if only the active view should be fixed, - * True if also all extra views should removed + * @param aOperation Operation to be executed */ IMPORT_C void RestoreConfigurationsL( const TInt aAppUid, - const TBool aResetAllViews ); + const TRestore aOperation ); private: // Methods diff -r 3310e4b0dae0 -r 8a75bf74485c homescreensrv_plat/sapi_homescreenplugin/hspsservice/src/hspspersonalisationservice.cpp --- a/homescreensrv_plat/sapi_homescreenplugin/hspsservice/src/hspspersonalisationservice.cpp Tue May 18 16:21:42 2010 +0100 +++ b/homescreensrv_plat/sapi_homescreenplugin/hspsservice/src/hspspersonalisationservice.cpp Fri May 28 13:36:52 2010 +0100 @@ -432,10 +432,24 @@ // ----------------------------------------------------------------------------- EXPORT_C void CHspsPersonalisationService::RestoreConfigurationsL( const TInt aAppUid, - const TBool aResetAllViews ) + const TRestore aOperation ) { + ThspsRestore operation( EhspsRestoreAll ); + if( aOperation == EDefault ) + { + operation = EhspsRestoreAll; + } + else if( aOperation == ERom ) + { + operation = EhspsRestoreRom; + } + else if( aOperation == EViews ) + { + operation = EhspsRestoreViews; + } + ThspsServiceCompletedMessage ret = - iHspsClient->hspsRestoreConfigurations( aAppUid, aResetAllViews ); + iHspsClient->hspsRestoreConfigurations( aAppUid, operation ); if( ret != EhspsRestoreConfigurationsSuccess ) { // Get error code from the server process diff -r 3310e4b0dae0 -r 8a75bf74485c homescreensrv_plat/sapi_homescreenplugin/inc/hspsliwvocabulary.hrh --- a/homescreensrv_plat/sapi_homescreenplugin/inc/hspsliwvocabulary.hrh Tue May 18 16:21:42 2010 +0100 +++ b/homescreensrv_plat/sapi_homescreenplugin/inc/hspsliwvocabulary.hrh Fri May 28 13:36:52 2010 +0100 @@ -72,8 +72,9 @@ _LIT8( KHspsLiwStorePluginRefence, "storePluginConf" ); _LIT8( KHspsLiwStoreAppConf, "storeAppConf" ); _LIT8( KHspsLiwRestore, "restore" ); -_LIT8( KHspsLiwRestoreActive, "active"); -_LIT8( KHspsLiwRestoreAll, "all"); +_LIT8( KHspsLiwRestoreDefault, "default"); +_LIT8( KHspsLiwRestoreRom, "rom"); +_LIT8( KHspsLiwRestoreViews, "views"); //Output words. _LIT8( KHspsLiwPluginId, "pluginId" ); diff -r 3310e4b0dae0 -r 8a75bf74485c homescreensrv_plat/sapi_homescreenplugin/src/hspsconfigurationif.cpp --- a/homescreensrv_plat/sapi_homescreenplugin/src/hspsconfigurationif.cpp Tue May 18 16:21:42 2010 +0100 +++ b/homescreensrv_plat/sapi_homescreenplugin/src/hspsconfigurationif.cpp Fri May 28 13:36:52 2010 +0100 @@ -1193,23 +1193,31 @@ } TLiwVariant inParamVariant = inParam->Value(); - TPtrC8 restore( inParamVariant.AsData() ); - - TBool restoreAll = EFalse; - if( restore.CompareF( KHspsLiwRestoreAll ) == 0 ) + TPtrC8 restorePtr( inParamVariant.AsData() ); + + CHspsPersonalisationService::TRestore operation( CHspsPersonalisationService::EDefault ); + if( restorePtr.CompareF( KHspsLiwRestoreDefault ) == 0 ) { - restoreAll = ETrue; + operation = CHspsPersonalisationService::EDefault; + } + else if( restorePtr.CompareF( KHspsLiwRestoreRom ) == 0 ) + { + operation = CHspsPersonalisationService::ERom; } - else if( restore.CompareF( KHspsLiwRestoreActive ) != 0 ) + else if( restorePtr.CompareF( KHspsLiwRestoreViews ) == 0 ) + { + operation = CHspsPersonalisationService::EViews; + } + else { User::Leave( KErrArgument ); - } + } // Get client application's uid TInt appUid; iHspsConfigurationService->GetAppUidL( appUid ); - iHspsPersonalisationService->RestoreConfigurationsL( appUid, restoreAll ); + iHspsPersonalisationService->RestoreConfigurationsL( appUid, operation ); // Invalidate ODT. iHspsConfigurationService->InvalidateODT(); diff -r 3310e4b0dae0 -r 8a75bf74485c homescreensrv_plat/sapi_homescreenplugin/tsrc/hspsconfigurationif/inc/mt_hsps_restoreconfigurations_1.h --- a/homescreensrv_plat/sapi_homescreenplugin/tsrc/hspsconfigurationif/inc/mt_hsps_restoreconfigurations_1.h Tue May 18 16:21:42 2010 +0100 +++ b/homescreensrv_plat/sapi_homescreenplugin/tsrc/hspsconfigurationif/inc/mt_hsps_restoreconfigurations_1.h Fri May 28 13:36:52 2010 +0100 @@ -35,27 +35,27 @@ Test step 1: • Input: - RestoreConfigurations(“active”) + RestoreConfigurations(“default”) • Expected output: - Restoring succeeded + Restoring from eMMC/UDA/ROM succeeded Test step 2: • Input: GetActiveAppConf • Expected output: - ROM configuration is restored and returned. + Default configuration is restored and returned. Test step 3: • Input: GetPluginConf(“Typical - View1”) • Expected output: - ROM view configuration is returned. + ROM's view configuration from is returned. Test step 4: • Input: - RestoreConfigurations(“all”) + RestoreConfigurations(“views”) • Expected output: - Restoring succeeded + Restoring of the views succeeded Test step 5: • Input: @@ -101,9 +101,9 @@ // - Variant value 10, 5, -6,0,0,0, -26, -'a','c','t','i','v','e' +7,0,0,0, +30, +'d','e','f','a','u','l','t' }; // Test step 1 output: @@ -1883,9 +1883,9 @@ // - Variant value 10, 5, -3,0,0,0, -14, -'a','l','l' +5,0,0,0, +22, +'v','i','e','w','s' }; // Test step 4 output: diff -r 3310e4b0dae0 -r 8a75bf74485c homescreensrv_plat/sapi_menucontent/mcsservice/src/mcsexecuteaction.cpp --- a/homescreensrv_plat/sapi_menucontent/mcsservice/src/mcsexecuteaction.cpp Tue May 18 16:21:42 2010 +0100 +++ b/homescreensrv_plat/sapi_menucontent/mcsservice/src/mcsexecuteaction.cpp Fri May 28 13:36:52 2010 +0100 @@ -124,15 +124,10 @@ void CMCSExecuteAction::RunL() { TInt err = iStatus.Int(); - if ( err == KErrNone ) { - TRAP( err, ExecuteL( iItemId, iAction ) ); - } - if(err != KErrNone) - { - NotifyRequestResult( err ); - } + ExecuteL( iItemId, iAction ); + } } // --------------------------------------------------------------------------- @@ -142,10 +137,6 @@ TInt CMCSExecuteAction::RunError(TInt aError) { NotifyRequestResult( aError ); - if ( (aError != KErrDiskFull) && (aError != KErrNoMemory)) - { - aError = KErrNone; - } return aError; } diff -r 3310e4b0dae0 -r 8a75bf74485c idlefw/plugins/devicestatus/src/aisimregpublisher.cpp --- a/idlefw/plugins/devicestatus/src/aisimregpublisher.cpp Tue May 18 16:21:42 2010 +0100 +++ b/idlefw/plugins/devicestatus/src/aisimregpublisher.cpp Fri May 28 13:36:52 2010 +0100 @@ -1,5 +1,5 @@ /* -* Copyright (c) 2005-2006 Nokia Corporation and/or its subsidiary(-ies). +* Copyright (c) 2005-2010 Nokia Corporation and/or its subsidiary(-ies). * All rights reserved. * This component and the accompanying materials are made available * under the terms of "Eclipse Public License v1.0" @@ -21,6 +21,7 @@ #include "ainetworkinfolistener.h" #include #include +#include #include @@ -49,6 +50,7 @@ void CAiSimRegPublisher::ConstructL() { + FeatureManager::InitializeLibL(); iListener = CAiNetworkInfoListener::InstanceL(); } @@ -65,6 +67,7 @@ CAiSimRegPublisher::~CAiSimRegPublisher() { + FeatureManager::UnInitializeLib(); if( iListener ) { iListener->RemoveObserver( *this ); @@ -174,6 +177,15 @@ default: break; } + } + else if ( FeatureManager::FeatureSupported( KFeatureIdFfManualSelectionPopulatedPlmnList ) + && aMessage == + static_cast( KErrGsmMMNetworkFailure ) ) + { + iContentObserver->Publish( *iExtension, + EAiDeviceStatusContentNetRegStatus, + EAiDeviceStatusResourceNetRegFail, + 0 ); } } diff -r 3310e4b0dae0 -r 8a75bf74485c menucontentsrv/bwins/mcsmenuengu.def --- a/menucontentsrv/bwins/mcsmenuengu.def Tue May 18 16:21:42 2010 +0100 +++ b/menucontentsrv/bwins/mcsmenuengu.def Fri May 28 13:36:52 2010 +0100 @@ -1,34 +1,34 @@ EXPORTS - ??1CMenuEng@@UAE@XZ @ 1 NONAME ; CMenuEng::~CMenuEng(void) - ??1CMenuEngObject@@UAE@XZ @ 2 NONAME ; CMenuEngObject::~CMenuEngObject(void) - ?AddL@CMenuEng@@QAEXAAVCMenuEngObject@@HH@Z @ 3 NONAME ; void CMenuEng::AddL(class CMenuEngObject &, int, int) - ?AppendNotifyL@CMenuEng@@QAEXHH@Z @ 4 NONAME ; void CMenuEng::AppendNotifyL(int, int) - ?DequeueOperation@CMenuEng@@QAEXAAVMMenuEngOperation@@@Z @ 5 NONAME ; void CMenuEng::DequeueOperation(class MMenuEngOperation &) - ?Exist@CMenuEng@@QBEHH@Z @ 6 NONAME ; int CMenuEng::Exist(int) const - ?FindAttribute@CMenuEngObject@@QBEHABVTDesC16@@AAVTPtrC16@@AAH@Z @ 7 NONAME ; int CMenuEngObject::FindAttribute(class TDesC16 const &, class TPtrC16 &, int &) const - ?Flags@CMenuEngObject@@QBEKH@Z @ 8 NONAME ; unsigned long CMenuEngObject::Flags(int) const + ?RemoveAttribute@CMenuEngObject@@QAEXABVTDesC16@@@Z @ 1 NONAME ; void CMenuEngObject::RemoveAttribute(class TDesC16 const &) + ?TraverseFolderL@CMenuEng@@QBEXHAAVMMenuEngVisitor@@@Z @ 2 NONAME ; void CMenuEng::TraverseFolderL(int, class MMenuEngVisitor &) const + ?QueueOperationL@CMenuEng@@QAEXAAVMMenuEngOperation@@@Z @ 3 NONAME ; void CMenuEng::QueueOperationL(class MMenuEngOperation &) + ??1CMenuEngObject@@UAE@XZ @ 4 NONAME ; CMenuEngObject::~CMenuEngObject(void) + ??1CMenuEng@@UAE@XZ @ 5 NONAME ; CMenuEng::~CMenuEng(void) + ?RootFolderL@CMenuEng@@QBEXAAH@Z @ 6 NONAME ; void CMenuEng::RootFolderL(int &) const + ?MoveToFolderL@CMenuEng@@QAEXAAV?$RArray@H@@HH@Z @ 7 NONAME ; void CMenuEng::MoveToFolderL(class RArray &, int, int) + ?GetOnceLegacyFormat@CMenuEng@@QAEHXZ @ 8 NONAME ; int CMenuEng::GetOnceLegacyFormat(void) ?GetAttribute@CMenuEngObject@@QBEHHAAVTPtrC16@@0AAH@Z @ 9 NONAME ; int CMenuEngObject::GetAttribute(int, class TPtrC16 &, class TPtrC16 &, int &) const - ?GetItemL@CMenuEng@@QBEXHAAVTMenuItem@@@Z @ 10 NONAME ; void CMenuEng::GetItemL(int, class TMenuItem &) const - ?GetItemsL@CMenuEng@@QBEXAAV?$RArray@VTMenuItem@@@@HPBVMMenuEngFilter@@H@Z @ 11 NONAME ; void CMenuEng::GetItemsL(class RArray &, int, class MMenuEngFilter const *, int) const - ?GetOnceLegacyFormat@CMenuEng@@QAEHXZ @ 12 NONAME ; int CMenuEng::GetOnceLegacyFormat(void) - ?Id@CMenuEngObject@@QBEHXZ @ 13 NONAME ; int CMenuEngObject::Id(void) const - ?MoveToFolderL@CMenuEng@@QAEXAAV?$RArray@H@@HH@Z @ 14 NONAME ; void CMenuEng::MoveToFolderL(class RArray &, int, int) - ?NewL@CMenuEng@@SAPAV1@ABVTDesC16@@AAVMMenuEngObserver@@@Z @ 15 NONAME ; class CMenuEng * CMenuEng::NewL(class TDesC16 const &, class MMenuEngObserver &) - ?NewObjectL@CMenuEng@@QAEPAVCMenuEngObject@@ABVTDesC16@@@Z @ 16 NONAME ; class CMenuEngObject * CMenuEng::NewObjectL(class TDesC16 const &) - ?NumAttributes@CMenuEngObject@@QBEHXZ @ 17 NONAME ; int CMenuEngObject::NumAttributes(void) const - ?ObjectL@CMenuEng@@QBEABVCMenuEngObject@@H@Z @ 18 NONAME ; class CMenuEngObject const & CMenuEng::ObjectL(int) const - ?ParentFolderL@CMenuEng@@QBEXHAAH@Z @ 19 NONAME ; void CMenuEng::ParentFolderL(int, int &) const - ?QueueOperationL@CMenuEng@@QAEXAAVMMenuEngOperation@@@Z @ 20 NONAME ; void CMenuEng::QueueOperationL(class MMenuEngOperation &) - ?RemoveAttribute@CMenuEngObject@@QAEXABVTDesC16@@@Z @ 21 NONAME ; void CMenuEngObject::RemoveAttribute(class TDesC16 const &) - ?RemoveL@CMenuEng@@QAEXH@Z @ 22 NONAME ; void CMenuEng::RemoveL(int) - ?ReorderL@CMenuEng@@QAEXHH@Z @ 23 NONAME ; void CMenuEng::ReorderL(int, int) - ?Reset@CMenuEngObject@@QAEXXZ @ 24 NONAME ; void CMenuEngObject::Reset(void) - ?RootFolderL@CMenuEng@@QBEXAAH@Z @ 25 NONAME ; void CMenuEng::RootFolderL(int &) const - ?SetAttributeL@CMenuEngObject@@QAEXABVTDesC16@@0H@Z @ 26 NONAME ; void CMenuEngObject::SetAttributeL(class TDesC16 const &, class TDesC16 const &, int) - ?SetFlags@CMenuEngObject@@QAEXKH@Z @ 27 NONAME ; void CMenuEngObject::SetFlags(unsigned long, int) - ?TraverseFolderL@CMenuEng@@QBEXHAAVMMenuEngVisitor@@@Z @ 28 NONAME ; void CMenuEng::TraverseFolderL(int, class MMenuEngVisitor &) const - ?Type@CMenuEngObject@@QBE?AVTPtrC16@@XZ @ 29 NONAME ; class TPtrC16 CMenuEngObject::Type(void) const - ?GetNative@CMenuEngObject@@QBEHXZ @ 30 NONAME ; int CMenuEngObject::GetNative(void) const - ?SetNative@CMenuEngObject@@QAEXH@Z @ 31 NONAME ; void CMenuEngObject::SetNative(int) - ?ModifiableObjectL@CMenuEng@@QAEAAVCMenuEngObject@@HH@Z @ 32 NONAME ; class CMenuEngObject & CMenuEng::ModifiableObjectL(int, int) + ?RemoveL@CMenuEng@@QAEXH@Z @ 10 NONAME ; void CMenuEng::RemoveL(int) + ?Type@CMenuEngObject@@QBE?AVTPtrC16@@XZ @ 11 NONAME ; class TPtrC16 CMenuEngObject::Type(void) const + ?ParentFolderL@CMenuEng@@QBEXHAAH@Z @ 12 NONAME ; void CMenuEng::ParentFolderL(int, int &) const + ?NewObjectL@CMenuEng@@QAEPAVCMenuEngObject@@ABVTDesC16@@@Z @ 13 NONAME ; class CMenuEngObject * CMenuEng::NewObjectL(class TDesC16 const &) + ?ObjectL@CMenuEng@@QBEABVCMenuEngObject@@H@Z @ 14 NONAME ; class CMenuEngObject const & CMenuEng::ObjectL(int) const + ?Id@CMenuEngObject@@QBEHXZ @ 15 NONAME ; int CMenuEngObject::Id(void) const + ?Flags@CMenuEngObject@@QBEKH@Z @ 16 NONAME ; unsigned long CMenuEngObject::Flags(int) const + ?AppendNotifyL@CMenuEng@@QAEXHH@Z @ 17 NONAME ; void CMenuEng::AppendNotifyL(int, int) + ?GetItemL@CMenuEng@@QBEXHAAVTMenuItem@@@Z @ 18 NONAME ; void CMenuEng::GetItemL(int, class TMenuItem &) const + ?SetAttributeL@CMenuEngObject@@QAEXABVTDesC16@@0H@Z @ 19 NONAME ; void CMenuEngObject::SetAttributeL(class TDesC16 const &, class TDesC16 const &, int) + ?GetItemsL@CMenuEng@@QBEXAAV?$RArray@VTMenuItem@@@@HPBVMMenuEngFilter@@H@Z @ 20 NONAME ; void CMenuEng::GetItemsL(class RArray &, int, class MMenuEngFilter const *, int) const + ?SetAppType@CMenuEngObject@@QAEXW4TAppType@1@@Z @ 21 NONAME ; void CMenuEngObject::SetAppType(enum CMenuEngObject::TAppType) + ?DequeueOperation@CMenuEng@@QAEXAAVMMenuEngOperation@@@Z @ 22 NONAME ; void CMenuEng::DequeueOperation(class MMenuEngOperation &) + ?NewL@CMenuEng@@SAPAV1@ABVTDesC16@@AAVMMenuEngObserver@@@Z @ 23 NONAME ; class CMenuEng * CMenuEng::NewL(class TDesC16 const &, class MMenuEngObserver &) + ?AddL@CMenuEng@@QAEXAAVCMenuEngObject@@HH@Z @ 24 NONAME ; void CMenuEng::AddL(class CMenuEngObject &, int, int) + ?NumAttributes@CMenuEngObject@@QBEHXZ @ 25 NONAME ; int CMenuEngObject::NumAttributes(void) const + ?ModifiableObjectL@CMenuEng@@QAEAAVCMenuEngObject@@HH@Z @ 26 NONAME ; class CMenuEngObject & CMenuEng::ModifiableObjectL(int, int) + ?Reset@CMenuEngObject@@QAEXXZ @ 27 NONAME ; void CMenuEngObject::Reset(void) + ?Exist@CMenuEng@@QBEHH@Z @ 28 NONAME ; int CMenuEng::Exist(int) const + ?SetFlags@CMenuEngObject@@QAEXKH@Z @ 29 NONAME ; void CMenuEngObject::SetFlags(unsigned long, int) + ?GetAppType@CMenuEngObject@@QBE?AW4TAppType@1@XZ @ 30 NONAME ; enum CMenuEngObject::TAppType CMenuEngObject::GetAppType(void) const + ?ReorderL@CMenuEng@@QAEXHH@Z @ 31 NONAME ; void CMenuEng::ReorderL(int, int) + ?FindAttribute@CMenuEngObject@@QBEHABVTDesC16@@AAVTPtrC16@@AAH@Z @ 32 NONAME ; int CMenuEngObject::FindAttribute(class TDesC16 const &, class TPtrC16 &, int &) const diff -r 3310e4b0dae0 -r 8a75bf74485c menucontentsrv/bwins/mcsmenuu.def --- a/menucontentsrv/bwins/mcsmenuu.def Tue May 18 16:21:42 2010 +0100 +++ b/menucontentsrv/bwins/mcsmenuu.def Fri May 28 13:36:52 2010 +0100 @@ -1,59 +1,59 @@ EXPORTS - ??0CMenuHandler@@IAE@AAVRMenu@@@Z @ 1 NONAME ; CMenuHandler::CMenuHandler(class RMenu &) - ??1CMenuCompletedOperation@@UAE@XZ @ 2 NONAME ; CMenuCompletedOperation::~CMenuCompletedOperation(void) - ??1CMenuFilter@@UAE@XZ @ 3 NONAME ; CMenuFilter::~CMenuFilter(void) - ??1CMenuHandler@@UAE@XZ @ 4 NONAME ; CMenuHandler::~CMenuHandler(void) - ??1CMenuItem@@UAE@XZ @ 5 NONAME ; CMenuItem::~CMenuItem(void) - ?BaseConstructL@CMenuHandler@@IAEXXZ @ 6 NONAME ; void CMenuHandler::BaseConstructL(void) - ?Cancel@RMenuNotifier@@QAEXXZ @ 7 NONAME ; void RMenuNotifier::Cancel(void) - ?Close@RMenu@@QAEXXZ @ 8 NONAME ; void RMenu::Close(void) - ?Close@RMenuNotifier@@QAEXXZ @ 9 NONAME ; void RMenuNotifier::Close(void) - ?CreateL@CMenuItem@@SAPAV1@AAVRMenu@@ABVTDesC16@@HH@Z @ 10 NONAME ; class CMenuItem * CMenuItem::CreateL(class RMenu &, class TDesC16 const &, int, int) - ?DoNotHaveAttributeL@CMenuFilter@@QAEXABVTDesC16@@@Z @ 11 NONAME ; void CMenuFilter::DoNotHaveAttributeL(class TDesC16 const &) + ?SupportsType@CMenuHandler@@UAEHABVTDesC16@@@Z @ 1 NONAME ; int CMenuHandler::SupportsType(class TDesC16 const &) + ?HaveAttributeL@CMenuFilter@@QAEXABVTDesC16@@0@Z @ 2 NONAME ; void CMenuFilter::HaveAttributeL(class TDesC16 const &, class TDesC16 const &) + ?GetAttribute@CMenuFilter@@QBEHHAAVTPtrC16@@0@Z @ 3 NONAME ; int CMenuFilter::GetAttribute(int, class TPtrC16 &, class TPtrC16 &) const + ?Open@RMenuNotifier@@QAEHAAVRMenu@@@Z @ 4 NONAME ; int RMenuNotifier::Open(class RMenu &) + ?Notify@RMenuNotifier@@QAEXHHAAVTRequestStatus@@@Z @ 5 NONAME ; void RMenuNotifier::Notify(int, int, class TRequestStatus &) + ?SetAttributeL@CMenuItem@@QAEXABVTDesC16@@0@Z @ 6 NONAME ; void CMenuItem::SetAttributeL(class TDesC16 const &, class TDesC16 const &) + ?Close@RMenuNotifier@@QAEXXZ @ 7 NONAME ; void RMenuNotifier::Close(void) + ?RunningStatusL@CMenuItem@@QAEHXZ @ 8 NONAME ; int CMenuItem::RunningStatusL(void) + ?ResourceMark@RMenu@@QAEXXZ @ 9 NONAME ; void RMenu::ResourceMark(void) + ?OpenL@RMenu@@QAEXABVTDesC16@@@Z @ 10 NONAME ; void RMenu::OpenL(class TDesC16 const &) + ?GetRunningAppsL@RMenu@@QAEXAAV?$RArray@VTUid@@@@@Z @ 11 NONAME ; void RMenu::GetRunningAppsL(class RArray &) ?Flags@CMenuItem@@QBEKXZ @ 12 NONAME ; unsigned long CMenuItem::Flags(void) const - ?FlagsOff@CMenuFilter@@QBEKXZ @ 13 NONAME ; unsigned long CMenuFilter::FlagsOff(void) const + ?Reset@CMenuFilter@@QAEXXZ @ 13 NONAME ; void CMenuFilter::Reset(void) ?FlagsOn@CMenuFilter@@QBEKXZ @ 14 NONAME ; unsigned long CMenuFilter::FlagsOn(void) const - ?GetAttribute@CMenuFilter@@QBEHHAAVTPtrC16@@0@Z @ 15 NONAME ; int CMenuFilter::GetAttribute(int, class TPtrC16 &, class TPtrC16 &) const - ?GetAttributeL@CMenuItem@@QAE?AVTPtrC16@@ABVTDesC16@@AAH@Z @ 16 NONAME ; class TPtrC16 CMenuItem::GetAttributeL(class TDesC16 const &, int &) - ?GetAttributeListL@CMenuItem@@QAEXAAV?$RArray@V?$TBuf@$0EA@@@@@@Z @ 17 NONAME ; void CMenuItem::GetAttributeListL(class RArray > &) - ?GetItemsL@RMenu@@QAEXAAV?$RArray@VTMenuItem@@@@HPBVCMenuFilter@@H@Z @ 18 NONAME ; void RMenu::GetItemsL(class RArray &, int, class CMenuFilter const *, int) - ?GetRunningAppsL@RMenu@@QAEXAAV?$RArray@VTUid@@@@@Z @ 19 NONAME ; void RMenu::GetRunningAppsL(class RArray &) - ?HandleCommandL@CMenuHandler@@UAEPAVCMenuOperation@@AAVCMenuItem@@ABVTDesC8@@1AAVTRequestStatus@@@Z @ 20 NONAME ; class CMenuOperation * CMenuHandler::HandleCommandL(class CMenuItem &, class TDesC8 const &, class TDesC8 const &, class TRequestStatus &) - ?HandleCommandL@CMenuItem@@QAEPAVCMenuOperation@@ABVTDesC8@@0AAVTRequestStatus@@@Z @ 21 NONAME ; class CMenuOperation * CMenuItem::HandleCommandL(class TDesC8 const &, class TDesC8 const &, class TRequestStatus &) - ?HaveAttributeL@CMenuFilter@@QAEXABVTDesC16@@0@Z @ 22 NONAME ; void CMenuFilter::HaveAttributeL(class TDesC16 const &, class TDesC16 const &) - ?Id@CMenuItem@@QBEHXZ @ 23 NONAME ; int CMenuItem::Id(void) const - ?MoveToFolderL@RMenu@@QAEPAVCMenuOperation@@ABV?$RArray@H@@HHAAVTRequestStatus@@@Z @ 24 NONAME ; class CMenuOperation * RMenu::MoveToFolderL(class RArray const &, int, int, class TRequestStatus &) - ?NewL@CMcsCacheHandler@@SAPAV1@AAVCMenuEng@@AAVCMenuSrvEngUtils@@@Z @ 25 NONAME ; class CMcsCacheHandler * CMcsCacheHandler::NewL(class CMenuEng &, class CMenuSrvEngUtils &) - ?NewL@CMcsSatMonitor@@SAPAV1@AAVCMenuEng@@@Z @ 26 NONAME ; class CMcsSatMonitor * CMcsSatMonitor::NewL(class CMenuEng &) - ?NewL@CMenuCompletedOperation@@SAPAV1@AAVRMenu@@HAAVTRequestStatus@@H@Z @ 27 NONAME ; class CMenuCompletedOperation * CMenuCompletedOperation::NewL(class RMenu &, int, class TRequestStatus &, int) - ?NewL@CMenuFilter@@SAPAV1@XZ @ 28 NONAME ; class CMenuFilter * CMenuFilter::NewL(void) - ?NewLC@CMenuFilter@@SAPAV1@XZ @ 29 NONAME ; class CMenuFilter * CMenuFilter::NewLC(void) - ?Notify@RMenuNotifier@@QAEXHHAAVTRequestStatus@@@Z @ 30 NONAME ; void RMenuNotifier::Notify(int, int, class TRequestStatus &) - ?NumAttributes@CMenuFilter@@QBEHXZ @ 31 NONAME ; int CMenuFilter::NumAttributes(void) const - ?Open@RMenuNotifier@@QAEHAAVRMenu@@@Z @ 32 NONAME ; int RMenuNotifier::Open(class RMenu &) - ?OpenL@CMenuItem@@SAPAV1@AAVRMenu@@ABVTMenuItem@@@Z @ 33 NONAME ; class CMenuItem * CMenuItem::OpenL(class RMenu &, class TMenuItem const &) - ?OpenL@CMenuItem@@SAPAV1@AAVRMenu@@H@Z @ 34 NONAME ; class CMenuItem * CMenuItem::OpenL(class RMenu &, int) - ?OpenL@RMenu@@QAEXABVTDesC16@@@Z @ 35 NONAME ; void RMenu::OpenL(class TDesC16 const &) - ?Parent@CMenuItem@@QBEHXZ @ 36 NONAME ; int CMenuItem::Parent(void) const - ?RemoveAttribute@CMenuFilter@@QAEXABVTDesC16@@@Z @ 37 NONAME ; void CMenuFilter::RemoveAttribute(class TDesC16 const &) - ?RemoveAttributeL@CMenuItem@@QAEXABVTDesC16@@@Z @ 38 NONAME ; void CMenuItem::RemoveAttributeL(class TDesC16 const &) + ?SetFlags@CMenuItem@@QAEXKH@Z @ 15 NONAME ; void CMenuItem::SetFlags(unsigned long, int) + ?NewL@CMcsSatMonitor@@SAPAV1@AAVCMenuEng@@@Z @ 16 NONAME ; class CMcsSatMonitor * CMcsSatMonitor::NewL(class CMenuEng &) + ?MoveToFolderL@RMenu@@QAEPAVCMenuOperation@@ABV?$RArray@H@@HHAAVTRequestStatus@@@Z @ 17 NONAME ; class CMenuOperation * RMenu::MoveToFolderL(class RArray const &, int, int, class TRequestStatus &) + ?Type@CMenuFilter@@QBE?AVTPtrC16@@XZ @ 18 NONAME ; class TPtrC16 CMenuFilter::Type(void) const + ?ResourceCount@RMenu@@QAEHXZ @ 19 NONAME ; int RMenu::ResourceCount(void) + ?SetFlags@CMenuFilter@@QAEXKK@Z @ 20 NONAME ; void CMenuFilter::SetFlags(unsigned long, unsigned long) + ?RunMenuServer@@YAHXZ @ 21 NONAME ; int RunMenuServer(void) + ?NewLC@CMenuFilter@@SAPAV1@XZ @ 22 NONAME ; class CMenuFilter * CMenuFilter::NewLC(void) + ?BaseConstructL@CMenuHandler@@IAEXXZ @ 23 NONAME ; void CMenuHandler::BaseConstructL(void) + ?SetType@CMenuFilter@@QAEXABVTDesC16@@@Z @ 24 NONAME ; void CMenuFilter::SetType(class TDesC16 const &) + ?NumAttributes@CMenuFilter@@QBEHXZ @ 25 NONAME ; int CMenuFilter::NumAttributes(void) const + ?Id@CMenuItem@@QBEHXZ @ 26 NONAME ; int CMenuItem::Id(void) const + ?RemoveAttributeL@CMenuItem@@QAEXABVTDesC16@@@Z @ 27 NONAME ; void CMenuItem::RemoveAttributeL(class TDesC16 const &) + ?Parent@CMenuItem@@QBEHXZ @ 28 NONAME ; int CMenuItem::Parent(void) const + ?NewL@CMenuFilter@@SAPAV1@XZ @ 29 NONAME ; class CMenuFilter * CMenuFilter::NewL(void) + ?ReorderL@RMenu@@QAEPAVCMenuOperation@@HHAAVTRequestStatus@@@Z @ 30 NONAME ; class CMenuOperation * RMenu::ReorderL(int, int, class TRequestStatus &) + ?RemoveAttribute@CMenuFilter@@QAEXABVTDesC16@@@Z @ 31 NONAME ; void CMenuFilter::RemoveAttribute(class TDesC16 const &) + ?Type@CMenuItem@@QBE?AVTPtrC16@@XZ @ 32 NONAME ; class TPtrC16 CMenuItem::Type(void) const + ?HandleCommandL@CMenuItem@@QAEPAVCMenuOperation@@ABVTDesC8@@0AAVTRequestStatus@@@Z @ 33 NONAME ; class CMenuOperation * CMenuItem::HandleCommandL(class TDesC8 const &, class TDesC8 const &, class TRequestStatus &) + ?ResourceCheck@RMenu@@QAEXXZ @ 34 NONAME ; void RMenu::ResourceCheck(void) + ?HandleCommandL@CMenuHandler@@UAEPAVCMenuOperation@@AAVCMenuItem@@ABVTDesC8@@1AAVTRequestStatus@@@Z @ 35 NONAME ; class CMenuOperation * CMenuHandler::HandleCommandL(class CMenuItem &, class TDesC8 const &, class TDesC8 const &, class TRequestStatus &) + ?Cancel@RMenuNotifier@@QAEXXZ @ 36 NONAME ; void RMenuNotifier::Cancel(void) + ??1CMenuItem@@UAE@XZ @ 37 NONAME ; CMenuItem::~CMenuItem(void) + ?GetAttributeL@CMenuItem@@QAE?AVTPtrC16@@ABVTDesC16@@AAH@Z @ 38 NONAME ; class TPtrC16 CMenuItem::GetAttributeL(class TDesC16 const &, int &) ?RemoveL@RMenu@@QAEPAVCMenuOperation@@HAAVTRequestStatus@@@Z @ 39 NONAME ; class CMenuOperation * RMenu::RemoveL(int, class TRequestStatus &) - ?ReorderL@RMenu@@QAEPAVCMenuOperation@@HHAAVTRequestStatus@@@Z @ 40 NONAME ; class CMenuOperation * RMenu::ReorderL(int, int, class TRequestStatus &) - ?Reset@CMenuFilter@@QAEXXZ @ 41 NONAME ; void CMenuFilter::Reset(void) - ?ResourceCheck@RMenu@@QAEXXZ @ 42 NONAME ; void RMenu::ResourceCheck(void) - ?ResourceCount@RMenu@@QAEHXZ @ 43 NONAME ; int RMenu::ResourceCount(void) - ?ResourceMark@RMenu@@QAEXXZ @ 44 NONAME ; void RMenu::ResourceMark(void) - ?RootFolderL@RMenu@@QAEHXZ @ 45 NONAME ; int RMenu::RootFolderL(void) - ?RunMenuServer@@YAHXZ @ 46 NONAME ; int RunMenuServer(void) - ?RunningStatusL@CMenuItem@@QAEHXZ @ 47 NONAME ; int CMenuItem::RunningStatusL(void) - ?SaveL@CMenuItem@@QAEPAVCMenuOperation@@AAVTRequestStatus@@@Z @ 48 NONAME ; class CMenuOperation * CMenuItem::SaveL(class TRequestStatus &) - ?SetAttributeL@CMenuItem@@QAEXABVTDesC16@@0@Z @ 49 NONAME ; void CMenuItem::SetAttributeL(class TDesC16 const &, class TDesC16 const &) - ?SetFlags@CMenuFilter@@QAEXKK@Z @ 50 NONAME ; void CMenuFilter::SetFlags(unsigned long, unsigned long) - ?SetFlags@CMenuItem@@QAEXKH@Z @ 51 NONAME ; void CMenuItem::SetFlags(unsigned long, int) - ?SetType@CMenuFilter@@QAEXABVTDesC16@@@Z @ 52 NONAME ; void CMenuFilter::SetType(class TDesC16 const &) - ?SupportsType@CMenuHandler@@UAEHABVTDesC16@@@Z @ 53 NONAME ; int CMenuHandler::SupportsType(class TDesC16 const &) - ?Type@CMenuFilter@@QBE?AVTPtrC16@@XZ @ 54 NONAME ; class TPtrC16 CMenuFilter::Type(void) const - ?Type@CMenuItem@@QBE?AVTPtrC16@@XZ @ 55 NONAME ; class TPtrC16 CMenuItem::Type(void) const - ?__DbgSetAllocFail@RMenu@@QAEXW4TAllocFail@RAllocator@@H@Z @ 56 NONAME ; void RMenu::__DbgSetAllocFail(enum RAllocator::TAllocFail, int) - ?GetListL@RMenuSapi@@QAEXAAVTDes8@@AAVRBuf8@@@Z @ 57 NONAME ; void RMenuSapi::GetListL(class TDes8 &, class RBuf8 &) + ?NewL@CMenuCompletedOperation@@SAPAV1@AAVRMenu@@HAAVTRequestStatus@@H@Z @ 40 NONAME ; class CMenuCompletedOperation * CMenuCompletedOperation::NewL(class RMenu &, int, class TRequestStatus &, int) + ?OpenL@CMenuItem@@SAPAV1@AAVRMenu@@H@Z @ 41 NONAME ; class CMenuItem * CMenuItem::OpenL(class RMenu &, int) + ?GetAttributeListL@CMenuItem@@QAEXAAV?$RArray@V?$TBuf@$0EA@@@@@@Z @ 42 NONAME ; void CMenuItem::GetAttributeListL(class RArray > &) + ?Close@RMenu@@QAEXXZ @ 43 NONAME ; void RMenu::Close(void) + ?CreateL@CMenuItem@@SAPAV1@AAVRMenu@@ABVTDesC16@@HH@Z @ 44 NONAME ; class CMenuItem * CMenuItem::CreateL(class RMenu &, class TDesC16 const &, int, int) + ??1CMenuFilter@@UAE@XZ @ 45 NONAME ; CMenuFilter::~CMenuFilter(void) + ??0CMenuHandler@@IAE@AAVRMenu@@@Z @ 46 NONAME ; CMenuHandler::CMenuHandler(class RMenu &) + ?GetItemsL@RMenu@@QAEXAAV?$RArray@VTMenuItem@@@@HPBVCMenuFilter@@H@Z @ 47 NONAME ; void RMenu::GetItemsL(class RArray &, int, class CMenuFilter const *, int) + ?__DbgSetAllocFail@RMenu@@QAEXW4TAllocFail@RAllocator@@H@Z @ 48 NONAME ; void RMenu::__DbgSetAllocFail(enum RAllocator::TAllocFail, int) + ?FlagsOff@CMenuFilter@@QBEKXZ @ 49 NONAME ; unsigned long CMenuFilter::FlagsOff(void) const + ?GetListL@RMenuSapi@@QAEXAAVTDes8@@AAVRBuf8@@@Z @ 50 NONAME ; void RMenuSapi::GetListL(class TDes8 &, class RBuf8 &) + ?DoNotHaveAttributeL@CMenuFilter@@QAEXABVTDesC16@@@Z @ 51 NONAME ; void CMenuFilter::DoNotHaveAttributeL(class TDesC16 const &) + ??1CMenuHandler@@UAE@XZ @ 52 NONAME ; CMenuHandler::~CMenuHandler(void) + ??1CMenuCompletedOperation@@UAE@XZ @ 53 NONAME ; CMenuCompletedOperation::~CMenuCompletedOperation(void) + ?RootFolderL@RMenu@@QAEHXZ @ 54 NONAME ; int RMenu::RootFolderL(void) + ?OpenL@CMenuItem@@SAPAV1@AAVRMenu@@ABVTMenuItem@@@Z @ 55 NONAME ; class CMenuItem * CMenuItem::OpenL(class RMenu &, class TMenuItem const &) + ?SaveL@CMenuItem@@QAEPAVCMenuOperation@@AAVTRequestStatus@@@Z @ 56 NONAME ; class CMenuOperation * CMenuItem::SaveL(class TRequestStatus &) + ?NewL@CMcsCacheHandler@@SAPAV1@AAVCMenuEng@@AAVCMenuSrvEngUtils@@@Z @ 57 NONAME ; class CMcsCacheHandler * CMcsCacheHandler::NewL(class CMenuEng &, class CMenuSrvEngUtils &) diff -r 3310e4b0dae0 -r 8a75bf74485c menucontentsrv/eabi/mcsmenuengu.def --- a/menucontentsrv/eabi/mcsmenuengu.def Tue May 18 16:21:42 2010 +0100 +++ b/menucontentsrv/eabi/mcsmenuengu.def Fri May 28 13:36:52 2010 +0100 @@ -1,9 +1,9 @@ EXPORTS - _ZN14CMenuEngObject13SetAttributeLERK7TDesC16S2_i @ 1 NONAME - _ZN14CMenuEngObject15RemoveAttributeERK7TDesC16 @ 2 NONAME - _ZN14CMenuEngObject5ResetEv @ 3 NONAME - _ZN14CMenuEngObject8SetFlagsEmi @ 4 NONAME - _ZN14CMenuEngObject9SetNativeEi @ 5 NONAME + _ZN14CMenuEngObject10SetAppTypeENS_8TAppTypeE @ 1 NONAME + _ZN14CMenuEngObject13SetAttributeLERK7TDesC16S2_i @ 2 NONAME + _ZN14CMenuEngObject15RemoveAttributeERK7TDesC16 @ 3 NONAME + _ZN14CMenuEngObject5ResetEv @ 4 NONAME + _ZN14CMenuEngObject8SetFlagsEmi @ 5 NONAME _ZN14CMenuEngObjectD0Ev @ 6 NONAME _ZN14CMenuEngObjectD1Ev @ 7 NONAME _ZN14CMenuEngObjectD2Ev @ 8 NONAME @@ -21,12 +21,12 @@ _ZN8CMenuEngD0Ev @ 20 NONAME _ZN8CMenuEngD1Ev @ 21 NONAME _ZN8CMenuEngD2Ev @ 22 NONAME - _ZNK14CMenuEngObject12GetAttributeEiR7TPtrC16S1_Ri @ 23 NONAME - _ZNK14CMenuEngObject13FindAttributeERK7TDesC16R7TPtrC16Ri @ 24 NONAME - _ZNK14CMenuEngObject2IdEv @ 25 NONAME - _ZNK14CMenuEngObject4TypeEv @ 26 NONAME - _ZNK14CMenuEngObject5FlagsEi @ 27 NONAME - _ZNK14CMenuEngObject9GetNativeEv @ 28 NONAME + _ZNK14CMenuEngObject10GetAppTypeEv @ 23 NONAME + _ZNK14CMenuEngObject12GetAttributeEiR7TPtrC16S1_Ri @ 24 NONAME + _ZNK14CMenuEngObject13FindAttributeERK7TDesC16R7TPtrC16Ri @ 25 NONAME + _ZNK14CMenuEngObject2IdEv @ 26 NONAME + _ZNK14CMenuEngObject4TypeEv @ 27 NONAME + _ZNK14CMenuEngObject5FlagsEi @ 28 NONAME _ZNK8CMenuEng11RootFolderLERi @ 29 NONAME _ZNK8CMenuEng13ParentFolderLEiRi @ 30 NONAME _ZNK8CMenuEng15TraverseFolderLEiR15MMenuEngVisitor @ 31 NONAME diff -r 3310e4b0dae0 -r 8a75bf74485c menucontentsrv/eabi/mcsmenuu.def --- a/menucontentsrv/eabi/mcsmenuu.def Tue May 18 16:21:42 2010 +0100 +++ b/menucontentsrv/eabi/mcsmenuu.def Fri May 28 13:36:52 2010 +0100 @@ -65,20 +65,20 @@ _ZNK9CMenuItem4TypeEv @ 64 NONAME _ZNK9CMenuItem5FlagsEv @ 65 NONAME _ZNK9CMenuItem6ParentEv @ 66 NONAME - _ZTI12CMenuHandler @ 67 NONAME ; ## - _ZTI18TMenuSrvAttrFilter @ 68 NONAME ; ## - _ZTI18TMenuSrvTypeFilter @ 69 NONAME ; ## - _ZTI22RMcsDrmObserverManager @ 70 NONAME ; ## - _ZTI22TMenuSrvTypeAttrFilter @ 71 NONAME ; ## - _ZTI23TMenuSrvHiddenAppFilter @ 72 NONAME ; ## - _ZTI24TMenuSrvAttrExistsFilter @ 73 NONAME ; ## - _ZTI28TMenuSrvTypeAttrExistsFilter @ 74 NONAME ; ## - _ZTV12CMenuHandler @ 75 NONAME ; ## - _ZTV18TMenuSrvAttrFilter @ 76 NONAME ; ## - _ZTV18TMenuSrvTypeFilter @ 77 NONAME ; ## - _ZTV22RMcsDrmObserverManager @ 78 NONAME ; ## - _ZTV22TMenuSrvTypeAttrFilter @ 79 NONAME ; ## - _ZTV23TMenuSrvHiddenAppFilter @ 80 NONAME ; ## - _ZTV24TMenuSrvAttrExistsFilter @ 81 NONAME ; ## - _ZTV28TMenuSrvTypeAttrExistsFilter @ 82 NONAME ; ## + _ZTI12CMenuHandler @ 67 NONAME + _ZTI18TMenuSrvAttrFilter @ 68 NONAME + _ZTI18TMenuSrvTypeFilter @ 69 NONAME + _ZTI22RMcsDrmObserverManager @ 70 NONAME + _ZTI22TMenuSrvTypeAttrFilter @ 71 NONAME + _ZTI23TMenuSrvHiddenAppFilter @ 72 NONAME + _ZTI24TMenuSrvAttrExistsFilter @ 73 NONAME + _ZTI28TMenuSrvTypeAttrExistsFilter @ 74 NONAME + _ZTV12CMenuHandler @ 75 NONAME + _ZTV18TMenuSrvAttrFilter @ 76 NONAME + _ZTV18TMenuSrvTypeFilter @ 77 NONAME + _ZTV22RMcsDrmObserverManager @ 78 NONAME + _ZTV22TMenuSrvTypeAttrFilter @ 79 NONAME + _ZTV23TMenuSrvHiddenAppFilter @ 80 NONAME + _ZTV24TMenuSrvAttrExistsFilter @ 81 NONAME + _ZTV28TMenuSrvTypeAttrExistsFilter @ 82 NONAME diff -r 3310e4b0dae0 -r 8a75bf74485c menucontentsrv/eabi/mcssathandleru.def --- a/menucontentsrv/eabi/mcssathandleru.def Tue May 18 16:21:42 2010 +0100 +++ b/menucontentsrv/eabi/mcssathandleru.def Fri May 28 13:36:52 2010 +0100 @@ -4,6 +4,6 @@ _ZN14CMcsSatHandler7GetNameER6TDes16 @ 3 NONAME _ZN14CMcsSatHandler9LoadIconLEv @ 4 NONAME _ZN15CMcsSatNotifier4NewLEP23MMcsSATNotifierCallback4TUidj @ 5 NONAME - _ZTI15CMcsSatNotifier @ 6 NONAME ; ## - _ZTV15CMcsSatNotifier @ 7 NONAME ; ## + _ZTI15CMcsSatNotifier @ 6 NONAME + _ZTV15CMcsSatNotifier @ 7 NONAME diff -r 3310e4b0dae0 -r 8a75bf74485c menucontentsrv/enginc/menuengobject.h --- a/menucontentsrv/enginc/menuengobject.h Tue May 18 16:21:42 2010 +0100 +++ b/menucontentsrv/enginc/menuengobject.h Fri May 28 13:36:52 2010 +0100 @@ -42,6 +42,17 @@ public: // construction /** + * Enum indicating type of application. + */ + enum TAppType + { + ENoTypeApp, + ENativeApp, + EJavaApp, + EWidgetApp + }; + + /** * Destructor. */ IMPORT_C virtual ~CMenuEngObject(); @@ -144,19 +155,19 @@ const TDesC& aAttrName, const TDesC& aAttrValue, TBool aLocalized ); // Set attribute value. - + /** * Method to set iNative for apps. */ - IMPORT_C void SetNative( TBool aNative ); + IMPORT_C void SetAppType( TAppType aNative ); /** * Method to get iNative for apps. * @return ETrue if app is native. */ - IMPORT_C TBool GetNative() const; + IMPORT_C TAppType GetAppType() const; - + /** * Remove attribute. * @param aAttrName Name. @@ -197,30 +208,30 @@ * @return Type identifier. */ const TDesC& TypeIdentifier(); - - /** + + /** * Updates flags with hidden flag from central repository if nececerry. * @param aFlags flags. - */ + */ void UpdateCrHiddenFlagL( TUint32& aFlags ) const; - /** + /** * Parses descriptor containing folders hidden in central repository. * @param aHiddenFolders descriptor containing folders hidden in central repository. * @param aHiddenFoldersArray array to fill with names of folders hidden in central repository. - */ - void ParseHiddenFoldersL( - const TDesC& aHiddenFolders, + */ + void ParseHiddenFoldersL( + const TDesC& aHiddenFolders, RArray& aHiddenFoldersArray ) const; - /** + /** * Checks wether folder name is in Central Repository. * @param aFolderName descriptor containing name of a folder. * @return ETrue if folder is in array, EFalse otherwise. - */ + */ TBool IsInCrL( const TDesC& aFolderName ) const; - + private: // data @@ -229,7 +240,7 @@ RBuf iType; /// Type. Own. RMenuEngObjectAttrArray iAttributes; ///< Attributes. Own. TUint32 iFlags; ///< Flags. - TBool iNative; ///< app is not of midlet/java type + TAppType iAppType; ///< app type }; diff -r 3310e4b0dae0 -r 8a75bf74485c menucontentsrv/engsrc/menuengobject.cpp --- a/menucontentsrv/engsrc/menuengobject.cpp Tue May 18 16:21:42 2010 +0100 +++ b/menucontentsrv/engsrc/menuengobject.cpp Fri May 28 13:36:52 2010 +0100 @@ -81,7 +81,8 @@ // CMenuEngObject::CMenuEngObject // --------------------------------------------------------- // -CMenuEngObject::CMenuEngObject( CMenuEng& aEng ): iEng( aEng ), iNative( ETrue ) +CMenuEngObject::CMenuEngObject( CMenuEng& aEng ): iEng( aEng ), + iAppType( ENoTypeApp ) { } @@ -143,30 +144,30 @@ // CMenuEngObject::ParseHiddenFoldersL // --------------------------------------------------------- // -void CMenuEngObject::ParseHiddenFoldersL( - const TDesC& aHiddenFolders, +void CMenuEngObject::ParseHiddenFoldersL( + const TDesC& aHiddenFolders, RArray& aHiddenFoldersArray ) const { TLex input( aHiddenFolders ); TLexMark startMark; - input.Mark( startMark ); + input.Mark( startMark ); TBool notEmpty = EFalse; while ( !input.Eos() ) { if( input.Peek() == ',') { User::LeaveIfError( aHiddenFoldersArray. - Append( input.MarkedToken( startMark ) ) ); + Append( input.MarkedToken( startMark ) ) ); input.Inc(); input.Mark( startMark ); } - input.Inc(); - notEmpty = ETrue; + input.Inc(); + notEmpty = ETrue; } if ( notEmpty ) { User::LeaveIfError( aHiddenFoldersArray. - Append( input.MarkedToken( startMark ) ) ); + Append( input.MarkedToken( startMark ) ) ); } } @@ -179,15 +180,15 @@ RBuf hiddenCRFolders; CleanupClosePushL( hiddenCRFolders ); hiddenCRFolders.CreateL( KCenRepBufferSize ); - + CRepository* cenRepSession = CRepository::NewLC( KCRUidMenu ); cenRepSession->Get( KMenuHideCPFolder, hiddenCRFolders ); CleanupStack::PopAndDestroy( cenRepSession ); - + RArray hiddenFoldersArray; CleanupClosePushL( hiddenFoldersArray ); ParseHiddenFoldersL( hiddenCRFolders, hiddenFoldersArray ); - + TBool result(EFalse); TInt id = hiddenFoldersArray.Find(aFolderName); if (KErrNotFound != id ) @@ -199,7 +200,7 @@ result = ETrue; } } - + CleanupStack::PopAndDestroy( &hiddenFoldersArray ); CleanupStack::PopAndDestroy( &hiddenCRFolders ); @@ -278,10 +279,10 @@ // ---------------------------------------------------------------------------- // CMenuEngObject::SetAttributeL -// Menu item lock flags are checked (e.g. can rename), but only when the +// Menu item lock flags are checked (e.g. can rename), but only when the // current SetAttributeL call is not made from the object factories. // If it is called from there, no flags checking is made. -// This method is called from object factories when the engine is in +// This method is called from object factories when the engine is in // ELoadRamFile or ELoadRomFile states. // ---------------------------------------------------------------------------- // @@ -297,12 +298,12 @@ ( const TDesC& aAttrName, const TDesC& aAttrValue, TBool aLocalized ) { CheckAttrNameL( aAttrName ); - - if ( iEng.State() != CMenuEng::ELoadRamFile && + + if ( iEng.State() != CMenuEng::ELoadRamFile && iEng.State() != CMenuEng::ELoadRomFile && - Flags() & TMenuItem::ELockName && - ( 0 == aAttrName.Compare( KMenuAttrShortName ) || - 0 == aAttrName.Compare( KMenuAttrLongName ) || + Flags() & TMenuItem::ELockName && + ( 0 == aAttrName.Compare( KMenuAttrShortName ) || + 0 == aAttrName.Compare( KMenuAttrLongName ) || 0 == aAttrName.Compare( KMenuAttrTitleName ) ) ) { User::Leave( KErrAccessDenied ); @@ -329,18 +330,18 @@ // CMenuEngObject::SetNative // --------------------------------------------------------- // -EXPORT_C void CMenuEngObject::SetNative( TBool aNative ) +EXPORT_C void CMenuEngObject::SetAppType( TAppType aAppType ) { - iNative = aNative; + iAppType = aAppType; } // --------------------------------------------------------- // CMenuEngObject::GetNative // --------------------------------------------------------- // -EXPORT_C TBool CMenuEngObject::GetNative() const +EXPORT_C CMenuEngObject::TAppType CMenuEngObject::GetAppType() const { - return iNative; + return iAppType; } // --------------------------------------------------------- @@ -395,4 +396,4 @@ return iType; } -// End of File +// End of File diff -r 3310e4b0dae0 -r 8a75bf74485c menucontentsrv/group/mcsmenu.mmp --- a/menucontentsrv/group/mcsmenu.mmp Tue May 18 16:21:42 2010 +0100 +++ b/menucontentsrv/group/mcsmenu.mmp Fri May 28 13:36:52 2010 +0100 @@ -12,7 +12,7 @@ * Contributors: * * Description: -* Version : %version: sa1spcx1#11.1.7.1.6 % << Don't touch! Updated by Synergy at check-out. +* Version : %version: sa1spcx1#11.1.7.1.7 % << Don't touch! Updated by Synergy at check-out. * */ @@ -56,6 +56,7 @@ SOURCE menusrvstream.cpp SOURCE menusrveng.cpp SOURCE menusrvengutils.cpp +SOURCE menusrvappattributes.cpp SOURCE timeout.cpp SOURCE menusrvappscanner.cpp SOURCE menusrvfoldercrnotifier.cpp @@ -72,23 +73,24 @@ SOURCE mcsdrmobserver.cpp SOURCE mcsdrmscanner.cpp SOURCE mcsdrmobservermanager.cpp -SOURCE mcschildrenhandler.cpp -SOURCE mcschildrenscanner.cpp +SOURCE mcschildrenhandler.cpp +SOURCE mcschildrenscanner.cpp +SOURCE menusrvtypefilters.cpp -SOURCE mcsmmcobserver.cpp +SOURCE mcsmmcobserver.cpp SOURCE mcsfreespaceobserver.cpp -SOURCE mcsinstallnotifier.cpp -SOURCE mcssuiteobjectattr.cpp -SOURCE mcssuiteobject.cpp -SOURCE mcssuiteobjectfactory.cpp -SOURCE mcssuiteparser.cpp -SOURCE menusvrsuite.cpp -SOURCE mcssuitehandler.cpp +SOURCE mcsinstallnotifier.cpp +SOURCE mcssuiteobjectattr.cpp +SOURCE mcssuiteobject.cpp +SOURCE mcssuiteobjectfactory.cpp +SOURCE mcssuiteparser.cpp +SOURCE menusvrsuite.cpp +SOURCE mcssuitehandler.cpp SOURCE mcsgetlistcreatorinterface.cpp SOURCE mcsgetlisthandler.cpp -SOURCE mcsgetlistflatcreator.cpp -SOURCE mcsgetlisttreecreator.cpp +SOURCE mcsgetlistflatcreator.cpp +SOURCE mcsgetlisttreecreator.cpp USERINCLUDE ../inc @@ -128,3 +130,4 @@ LIBRARY liwServiceHandler.lib LIBRARY xcfw.lib + diff -r 3310e4b0dae0 -r 8a75bf74485c menucontentsrv/srvinc/mcsrunningappshandler.h --- a/menucontentsrv/srvinc/mcsrunningappshandler.h Tue May 18 16:21:42 2010 +0100 +++ b/menucontentsrv/srvinc/mcsrunningappshandler.h Fri May 28 13:36:52 2010 +0100 @@ -11,8 +11,8 @@ * * Contributors: * -* Description: This class maintains a list of the running apps, and listen -* for changes in the running apps. It calls the observer if there is such a +* Description: This class maintains a list of the running apps, and listen +* for changes in the running apps. It calls the observer if there is such a * change. * * @@ -37,6 +37,103 @@ class CMcsRunningAppsHiddenAttrScanner; class CMcsRunningAppsAddRemoveHandler; + +/* +* +*/ +class TRunningAppsAttr + { +public: + /* + * + */ + TRunningAppsAttr ( TUid aUid, TBool aFswHidden = EFalse, + TBool aHidden = EFalse, TBool aIsRunning = EFalse ) + { + iUid = aUid; + iHidden = aHidden; + iFswHidden = aFswHidden; + iIsRunning = aIsRunning; + } + + /* + * + */ + TUid GetUid() const + { + return iUid; + } + + /* + * + */ + TBool IsHidden() const + { + return iHidden; + } + + /* + * + */ + void SetHidden( TBool aHidden ) + { + iHidden = aHidden; + } + + /* + * + */ + TBool IsFswHidden() const + { + return iFswHidden; + } + + /* + * + */ + void SetFswHidden( TBool aFswHidden ) + { + iFswHidden = aFswHidden; + } + + + /* + * + */ + TBool IsRunning() const + { + return iIsRunning; + } + + /* + * + */ + void SetRunning( TBool aIsRunning ) + { + iIsRunning = aIsRunning; + } + + /* + * + */ + static TBool MatchByUid( const TRunningAppsAttr& aArg1, + const TRunningAppsAttr& aArg2) + { + return aArg1.GetUid() == aArg2.GetUid(); + } + +private: // data + + TUid iUid; + TBool iHidden; + TBool iFswHidden; + TBool iIsRunning; + + }; + + + + /** * Interface for updating RunningApps list stored in CMcsRunningAppsHandler class * @@ -52,21 +149,21 @@ EHiddenApps }; /* - * Called by HiddenAttr scanner, FSW monitor or WindowsGroup + * Called by HiddenAttr scanner, FSW monitor or WindowsGroup * Monitor. * @param aArray an array containing UIDs of running, hidden or - * fsw apps - * @param aType type of data stored in aArray + * fsw apps + * @param aType type of data stored in aArray */ - virtual void HandleListUpdateL(const RArray& aArray, + virtual void HandleListUpdateL(const RArray& aArray, TArrayDataType aType ) = 0; - + /* * Called by AddRemoveHandler * @param aFolder id of folder for which the method was invoked */ virtual void HandleAddRemoveRunningAppL( TInt aFolder ) = 0; - + }; /* @@ -81,7 +178,7 @@ /** * Factory method. */ - static CMcsRunningAppsHandler* NewL( + static CMcsRunningAppsHandler* NewL( CMenuEng& aEng, CMcsCacheHandler& aCacheHandler ); @@ -89,7 +186,7 @@ * Destructor. */ ~CMcsRunningAppsHandler(); - + /** * Called by EngineEvents method * @param aFolder folder id @@ -103,7 +200,7 @@ * @param aEvents events */ void EngineEvents( TInt aFolder, TInt aEvents ); - + /** * Fills aArray with UIDs of running apps * @param aArray array to be filled with UIDs of running apps @@ -114,18 +211,18 @@ * Returns running status of an item * @param aItemId id of the item * @return running status of an item - */ + */ TBool GetRunningStatusL( TInt aItemId ); - + // from MMcsRunningAppsHandler - + /* - * Called by HiddenAttr scanner, FSW monitor or WindowsGroup + * Called by HiddenAttr scanner, FSW monitor or WindowsGroup * Monitor. * @param aArray an array containing UIDs of running, hidden or - * fsw apps - * @param aType type of data stored in aArray + * fsw apps + * @param aType type of data stored in aArray */ void HandleListUpdateL(const RArray& aArray, TArrayDataType aType ); @@ -133,14 +230,14 @@ * Called by AddRemoveHandler * @param id of folder for which the method was invoked */ - void HandleAddRemoveRunningAppL( TInt aFolder ); + void HandleAddRemoveRunningAppL( TInt aFolder ); private: /** * Constructor. */ - CMcsRunningAppsHandler( - CMenuEng& aEng, + CMcsRunningAppsHandler( + CMenuEng& aEng, CMcsCacheHandler& aCacheHandler ); /** @@ -165,7 +262,7 @@ * @param aArray array with UIDs of hidden apps */ void HandleHiddenAppsChangedL(const RArray& aArray ); - + /** * Sends AttributeChange notification for item and parents of the item * it it is necessary, it is also responsible for removing data from cache @@ -181,7 +278,7 @@ * @param aAppUid uid of items with changed running status attribute */ void HandleNotificationL( TUid aAppUid ); - + /** * Gets list of items with secified uid * @param aAppUid items uid @@ -196,13 +293,13 @@ */ void UpdateFolderRunningStatusL( TInt aFolderId, TBool aNewRunningStatus ); - + /** * Updates array containing folders with running status. * It is called at startup and it scans all folders */ void UpdateFoldersRunningStatusL( ); - + /** * Gets running status for CMenuEngObject * @param aEngObj object to be checked @@ -213,19 +310,19 @@ /** * Gets previous Folder running status * @param aId id of the folder - * @return previous running status of a folder (stored in + * @return previous running status of a folder (stored in * iRunningFolderStatus array ) */ TBool GetFolderPreviousRunningStatusL( TInt aId ); - + /** * Gets current folder running status * @param aId id of the folder * @return running status of a folder */ TBool GetFolderRunningStatusL( TInt aId ); - + /** * Gets current application running status * @param aUid UID of an application @@ -233,14 +330,14 @@ */ TBool GetAppRunningStatusL( TUid aUid ); -private: +private: CMenuEng& iEng ; ///< Engine. not own /** not own */ CMcsCacheHandler& iCacheHandler; - + /* * own */ @@ -250,26 +347,26 @@ * own */ CMcsRunningAppsFswMonitor* iFswMonitor; - + /* * own */ - CMcsRunningAppsHiddenAttrScanner* iHiddenAttrScanner; - + CMcsRunningAppsHiddenAttrScanner* iHiddenAttrScanner; + /* - * own + * own */ CMcsRunningAppsAddRemoveHandler* iAddRemoveHandler; - + /* * own */ RArray iRunningApps; - + /* * own */ RArray iRunningFolderStatus; }; - + #endif // __MCSRUNNINGAPPSHANDLER_H__ diff -r 3310e4b0dae0 -r 8a75bf74485c menucontentsrv/srvinc/menusrvappattributes.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/menucontentsrv/srvinc/menusrvappattributes.h Fri May 28 13:36:52 2010 +0100 @@ -0,0 +1,151 @@ +/* +* Copyright (c) 2008 Nokia Corporation and/or its subsidiary(-ies). +* All rights reserved. +* This component and the accompanying materials are made available +* under the terms of "Eclipse Public License v1.0" +* which accompanies this distribution, and is available +* at the URL "http://www.eclipse.org/legal/epl-v10.html". +* +* Initial Contributors: +* Nokia Corporation - initial contribution. +* +* Contributors: +* +* Description: The API supports item information that is not supported by +* the MCS server itself +* +*/ + +#ifndef CMENUSRVAPPATTRIBUTES_H_ +#define CMENUSRVAPPATTRIBUTES_H_ + +#include +#include "menuengobject.h" + + +NONSHARABLE_CLASS( CMenuSrvAppAttributes ) : public CBase + { + +public: + + /** + * Two-phased constructor. + * @param aCapability application capability buffer. + * @param aAppInfo apparc application info. + */ + static CMenuSrvAppAttributes* NewL( TApaAppCapabilityBuf& aCapability, + TApaAppInfo& aAppInfo ); + + /** + * Two-phased constructor. + * @param aCapability application capability buffer. + * @param aAppInfo apparc application info. + */ + static CMenuSrvAppAttributes* NewLC( TApaAppCapabilityBuf& aCapability, + TApaAppInfo& aAppInfo ); + + /** + * Destructor. + */ + ~CMenuSrvAppAttributes(); + + /** + * Gets application uid. + * @return application uid. + */ + TUid GetUid() const; + + /** + * Gets hidden attribute of application. + * @return ETrue if application is hidden. + */ + TBool IsHidden() const; + + /** + * Sets hidden attribute of application. + * @param application hidden attribute. + */ + void SetHidden( TBool aAppIsHidden ); + + /** + * Sets application type. + * @param application type. + */ + void SetAppType( CMenuEngObject::TAppType aAppType ); + + /** + * Gets application type. + * @return application type. + */ + CMenuEngObject::TAppType GetAppType() const; + + /** + * Gets application group name. + * @return application group name. + */ + const TPtrC GetGroupName() const; + + /** + * Gets application full name. + * @return application full name. + */ + const TPtrC GetFullName() const; + + /** + * Gets application caption. + * @return application caption. + */ + const TPtrC GetCaption() const; + + /** + * Gets application short caption. + * @return application short caption. + */ + const TPtrC GetShortCaption() const; + + /** + * Match items function used for finding in array. + * @return ETrue if items match. + */ + static TBool MatchItems(const CMenuSrvAppAttributes& aItem1, + const CMenuSrvAppAttributes& aItem2); + +private: + + /** + * Second phased constructor. + * @param aCapability application capability buffer. + * @param aAppInfo apparc application info. + */ + void ConstructL( TApaAppCapabilityBuf& aCapability, + TApaAppInfo& aAppInfo ); + + /** + * Constructor. + */ + CMenuSrvAppAttributes(); + +private: // data + + RBuf iGroupName; // Series 60 extension to allow apps + //to be categorized according a logical group name, e.g. 'games' + + /** The full path name of the application DLL. */ + RBuf iFullName; + + /** The caption for the application. */ + RBuf iCaption; + + /** The short caption for the application. */ + RBuf iShortCaption; + + /** The application specific UID. */ + TUid iUid; + + /** The application type see TAppType. */ + CMenuEngObject::TAppType iAppType; + + TBool iAppIsHidden; // not shown in the Shell etc. + }; + +#endif /* CMENUSRVAPPATTRIBUTES_H_ */ diff -r 3310e4b0dae0 -r 8a75bf74485c menucontentsrv/srvinc/menusrvappscanner.h --- a/menucontentsrv/srvinc/menusrvappscanner.h Tue May 18 16:21:42 2010 +0100 +++ b/menucontentsrv/srvinc/menusrvappscanner.h Fri May 28 13:36:52 2010 +0100 @@ -33,11 +33,11 @@ // FORWARD DECLARATION class CMenuEng; -class TAppAtributes; +class CMenuSrvAppAttributes; class CMenuSrvMmcHistory; class CRepository; class CCenRepNotifyHandler; -class RWidgetRegistryClientSession; +class CMenuSrvEngUtils; /** * Application scanner. @@ -78,8 +78,9 @@ * Two-phased constructor. * @param aEng Engine. */ - static CMenuSrvAppScanner* NewL( CMenuEng& aEng ); - + static CMenuSrvAppScanner* NewL( + CMenuEng& aEng, + CMenuSrvEngUtils& aSrvEngUtils ); private: // Constructors and destructor @@ -87,7 +88,7 @@ * Constructor. * @param aEng Engine. */ - CMenuSrvAppScanner( CMenuEng& aEng ); + CMenuSrvAppScanner( CMenuEng& aEng, CMenuSrvEngUtils& aSrvEngUtils ); /** * Second phased constructor. @@ -166,7 +167,8 @@ /** */ - void HandleLockDeleteFlagUpdateL( const TMenuItem& aItem,TInt aUid ); + void HandleLockDeleteFlagUpdateL( + const TMenuItem& aItem, const CMenuSrvAppAttributes& aApaItem ); /** * Updates application's missing attribute. @@ -182,17 +184,16 @@ * @param aApaItemHidden Application's hidden status from ApaLsSession. */ void HandleHiddenFlagUpdateL( - const TMenuItem & aItem, - TInt & aAppUid, - TBool aApaItemHidden ); + const TMenuItem & aItem, + const CMenuSrvAppAttributes& aApaItem ); /** * Updates native attribute. * @param aItem menu item. * @param aUid Application's uid. */ void HandleNativeAttrUpdateL( - const TMenuItem& aItem, - TInt aUid ); + const TMenuItem& aItem, + const CMenuSrvAppAttributes& aApaItem ); /** * Updates mmc attribute. @@ -201,32 +202,24 @@ * @param aMmcId MMC ID of currently inserted MMC, or 0. */ void HandleMmcAttrUpdateL( - const TMenuItem& aItem, - TInt aUid, - TUint aMmcId ); - + const TMenuItem& aItem, + const CMenuSrvAppAttributes& aApaItem, + TUint aMmcId ); /** */ - TBool IsInRomL( TInt aUid ); - - /** - */ - void GetCrItemsL( RArray& aArray ); + void GetCrItemsL( RPointerArray& aArray ); /** */ void ParseUidsL( const TDesC& aHiddenApplications, - RArray& aArray ); - /** - */ - void GetApaItemsL( RArray& aArray ); + RPointerArray& aArray ); /** */ void SetHidden( const TDesC& aHiddenAppUid, - RArray& aArray ); + RPointerArray& aArray ); /** */ @@ -245,16 +238,10 @@ * @param aCurrentMmcId MMC ID of currently inserted MMC, or 0. */ void AddAppItemL( - TUint aUid, - TUint aCurrentMmcId ); - - TInt CreateInstallFolderL( TUint aUid ); + const CMenuSrvAppAttributes& aApaItem, + TUint aCurrentMmcId ); - /** - * @param aAppUid application UID - * @return TBool - */ - TBool IsMidlet( const TUid aAppUid ); + TInt CreateInstallFolderL( const CMenuSrvAppAttributes& aApaItem ); /** @@ -295,10 +282,10 @@ * @param aEvent menu item's event for engine. */ void SetObjectFlagsL( - TBool aFlagValue, - const TMenuItem& aItem, - const TMenuItem::TFlags& aFlag, - const RMenuNotifier::TEvent& aEvent = RMenuNotifier::EItemAttributeChanged ); + TBool aFlagValue, + const TMenuItem& aItem, + const TMenuItem::TFlags& aFlag, + const RMenuNotifier::TEvent& aEvent = RMenuNotifier::EItemAttributeChanged ); /** * Check currently inserted MMC card, update and save MMC history. @@ -318,8 +305,8 @@ * @return ETrue if aFileName is on given default drive type. */ TBool IsFileInDrive( - const TDesC& aFileName, - const DriveInfo::TDefaultDrives& aDefaultDrive ) const; + const TDesC& aFileName, + const DriveInfo::TDefaultDrives& aDefaultDrive ) const; /** * Check if application is installed on given drive type. @@ -327,23 +314,30 @@ * @param aDefaultDrive drive type. * @return ETrue if app is installed on given drive type. */ - TBool IsAppInDrive( - const TUid aUid, - const DriveInfo::TDefaultDrives& aDefaultDrive ) const; + TBool IsAppInDrive( + const CMenuSrvAppAttributes& aApaItem, + const DriveInfo::TDefaultDrives& aDefaultDrive ) const; /** * Check if application is installed on MMC. * @param aUid app uid. * @return ETrue if app is installed on MMC. */ - TBool IsMmcApp( const TUid aUid ) const; + TBool IsInMmc( const CMenuSrvAppAttributes& aApaItem ) const; /** * Check if application is installed on mass storage. * @param aUid app uid. * @return ETrue if app is installed on mass storage. */ - TBool IsMassStorageApp( const TUid aUid ) const; + TBool IsInMassStorage( const CMenuSrvAppAttributes& aApaItem ) const; + + /** + * Check if application is installed on ROM. + * @param aUid app uid. + * @return ETrue if app is installed on ROM. + */ + TBool IsInRomL( const CMenuSrvAppAttributes& aApaItem ) const; /** * Check if drive's status is EDriveInUse. @@ -393,7 +387,7 @@ */ void UpdateApplicationItemL( RArray& aMcsItems, - const TAppAtributes& aApaItem, + const CMenuSrvAppAttributes& aApaItem, TUint aMmcId, TBool isLegacy ); @@ -415,12 +409,11 @@ private: // data - CMenuEng& iEng ; ///< Engine. - RApaLsSession iApaLsSession; ///< AppArc session. Own. + CMenuEng& iEng; ///< Engine. + CMenuSrvEngUtils& iSrvEngUtils; ///< Server engine utils. CApaAppListNotifier* iNotifier; ///< Change notifier. Own. CMenuSrvMmcHistory* iMmcHistory; ///< MMC history. Own. RFs iFs; ///< File Server Session. Own. - RWidgetRegistryClientSession iWidgetSession;///