PECengine/AttributeLibrary2/SrcAttributeBase/CPEngAttrModelAsyncDataSetHook.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Thu, 17 Dec 2009 08:41:52 +0200
changeset 0 094583676ce7
permissions -rw-r--r--
Revision: 200949 Kit: 200951

/*
* Copyright (c) 2004 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:  Attribute asynhronous data set hook.
*
*/

#ifndef CPENGATTRMODELASYNCDATASETHOOK_H
#define CPENGATTRMODELASYNCDATASETHOOK_H

//  INCLUDES
#include <E32Base.h>


//FORWARD DECLARATION
class CPEngPresenceAttrModel;
class MPEngPresenceAttrModelTypeImp;



// CLASS DECLARATION
/**
 * Attribute asynhronous data set hook.
 *
 * @since 3.0
 */
NONSHARABLE_CLASS( CPEngAttrModelAsyncDataSetHook ) : public CActive
    {
public: //Constructor and destructor

    /**
     * C++ default constructor.
     */
    CPEngAttrModelAsyncDataSetHook();


    /**
     * Destructor.
     * Cancels any outstanding request.
     */
    ~CPEngAttrModelAsyncDataSetHook();


public: // New functions

    /**
     * Initializess the hook.
     *
     * Sets the request status where to hook in
     * and also the attribute objects which to callback
     * when the request is completed or gets canceled.
     *
     * If hook is already active, leaves with KErrInUse.
     *
     * @since 3.0
     * @param aStatus The request status to hook in.
     * @param aAttributeModel The attribute model owning the hook.
     * @param aTypeImp The attribute model implementation
     * which data set to hook in.
     */
    void InitializeLC( TRequestStatus& aRequestStatus,
                       CPEngPresenceAttrModel& aAttributeModel,
                       MPEngPresenceAttrModelTypeImp& aTypeImp );



    /**
     * Gets the hooks own request status.
     *
     * This request status is given prior
     * starting the hook to concrete asynchronous
     * request.
     *
     * @since 3.0
     * @param The hook own request status.
     */
    TRequestStatus& Status();


    /**
     * Starts the data set hook.
     *
     * The hook must be properly initialized before a
     * call to start.
     *
     * Registered attribute object callbacks are called
     * when something happens in the hook.
     *
     * If the hook wasn't properly initialized before
     * starting, panics.
     *
     * @since 3.0
     */
    void Activate();


protected:  // Functions from CActive

    /**
     * Gets called when actual request completes.
     *
     * @since 3.0
     */
    void RunL();


    /**
     * Gets called when hook is cancelled.
     *
     * @since 3.0
     */
    void DoCancel();


protected:  // Helpers
    void Reset();
    static void ResetTheHook( TAny* aHook );


private:    // Data

    //REF: Attribute model (owner) to update after complete
    CPEngPresenceAttrModel*  iHookOwner;

    //REF: Attribute model implementation to cancel
    MPEngPresenceAttrModelTypeImp* iHookedImp;

    //REF: Request status to complete after hook operation
    TRequestStatus* iStatusToComplete;

    };

#endif      // CPENGATTRMODELASYNCDATASETHOOK_H

// End of File