contextframework/cfw/inc/basicoperationsplugin/cfcontextoperation.h
author Pat Downey <patd@symbian.org>
Tue, 18 May 2010 16:46:03 +0100
branchRCL_3
changeset 32 afba831adaf6
parent 0 2e3d3ce01487
permissions -rw-r--r--
Re-merge Symbian FOundation splash screen changes.

/*
* Copyright (c) 2004-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:  CCFContextOperation class declaration.
*
*/



#ifndef C_CFCONTEXTOPERATION_H
#define C_CFCONTEXTOPERATION_H

// INCLUDES
#include <e32base.h>
#include <cfcontextobject.h>

#include "cfoperationnode.h"
#include "cfscriptlistener.h"

// FORWARD DECLARATIONS

// CLASS DECLARATION

/**
*  CCFContextOperation class is the base class for all Context Framework script
*  operations that operate on contexts.
*  All instances of this class are leaf nodes in operation tree.
*
*  @lib CFScriptEngine
*  @since Series 60 2.6
*/
NONSHARABLE_CLASS( CCFContextOperation ): public CCFOperationNode,
    public MCFScriptListener
    {
public: // Constructors and destructor

    /**
    * Destructor.
    */
    virtual ~CCFContextOperation();

public: // Enumerations

    enum TCmpType
        {
        EInvalidCmpType = -1,
        EIntCmp,
        EFloatCmp,
        EPositionCmp,
        ETimeCmp,
        EStringCmp
        };


public: // From MCFScriptListener

    /**
    * Performs evaluation based on a context.
    * @param aContext is the context for evaluation.
    * @param aContextLevelDelay is storage for context level delay required by
    *   the evaluation.
    * @return ETrue if evaluation was performed and firing actions should be
    *   considered based on clause conditions, EFalse otherwise.
    */
    TBool Evaluate( const CCFContextObject& aContext,
            TInt& aContextLevelDelay );

    /**
    * Returns a context source this listener is interested in.
    * @returns the source of the context.
    */
    TPtrC Source() const;

    /**
    * Returns a context type this listener is interested in.
    * @returns the type of the context.
    */
    TPtrC Type() const;

    /**
    * Tests if this listener requires notification of all contexts.
    * @returns ETrue if this listener is interested in all contexts,
    *   EFalse otherwise.
    */
    TBool IsAllRequired() const;

protected:

    /**
    * C++ default constructor.
    */
    CCFContextOperation( MCFOperationServices& aServices,
            CCFOperationNode* aParent,
            HBufC* aType,
            HBufC* aSource );

protected: // New functions

    /**
    * All concrete classes must implement this method.
    * @param aContext is context that has changed.
    * @return the result of the comparison.
    */
    virtual TBool IsTrueL( const CCFContextObject& aContext ) = 0;

    /**
    * Updates the previous value the operation was evaluated with.
    * @param aNewValue is the new previous value.
    * @return KErrNone when update was successful, KErrNoMemory if update failed
    *   due to low memory.
    */
    TInt UpdatePreviousValue( const TDesC& aNewValue );

    /**
    * Gets the previous value the operation was evaluated with.
    * @return the previous value the operation was evaluated with.
    */
    const TDesC& PreviousValue();

protected: // From CCFOperationNode

    /**
    * Activates this node by subscribing to a context.
    * @return None.
    */
    void ActivateL();

    /**
    * Deactivates this node by removing context subscription.
    * @return None.
    */
    void Deactivate();

    /**
    * Asks this node to check its security (via services interface). For
    * example, the security of contexts to be subscribed.
    * @return KErrNone if security check passed, otherwise any of the system
    *   wide error codes.
    */
    TInt CheckSecurity();

private: // From CCFOperationNode

    /**
    * Called by child node, to ask the parent to re-evaluate its value,
    * since the child's value has changed.
    */
    void Evaluate();

protected: // Data

    /**
    * Context level delay for firing actions after evaluation
    * (defined by contextRef).
    */
    TInt iContextLevelDelay;

private: // Data

    /**
    * Context source and type as defined by contextRef for the operation.
    */
    HBufC* iSource;
    HBufC* iType;

    /** Previous context value. */
    HBufC* iPreviousValue;
    };

#endif // C_CFCONTEXTOPERATION_H