--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/meetingrequest/mrpolicy/inc/cesmrpolicymanager.h Wed Sep 01 12:28:57 2010 +0100
@@ -0,0 +1,124 @@
+/*
+* Copyright (c) 2007-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: ESMR service policy
+*
+*/
+
+
+#ifndef CESMRPOLICYMANAGER_H
+#define CESMRPOLICYMANAGER_H
+
+#include <e32base.h>
+
+#include "esmrutilsapiext.h"
+#include "esmrdef.h"
+#include "tesmrscenariodata.h"
+#include "mmrpolicyprovider.h"
+
+#include <barsc.h>
+
+
+class CESMRPolicy;
+class MESMRCalEntry;
+class MMRPolicyResolver;
+class CMRPolicyResolver;
+
+/**
+ * CESMRPolicyManager defines ESMR policymanager.
+ * ES MR policies are relates to different roles and task scenarions.
+ * Policies are used by user interface views and tasks. CESMRPolicyManager
+ * provides interface for accessing these policies.
+ * CESMRPolicyManager uses CCoeEnv.
+ *
+ * @see CESMRPolicy
+ * @lib esmrpolicy.lib
+ */
+NONSHARABLE_CLASS(CESMRPolicyManager) : public CBase,
+ public MMRPolicyProvider
+ {
+public: // Construction and destruction
+ /**
+ * Two-phased constructor. Creates new CESMRPolicyManager object.
+ * Ownership is transferred to caller.
+ *
+ * @return Pointer to created and initialized esmr policy object.
+ */
+ IMPORT_C static CESMRPolicyManager* NewL();
+
+ /**
+ * C++ destructor.
+ */
+ IMPORT_C ~CESMRPolicyManager();
+
+public: // Interface
+ /**
+ * Fetches current policy object.
+ * @return Current policy object
+ */
+ IMPORT_C CESMRPolicy& CurrentPolicy();
+
+ /**
+ * Resolves policy to be used.
+ * @param aScenarioData Scenario Data for resolving correct policy
+ * @param aESMREntry Reference to ES MR Entry.
+ * @param aCustomResolver to be used. If NULL, resolver is determined by
+ * policy manager
+ */
+ IMPORT_C void ResolvePolicyL(
+ const TESMRScenarioData& aScenarioData,
+ MESMRCalEntry& aESMREntry,
+ MMRPolicyResolver* aCustomResolver = NULL );
+
+ /**
+ * Adds the current policy on stack for preserving it if a new policy
+ * needs to be resolved and the current policy is still needed afterwards.
+ */
+ IMPORT_C void PushPolicyL();
+
+ /**
+ * Restores the topmost policy from the stack as the current policy.
+ * @return the policy from stack or NULL if stack is empty.
+ */
+ IMPORT_C CESMRPolicy* PopPolicy();
+
+public: // from MMRPolicyProvider
+
+ const CESMRPolicy& CurrentPolicy() const;
+
+private: // Implementation
+
+ CESMRPolicyManager();
+ void ConstructL();
+
+private: // data
+
+ /**
+ * Current policy resolver.
+ * Own.
+ */
+ MMRPolicyResolver* iResolverPlugin;
+
+ /**
+ * Current policy object
+ * Own.
+ */
+ CESMRPolicy* iCurrentPolicy;
+
+ /**
+ * Array for preserving policies
+ */
+ RPointerArray< CESMRPolicy > iPolicyStack;
+ };
+
+#endif // CESMRPOLICYMANAGER_H