keepalive/flextimer/server/engine/inc/flextimeritem.h
author hgs
Mon, 24 May 2010 20:51:35 +0300
changeset 32 5c4486441ae6
permissions -rw-r--r--
201021
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
32
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
 * Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies). 
hgs
parents:
diff changeset
     3
 * All rights reserved.
hgs
parents:
diff changeset
     4
 * This component and the accompanying materials are made available
hgs
parents:
diff changeset
     5
 * under the terms of "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     6
 * which accompanies this distribution, and is available
hgs
parents:
diff changeset
     7
 * at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     8
 *
hgs
parents:
diff changeset
     9
 * Initial Contributors:
hgs
parents:
diff changeset
    10
 * Nokia Corporation - Initial contribution
hgs
parents:
diff changeset
    11
 *
hgs
parents:
diff changeset
    12
 * Description:
hgs
parents:
diff changeset
    13
 * This class contains definition of CFlexTimerItem.
hgs
parents:
diff changeset
    14
 *
hgs
parents:
diff changeset
    15
 */
hgs
parents:
diff changeset
    16
hgs
parents:
diff changeset
    17
// Protection against nested includes
hgs
parents:
diff changeset
    18
#ifndef FLEXTIMERITEM_H
hgs
parents:
diff changeset
    19
#define FLEXTIMERITEM_H
hgs
parents:
diff changeset
    20
hgs
parents:
diff changeset
    21
// System includes
hgs
parents:
diff changeset
    22
#include <e32base.h>
hgs
parents:
diff changeset
    23
hgs
parents:
diff changeset
    24
// User includes
hgs
parents:
diff changeset
    25
// None
hgs
parents:
diff changeset
    26
hgs
parents:
diff changeset
    27
// Forward declarations
hgs
parents:
diff changeset
    28
class MFlexTimerServiceCB;
hgs
parents:
diff changeset
    29
hgs
parents:
diff changeset
    30
// Class declaration
hgs
parents:
diff changeset
    31
/**
hgs
parents:
diff changeset
    32
 *  Timer item that contains expiry time, window size and other timer specific
hgs
parents:
diff changeset
    33
 *  parameters. Class implements container for one timer information in
hgs
parents:
diff changeset
    34
 *  FlexTimerServer.
hgs
parents:
diff changeset
    35
 */
hgs
parents:
diff changeset
    36
