satengine/satserver/Commands/SimSessionEndCmd/src/CSimSessionEndHandler.cpp
author hgs
Fri, 03 Sep 2010 13:59:20 +0300
changeset 46 2fa1fa551b0b
parent 33 8d5d7fcf9b59
permissions -rw-r--r--
201035
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
33
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2002-2007 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:  Handles SimSessionEnd command
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
hgs
parents:
diff changeset
    20
// INCLUDE FILES
hgs
parents:
diff changeset
    21
#include    "MSatApi.h"
hgs
parents:
diff changeset
    22
#include    "MSatUiSession.h"
hgs
parents:
diff changeset
    23
#include    "MSatSUiClientHandler.h"
hgs
parents:
diff changeset
    24
#include    "CSimSessionEndHandler.h"
hgs
parents:
diff changeset
    25
#include    "SatLog.h"
hgs
parents:
diff changeset
    26
hgs
parents:
diff changeset
    27
// CONSTANTS
hgs
parents:
diff changeset
    28
const TInt KSimSessionEndDelay = 60000000;
hgs
parents:
diff changeset
    29
hgs
parents:
diff changeset
    30
// ============================ MEMBER FUNCTIONS ===============================
hgs
parents:
diff changeset
    31
hgs
parents:
diff changeset
    32
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    33
// CSimSessionEndHandler::CSimSessionEndHandler
hgs
parents:
diff changeset
    34
// C++ default constructor can NOT contain any code, that
hgs
parents:
diff changeset
    35
// might leave.
hgs
parents:
diff changeset
    36
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    37
//
hgs
parents:
diff changeset
    38
CSimSessionEndHandler::CSimSessionEndHandler() :
hgs
parents:
diff changeset
    39
    CSatCommandHandler()
