keepalive/flextimer/server/inc/mflextimerservice.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
 * Contributors:
hgs
parents:
diff changeset
    13
 *
hgs
parents:
diff changeset
    14
 * Description:
hgs
parents:
diff changeset
    15
 * This class contains definition of MFlexTimerService
hgs
parents:
diff changeset
    16
 *
hgs
parents:
diff changeset
    17
 */
hgs
parents:
diff changeset
    18
/*
hgs
parents:
diff changeset
    19
 * %version: 1 %
hgs
parents:
diff changeset
    20
 */
hgs
parents:
diff changeset
    21
// Protection against nested includes
hgs
parents:
diff changeset
    22
#ifndef MFLEXTIMERSERVICE_H
hgs
parents:
diff changeset
    23
#define MFLEXTIMERSERVICE_H
hgs
parents:
diff changeset
    24
hgs
parents:
diff changeset
    25
//Forward declarations
hgs
parents:
diff changeset
    26
class TTime;
hgs
parents:
diff changeset
    27
class MFlexTimerServiceCB;
hgs
parents:
diff changeset
    28
hgs
parents:
diff changeset
    29
// Class declaration
hgs
parents:
diff changeset
    30
/**
hgs
parents:
diff changeset
    31
 *  Interface to flexible timer engine. This interface is used by client
hgs
parents:
diff changeset
    32
 *  sessions to start and cancel timers.
hgs
parents:
diff changeset
    33
 */
hgs
parents:
diff changeset
    34
class MFlexTimerService
hgs
parents:
diff changeset
    35
    {
hgs
parents:
diff changeset
    36
public:
hgs
parents:
diff changeset
    37
hgs
parents:
diff changeset
    38
    /** Pure virtual functions*/
hgs
parents:
diff changeset
    39
    /**
hgs
parents:
diff changeset
    40
     * Function for adding a new timer with specified parameters. 
hgs
parents:
diff changeset
    41
     * After timer expires aFlexTimerServiceCB is used to inform a client
hgs
parents:
diff changeset
    42
     * session about that. Both parameter times should be in the future
hgs
parents:
diff changeset
    43
     * and min should be earlier than max
hgs
parents:
diff changeset
    44
     * 
hgs
parents:
diff changeset
    45
     * @param aWinStartInterval Time interval from present to left side of the
hgs
parents:
diff changeset
    46
     *  window
hgs
parents:
diff changeset
    47
     * @param aWinEndInterval Time interval from present to right side of the
hgs
parents:
diff changeset
    48
     *  window
hgs
parents:
diff changeset
    49
     * @param aCancelAtSystemTimeChange Whether timer should be aborted if
hgs
parents:
diff changeset
    50
     *  system time changes.
hgs
parents:
diff changeset
    51
     * @param aFlexTimerServiceCB Callback interface for timer
hgs
parents:
diff changeset
    52
     *  expiration (also used as an ID)
hgs
parents:
diff changeset
    53
     * 
hgs
parents:
diff changeset
    54
     * @return KErrNone or some other system wide error code.
hgs
parents:
diff changeset
    55
     *
hgs
parents:
diff changeset
    56
     */
hgs
parents:
diff changeset
    57
    virtual TInt AddTimer(
hgs
parents:
diff changeset
    58
            const TTimeIntervalMicroSeconds& aWinStartInterval,
hgs
parents:
diff changeset
    59
            const TTimeIntervalMicroSeconds& aWinEndInterval,
hgs
parents:
diff changeset
    60
            TBool aCancelAtSystemTimeChange,
hgs
parents:
diff changeset
    61
            const MFlexTimerServiceCB* aFlexTimerServiceCB ) = 0;
hgs
parents:
diff changeset
    62
hgs
parents:
diff changeset
    63
    /**
hgs
parents:
diff changeset
    64
     * Function for cancellin a running timer. After this function returns,
hgs
parents:
diff changeset
    65
     * all references to corresponding timer are deleted and they can not be
hgs
parents:
diff changeset
    66
     * referred again.
hgs
parents:
diff changeset
    67
     * 
hgs
parents:
diff changeset
    68
     * @param aFlexTimerServiceCB ID used when timer was added
hgs
parents:
diff changeset
    69
     * @return KErrNone or some other system wide error code.
hgs
parents:
diff changeset
    70
     */
hgs
parents:
diff changeset
    71
    virtual TInt CancelTimer(
hgs
parents:
diff changeset
    72
            const MFlexTimerServiceCB* aFlexTimerServiceCB ) = 0;
hgs
parents:
diff changeset
    73
hgs
parents:
diff changeset
    74
    };
hgs
parents:
diff changeset
    75
hgs
parents:
diff changeset
    76
#endif  /* MFLEXTIMERSERVICE_H */