keepalive/flextimer/client/src/flextimer.cpp
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:  Implementation of CFlexTimer class
hgs
parents:
diff changeset
    15
 *
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
//#include <e32panic.h>
hgs
parents:
diff changeset
    22
hgs
parents:
diff changeset
    23
#include "flextimer.h"
hgs
parents:
diff changeset
    24
#include "flextimerpanic.h"
hgs
parents:
diff changeset
    25
#include "OstTraceDefinitions.h"
hgs
parents:
diff changeset
    26
#ifdef OST_TRACE_COMPILER_IN_USE
hgs
parents:
diff changeset
    27
#include "flextimerTraces.h"
hgs
parents:
diff changeset
    28
#endif
hgs
parents:
diff changeset
    29
hgs
parents:
diff changeset
    30
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    31
// Destructs the object.
hgs
parents:
diff changeset
    32
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    33
//
hgs
parents:
diff changeset
    34
EXPORT_C CFlexTimer::~CFlexTimer()
hgs
parents:
diff changeset
    35
    {
hgs
parents:
diff changeset
    36
    OstTrace1( TRACE_NORMAL, CFLEXTIMER_CFLEXTIMER,
hgs
parents:
diff changeset
    37
               "CFlexTimer::~CFlexTimer;this=%x", this );
hgs
parents:
diff changeset
    38
    
hgs
parents:
diff changeset
    39
    Cancel();
hgs
parents:
diff changeset
    40
    iTimer.Close();
hgs
parents:
diff changeset
    41
    }
hgs
parents:
diff changeset
    42
hgs
parents:
diff changeset
    43
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    44
// Fire timer at latest on the given interval. 32-bit interval.
hgs
parents:
diff changeset
    45
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    46
//
hgs
parents:
diff changeset
    47
EXPORT_C void CFlexTimer::After( TTimeIntervalMicroSeconds32 aInterval )
hgs
parents:
diff changeset
    48
    {
hgs
parents:
diff changeset
    49
    OstTraceExt2( TRACE_NORMAL, CFLEXTIMER_AFTER32,
hgs
parents:
diff changeset
    50
                  "CFlexTimer::After32;this=%x;aInterval=%d",
hgs
parents:
diff changeset
    51
                  ( TUint )this, aInterval.Int() );
hgs
parents:
diff changeset
    52
    
hgs
parents:
diff changeset
    53
    __ASSERT_ALWAYS( IsAdded(),
hgs
parents:
diff changeset
    54
                     User::Panic( KCFlexTimerPanicCat, 
hgs
parents:
diff changeset
    55
                                  EFlexTimerNotAddedToActiveScheduler ) );
hgs
parents:
diff changeset
    56
    iTimer.After( iStatus, aInterval );
hgs
parents:
diff changeset
    57
    SetActive();
hgs
parents:
diff changeset
    58
    }
hgs
parents:
diff changeset
    59
hgs
parents:
diff changeset
    60
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    61
// Fire timer at latest on the given interval. 64-bit interval.
hgs
parents:
diff changeset
    62
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    63
//
hgs
parents:
diff changeset
    64
EXPORT_C void CFlexTimer::After( TTimeIntervalMicroSeconds aInterval )
hgs
parents:
diff changeset
    65
    {
hgs
parents:
diff changeset
    66
    OstTraceExt2( TRACE_NORMAL, CFLEXTIMER_AFTER64,
hgs
parents:
diff changeset
    67
                  "CFlexTimer::After64;this=%x;aInterval=%llu",
hgs
parents:
diff changeset
    68
                  ( TUint )this, aInterval.Int64() );
hgs
parents:
diff changeset
    69
    
hgs
parents:
diff changeset
    70
    __ASSERT_ALWAYS( IsAdded(),
hgs
parents:
diff changeset
    71
                     User::Panic(KCFlexTimerPanicCat,
hgs
parents:
diff changeset
    72
                                 EFlexTimerNotAddedToActiveScheduler ) );
hgs
parents:
diff changeset
    73
    iTimer.After( iStatus, aInterval );
hgs
parents:
diff changeset
    74
    SetActive();
hgs
parents:
diff changeset
    75
    }
hgs
parents:
diff changeset
    76
hgs
parents:
diff changeset
    77
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    78
// Fire timer between at latest by the given time value.
hgs
parents:
diff changeset
    79
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    80
//
hgs
parents:
diff changeset
    81
EXPORT_C void CFlexTimer::At( const TTime& aTime )
hgs
parents:
diff changeset
    82
    {
hgs
parents:
diff changeset
    83
    OstTraceExt2( TRACE_NORMAL, CFLEXTIMER_AT,
hgs
parents:
diff changeset
    84
                  "CFlexTimer::At;this=%x;aTime=%lld", ( TUint )this,
hgs
parents:
diff changeset
    85
                  aTime.Int64() );
hgs
parents:
diff changeset
    86
    
hgs
parents:
diff changeset
    87
    __ASSERT_ALWAYS( IsAdded(),
hgs
parents:
diff changeset
    88
                     User::Panic( KCFlexTimerPanicCat,
hgs
parents:
diff changeset
    89
                                  EFlexTimerNotAddedToActiveScheduler ) );
hgs
parents:
diff changeset
    90
    iTimer.At( iStatus, aTime );
hgs
parents:
diff changeset
    91
    SetActive();
hgs
parents:
diff changeset
    92
    }
hgs
parents:
diff changeset
    93
