wlan_bearer/wlanengine/wlan_symbian/wlanengine_symbian_3.1/inc/wlantimerservices.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Tue, 02 Feb 2010 02:03:13 +0200
changeset 0 c40eb8fe8501
child 3 6524e815f76f
permissions -rw-r--r--
Revision: 201003 Kit: 201005

/*
* 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 the License "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:  This class implements timer service with callback functionality.
*
*/

/*
* %version: 3 %
*/

#ifndef WLANTIMERSERVICES_H
#define WLANTIMERSERVICES_H

#include <e32base.h>
#include <e32std.h>
#include <e32cmn.h>


/**
 * Callback interface
 */
class MWlanTimerServiceCallback
    {
    public:
    
        /**
         * Timeout has occurred.
         */
        virtual void OnTimeout() = 0;

    };

class CTimeoutRequestEntry : public CBase
    {
public:
    CTimeoutRequestEntry::CTimeoutRequestEntry(
    	TTime& aAt,
    	MWlanTimerServiceCallback& aCb,
    	TUint aRequestId,
    	TBool aDoSeveralRounds ) :
        iCb( aCb ),
        iAt( aAt ),
        iRequestId( aRequestId ),
        iDoSeveralRounds( aDoSeveralRounds )
    {}
    void Timeout()
        {
        iCb.OnTimeout();
        }
    const TTime& At() const
        {
        return iAt;
        }
    TTime& GetAt()
        {
        return iAt;
        }
    const TUint RequestId() const
        {
        return iRequestId;
        }
    TBool& GetDoSeveralRounds()
        {
        return iDoSeveralRounds;
        }
    
private:
    MWlanTimerServiceCallback& iCb;
    TTime iAt;
    TUint iRequestId;
    TBool iDoSeveralRounds;
    };

/**
 * Class providing timer services.
 *
 * @since S60 v5.2
 */
NONSHARABLE_CLASS( CWlanTimerServices ) : public CActive
    {
public: // Constructors and destructor

    /**
     * Static constructor.
     */
    static CWlanTimerServices* NewL();

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

public: // New functions

    /**
     * Start the timer
     *
     * @since S60 v5.2
     * @param aRequestId reference to request id
     * @param aAt reference to time when timeout should occur
     * @param aCb reference to callback object
     * @return error code
     */
    TInt StartTimer( TUint& aRequestId, TTime& aAt, MWlanTimerServiceCallback& aCb );

    /**
     * Stop the timer
     *
     * @since S60 v5.2
     * @param aRequestId Id of timer to stop
     */
    void StopTimer( const TUint& aRequestId );
    
    /**
     * Handles timer timeout.
     *
     * @since S60 v5.2
     */
    void HandleTimeout();
    
public: // Functions from base classes

    /**
    * From CActive Is executed when synchronous request is ready.
    */
    void RunL();

    /**
    * From CActive Cancel synchronous request.
    */
    void DoCancel();

private: // Functions

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

    /**
     * Symbian 2nd phase constructor.
     */
    void ConstructL();
    
    /**
     * Compare timeouts of two timeout request entries.
     *
     * @since S60 v5.2
     *
     * @param aFirst first entry.
     * @param aSecond second entry.
     * @return  0 if entries have same timeout value,
     *          1 if first entry has bigger timeout value,
     *         -1 if second entry has bigger timeout value
     */
    static TInt CompareTimeouts( const CTimeoutRequestEntry& aFirst,
                                 const CTimeoutRequestEntry& aSecond );
    
    /**
     * Calculates a microsecond interval to be used in timer.
     *
     * @since S60 v5.2
     *
     * @param aInterval interval will be written to here.
     * @param aAt time when timeout should occur. If more than a day apart from current time,
     *            day will be set to current day.
     * @param aDoSeveralRounds here will be written whether several timer rounds are needed.
     * @return  KErrArgument if aAt happens in past,
     *          KErrNone otherwise
     */
    TInt CalculateInterval( TTimeIntervalMicroSeconds32& aInterval,
                            TTime& aAt,
                            TBool& aDoSeveralRounds ) const;
    
    /**
     * Returns request id of the first request.
     *
     * @since S60 v5.2
     *
     * @return id of the first request
     */
    TInt RequestIdOfFirstEntry();
    
    /**
     * Removes a request from the request map.
     *
     * @since S60 v5.2
     *
     * @param aRequestId request to be removed.
     */
    void RemoveRequest( const TUint& aRequestId );
    
    /**
     * Get interval for next request.
     * Times out requests which happen in past and only
     * returns interval for next request happening in future.
     *
     * @since S60 v5.2
     * 
     * @return interval for the next request
     */
    TTimeIntervalMicroSeconds32 GetIntervalForNextRequest();
    
    /**
     * Is time in future.
     *
     * @since S60 v5.2
     * 
     * @return ETrue if time is in the future,
     *         EFalse otherwise
     */
    TBool IsTimeInFuture( const TTime& aAt ) const;
    
    /**
     * Activates timer
     *
     * @since S60 v5.2
     * 
     * @param aInterval interval for timer
     */
    void ActivateTimer( const TTimeIntervalMicroSeconds32& aInterval );
    
private: // Data
   
    /**
     * The timer.
     */
    RTimer iTimer;
        
    /**
     * All timeout requests.
     */
    RArray<CTimeoutRequestEntry> iRequests;
    
    /**
     * Unique identifier for requests.
     */
    TUint iRequestId;
    
    };



#endif // WLANTIMERSERVICES_H