menucontentsrv/srvinc/menusrveng.h
branchRCL_3
changeset 114 a5a39a295112
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/menucontentsrv/srvinc/menusrveng.h	Wed Sep 01 12:22:09 2010 +0100
@@ -0,0 +1,294 @@
+/*
+* Copyright (c) 2009 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:
+*
+*/
+
+#ifndef __MENUSRVENG_H__
+#define __MENUSRVENG_H__
+
+//  INCLUDES
+
+#include <e32base.h>
+#include "menuengobserver.h"
+#include "menuengobject.h"
+#include "menusrvengutils.h"
+#include "menusrvattr.h"
+// FORWARD DECLARATION
+
+class CMenuEng;
+class CMenuSrv;
+class CMenuSrvSession;
+class CTimeout;
+class CMenuSrvAppScanner;
+class CMenuSrvFolderCrNotifier;
+class CMcsSatMonitor;
+class CMcsDrmHandler;
+class CMcsCacheHandler;
+class CMcsChildrenHandler;
+class CMcsRunningAppsHandler;
+class CMcsGetlistHandler;
+/**
+* In release code the macro must be undefined and application
+* scanning must be enabled!
+* Define the macro only for testing purposes!
+*/
+#undef __TEST_DISABLE_APPSCAN
+
+// GLOBAL FUNCTIONS
+
+/**
+* Menu engine instance.
+* Shared by the sessions using the same content file.
+* It is also "shared" by its own iTimedClose timer. The timer keeps this
+* object alive without any sessions, for a short time.
+* It is a reference counting object, but that is only used for sanity
+* checking: this->CObject::iAccessCount == iSessions.Count() + 1.
+*/
+NONSHARABLE_CLASS( CMenuSrvEng ) : public CObject, public MMenuEngObserver
+    {
+public:
+    enum TExtendedAttributes
+        {
+        EMenuAttrTitleName,
+        EMenuAttrShortName,
+        EMenuAttrLongName,
+        EMenuAttrIconFile,
+        EMenuAttrIconId,
+        EMenuAttrMaskId
+        };
+
+public:     // construction
+
+    /**
+    * Destructor.
+    */
+    virtual ~CMenuSrvEng();
+
+    /**
+    * Two-phased constructor. Leaves on failure.
+    * @param aMenuSrv Menu Server.
+    * @param aContentName Content file name.
+    * @return The constructed object.
+    */
+    static CMenuSrvEng* NewL( CMenuSrv& aMenuSrv, const TDesC& aContentName );
+
+private:    // construction
+
+    /**
+    * Constructor.
+    * @param aMenuSrv Menu Server.
+    */
+    CMenuSrvEng( CMenuSrv& aMenuSrv );
+
+    /**
+    * Second-phase constructor.
+    * @param aContentName Content file name.
+    */
+    void ConstructL( const TDesC& aContentName );
+
+public:     // new methods
+
+    /**
+    * Get content file name (without extension).
+    * @return Content file name.
+    */
+    const TDesC& ContentName() const { return iContentName; }
+
+    /**
+    * Get the Engine.
+    * @return Engine.
+    */
+    CMenuEng& Engine() { return *iEng; }
+
+    /**
+    * Add a session. Ownership not taken, this object only keeps a list of
+    * sessions that are dependent on its engine.
+    * @param aSession Session.
+    */
+    void AddSessionL( CMenuSrvSession* aSession );
+
+    /**
+    * Remove a session. Safe to call if not added.
+    * When no more sessions remain dependent on this object, timed
+    * self-deletion is scheduled.
+    */
+    void RemoveSession( CMenuSrvSession* aSession );
+
+
+    /**
+    * Get attribute name list.
+    * @since S60 v5.0
+    * @param aList Attribute name list.
+    * @throws System-wide error codes if an error occurs.
+    * @panic None.
+    *
+    */
+    void GetAttributeListL(
+  		  TInt aId,
+  		  RArray<TPtrC>& aList );
+
+    /**
+    * Get attribute value.
+    * @since S60 v5.0
+    * @param aAttrName Attribute name.
+    * @param aAttrExists Will be set to indicate whether attribute exists
+    * or not.
+    * @return Attribute value. Empty string if attribute does not exist.
+    */
+    TPtrC GetAttributeL( TInt aId, const TDesC& aAttrName, TBool& aAttrExists );
+
+    void GetAttributeL( TInt aId, const TDesC& aAttrName,
+        TBool& aAttrExists, TDes& aAttrVal );
+
+     /**
+     * Get array of running apps
+     *
+     */
+    void GetRunningAppsL(  RArray<TUid>& aArray );
+
+
+    /**
+     * Fetches children count for a folder
+     */
+    TUint GetChildrenCountL( TInt aId );
+
+    /**
+    * Builds output list for GetList operation and returns result
+    * @param aSerializedInput serialized list with input parameters
+    * 	for GetList operation
+    * @return size of output list
+    */
+    TInt GetListSizeL( const TDesC8& aSerializedInput );
+
+    /**
+    * Returns serialized list containing result of GetList oepration
+    * @return serialized output list
+    */
+    TPtrC8 GetListDataL( );
+
+    /**
+    * Closes output buffer.
+    */
+    void CloseOutputBuffer( );
+
+    /**
+    * Cleans attribute cache. Used in case of no memory.
+    */
+    void CleanAttributeCache( );
+
+private:    // from MMenuEngObserver
+
+
+    void GetExtendedAttributesL( TInt aId, const TDesC& aAttrName,
+        TBool& aAttrExists, TDes& aAttrVal );
+
+    void AddToCacheL( TInt aId, const TDesC& aAttrName, TDes& aAttrVal );
+
+
+    /**
+    * Fetches an application native attribute value.
+    * @param aId item id.
+    * @param aAttrExists ETrue if attribute exist.
+    * @param aAttrVal attribute value.
+    */
+    void ApplicationNativeAttributeL(
+    		TInt aId,
+    		TBool & aAttrExists,
+    		TDes & aAttrVal );
+
+    /**
+    * Engine event. Dispatch events to all dependent sessions.
+    * @param aFolder Events relate to this folder. May be 0.
+    * @param aEvents Events.
+    */
+    void EngineEvents( TInt aFolder, TInt aEvents );
+
+    /**
+    * Unrecoverable engine error. Dispatch to all dependent sessions.
+    * @param aErr Error code.
+    */
+    void EngineError( TInt aErr );
+
+    /**
+     * Engine tree reload event.
+     * Run appscanner again.
+     */
+    void EngineTreeReloaded();
+    /**
+    * Fetches an attribute value from the caption info attributes
+    */
+    void CaptionInfoL( TInt aId, const TDesC& aAttrName,
+        TBool& aExists, TDes& aAttrVal );
+
+
+    /**
+    * Fetches an attribute value from the skin icon info attributes
+    */
+    void SkinInfoL( TInt aId, TInt aSelect, TBool& aExists, TDes& aAttrVal  );
+
+    /**
+    * Fetches the DRM protection attribute value
+    */
+    void AppDrmProtectionL( TInt aId, TBool& aExists, TDes& aAttrVal );
+
+    /**
+    * Fetches an attribute value from the caption info attributes for application
+    */
+    TPtrC AppCaptionInfoL( const CMenuEngObject& aEngObj,
+        const TDesC& aAttrName, TBool& aExists );
+
+    /**
+     * Fetches the children_count attribute value (for folders)
+     */
+    void FolderChildrenCountL( TInt aId, TBool& aExists, TDes& aAttrVal );
+
+    /**
+    * Fetches the running status for application and folder
+    */
+    void GetAppRunningL( TInt aId, TBool& aExists, TDes& aAttrVal );
+
+    /**
+    * Appends extended attributes to attributes list
+    */
+    void AppendExtendedAttrributesL(
+    		const TDesC& aType,
+    		RArray<TPtrC>& aList );
+
+
+private:    // Data
+
+    CMenuSrv& iMenuSrv; ///< Menu Server.
+    RBuf iContentName; ///< Content name. Own.
+    RPointerArray<CMenuSrvSession> iSessions; ///< Sessions using this engine.
+    CMenuEng* iEng; ///< Engine. Own.
+    CTimeout* iTimedClose; ///< Closing timer. Closes this object.
+    CMenuSrvAppScanner* iAppScanner; ///< App scanner. Own.
+    CMenuSrvFolderCrNotifier* iFolderNotifier; ///< Folder scanner. Own.
+    CMenuSrvEngUtils* iCMenuSrvEngUtils;///CMenuSrvEngUtils. Own.
+    CMcsSatMonitor* iMcsSatMonitor;
+    CMcsDrmHandler* iDrmHander;
+    CMcsRunningAppsHandler* iRunningAppsHandler;//own
+    CMcsCacheHandler* iCacheHandler;
+    CMcsChildrenHandler* iChildrenHandler;
+    CMcsGetlistHandler* iGetlistHandler;
+    };
+
+#ifdef __TEST_DISABLE_APPSCAN
+#pragma message("Undefine __TEST_DISABLE_APPSCAN !")
+#endif
+
+#endif // __MENUSRVENG_H__
+
+// End of File