hgs
parents:
diff changeset
    94
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    95
// Fire timer between at latest by the given time value.
hgs
parents:
diff changeset
    96
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    97
//
hgs
parents:
diff changeset
    98
EXPORT_C void CFlexTimer::AtUTC( const TTime& aTime )
hgs
parents:
diff changeset
    99
    {
hgs
parents:
diff changeset
   100
    OstTraceExt2( TRACE_NORMAL, CFLEXTIMER_ATUTC,
hgs
parents:
diff changeset
   101
                  "CFlexTimer::AtUTC;this=%x;aTime=%lld",
hgs
parents:
diff changeset
   102
                  ( TUint )this, aTime.Int64() );
hgs
parents:
diff changeset
   103
    
hgs
parents:
diff changeset
   104
    __ASSERT_ALWAYS( IsAdded(),
hgs
parents:
diff changeset
   105
                     User::Panic(KCFlexTimerPanicCat,
hgs
parents:
diff changeset
   106
                                 EFlexTimerNotAddedToActiveScheduler ) );
hgs
parents:
diff changeset
   107
    iTimer.AtUTC( iStatus, aTime );
hgs
parents:
diff changeset
   108
    SetActive();
hgs
parents:
diff changeset
   109
    }
hgs
parents:
diff changeset
   110
hgs
parents:
diff changeset
   111
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   112
// Sets the window size in which alignment is possible for the timer.
hgs
parents:
diff changeset
   113
// This is a synchronous command. 32-bit function argument.
hgs
parents:
diff changeset
   114
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   115
//
hgs
parents:
diff changeset
   116
EXPORT_C TInt CFlexTimer::Configure( TTimeIntervalMicroSeconds32 aWindowSize )
hgs
parents:
diff changeset
   117
    {
hgs
parents:
diff changeset
   118
    OstTraceExt2( TRACE_NORMAL, CFLEXTIMER_CONFIGURE,
hgs
parents:
diff changeset
   119
                  "CFlexTimer::Configure32;this=%x;aWindowSize=%d",
hgs
parents:
diff changeset
   120
                  ( TUint )this, aWindowSize.Int() );
hgs
parents:
diff changeset
   121
    
hgs
parents:
diff changeset
   122
    return iTimer.Configure( aWindowSize );
hgs
parents:
diff changeset
   123
    }
hgs
parents:
diff changeset
   124
hgs
parents:
diff changeset
   125
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   126
// Sets the window size in which alignment is possible for the timer.
hgs
parents:
diff changeset
   127
// This is a synchronous command. 64-bit function argument.
hgs
parents:
diff changeset
   128
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   129
//
hgs
parents:
diff changeset
   130
EXPORT_C TInt CFlexTimer::Configure( TTimeIntervalMicroSeconds aWindowSize )
hgs
parents:
diff changeset
   131
    {
hgs
parents:
diff changeset
   132
    OstTraceExt2( TRACE_NORMAL, DUP1_CFLEXTIMER_CONFIGURE,
hgs
parents:
diff changeset
   133
                  "CFlexTimer::Configure64;this=%x;aWindowSize=%lld",
hgs
parents:
diff changeset
   134
                  ( TUint )this, aWindowSize.Int64() );
hgs
parents:
diff changeset
   135
    
hgs
parents:
diff changeset
   136
    return iTimer.Configure( aWindowSize );
hgs
parents:
diff changeset
   137
    }
hgs
parents:
diff changeset
   138
hgs
parents:
diff changeset
   139
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   140
// Constructs the object. Connects to the server and create a session.
hgs
parents:
diff changeset
   141
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   142
//
hgs
parents:
diff changeset
   143
EXPORT_C void CFlexTimer::ConstructL()
hgs
parents:
diff changeset
   144
    {
hgs
parents:
diff changeset
   145
    OstTrace1( TRACE_NORMAL, CFLEXTIMER_CONSTRUCTL,
hgs
parents:
diff changeset
   146
               "CFlexTimer::ConstructL;this=%x", ( TUint )this );
hgs
parents:
diff changeset
   147
    
hgs
parents:
diff changeset
   148
    User::LeaveIfError(iTimer.Connect());
hgs
parents:
diff changeset
   149
    }
hgs
parents:
diff changeset
   150
hgs
parents:
diff changeset
   151
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   152
// Constructs the object.
hgs
parents:
diff changeset
   153
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   154
//
hgs
parents:
diff changeset
   155
EXPORT_C CFlexTimer::CFlexTimer( TInt aPriority ) :
hgs
parents:
diff changeset
   156
    CActive( aPriority )
hgs
parents:
diff changeset
   157
    {
hgs
parents:
diff changeset
   158
    }
hgs
parents:
diff changeset
   159
hgs
parents:
diff changeset
   160
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   161
// Inherited from CActive. Handles the object canceling operations.
hgs
parents:
diff changeset
   162
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   163
//
hgs
parents:
diff changeset
   164
EXPORT_C void CFlexTimer::DoCancel()
hgs
parents:
diff changeset
   165
    {
hgs
parents:
diff changeset
   166
    OstTrace1( TRACE_NORMAL, CFLEXTIMER_DOCANCEL,
hgs
parents:
diff changeset
   167
               "CFlexTimer::DoCancel;this=%x", ( TUint )this );
hgs
parents:
diff changeset
   168
    
hgs
parents:
diff changeset
   169
    iTimer.Cancel();
hgs
parents:
diff changeset
   170
    }
hgs
parents:
diff changeset
   171