hgs
parents:
diff changeset
    40
    {
hgs
parents:
diff changeset
    41
    LOG( SIMPLE, "SIMSESSIONEND: \
hgs
parents:
diff changeset
    42
        CSimSessionEndHandler::CSimSessionEndHandler calling - exiting" )
hgs
parents:
diff changeset
    43
    }
hgs
parents:
diff changeset
    44
hgs
parents:
diff changeset
    45
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    46
// CSimSessionEndHandler::ConstructL
hgs
parents:
diff changeset
    47
// Symbian 2nd phase constructor can leave.
hgs
parents:
diff changeset
    48
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    49
//
hgs
parents:
diff changeset
    50
void CSimSessionEndHandler::ConstructL()
hgs
parents:
diff changeset
    51
    {
hgs
parents:
diff changeset
    52
    LOG( SIMPLE, "SIMSESSIONEND: CSimSessionEndHandler::ConstructL calling" )
hgs
parents:
diff changeset
    53
hgs
parents:
diff changeset
    54
    iTimer = CPeriodic::NewL( EPriorityStandard );
hgs
parents:
diff changeset
    55
hgs
parents:
diff changeset
    56
    iUtils->RegisterL( this, MSatUtils::EDelaySimSessionEnd );
hgs
parents:
diff changeset
    57
    iUtils->RegisterL( this, MSatUtils::EDestroySimSessionEndTimer );
hgs
parents:
diff changeset
    58
    iUtils->RegisterL( this, MSatUtils::ESessionTerminatedByUser );
hgs
parents:
diff changeset
    59
    iUtils->RegisterL( this, MSatUtils::ESimSessionEndCallBack );
hgs
parents:
diff changeset
    60
    iUtils->RegisterL( this, MSatUtils::ESustainedTextInDisplay );
hgs
parents:
diff changeset
    61
    iUtils->RegisterL( this, MSatUtils::ESustainedTextRemoved );
hgs
parents:
diff changeset
    62
    iUtils->RegisterL( this, MSatUtils::ESatUiLaunched );
hgs
parents:
diff changeset
    63
hgs
parents:
diff changeset
    64
    LOG( SIMPLE, "SIMSESSIONEND: CSimSessionEndHandler::ConstructL exiting" )
hgs
parents:
diff changeset
    65
    }
hgs
parents:
diff changeset
    66
hgs
parents:
diff changeset
    67
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    68
// CSimSessionEndHandler::NewL
hgs
parents:
diff changeset
    69
// Two-phased constructor.
hgs
parents:
diff changeset
    70
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    71
//
hgs
parents:
diff changeset
    72
CSimSessionEndHandler* CSimSessionEndHandler::NewL( MSatUtils* aUtils )
hgs
parents:
diff changeset
    73
    {
hgs
parents:
diff changeset
    74
    LOG( SIMPLE, "SIMSESSIONEND: CSimSessionEndHandler::NewL calling" )
hgs
parents:
diff changeset
    75
hgs
parents:
diff changeset
    76
    CSimSessionEndHandler* self = new( ELeave ) CSimSessionEndHandler;
hgs
parents:
diff changeset
    77
hgs
parents:
diff changeset
    78
    CleanupStack::PushL( self );
hgs
parents:
diff changeset
    79
    self->BaseConstructL( aUtils );
hgs
parents:
diff changeset
    80
    self->ConstructL();
hgs
parents:
diff changeset
    81
    CleanupStack::Pop( self );
hgs
parents:
diff changeset
    82
hgs
parents:
diff changeset
    83
    LOG( SIMPLE, "SIMSESSIONEND: CSimSessionEndHandler::NewL exiting" )
hgs
parents:
diff changeset
    84
    return self;
hgs
parents:
diff changeset
    85
    }
hgs
parents:
diff changeset
    86
hgs
parents:
diff changeset
    87
hgs
parents:
diff changeset
    88
// Destructor
hgs
parents:
diff changeset
    89
CSimSessionEndHandler::~CSimSessionEndHandler()
hgs
parents:
diff changeset
    90
    {
hgs
parents:
diff changeset
    91
    LOG( SIMPLE,
hgs
parents:
diff changeset
    92
        "SIMSESSIONEND: CSimSessionEndHandler::~CSimSessionEndHandler calling" )
hgs
parents:
diff changeset
    93
hgs
parents:
diff changeset
    94
    Cancel();
hgs
parents:
diff changeset
    95
hgs
parents:
diff changeset
    96
    if ( iTimer )
hgs
parents:
diff changeset
    97
        {
hgs
parents:
diff changeset
    98
        iTimer->Cancel();
hgs
parents:
diff changeset
    99
        }
hgs
parents:
diff changeset
   100
    delete iTimer;
hgs
parents:
diff changeset
   101
hgs
parents:
diff changeset
   102
    LOG( SIMPLE,
hgs
parents:
diff changeset
   103
        "SIMSESSIONEND: CSimSessionEndHandler::~CSimSessionEndHandler exiting" )
hgs
parents:
diff changeset
   104
    }
hgs
parents:
diff changeset
   105
hgs
parents:
diff changeset
   106
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   107
// CSimSessionEndHandler::TimerCallback
hgs
parents:
diff changeset
   108
// (other items were commented in a header).
hgs
parents:
diff changeset
   109
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   110
//
hgs
parents:
diff changeset
   111
TInt CSimSessionEndHandler::TimerCallback( TAny* aSimSessionEndHandler )
hgs
parents:
diff changeset
   112
    {
hgs
parents:
diff changeset
   113
    LOG( SIMPLE, "SIMSESSIONEND: CSimSessionEndHandler::TimerCallback calling" )
hgs
parents:
diff changeset
   114
hgs
parents:
diff changeset
   115
    CSimSessionEndHandler* handler =
hgs
parents:
diff changeset
   116
        static_cast<CSimSessionEndHandler*>( aSimSessionEndHandler );
hgs
parents:
diff changeset
   117
        
hgs
parents:
diff changeset
   118
    if ( handler )
hgs
parents:
diff changeset
   119
        {
hgs
parents:
diff changeset
   120
        LOG( SIMPLE, 
hgs
parents:
diff changeset
   121
        "SIMSESSIONEND: CSimSessionEndHandler::TimerCallback handler true" )
hgs
parents:
diff changeset
   122
        handler->iTimer->Cancel();
hgs
parents:
diff changeset
   123
        handler->HandleCommand();
hgs
parents:
diff changeset
   124
        }
hgs
parents:
diff changeset
   125
hgs
parents:
diff changeset
   126
    LOG( SIMPLE, "SIMSESSIONEND: CSimSessionEndHandler::TimerCallback exiting" )
hgs
parents:
diff changeset
   127
    return KErrNone;
hgs
parents:
diff changeset
   128
    }
hgs
parents:
diff changeset
   129
hgs
parents:
diff changeset
   130
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   131
// CSimSessionEndHandler::Event
hgs
parents:
diff changeset
   132
// Waits for indication of user wanting to close the sim session.
hgs
parents:
diff changeset
   133
// (other items were commented in a header).
hgs
parents:
diff changeset
   134
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   135
//
hgs
parents:
diff changeset
   136
void CSimSessionEndHandler::Event( TInt aEvent )
hgs
parents:
diff changeset
   137
    {
hgs
parents:
diff changeset
   138
    LOG( SIMPLE, "SIMSESSIONEND: CSimSessionEndHandler::Event calling" )
hgs
parents:
diff changeset
   139
hgs
parents:
diff changeset
   140
    switch ( aEvent )
hgs
parents:
diff changeset
   141
        {
hgs
parents:
diff changeset
   142
        case MSatUtils::ESatUiLaunched:
hgs
parents:
diff changeset
   143
            {
hgs
parents:
diff changeset
   144
            LOG( NORMAL, 
hgs
parents:
diff changeset
   145
            "SIMSESSIONEND: CSimSessionEndHandler::Event UI is launched" )
hgs
parents:
diff changeset
   146
            // New UI session, reset flag
hgs
parents:
diff changeset
   147
            iSimSessionTerminatedByUser = EFalse;
hgs
parents:
diff changeset
   148
            break;
hgs
parents:
diff changeset
   149
            }
hgs
parents:
diff changeset
   150
hgs
parents:
diff changeset
   151
        case MSatUtils::ESessionTerminatedByUser:
hgs
parents:
diff changeset
   152
            {
hgs
parents:
diff changeset
   153
            LOG( NORMAL, 
hgs
parents:
diff changeset
   154
            "SIMSESSIONEND: CSimSessionEndHandler::Event \
hgs
parents:
diff changeset
   155
            ESessionTerminatedByUser" )
hgs
parents:
diff changeset
   156
            // Next SimSessionEnd will close the ui session.
hgs
parents:
diff changeset
   157
            iSimSessionTerminatedByUser = ETrue;
hgs
parents:
diff changeset
   158
            break;
hgs
parents:
diff changeset
   159
            }
hgs
parents:
diff changeset
   160
hgs
parents:
diff changeset
   161
        case MSatUtils::EDelaySimSessionEnd:
hgs
parents:
diff changeset
   162
            {
hgs
parents:
diff changeset
   163
            LOG( NORMAL, 
hgs
parents:
diff changeset
   164
            "SIMSESSIONEND: CSimSessionEndHandler::Event \
hgs
parents:
diff changeset
   165
            EDelaySimSessionEnd" )
hgs
parents:
diff changeset
   166
            iTimer->Cancel();
hgs
parents:
diff changeset
   167
            TCallBack callback( TimerCallback, this );
hgs
parents:
diff changeset
   168
            iTimer->Start( KSimSessionEndDelay, KSimSessionEndDelay, callback );
hgs
parents:
diff changeset
   169
            break;
hgs
parents:
diff changeset
   170
            }
hgs
parents:
diff changeset
   171
hgs
parents:
diff changeset
   172
        case MSatUtils::EDestroySimSessionEndTimer:
hgs
parents:
diff changeset
   173
            {
hgs
parents:
diff changeset
   174
            LOG( NORMAL, 
hgs
parents:
diff changeset
   175
            "SIMSESSIONEND: CSimSessionEndHandler::Event \
hgs
parents:
diff changeset
   176
            EDestroySimSessionEndTimer" )
hgs
parents:
diff changeset
   177
            iTimer->Cancel();
hgs
parents:
diff changeset
   178
            break;
hgs
parents:
diff changeset
   179
            }
hgs
parents:
diff changeset
   180
hgs
parents:
diff changeset
   181
        case MSatUtils::ESimSessionEndCallBack:
hgs
parents:
diff changeset
   182
            {
hgs
parents:
diff changeset
   183
            LOG( NORMAL, 
hgs
parents:
diff changeset
   184
            "SIMSESSIONEND: CSimSessionEndHandler::Event \
hgs
parents:
diff changeset
   185
            ESimSessionEndCallBack" )
hgs
parents:
diff changeset
   186
            // Forced Sim session end.
hgs
parents:
diff changeset
   187
            iTimer->Cancel();
hgs
parents:
diff changeset
   188
            HandleCommand();
hgs
parents:
diff changeset
   189
            break;
hgs
parents:
diff changeset
   190
            }
hgs
parents:
diff changeset
   191
hgs
parents:
diff changeset
   192
        case MSatUtils::ESustainedTextInDisplay:
hgs
parents:
diff changeset
   193
            {
hgs
parents:
diff changeset
   194
            LOG( NORMAL, "SIMSESSIONEND: CSimSessionEndHandler::Event \
hgs
parents:
diff changeset
   195
            ESustainedTextInDisplay" )
hgs
parents:
diff changeset
   196
            // Indication of sustained text
hgs
parents:
diff changeset
   197
            iSustainedTextActive = ETrue;
hgs
parents:
diff changeset
   198
            break;
hgs
parents:
diff changeset
   199
            }
hgs
parents:
diff changeset
   200
hgs
parents:
diff changeset
   201
        case MSatUtils::ESustainedTextRemoved:
hgs
parents:
diff changeset
   202
            {
hgs
parents:
diff changeset
   203
            LOG( NORMAL, "SIMSESSIONEND: CSimSessionEndHandler::Event \
hgs
parents:
diff changeset
   204
            ESustainedTextRemoved" )
hgs
parents:
diff changeset
   205
            // Indication of sustained text cleared
hgs
parents:
diff changeset
   206
            iSustainedTextActive = EFalse;
hgs
parents:
diff changeset
   207
            // If last sim session end is pending because of sustained text, 
hgs
parents:
diff changeset
   208
            // execute it now
hgs
parents:
diff changeset
   209
            if ( iSimSessionEndPending )
hgs
parents:
diff changeset
   210
                {
hgs
parents:
diff changeset
   211
                LOG( NORMAL, 
hgs
parents:
diff changeset
   212
                "SIMSESSIONEND: CSimSessionEndHandler::Event \
hgs
parents:
diff changeset
   213
                iSimSessionEndPending" )
hgs
parents:
diff changeset
   214
                HandleCommand();
hgs
parents:
diff changeset
   215
                }
hgs
parents:
diff changeset
   216
hgs
parents:
diff changeset
   217
            break;
hgs
parents:
diff changeset
   218
            }
hgs
parents:
diff changeset
   219
hgs
parents:
diff changeset
   220
        default:
hgs
parents:
diff changeset
   221
            {
hgs
parents:
diff changeset
   222
            LOG2( NORMAL, 
hgs
parents:
diff changeset
   223
            "SIMSESSIONEND: CSimSessionEndHandler::Event \
hgs
parents:
diff changeset
   224
            Unexpected event: %i", aEvent )
hgs
parents:
diff changeset
   225
            CSatCommandHandler::Event( aEvent );
hgs
parents:
diff changeset
   226
            break;
hgs
parents:
diff changeset
   227
            }
hgs
parents:
diff changeset
   228
        }
hgs
parents:
diff changeset
   229
hgs
parents:
diff changeset
   230
    LOG( SIMPLE, "SIMSESSIONEND: CSimSessionEndHandler::Event exiting" )
hgs
parents:
diff changeset
   231
    }
hgs
parents:
diff changeset
   232
hgs
parents:
diff changeset
   233
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   234
// CSimSessionEndHandler::DoCancel
hgs
parents:
diff changeset
   235
// Cancels the sat request.
hgs
parents:
diff changeset
   236
// (other items were commented in a header).
hgs
parents:
diff changeset
   237
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   238
//
hgs
parents:
diff changeset
   239
void CSimSessionEndHandler::DoCancel()
hgs
parents:
diff changeset
   240
    {
hgs
parents:
diff changeset
   241
    LOG( SIMPLE, "SIMSESSIONEND: CSimSessionEndHandler::DoCancel calling" )
hgs
parents:
diff changeset
   242
hgs
parents:
diff changeset
   243
    iUtils->USatAPI().NotifySimSessionEndCancel();
hgs
parents:
diff changeset
   244
hgs
parents:
diff changeset
   245
    LOG( SIMPLE, "SIMSESSIONEND: CSimSessionEndHandler::DoCancel exiting" )
hgs
parents:
diff changeset
   246
    }
hgs
parents:
diff changeset
   247
hgs
parents:
diff changeset
   248
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   249
// CSimSessionEndHandler::IssueUSATRequest
hgs
parents:
diff changeset
   250
// (other items were commented in a header).
hgs
parents:
diff changeset
   251
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   252
//
hgs
parents:
diff changeset
   253
void CSimSessionEndHandler::IssueUSATRequest( TRequestStatus& aStatus )
hgs
parents:
diff changeset
   254
    {
hgs
parents:
diff changeset
   255
    LOG( SIMPLE,
hgs
parents:
diff changeset
   256
        "SIMSESSIONEND: CSimSessionEndHandler::IssueUSATRequest calling" )
hgs
parents:
diff changeset
   257
hgs
parents:
diff changeset
   258
    iUtils->USatAPI().NotifySimSessionEnd( aStatus );
hgs
parents:
diff changeset
   259
hgs
parents:
diff changeset
   260
    LOG( SIMPLE,
hgs
parents:
diff changeset
   261
        "SIMSESSIONEND: CSimSessionEndHandler::IssueUSATRequest exiting" )
hgs
parents:
diff changeset
   262
    }
hgs
parents:
diff changeset
   263
hgs
parents:
diff changeset
   264
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   265
// CSimSessionEndHandler::CommandAllowed
hgs
parents:
diff changeset
   266
// (other items were commented in a header).
hgs
parents:
diff changeset
   267
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   268
//
hgs
parents:
diff changeset
   269
TBool CSimSessionEndHandler::CommandAllowed()
hgs
parents:
diff changeset
   270
    {
hgs
parents:
diff changeset
   271
    LOG( SIMPLE, "SIMSESSIONEND: \
hgs
parents:
diff changeset
   272
        CSimSessionEndHandler::CommandAllowed calling - exiting" )
hgs
parents:
diff changeset
   273
    return ETrue;
hgs
parents:
diff changeset
   274
    }
hgs
parents:
diff changeset
   275
hgs
parents:
diff changeset
   276
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   277
// CSimSessionEndHandler::NeedUiSession
hgs
parents:
diff changeset
   278
// (other items were commented in a header).
hgs
parents:
diff changeset
   279
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   280
//
hgs
parents:
diff changeset
   281
TBool CSimSessionEndHandler::NeedUiSession()
hgs
parents:
diff changeset
   282
    {
hgs
parents:
diff changeset
   283
    LOG( SIMPLE, "SIMSESSIONEND: \
hgs
parents:
diff changeset
   284
        CSimSessionEndHandler::NeedUiSession calling - exiting" )
hgs
parents:
diff changeset
   285
    return EFalse;
hgs
parents:
diff changeset
   286
    }
hgs
parents:
diff changeset
   287
hgs
parents:
diff changeset
   288
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   289
// CSimSessionEndHandler::HandleCommand
hgs
parents:
diff changeset
   290
// (other items were commented in a header).
hgs
parents:
diff changeset
   291
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   292
//
hgs
parents:
diff changeset
   293
void CSimSessionEndHandler::HandleCommand()
hgs
parents:
diff changeset
   294
    {
hgs
parents:
diff changeset
   295
    LOG( SIMPLE, "SIMSESSIONEND: CSimSessionEndHandler::HandleCommand calling" )
hgs
parents:
diff changeset
   296
hgs
parents:
diff changeset
   297
    // Note that the framework has destroyed the simsession
hgs
parents:
diff changeset
   298
    // end timer, when HandleCommand is called.
hgs
parents:
diff changeset
   299
    if ( !iSimSessionTerminatedByUser && !iSustainedTextActive )
hgs
parents:
diff changeset
   300
        {
hgs
parents:
diff changeset
   301
        LOG( SIMPLE, 
hgs
parents:
diff changeset
   302
        "SIMSESSIONEND: CSimSessionEndHandler::HandleCommand \
hgs
parents:
diff changeset
   303
        ESimSessionEndExecuting" )
hgs
parents:
diff changeset
   304
        iUtils->NotifyEvent( MSatUtils::ESimSessionEndExecuting );
hgs
parents:
diff changeset
   305
        }
hgs
parents:
diff changeset
   306
hgs
parents:
diff changeset
   307
    MSatUiSession* uiSession = iUtils->SatUiHandler().UiSession();
hgs
parents:
diff changeset
   308
    if ( uiSession )
hgs
parents:
diff changeset
   309
        {
hgs
parents:
diff changeset
   310
        // If sustained Display text is on screen, cannot close UI
hgs
parents:
diff changeset
   311
        if ( !iSustainedTextActive && ( iSimSessionTerminatedByUser ||
hgs
parents:
diff changeset
   312
            !iUtils->SatUiHandler().UiLaunchedByUser() ) )
hgs
parents:
diff changeset
   313
            {
hgs
parents:
diff changeset
   314
            iSimSessionTerminatedByUser = EFalse;
hgs
parents:
diff changeset
   315
            iSimSessionEndPending = EFalse;
hgs
parents:
diff changeset
   316
            // Number of executing command handlers should be 0.
hgs
parents:
diff changeset
   317
            TInt expectedCommCount = 0;
hgs
parents:
diff changeset
   318
hgs
parents:
diff changeset
   319
            // If SimSessionEnd is executing ie. not active, it has to take
hgs
parents:
diff changeset
   320
            // into account when checking executing command handlers.
hgs
parents:
diff changeset
   321
            if ( !IsActive() )
hgs
parents:
diff changeset
   322
                {
hgs
parents:
diff changeset
   323
                LOG( SIMPLE, 
hgs
parents:
diff changeset
   324
                "SIMSESSIONEND: CSimSessionEndHandler::HandleCommand \
hgs
parents:
diff changeset
   325
                isn't Active" )
hgs
parents:
diff changeset
   326
                expectedCommCount = 1;
hgs
parents:
diff changeset
   327
                }
hgs
parents:
diff changeset
   328
hgs
parents:
diff changeset
   329
            LOG2( NORMAL, "SIMSESSIONEND: Expected commands: %i",
hgs
parents:
diff changeset
   330
                expectedCommCount )
hgs
parents:
diff changeset
   331
            // SimSession end is currently executing, therefore there is one
hgs
parents:
diff changeset
   332
            // executing command.
hgs
parents:
diff changeset
   333
            if ( expectedCommCount ==
hgs
parents:
diff changeset
   334
                 iUtils->NumberOfExecutingCommandHandlers() )
hgs
parents:
diff changeset
   335
                {
hgs
parents:
diff changeset
   336
                LOG( SIMPLE, 
hgs
parents:
diff changeset
   337
                "SIMSESSIONEND: CSimSessionEndHandler::HandleCommand \
hgs
parents:
diff changeset
   338
                expectedCommCount==iUtils->NumberOfExecutingCommandHandlers()" )
hgs
parents:
diff changeset
   339
                // Close the ui session only if there are no
hgs
parents:
diff changeset
   340
                // executing commands.
hgs
parents:
diff changeset
   341
                uiSession->CloseUiSession();
hgs
parents:
diff changeset
   342
                }
hgs
parents:
diff changeset
   343
            }
hgs
parents:
diff changeset
   344
        else
hgs
parents:
diff changeset
   345
            {
hgs
parents:
diff changeset
   346
            if ( iSustainedTextActive )
hgs
parents:
diff changeset
   347
                {
hgs
parents:
diff changeset
   348
                LOG( SIMPLE, 
hgs
parents:
diff changeset
   349
                "SIMSESSIONEND: CSimSessionEndHandler::HandleCommand \
hgs
parents:
diff changeset
   350
                iSustainedTextActive true" )
hgs
parents:
diff changeset
   351
                iSimSessionEndPending = ETrue;
hgs
parents:
diff changeset
   352
                }
hgs
parents:
diff changeset
   353
            }
hgs
parents:
diff changeset
   354
        }
hgs
parents:
diff changeset
   355
hgs
parents:
diff changeset
   356
    // Renew the request, because the sim session end does not send
hgs
parents:
diff changeset
   357
    // terminal response, which would renew the request automatically.
hgs
parents:
diff changeset
   358
    Start();
hgs
parents:
diff changeset
   359
hgs
parents:
diff changeset
   360
    LOG( SIMPLE, "SIMSESSIONEND: CSimSessionEndHandler::HandleCommand exiting" )
hgs
parents:
diff changeset
   361
    }
hgs
parents:
diff changeset
   362
hgs
parents:
diff changeset
   363
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   364
// CSimSessionEndHandler::UiLaunchFailed
hgs
parents:
diff changeset
   365
// (other items were commented in a header).
hgs
parents:
diff changeset
   366
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   367
//
hgs
parents:
diff changeset
   368
void CSimSessionEndHandler::UiLaunchFailed()
hgs
parents:
diff changeset
   369
    {
hgs
parents:
diff changeset
   370
    // This command does not launch ui client.
hgs
parents:
diff changeset
   371
    LOG( SIMPLE,
hgs
parents:
diff changeset
   372
        "SIMSESSIONEND: CSimSessionEndHandler::UiLaunchFailed calling-exiting" )
hgs
parents:
diff changeset
   373
    }
hgs
parents:
diff changeset
   374
hgs
parents:
diff changeset
   375
//  End of File