class CFlexTimerItem : public CBase
hgs
parents:
diff changeset
    37
    {
hgs
parents:
diff changeset
    38
public:
hgs
parents:
diff changeset
    39
hgs
parents:
diff changeset
    40
    /** Constructor
hgs
parents:
diff changeset
    41
     *
hgs
parents:
diff changeset
    42
     * Constructs new timer item that contains all information needed to
hgs
parents:
diff changeset
    43
     * decide when to launch timer.
hgs
parents:
diff changeset
    44
     *
hgs
parents:
diff changeset
    45
     * @param aAbsoluteMinTime Left side of the timer launch window.
hgs
parents:
diff changeset
    46
     * @param aAbsoluteMaxTime Right side of the timer launch window.
hgs
parents:
diff changeset
    47
     * @param aCancelAtSystemTimeChange Whether system time change should
hgs
parents:
diff changeset
    48
     * trigger abort.
hgs
parents:
diff changeset
    49
     * @param aFlexTimerServiceCB Call back interface. Used to inform about
hgs
parents:
diff changeset
    50
     * timeout, abort etc.
hgs
parents:
diff changeset
    51
     * @return New CFlexTimer object.
hgs
parents:
diff changeset
    52
     */
hgs
parents:
diff changeset
    53
    static CFlexTimerItem* NewL( const TTime& aAbsoluteMinTime,
hgs
parents:
diff changeset
    54
        const TTime& aAbsoluteMaxTime,
hgs
parents:
diff changeset
    55
        TBool aCancelAtSystemTimeChange,
hgs
parents:
diff changeset
    56
        const MFlexTimerServiceCB* aFlexTimerServiceCB );
hgs
parents:
diff changeset
    57
hgs
parents:
diff changeset
    58
    /** Destructor
hgs
parents:
diff changeset
    59
     * Destructs timer item.
hgs
parents:
diff changeset
    60
     */
hgs
parents:
diff changeset
    61
    virtual ~CFlexTimerItem();
hgs
parents:
diff changeset
    62
hgs
parents:
diff changeset
    63
public:
hgs
parents:
diff changeset
    64
    /**
hgs
parents:
diff changeset
    65
     * Gets the earliest possible moment when this timer can expire. 
hgs
parents:
diff changeset
    66
     * Places value to reference parameter. 
hgs
parents:
diff changeset
    67
     *
hgs
parents:
diff changeset
    68
     * @param aMinAbsoluteTime After function returns this parameter contains
hgs
parents:
diff changeset
    69
     * absolute earliest moment when this timer can expire         
hgs
parents:
diff changeset
    70
     */
hgs
parents:
diff changeset
    71
    inline void GetMinAbsoluteTime( TTime& aMinAbsoluteTime );
hgs
parents:
diff changeset
    72
hgs
parents:
diff changeset
    73
    /**
hgs
parents:
diff changeset
    74
     * Gets the latest possible moment when this timer must expire. 
hgs
parents:
diff changeset
    75
     * Places value to reference parameter. 
hgs
parents:
diff changeset
    76
     *
hgs
parents:
diff changeset
    77
     * @param aMaxAbsoluteTime After function returns this parameter contains
hgs
parents:
diff changeset
    78
     * absolute latest moment when this timer must expire       
hgs
parents:
diff changeset
    79
     */
hgs
parents:
diff changeset
    80
    inline void GetMaxAbsoluteTime( TTime& aMaxAbsoluteTime );
hgs
parents:
diff changeset
    81
hgs
parents:
diff changeset
    82
    /**
hgs
parents:
diff changeset
    83
     * Checks whether this timer should be aborted if system time changes
hgs
parents:
diff changeset
    84
     *
hgs
parents:
diff changeset
    85
     * @return 
hgs
parents:
diff changeset
    86
     * ETrue - If timer should be aborted when system time changes
hgs
parents:
diff changeset
    87
     * EFalse - If timer should not be cancelled when system time changes        
hgs
parents:
diff changeset
    88
     */
hgs
parents:
diff changeset
    89
    inline TBool IsAbortedAtSystemTimeChange();
hgs
parents:
diff changeset
    90
hgs
parents:
diff changeset
    91
    /**
hgs
parents:
diff changeset
    92
     * Returns timers corresponding CB session pointer.
hgs
parents:
diff changeset
    93
     *
hgs
parents:
diff changeset
    94
     * @return pointer to session that initiated this timer       
hgs
parents:
diff changeset
    95
     */
hgs
parents:
diff changeset
    96
    const MFlexTimerServiceCB* GetCB();
hgs
parents:
diff changeset
    97
hgs
parents:
diff changeset
    98
private:
hgs
parents:
diff changeset
    99
    /**
hgs
parents:
diff changeset
   100
     * Private contructor. Constructs new timer item that contains all
hgs
parents:
diff changeset
   101
     * information needed to decide when to launch timer.
hgs
parents:
diff changeset
   102
     *
hgs
parents:
diff changeset
   103
     * @param aAbsoluteMinTime Left side of the timer launch window.
hgs
parents:
diff changeset
   104
     * @param aAbsoluteMaxTime Right side of the timer launch window.
hgs
parents:
diff changeset
   105
     * @param aCancelAtSystemTimeChange Whether system time change should
hgs
parents:
diff changeset
   106
     * trigger abort.
hgs
parents:
diff changeset
   107
     * @param aFlexTimerServiceCB Call back interface. Used to inform about
hgs
parents:
diff changeset
   108
     * timeout, abort etc.
hgs
parents:
diff changeset
   109
     *
hgs
parents:
diff changeset
   110
     * @return New CFlexTimer object.
hgs
parents:
diff changeset
   111
     * 
hgs
parents:
diff changeset
   112
     */
hgs
parents:
diff changeset
   113
    CFlexTimerItem( const TTime& aAbsoluteMinTime,
hgs
parents:
diff changeset
   114
        const TTime& aAbsoluteMaxTime,
hgs
parents:
diff changeset
   115
        TBool aCancelAtSystemTimeChange,
hgs
parents:
diff changeset
   116
        const MFlexTimerServiceCB* aFlexTimerServiceCB );
hgs
parents:
diff changeset
   117
hgs
parents:
diff changeset
   118
public:
hgs
parents:
diff changeset
   119
    //Data
hgs
parents:
diff changeset
   120
    /**
hgs
parents:
diff changeset
   121
     * Single linked list link object for timers lists
hgs
parents:
diff changeset
   122
     */
hgs
parents:
diff changeset
   123
    TSglQueLink iLink;
hgs
parents:
diff changeset
   124
hgs
parents:
diff changeset
   125
private:
hgs
parents:
diff changeset
   126
    // Data
hgs
parents:
diff changeset
   127
    /**
hgs
parents:
diff changeset
   128
     * Whether timer should be aborted when system time changes.
hgs
parents:
diff changeset
   129
     */
hgs
parents:
diff changeset
   130
    TBool iAbortAtSystemTimeChange;
hgs
parents:
diff changeset
   131
hgs
parents:
diff changeset
   132
    /**
hgs
parents:
diff changeset
   133
     * Left side of the time window when timer can be fired
hgs
parents:
diff changeset
   134
     */
hgs
parents:
diff changeset
   135
    TTime iAbsoluteMinTime;
hgs
parents:
diff changeset
   136
hgs
parents:
diff changeset
   137
    /**
hgs
parents:
diff changeset
   138
     * Right side of the time window when timer can be fired
hgs
parents:
diff changeset
   139
     */
hgs
parents:
diff changeset
   140
    TTime iAbsoluteMaxTime;
hgs
parents:
diff changeset
   141
hgs
parents:
diff changeset
   142
    /**
hgs
parents:
diff changeset
   143
     * pointer to the session interface that is used to inform timeout
hgs
parents:
diff changeset
   144
     */
hgs
parents:
diff changeset
   145
    const MFlexTimerServiceCB* iMFlexTimerServiceCB;
hgs
parents:
diff changeset
   146
    };
hgs
parents:
diff changeset
   147
hgs
parents:
diff changeset
   148
#include "flextimeritem.inl"
hgs
parents:
diff changeset
   149
hgs
parents:
diff changeset
   150
#endif  //FLEXTIMERITEM_H